@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..900&family=DM+Sans:ital,opsz,wght@0,9..40,400..700;1,9..40,400..700&display=swap";:root{--bg-cream: #FDF6E8;--bg-cream-dark: #F5EBD6;--surface: #FFFFFF;--surface-elevated: #FFFEFA;--primary: #6B4EE6;--primary-light: #8B72F0;--primary-dark: #5138C2;--primary-glow: rgba(107, 78, 230, .25);--coral: #FF6B6B;--coral-light: #FF8A8A;--teal: #00D4AA;--teal-light: #4EEDC8;--teal-dark: #00A888;--text-primary: #2D2A32;--text-secondary: #6B6777;--text-muted: #9B95A6;--border: #E8E2D9;--border-light: #F0EBE3;--error: #E53E3E;--error-light: #FED7D7;--success: var(--teal);--success-light: #C6F6D5;--shadow-sm: 0 2px 8px rgba(45, 42, 50, .06);--shadow-md: 0 4px 20px rgba(45, 42, 50, .08);--shadow-lg: 0 8px 40px rgba(45, 42, 50, .12);--shadow-glow: 0 4px 30px var(--primary-glow);--font-display: "Fraunces", Georgia, serif;--font-body: "DM Sans", -apple-system, sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-cream);line-height:1.6;min-height:100vh;position:relative}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:9999}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;line-height:1.2;letter-spacing:-.02em}h1{font-size:clamp(2rem,6vw,3.5rem)}h2{font-size:clamp(1.5rem,4vw,2.5rem)}h3{font-size:clamp(1.25rem,3vw,1.75rem)}p{font-size:1rem;line-height:1.7}.page-container{min-height:100vh;display:flex;flex-direction:column}.page-content{flex:1;padding:var(--space-lg);max-width:480px;margin:0 auto;width:100%}@media(min-width:768px){.page-content{padding:var(--space-2xl)}}@media(max-width:380px){.page-content{padding:var(--space-md)}.page-title{font-size:1.75rem}.btn{padding:var(--space-sm) var(--space-md);font-size:.875rem}.stepper-btn{width:44px;height:44px}.photo-grid{gap:var(--space-xs)}.player-item,.game-header{padding:var(--space-sm)}.answer-btn{padding:var(--space-sm) var(--space-md);font-size:.875rem}}.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--surface);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6}.header-logo{display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--text-primary);text-decoration:none}.logo-icon{font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(107,78,230,.2))}.header-user{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--bg-cream);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;color:var(--text-secondary)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-lg)}.loading-spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);font-family:var(--font-body);font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-decoration:none;width:100%}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-md),0 4px 20px var(--primary-glow)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg),0 8px 30px var(--primary-glow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--surface);color:var(--text-primary);border:2px solid var(--border)}.btn-secondary:hover{border-color:var(--primary);color:var(--primary);background:#6b4ee60d}.btn-ghost{background:transparent;color:var(--text-secondary);padding:var(--space-sm) var(--space-md)}.btn-ghost:hover{color:var(--primary);background:#6b4ee614}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-success{background:var(--teal);color:#fff}.btn-success:hover{background:var(--teal-dark)}.back-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);color:var(--text-secondary);font-weight:500;background:none;border:none;cursor:pointer;transition:color var(--transition-fast);margin-bottom:var(--space-lg)}.back-btn:hover{color:var(--primary)}.card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.card-elevated{box-shadow:var(--shadow-md)}.input-group{display:flex;flex-direction:column;gap:var(--space-sm)}.input-label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.input{padding:var(--space-md) var(--space-lg);font-family:var(--font-body);font-size:1rem;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);transition:all var(--transition-fast);width:100%}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.input-code{font-family:var(--font-display);font-size:2rem;font-weight:700;text-align:center;letter-spacing:.3em;text-transform:uppercase;padding:var(--space-lg)}.stepper{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-md)}.stepper-btn{width:56px;height:56px;border-radius:50%;border:2px solid var(--border);background:var(--surface);font-size:1.5rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.stepper-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:#6b4ee60d}.stepper-btn:disabled{opacity:.3;cursor:not-allowed}.stepper-value{font-family:var(--font-display);font-size:3rem;font-weight:700;min-width:80px;text-align:center;color:var(--primary)}.room-code-display{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-lg);margin-bottom:var(--space-xl)}.room-code-value{font-family:var(--font-display);font-size:2rem;font-weight:700;letter-spacing:.2em;color:#fff}.copy-btn{padding:var(--space-sm) var(--space-md);background:#fff3;border:none;border-radius:var(--radius-sm);color:#fff;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.copy-btn:hover{background:#ffffff4d}.player-list{display:flex;flex-direction:column;gap:var(--space-sm)}.player-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border-light)}.player-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light),var(--coral-light));display:flex;align-items:center;justify-content:center;font-size:1.25rem}.player-info{flex:1}.player-name{font-weight:600;color:var(--text-primary)}.player-badge{font-size:.75rem;color:var(--primary);font-weight:500}.player-status{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem}.player-status.ready{background:var(--success-light);color:var(--teal-dark)}.player-status.waiting{background:var(--border-light);color:var(--text-muted)}.upload-zone{border:3px dashed var(--border);border-radius:var(--radius-lg);padding:var(--space-2xl);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--surface);margin-bottom:var(--space-xl)}.upload-zone:hover{border-color:var(--primary);background:#6b4ee608}.upload-icon{font-size:3rem;margin-bottom:var(--space-md)}.upload-text{color:var(--text-secondary)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm);margin-bottom:var(--space-xl)}.photo-thumb{aspect-ratio:1;border-radius:var(--radius-md);background:var(--bg-cream-dark);position:relative;overflow:hidden;border:2px solid var(--border-light)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-thumb-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center}.progress-bar{height:8px;background:var(--border);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-sm)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--teal));border-radius:var(--radius-full);transition:width var(--transition-base)}.progress-text{text-align:center;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xl)}.upload-zone-disabled{opacity:.5;cursor:not-allowed;border-color:var(--border-light)}.upload-zone-disabled:hover{border-color:var(--border-light);background:var(--surface)}.photo-thumb-img{width:100%;height:100%;object-fit:cover}.photo-thumb-img-loading{opacity:.5}.photo-thumb-uploading{position:relative}.photo-upload-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center}.photo-upload-status{color:#fff;font-size:.75rem;font-weight:500;text-align:center;padding:var(--space-xs) var(--space-sm);background:#0000004d;border-radius:var(--radius-sm)}.photo-upload-error{background:var(--error)}.photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--text-muted)}.hint-text{font-size:.875rem;color:var(--text-muted)}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.round-counter{font-family:var(--font-display);font-weight:600;color:var(--text-secondary)}.score-display{display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-display);font-weight:700;color:var(--primary)}.photo-display{position:relative;width:100%;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-cream-dark);margin-bottom:var(--space-xl);box-shadow:var(--shadow-lg);border:6px solid var(--surface)}.photo-display:after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 30px #0000001a;pointer-events:none}.photo-display img{width:100%;height:auto;display:block}.photo-placeholder{width:100%;min-height:200px;display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--text-muted)}.question-text{font-family:var(--font-display);font-size:1.5rem;font-weight:600;text-align:center;margin-bottom:var(--space-lg)}.answer-options{display:flex;flex-direction:column;gap:var(--space-sm)}.answer-btn{padding:var(--space-lg);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);text-align:left}.answer-btn:hover{border-color:var(--primary);background:#6b4ee60d;transform:translate(4px)}.answer-btn.selected{border-color:var(--primary);background:var(--primary);color:#fff}.answer-btn.correct{border-color:var(--teal);background:var(--teal);color:#fff}.answer-btn.incorrect{border-color:var(--error);background:var(--error-light);color:var(--error)}.waiting-text{text-align:center;color:var(--text-muted);font-size:.875rem;margin-top:var(--space-lg)}.results-container{text-align:center}.winner-section{padding:var(--space-2xl) 0;margin-bottom:var(--space-xl)}.trophy-icon{font-size:5rem;margin-bottom:var(--space-md);animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.winner-label{font-size:.875rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);margin-bottom:var(--space-sm)}.winner-name{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--primary);margin-bottom:var(--space-sm)}.winner-score{font-size:1.25rem;color:var(--text-secondary)}.leaderboard{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);text-align:left}.leaderboard-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;margin-bottom:var(--space-lg);text-align:center}.leaderboard-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--border-light)}.leaderboard-item:last-child{border-bottom:none}.leaderboard-rank{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.rank-1{background:linear-gradient(135deg,gold,orange);color:#fff}.rank-2{background:linear-gradient(135deg,silver,#a8a8a8);color:#fff}.rank-3{background:linear-gradient(135deg,#cd7f32,#b8860b);color:#fff}.rank-other{background:var(--border-light);color:var(--text-secondary)}.leaderboard-name{flex:1;font-weight:500}.leaderboard-name.is-you{color:var(--primary)}.leaderboard-score{font-family:var(--font-display);font-weight:700;color:var(--text-secondary)}.game-stats{display:flex;justify-content:center;gap:var(--space-lg);padding:var(--space-lg) 0;margin-bottom:var(--space-lg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-2xs)}.stat-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--primary)}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.room-info{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md);margin-bottom:var(--space-lg);background:var(--surface);border-radius:var(--radius-md)}.room-code-label{color:var(--text-muted);font-size:.875rem}.results-actions{display:flex;flex-direction:column;gap:var(--space-sm)}.landing-hero{padding:var(--space-2xl) 0;text-align:center}.hero-illustration{width:200px;height:200px;margin:0 auto var(--space-xl);background:linear-gradient(135deg,var(--primary-light) 0%,var(--coral) 50%,var(--teal) 100%);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:5rem;box-shadow:var(--shadow-lg);position:relative;animation:float 4s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-10px) rotate(2deg)}}.hero-illustration:before{content:"";position:absolute;inset:-4px;background:linear-gradient(135deg,var(--primary),var(--coral),var(--teal));border-radius:var(--radius-xl);z-index:-1;filter:blur(20px);opacity:.4}.hero-tagline{font-family:var(--font-display);font-size:clamp(2rem,8vw,3rem);font-weight:700;line-height:1.1;margin-bottom:var(--space-md);background:linear-gradient(135deg,var(--text-primary),var(--primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{color:var(--text-secondary);font-size:1.125rem;max-width:320px;margin:0 auto var(--space-2xl);line-height:1.6}.landing-actions{display:flex;flex-direction:column;gap:var(--space-md)}.page-title{font-family:var(--font-display);font-size:1.75rem;font-weight:700;margin-bottom:var(--space-lg);text-align:center}.page-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:var(--space-xl)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.section-title{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.room-info{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-md);background:var(--bg-cream-dark);border-radius:var(--radius-md);margin-bottom:var(--space-xl);font-size:.875rem;color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-slide-up{animation:slideUp .5s ease forwards}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.btn-small{padding:var(--space-xs) var(--space-md);font-size:.875rem;width:auto}.display-name-section{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);border:1px solid var(--border-light)}.display-name-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-sm)}.display-name-view{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.display-name-value{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--text-primary)}.display-name-edit{display:flex;flex-direction:column;gap:var(--space-sm)}.display-name-input{padding:var(--space-sm) var(--space-md);font-family:var(--font-display);font-size:1.25rem;font-weight:600;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--bg-cream);width:100%;transition:all var(--transition-fast)}.display-name-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.display-name-input:disabled{opacity:.6;cursor:not-allowed}.display-name-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.display-name-error{color:var(--error);font-size:.875rem;margin-top:var(--space-sm)}.edit-btn{color:var(--primary)}.share-hint{text-align:center;color:var(--text-muted);font-size:.875rem;margin-top:calc(var(--space-md) * -1);margin-bottom:var(--space-lg)}.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-lg)}.error-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-lg);text-align:center}.error-message{color:var(--error);font-size:.875rem;text-align:center;margin-top:var(--space-sm)}.offline-banner{background:var(--warning);color:var(--background);text-align:center;padding:var(--space-sm) var(--space-md);font-size:.875rem;font-weight:500;position:sticky;top:0;z-index:1000}.correct-answer{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-lg);background:linear-gradient(135deg,var(--teal) 0%,var(--teal-dark) 100%);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);text-align:center}.correct-answer-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:#fffc}.correct-answer-name{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:#fff}.vote-results{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg)}.results-header{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-md);text-align:center}.vote-result-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-sm);background:var(--bg-cream);border:2px solid var(--border-light)}.vote-result-item:last-child{margin-bottom:0}.vote-result-item.correct{border-color:var(--teal);background:#00d4aa14}.vote-result-item.incorrect{border-color:var(--error);background:#e53e3e0d}.voter-name{font-weight:600;color:var(--text-primary);min-width:80px}.vote-arrow{color:var(--text-muted);font-size:.875rem}.guessed-name{flex:1;color:var(--text-secondary)}.result-indicator{font-weight:700;font-size:.875rem;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.result-indicator.correct{color:var(--teal-dark);background:var(--success-light)}.result-indicator.incorrect{color:var(--error);background:var(--error-light)}.reveal-actions{margin-top:var(--space-lg)}
