.home{max-width:800px;margin:0 auto;padding:0 20px}.home-hero{text-align:center;padding:80px 0 48px}.home-eyebrow{text-transform:uppercase;letter-spacing:3px;color:var(--color-accent);margin-bottom:12px;font-size:.875rem;font-weight:500}.home-title{color:var(--color-text);margin-bottom:20px;font-size:4rem;font-weight:700}.home-subtitle{color:var(--color-text-muted);max-width:520px;margin:0 auto;font-size:1.15rem;line-height:1.7}.home-hero-photo{border:4px solid var(--color-accent);border-radius:50%;width:180px;height:180px;margin:0 auto 24px;overflow:hidden;box-shadow:0 4px 24px #c8a96e33}.home-hero-photo img{object-fit:cover;object-position:top center;width:100%;height:100%}.home-quote{text-align:center;background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:16px;margin-bottom:64px;padding:40px 32px}.quote-text{font-family:var(--font-display);color:var(--color-text);margin-bottom:8px;font-size:1.5rem;font-style:italic;line-height:1.5}.quote-cite{color:var(--color-text-muted);font-size:.875rem;font-style:normal}.home-highlights{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:64px;display:grid}.highlight-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);text-align:center;border-radius:12px;padding:28px 20px;transition:transform .2s,box-shadow .2s}.highlight-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000000f}.highlight-icon{margin-bottom:12px;font-size:2rem;display:block}.highlight-card h3{font-family:var(--font-display);margin-bottom:6px;font-size:1.05rem}.highlight-card p{color:var(--color-text-muted);font-size:.825rem;line-height:1.5}.home-love-story{border:1px solid var(--color-card-border);background:linear-gradient(135deg,#fdf6f0,#faf9f6);border-radius:16px;margin-bottom:64px;padding:48px 40px}.home-love-story h2{text-align:center;color:var(--color-text);margin-bottom:28px;font-size:2rem}.love-story-content p{color:var(--color-text);margin-bottom:16px;font-size:1.05rem;line-height:1.8}.love-story-content p:last-of-type{margin-bottom:0}.love-story-source{font-style:italic;color:var(--color-text-muted)!important;margin-top:20px!important;font-size:.9rem!important}.love-story-source a{color:var(--color-accent-dark);text-underline-offset:2px;text-decoration:underline}.home-timeline{margin-bottom:64px}.home-timeline h2{text-align:center;margin-bottom:36px;font-size:2rem}.timeline{padding-left:32px;position:relative}.timeline:before{content:"";background:var(--color-card-border);width:2px;position:absolute;top:8px;bottom:8px;left:7px}.timeline-item{margin-bottom:28px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-marker{background:var(--color-accent);border:3px solid var(--color-bg);width:16px;height:16px;box-shadow:0 0 0 2px var(--color-accent);border-radius:50%;position:absolute;top:6px;left:-32px}.timeline-content{padding-bottom:4px}.timeline-year{font-family:var(--font-display);color:var(--color-accent-dark);margin-bottom:4px;font-size:1.1rem;font-weight:600;display:block}.timeline-content p{color:var(--color-text-muted);font-size:.95rem;line-height:1.6}.home-facts{margin-bottom:64px}.home-facts h2{text-align:center;margin-bottom:28px;font-size:2rem}.fact-list{columns:1;padding:0;list-style:none}.fact-list li{border-bottom:1px solid var(--color-card-border);color:var(--color-text);break-inside:avoid;padding:12px 0 12px 20px;font-size:.95rem;position:relative}.fact-list li:before{content:"•";color:var(--color-accent);font-weight:700;position:absolute;left:0}.home-motorcycle{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:16px;margin-bottom:64px;padding:48px 40px}.home-motorcycle h2{text-align:center;margin-bottom:28px;font-size:2rem}.motorcycle-content p{color:var(--color-text);margin-bottom:16px;font-size:1.05rem;line-height:1.8}.motorcycle-content p:last-child{margin-bottom:0}.home-cta{text-align:center;border-top:1px solid var(--color-card-border);padding:60px 0}.home-cta-present{margin-bottom:16px;font-size:4rem}.home-cta h2{margin-bottom:12px;font-size:2.25rem}.home-cta p{color:var(--color-text-muted);margin-bottom:28px;font-size:1.1rem}.btn-play{border-radius:10px;padding:14px 36px;font-size:1.1rem;display:inline-block}.home-scores{padding-bottom:40px}.home-scores h2{text-align:center;margin-bottom:20px;font-size:1.75rem}.scores-list{flex-direction:column;gap:12px;display:flex}.score-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:12px;padding:16px 20px}.score-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.score-card-date{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;font-size:.8rem}.score-card-delete{border:1px solid var(--color-card-border);width:28px;height:28px;color:var(--color-text-muted);background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex}.score-card-delete:hover{border-color:var(--color-action);color:var(--color-action);transform:none}.score-card-players{flex-direction:column;gap:4px;display:flex}.score-card-row{align-items:center;gap:8px;padding:4px 0;display:flex}.score-card-rank{color:var(--color-text-muted);min-width:20px;font-size:.8rem}.score-card-name{flex:1;font-weight:500}.score-card-pts{color:var(--color-accent-dark);font-size:.9rem;font-weight:600}.home-roots{margin-bottom:64px}.home-roots h2{text-align:center;margin-bottom:28px;font-size:2rem}.roots-gallery{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.roots-photo{border:1px solid var(--color-card-border);background:var(--color-card-bg);border-radius:12px;margin:0;overflow:hidden}.roots-photo img{object-fit:cover;width:100%;height:200px;display:block}.roots-photo figcaption{color:var(--color-text-muted);text-align:center;padding:10px 12px;font-size:.8rem}@media (width<=600px){.roots-gallery{grid-template-columns:1fr}.roots-photo img{height:240px}}.home-footer{text-align:center;border-top:1px solid var(--color-card-border);padding:40px 0}.home-footer p{color:var(--color-text-muted);font-size:.875rem}@media (width<=768px){.home-highlights{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.home-hero{padding:48px 0 36px}.home-title{font-size:2.75rem}.home-highlights{grid-template-columns:1fr}.home-love-story,.home-motorcycle{padding:32px 24px}.quote-text{font-size:1.25rem}.home-quote{padding:28px 20px}}.lobby{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.lobby-back{color:var(--color-text-muted);font-size:.875rem;position:absolute;top:24px;left:24px}.lobby-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);text-align:center;border-radius:16px;width:100%;max-width:400px;padding:48px 40px}.lobby-present{margin-bottom:12px;font-size:3.5rem}.lobby-title{margin-bottom:8px;font-size:2.5rem}.lobby-subtitle{color:var(--color-text-muted);margin-bottom:32px}.lobby-actions{flex-direction:column;gap:12px;display:flex}.lobby-input{text-align:center;font-size:1rem}.lobby-code-input{letter-spacing:8px;text-transform:uppercase;font-size:1.5rem;font-weight:600}.lobby-btn{width:100%;padding:14px;font-size:1rem}.btn-secondary{color:var(--color-accent-dark);border:1px solid var(--color-card-border);background:0 0;padding:14px;font-size:1rem}.btn-secondary:hover{border-color:var(--color-accent)}.btn-text{color:var(--color-text-muted);background:0 0;padding:8px;font-size:.875rem}.btn-role{background:var(--color-card-bg);border:1px solid var(--color-card-border);width:100%;color:var(--color-text);text-align:left;border-radius:12px;align-items:center;gap:12px;padding:20px;font-size:1rem;transition:border-color .2s,transform .2s;display:flex}.btn-role:hover{border-color:var(--color-accent)}.btn-role-icon{font-size:1.5rem}.btn-role-label{font-weight:600}.lobby-name-label{color:var(--color-text-muted);margin-bottom:4px;font-size:.9rem}.lobby-error{color:var(--color-action);margin-top:12px;font-size:.875rem}@media (width<=480px){.lobby-card{padding:32px 24px}}.game{flex-direction:column;max-width:500px;min-height:100dvh;margin:0 auto;padding:0 20px 40px;display:flex}.game-status-banner{color:#000;text-align:center;text-transform:uppercase;letter-spacing:3px;background:#4ade80;margin:0 -20px;padding:12px 0;font-size:.875rem;font-weight:700}.game-header{align-items:center;gap:12px;padding:20px 0 16px;display:flex}.game-back{color:var(--color-text-muted);font-size:1.25rem}.game-header-title{font-family:var(--font-display);font-size:1.15rem;font-weight:600}.game-players{flex-direction:column;gap:8px;margin-top:8px;display:flex}.game-player-row{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:12px;align-items:center;gap:12px;padding:14px 16px;display:flex}.game-player-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.game-player-name{flex:1;font-size:1rem;font-weight:500}.game-player-you{color:var(--color-text-muted);margin-left:6px;font-size:.8rem;font-weight:400}.game-actions{flex-direction:column;gap:8px;margin-top:auto;padding-top:32px;display:flex}.game-start-btn{width:100%;padding:16px;font-size:1.1rem;font-weight:600}.game-status-banner.playing{background:var(--color-accent)}.game-roll-area{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;display:flex}.game-roll-label{color:var(--color-text-muted);font-size:1.1rem;font-weight:500}.game-roll-btn{background:var(--color-accent);color:#fff;letter-spacing:4px;cursor:pointer;border:none;border-radius:50%;width:200px;height:200px;font-size:2.5rem;font-weight:800;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 24px #c8a96e4d}.game-roll-btn:hover{transform:scale(1.05);box-shadow:0 6px 32px #c8a96e66}.game-roll-btn:active{transform:scale(.95)}.game-waiting-area{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;display:flex}.game-waiting-dot{background:var(--color-accent);border-radius:50%;width:8px;height:8px;margin-bottom:12px;animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.game-waiting-label{color:var(--color-text-muted);font-size:.95rem}.game-waiting-name{font-size:1.5rem;font-weight:700}@media (width<=480px){.game{padding:0 16px 32px}.game-status-banner{margin:0 -16px}}.tv{background:var(--color-bg);flex-direction:column;min-height:100dvh;display:flex}.tv-banner{background:var(--color-accent);color:#fff;text-align:center;letter-spacing:.5px;padding:14px 20px;font-size:1.15rem}.tv-banner strong{font-weight:800}.tv-banner em{text-underline-offset:3px;font-style:normal;text-decoration:underline}.tv-layout{flex:1;gap:40px;padding:40px;display:flex}.tv-board-area{flex:1;justify-content:center;align-items:center;display:flex}.tv-board-placeholder{border:2px dashed var(--color-card-border);border-radius:16px;justify-content:center;align-items:center;width:100%;height:100%;min-height:400px;display:flex}.tv-board-label{color:var(--color-text-muted);font-size:1.25rem;font-weight:500}.tv-lobby-center{text-align:center}.tv-logo{color:var(--color-text);margin-bottom:8px;font-size:4rem;font-weight:800}.tv-tagline{color:var(--color-text-muted);font-size:1.25rem}.tv-hint{text-align:center;color:var(--color-text-muted);padding:12px;font-size:.75rem;font-style:italic}.tv-sidebar{flex-direction:column;flex-shrink:0;gap:24px;width:300px;display:flex}.tv-join-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);text-align:center;border-radius:16px;padding:28px 24px}.tv-join-title{margin-bottom:20px;font-size:1.1rem;font-weight:600}.tv-qr{justify-content:center;margin-bottom:16px;display:flex}.tv-qr-img{border-radius:8px;width:180px;height:180px}.tv-join-url{color:var(--color-text-muted);word-break:break-all;font-size:.8rem}.tv-players-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:16px;flex:1;padding:24px}.tv-players-title{margin-bottom:12px;font-size:1rem;font-weight:600}.tv-players-empty{color:var(--color-text-muted);font-size:.875rem;font-style:italic}.tv-players-list{flex-direction:column;gap:8px;display:flex}.tv-player-row{background:var(--color-bg);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;animation:.3s playerSlideIn;display:flex}.tv-player-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.tv-player-name{font-size:.95rem;font-weight:500}.tv-player-row.active{background:var(--color-card-bg);border:1px solid var(--color-accent)}.tv-player-score{color:var(--color-accent-dark);margin-left:auto;font-size:.85rem;font-weight:600}.tv-turn-card{background:var(--color-card-bg);border:2px solid var(--color-accent);text-align:center;border-radius:16px;padding:28px 24px}.tv-turn-dot{border-radius:50%;width:16px;height:16px;margin:0 auto 12px}.tv-turn-name{margin-bottom:4px;font-size:1.5rem;font-weight:700}.tv-turn-label{color:var(--color-text-muted);font-size:.85rem}.tv-progress-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:16px;padding:20px 24px}.tv-progress-bar{background:var(--color-card-border);border-radius:3px;height:6px;margin-bottom:8px;overflow:hidden}.tv-progress-fill{background:var(--color-accent);border-radius:3px;height:100%;transition:width .3s}.tv-progress-label{color:var(--color-text-muted);font-size:.8rem}.tv-banner.playing{background:var(--color-accent-dark)}@keyframes playerSlideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-body:"Inter", system-ui, sans-serif;--font-display:"Inter", system-ui, sans-serif;--color-bg:#faf9f6;--color-text:#2c2c2c;--color-text-muted:#6b6b6b;--color-accent:#c8a96e;--color-accent-dark:#a88b4a;--color-card-bg:#fff;--color-card-border:#e8e4dc;--color-facts:#4a7c59;--color-action:#c2593a;--color-head:#3a6b8c}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);min-height:100dvh;line-height:1.6}h1,h2,h3{font-family:var(--font-display);line-height:1.2}a{color:var(--color-accent-dark);text-decoration:none}button{font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;font-weight:500;transition:all .2s}button:hover{transform:translateY(-1px)}.btn-primary{background:var(--color-accent);color:#fff;padding:12px 28px;font-size:1rem}.btn-primary:hover{background:var(--color-accent-dark)}input{font-family:var(--font-body);border:1px solid var(--color-card-border);background:var(--color-card-bg);border-radius:8px;outline:none;padding:12px 16px;font-size:1rem;transition:border-color .2s}input:focus{border-color:var(--color-accent)}
