:root{--bg: #f8f4ec;--surface: #ffffff;--surface-read: #fdf9f2;--line: rgba(45,42,38,.1);--text: #2d2a26;--text-soft: #8c8478;--accent: #d97548;--accent-hover: #c4673d;--danger: #d94444;--success: #3a9a6d;--warn: #b87a1a;--font-display: "Space Grotesk", "SF Pro Display", sans-serif;--font-serif: "DM Serif Display", Georgia, serif;--font-read: Charter, Georgia, "Times New Roman", serif;--font-mono: "IBM Plex Mono", "SF Mono", Menlo, monospace;--shadow-sm: 0 1px 4px rgba(45,42,38,.07);--shadow-md: 0 4px 16px rgba(45,42,38,.1);--radius: 14px}*{box-sizing:border-box;margin:0}html,body,#root{min-height:100dvh;background:var(--bg);color:var(--text);font-family:var(--font-display);-webkit-font-smoothing:antialiased}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.screen{flex:1;display:flex;flex-direction:column;align-items:center;padding:48px 20px env(safe-area-inset-bottom,24px);gap:20px;animation:fade-in .3s ease}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.eyebrow{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-soft)}.btn-primary{border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-family:var(--font-display);font-weight:700;font-size:1rem;padding:14px 40px;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .15s,background .15s}.btn-primary:hover{transform:translateY(-1px);background:var(--accent-hover)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-danger{border:none;border-radius:var(--radius);background:var(--danger);color:#fff;font-family:var(--font-display);font-weight:700;font-size:1rem;padding:14px 40px;cursor:pointer;transition:transform .15s}.btn-danger:hover{transform:translateY(-1px)}.btn-danger:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);color:var(--text);font-family:var(--font-mono);font-size:.82rem;padding:10px 20px;cursor:pointer;transition:border-color .2s,background .2s;text-decoration:none;display:inline-block}.btn-ghost:hover{border-color:var(--accent)}.notice{font-size:.8rem;color:var(--warn);text-align:center;max-width:400px}.loader-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-soft);font-size:.88rem}.loader{width:28px;height:28px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.screen-setup{justify-content:center;min-height:100dvh;position:relative}.profile-chip{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;background:var(--surface);padding:4px 12px 4px 4px;cursor:pointer;transition:border-color .2s;z-index:5}.profile-chip:hover{border-color:var(--accent)}.profile-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.profile-initial{width:24px;height:24px;border-radius:50%;background:var(--line);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--text-soft);text-transform:uppercase}.profile-signout{font-family:var(--font-mono);font-size:.65rem;color:var(--text-soft);letter-spacing:.03em}.prefs-gear{position:absolute;top:16px;right:120px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:50%;background:var(--surface);color:var(--text-soft);cursor:pointer;transition:border-color .2s,color .2s;z-index:5}.prefs-gear:hover{border-color:var(--accent);color:var(--accent)}.setup-tagline{font-family:var(--font-serif);font-size:1.1rem;color:var(--text-soft);text-align:center;max-width:360px;line-height:1.5}.setup-hint{font-size:.82rem;color:var(--text-soft);text-align:center;max-width:320px}.setup-rule{font-family:var(--font-mono);font-size:.75rem;color:var(--text-soft);letter-spacing:.04em}.roulette-window{width:100%;max-width:480px;height:110px;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--line);border-radius:18px;background:var(--surface);box-shadow:var(--shadow-md)}.roulette-title{font-family:var(--font-serif);font-size:clamp(1.5rem,5vw,2.4rem);text-align:center;padding:0 20px;color:var(--text);animation:slot-tick .06s ease}@keyframes slot-tick{0%{transform:translateY(-30%);opacity:.4}to{transform:translateY(0);opacity:1}}.topic-category{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);opacity:.7;text-align:center;margin-top:4px}.topic-desc{color:var(--text-soft);font-size:.9rem;text-align:center;max-width:440px}.setup-actions{display:flex;gap:12px}.pill-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.pill{border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--text-soft);font-family:var(--font-mono);font-size:.72rem;padding:6px 14px;cursor:pointer;transition:border-color .2s,color .2s,background .2s}.pill:hover{border-color:var(--accent);color:var(--text)}.pill.active{border-color:var(--pill-color, var(--accent));color:var(--pill-color, var(--accent));background:color-mix(in srgb,var(--pill-color, var(--accent)) 10%,var(--surface))}.screen-reading{padding-top:24px;gap:14px}.reading-header{width:100%;max-width:640px;text-align:center}.reading-subline{font-size:.82rem;color:var(--text-soft);margin-top:2px}.reading-body{width:100%;max-width:640px;max-height:55vh;overflow-y:auto;border-radius:16px;background:var(--surface-read);padding:28px 24px;box-shadow:var(--shadow-md);scroll-behavior:smooth}.reading-body p{margin:0 0 14px;line-height:1.8;color:var(--text);font-family:var(--font-read);font-size:1.02rem}.wiki-render{color:var(--text);font-family:var(--font-read);font-size:1.05rem;line-height:1.85;overflow-wrap:anywhere}.wiki-render *{max-width:100%}.wiki-render h2,.wiki-render h3,.wiki-render h4{margin:24px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--line);color:var(--text);font-family:var(--font-display);font-weight:700;font-size:1.1rem}.wiki-render h3{font-size:1rem}.wiki-render h4{font-size:.95rem}.wiki-render p{margin:0 0 14px}.wiki-render img,.wiki-render table,.wiki-render .infobox,.wiki-render .sidebar,.wiki-render .navbox,.wiki-render figure,.wiki-render .thumb,.wiki-render .gallery,.wiki-render sup,.wiki-render ul,.wiki-render ol,.wiki-render dl{display:none!important}.wiki-source-link{display:inline-block;margin-top:4px;font-family:var(--font-mono);font-size:.75rem;color:var(--accent);text-decoration:none;border-bottom:1px dashed var(--accent);padding-bottom:1px}.wiki-source-link:hover{opacity:.7}.circular-timer{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.circular-timer svg{position:absolute;top:0;left:0}.timer-text{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;color:var(--text);z-index:1}.circular-timer[style*="width: 100px"] .timer-text{font-size:1rem}.screen-booth{position:relative;padding:0;gap:0;overflow:hidden;background:#000}.booth-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;background:#000;transform:scaleX(-1)}.screen-booth.audio-only{background:var(--bg);padding:0}.audio-center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px 20px;width:100%}.mic-timer-wrap{position:relative;width:180px;height:180px;display:flex;align-items:center;justify-content:center}.mic-timer-ring{position:absolute;top:0;right:0;bottom:0;left:0}.mic-center-icon{animation:mic-breathe 3s ease-in-out infinite}@keyframes mic-breathe{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}.mic-timer-text{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;color:var(--text);letter-spacing:.04em}.screen-mode-pick{justify-content:center;text-align:center;background:linear-gradient(180deg,var(--bg) 0%,#f0ede6 100%)}.mode-pick-title{font-family:var(--font-serif);font-size:1.4rem;color:var(--text);margin:0}.mode-pick-sub{font-size:.8rem;color:var(--text-soft);margin-top:-8px}.mode-pick-options{display:flex;gap:16px;margin-top:8px;width:100%;max-width:380px}.mode-pick-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 16px;border:2px solid var(--line);border-radius:16px;background:var(--surface);cursor:pointer;transition:border-color .2s,transform .15s,box-shadow .2s;color:var(--text-soft)}.mode-pick-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-md);color:var(--accent)}.mode-pick-card strong{font-family:var(--font-display);font-size:.95rem;color:var(--text)}.mode-pick-card span{font-size:.72rem;color:var(--text-soft);line-height:1.4}.booth-hud{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:16px;width:100%}.booth-hud-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.booth-hud-top .eyebrow{background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 12px;border-radius:8px;color:#ffffffe6}.booth-hud-bottom{display:flex;flex-direction:column;gap:10px}.booth-dare{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.06em;color:#ffffffb3;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:6px 12px;border-radius:8px}.step-prompt-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:6px}.step-pill{border-radius:10px;border:1px solid rgba(255,255,255,.15);background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:8px;display:grid;gap:3px}.step-pill strong{font-size:.76rem;color:#fff}.step-pill span{font-size:.65rem;color:#ffffffa6;line-height:1.35}.step-pill.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 25%,rgba(0,0,0,.5))}.step-pill.done{opacity:.5}.live-caption{font-size:.78rem;color:#ffffffe6;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:8px 12px;border-radius:8px;max-height:60px;overflow:hidden}.live-caption.silence-nudge{color:#fbbf24;animation:pulse-nudge 1.5s ease-in-out infinite}@keyframes pulse-nudge{0%,to{opacity:.7}50%{opacity:1}}.booth-actions{display:flex;gap:10px;justify-content:center}.screen-review{padding-top:32px;max-width:640px;margin:0 auto;width:100%}.review-title{font-family:var(--font-serif);font-size:1.6rem;text-align:center}.video-strip{display:flex;gap:8px;overflow-x:auto;width:100%;padding:2px 0}.video-thumb{flex-shrink:0;display:flex;flex-direction:column;gap:4px;align-items:center}.review-video-sm{width:140px;height:100px;border-radius:10px;background:#000;object-fit:cover}.video-label{font-family:var(--font-mono);font-size:.65rem;color:var(--text-soft)}.metric-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;width:100%}.metric-card{border:1px solid var(--line);border-radius:12px;background:var(--surface);padding:12px;text-align:center;box-shadow:var(--shadow-sm)}.metric-card span{display:block;font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-soft);margin-bottom:4px}.metric-card strong{font-size:1rem}.progress-bar-inline{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:var(--surface);width:100%;font-size:.82rem}.progress-bar-inline span{color:var(--text-soft);font-size:.78rem}.progress-bar-inline strong{font-size:1.1rem}.score-badge{margin-left:auto;background:var(--accent);color:#fff;padding:3px 10px;border-radius:999px;font-family:var(--font-mono);font-size:.72rem;font-weight:700}.expand-btn{width:100%;text-align:center}.details-panel{display:flex;flex-direction:column;gap:16px;width:100%;animation:fade-in .25s ease}.rating-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.rating-card{border:1px solid var(--line);border-radius:10px;background:var(--surface);padding:10px;box-shadow:var(--shadow-sm)}.rating-card span{display:block;font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft)}.rating-card strong{display:block;margin:4px 0;font-size:.95rem}.rating-card p{margin:0;font-size:.78rem;color:var(--text-soft);line-height:1.4}.feedback-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px}.feedback-cols h4{font-size:.88rem;margin-bottom:8px}.feedback-cols ul{padding-left:16px;display:flex;flex-direction:column;gap:6px;font-size:.84rem;color:var(--text-soft);line-height:1.45}.tag-row{display:flex;flex-wrap:wrap;gap:6px}.tag{border-radius:999px;padding:4px 10px;font-family:var(--font-mono);font-size:.66rem}.tag.warn{border:1px solid rgba(184,122,26,.35);color:var(--warn);background:#b87a1a0f}.tag.ok{border:1px solid rgba(58,154,109,.35);color:var(--success);background:#3a9a6d0f}.tag.miss{border:1px solid rgba(217,68,68,.35);color:var(--danger);background:#d944440f}.next-focus h4{font-size:.88rem;margin-bottom:6px}.next-focus p{font-size:.84rem;color:var(--text-soft);line-height:1.5}.transcript-display{display:flex;flex-direction:column;gap:6px}.transcript-display label{font-family:var(--font-mono);font-size:.72rem;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em}.transcript-display p{border:1px solid var(--line);border-radius:10px;padding:12px;background:var(--surface-read);color:var(--text);font-family:var(--font-read);font-size:.88rem;line-height:1.6;max-height:160px;overflow-y:auto;margin:0}.review-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;width:100%;padding-top:8px}.artic-score-hero{display:flex;flex-direction:column;align-items:center;gap:4px;padding:28px 20px 20px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 8%,var(--surface)),var(--surface) 60%);width:100%;text-align:center;box-shadow:var(--shadow-md)}.artic-score-loading{padding:40px 20px;gap:16px}.artic-score-loading .loader{width:32px;height:32px}.artic-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-soft)}.artic-number{font-family:var(--font-serif);font-size:4rem;line-height:1;color:var(--text)}.artic-out-of{font-family:var(--font-mono);font-size:1rem;color:var(--text-soft);margin-top:-4px}.artic-delta{font-family:var(--font-mono);font-size:.78rem;color:var(--accent);margin-top:4px}.screen-auth{justify-content:center;min-height:100dvh;text-align:center}.auth-title{font-family:var(--font-serif);font-size:clamp(1.8rem,5vw,2.6rem);line-height:1.2;max-width:400px}.auth-subtitle{font-size:.95rem;color:var(--text-soft);max-width:340px;line-height:1.55}.btn-google{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);color:var(--text);font-family:var(--font-display);font-weight:600;font-size:.95rem;padding:14px 28px;cursor:pointer;box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s}.btn-google:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.auth-footer{font-family:var(--font-mono);font-size:.7rem;color:var(--text-soft);letter-spacing:.03em}.screen-onboard{justify-content:center;min-height:100dvh;text-align:center;position:relative}.onboard-page{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:400px;animation:page-turn .4s ease}@keyframes page-turn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.onboard-heading{font-family:var(--font-serif);font-size:clamp(1.6rem,5vw,2.2rem);line-height:1.2}.onboard-body{font-size:.95rem;color:var(--text-soft);line-height:1.6;max-width:360px}.onboard-steps{display:flex;flex-direction:column;gap:14px;width:100%;text-align:left}.onboard-step{display:flex;gap:14px;align-items:flex-start;padding:14px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.onboard-step strong{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);flex-shrink:0;margin-top:2px}.onboard-step p{font-size:.88rem;color:var(--text-soft);line-height:1.45;margin:0}.onboard-page-wide{max-width:460px}.category-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:420px}.category-pill{border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--text-soft);font-family:var(--font-mono);font-size:.78rem;padding:8px 16px;cursor:pointer;transition:border-color .2s,color .2s,background .2s,transform .15s}.category-pill:hover{border-color:var(--accent);color:var(--text)}.category-pill.selected{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface));font-weight:600;transform:scale(1.04)}.depth-options{display:flex;flex-direction:column;gap:10px;width:100%;max-width:360px}.depth-card{display:flex;flex-direction:column;gap:4px;padding:16px;border:1px solid var(--line);border-radius:14px;background:var(--surface);cursor:pointer;text-align:left;transition:border-color .2s,background .2s,transform .15s}.depth-card:hover{border-color:var(--accent)}.depth-card.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface));transform:scale(1.02)}.depth-card strong{font-family:var(--font-display);font-size:.95rem;color:var(--text)}.depth-card span{font-family:var(--font-mono);font-size:.72rem;color:var(--text-soft)}.prefs-prompt{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1px dashed var(--accent);border-radius:12px;background:color-mix(in srgb,var(--accent) 5%,var(--surface));width:100%;max-width:400px;cursor:pointer;transition:background .2s}.prefs-prompt:hover{background:color-mix(in srgb,var(--accent) 10%,var(--surface))}.prefs-prompt-text{flex:1}.prefs-prompt-text strong{display:block;font-size:.85rem;color:var(--text)}.prefs-prompt-text span{font-family:var(--font-mono);font-size:.68rem;color:var(--text-soft)}.prefs-prompt-arrow{font-size:1.2rem;color:var(--accent)}.onboard-dots{position:absolute;bottom:32px;display:flex;gap:8px}.onboard-dot{width:8px;height:8px;border-radius:50%;background:var(--line);transition:background .3s}.onboard-dot.active{background:var(--accent)}.live-feed{display:flex;flex-direction:column;gap:6px;max-height:140px;overflow:hidden;width:100%;max-width:340px}.feed-item{display:flex;align-items:center;gap:8px;font-size:.75rem;animation:feed-slide .5s ease;padding:5px 10px;border-radius:8px;background:#d975480f;border-left:2px solid var(--accent)}@keyframes feed-slide{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.feed-dot{width:6px;height:6px;border-radius:50%;background:#34d399;flex-shrink:0;animation:feed-pulse 2s ease-in-out infinite}@keyframes feed-pulse{0%,to{opacity:.5}50%{opacity:1}}.feed-name{font-weight:700;color:var(--accent);font-family:var(--font-display)}.feed-stars{color:var(--accent);font-size:.6rem;letter-spacing:1px;flex-shrink:0}.feed-action{color:var(--text-soft);font-family:var(--font-mono);font-size:.68rem}.leaderboard{width:100%;max-width:340px;display:flex;flex-direction:column;gap:8px;align-self:center}.lb-list{display:flex;flex-direction:column;gap:6px}.lb-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm)}.lb-me{border:1.5px solid var(--accent)}.lb-rank{width:26px;height:26px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.7rem;font-weight:700;color:var(--text-soft);flex-shrink:0}.lb-rank.gold{background:#fbbf24;color:#fff}.lb-rank.silver{background:#94a3b8;color:#fff}.lb-rank.bronze{background:#d97706;color:#fff}.lb-name{flex:1;font-weight:600;font-size:.88rem;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-details{display:flex;gap:14px;flex-shrink:0}.lb-detail-item{display:flex;flex-direction:column;align-items:center;gap:1px}.lb-detail-val{font-family:var(--font-display);font-size:.85rem;font-weight:700;color:var(--text)}.lb-detail-label{font-family:var(--font-mono);font-size:.55rem;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em}.lb-you-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius);border:1.5px dashed var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--surface));margin-top:2px}.prep-input{width:100%;max-width:420px;display:flex;flex-direction:column;gap:10px}.prep-textarea{resize:vertical;min-height:100px;max-height:250px;font-family:var(--font-read);font-size:.88rem;line-height:1.6}.brick-wall-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:var(--bg);overflow-y:auto;padding:24px 20px 40px}.brick-wall{max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.brick-header{display:flex;flex-direction:column;gap:4px}.brick-wall-title{font-family:var(--font-serif);font-size:1.3rem;margin:8px 0 0}.brick-wall-progress{font-family:var(--font-mono);font-size:.72rem;color:var(--text-soft)}.brick-chain-btn{width:100%;padding:14px 18px;border:2px solid var(--accent);border-radius:var(--radius);background:color-mix(in srgb,var(--accent) 8%,var(--surface));cursor:pointer;display:flex;flex-direction:column;gap:3px;font-family:var(--font-display);font-size:.9rem;font-weight:700;color:var(--accent);transition:transform .15s}.brick-chain-btn:hover{transform:translateY(-1px)}.brick-chain-btn span{font-weight:400;font-size:.72rem;color:var(--text-soft)}.brick-group{border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:8px}.brick-group.current{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 12%,transparent)}.brick-group.done{opacity:.5;border-color:var(--success)}.brick-group.locked{opacity:.35}.brick-group-header{display:flex;align-items:center;gap:10px}.brick-group-label{width:28px;height:28px;border-radius:8px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.75rem;font-weight:700;color:var(--text-soft);flex-shrink:0}.brick-group-label.complete{background:var(--success);color:#fff}.brick-group-title{font-weight:600;font-size:.85rem;flex:1}.brick-group-range{font-family:var(--font-mono);font-size:.65rem;color:var(--text-soft)}.brick-group-dots{font-family:var(--font-mono);font-size:.7rem;color:var(--text-soft)}.brick-group-body{display:flex;flex-direction:column;gap:6px;padding-left:4px}.brick-chain-btn-sm{width:100%;padding:8px 12px;border:1.5px dashed var(--accent);border-radius:10px;background:color-mix(in srgb,var(--accent) 5%,var(--surface));cursor:pointer;font-family:var(--font-display);font-size:.78rem;font-weight:600;color:var(--accent);transition:background .15s}.brick-chain-btn-sm:hover{background:color-mix(in srgb,var(--accent) 10%,var(--surface))}.brick-connect{border-color:var(--success);color:var(--success)}.brick-connect span{color:var(--text-soft)}.brick-list{display:flex;flex-direction:column;gap:8px}.brick-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:12px 16px;display:flex;flex-direction:column;gap:6px}.brick-item.done{opacity:.6;border-color:var(--success)}.brick-item.current{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 15%,transparent)}.brick-item-header{display:flex;align-items:center;gap:8px}.brick-num{width:24px;height:24px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.65rem;font-weight:700;color:var(--text-soft);flex-shrink:0}.brick-item.done .brick-num{background:var(--success);color:#fff}.brick-title{font-weight:600;font-size:.82rem;flex:1}.brick-dots{display:flex;gap:3px;flex-shrink:0}.brick-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--line)}.brick-dot.read.filled{background:#60a5fa;border-color:#60a5fa}.brick-dot.speak.filled{background:var(--accent);border-color:var(--accent)}.brick-preview{font-size:.78rem;color:var(--text-soft);line-height:1.5;margin:0}.brick-item-actions{display:flex;gap:8px}.brick-active{max-width:480px;margin:0 auto;padding:40px 20px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.brick-active-header{display:flex;flex-direction:column;gap:4px}.brick-active-title{font-family:var(--font-serif);font-size:1.2rem;font-weight:700}.brick-active-step{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);text-transform:uppercase;letter-spacing:.08em}.brick-active-text{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;text-align:left;max-height:50vh;overflow-y:auto;font-family:var(--font-read);font-size:1.05rem;line-height:1.7;color:var(--text)}.brick-active-text p{margin:0 0 12px}.brick-active-text p:last-child{margin-bottom:0}.brick-active-hint{font-size:.85rem;color:var(--text-soft);max-width:300px}.brick-active-actions{display:flex;gap:10px}.brick-complete{text-align:center;padding:20px}.brick-complete h3{font-family:var(--font-serif);color:var(--success)}.script-accuracy{width:100%;max-width:480px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;display:flex;flex-direction:column;gap:8px}.script-accuracy h4{font-family:var(--font-display);font-size:.85rem;font-weight:700;margin:0}.accuracy-bar-wrap{width:100%;height:8px;background:var(--line);border-radius:4px;overflow:hidden}.accuracy-bar{height:100%;background:var(--accent);border-radius:4px;transition:width .6s ease}.accuracy-score{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--text);margin:0}.accuracy-counts{font-family:var(--font-mono);font-size:.68rem;color:var(--text-soft);margin:0}.accuracy-missed{margin-top:4px}.accuracy-missed-label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;margin:0 0 4px}.accuracy-missed-list{display:flex;flex-wrap:wrap;gap:4px}.accuracy-missed-phrase{font-family:var(--font-mono);font-size:.7rem;color:var(--danger);background:color-mix(in srgb,var(--danger) 8%,var(--surface));padding:3px 8px;border-radius:6px}.prep-sticky{background:#fef9c3;border-left:3px solid #eab308;border-radius:6px;padding:8px 12px;margin:8px 0;font-family:var(--font-mono);font-size:.78rem;color:#92400e;line-height:1.5;font-style:italic}.prep-sticky-inline{background:#fef9c3;border-radius:4px;padding:2px 6px;font-family:var(--font-mono);font-size:.78rem;color:#92400e;font-style:italic}.export-wrap{position:relative}.export-menu{position:absolute;bottom:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);overflow:hidden;z-index:20;min-width:220px;animation:fade-in .15s ease}.export-menu button{display:flex;flex-direction:column;gap:2px;width:100%;padding:12px 16px;border:none;background:none;text-align:left;cursor:pointer;font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--text);transition:background .15s}.export-menu button:hover{background:var(--bg)}.export-menu button+button{border-top:1px solid var(--line)}.export-menu button span{font-family:var(--font-mono);font-size:.65rem;font-weight:400;color:var(--text-soft)}.booth-error-group{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.btn-sm{padding:8px 20px;font-size:.82rem}.practice-map{width:100%;max-width:480px;display:flex;flex-direction:column;gap:8px;position:relative}.map-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.map-count{font-family:var(--font-display);font-size:.82rem;font-weight:600;color:var(--text)}.map-period{font-family:var(--font-mono);font-size:.65rem;color:var(--text-soft);letter-spacing:.04em}.map-title{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft)}.map-scroll{overflow-x:auto;overflow-y:visible;padding-bottom:4px}.map-body{display:flex;gap:0;justify-content:center}.map-day-labels{display:flex;flex-direction:column;gap:4px;width:32px;flex-shrink:0}.map-day-label{height:28px;display:flex;align-items:center;font-family:var(--font-mono);font-size:.62rem;color:var(--text-soft);line-height:1}.map-grid{display:flex;gap:4px}.map-col{display:flex;flex-direction:column;gap:4px}.map-cell{width:28px;height:28px;border-radius:6px;background:var(--line);cursor:pointer;transition:transform .15s;outline:1px solid rgba(45,42,38,.06);outline-offset:-1px}.map-cell:hover{transform:scale(1.2);z-index:2;position:relative}.map-cell.future{cursor:default}.map-cell.level-0{background:var(--line)}.map-cell.level-1{background:color-mix(in srgb,var(--accent) 25%,var(--surface))}.map-cell.level-2{background:color-mix(in srgb,var(--accent) 50%,var(--surface))}.map-cell.level-3{background:color-mix(in srgb,var(--accent) 75%,var(--surface))}.map-cell.level-4{background:var(--accent)}.map-legend{display:flex;align-items:center;gap:3px;justify-content:flex-end}.map-legend-text{font-family:var(--font-mono);font-size:.58rem;color:var(--text-soft);margin:0 2px}.legend-swatch{cursor:default;outline:none}.legend-swatch:hover{transform:none}.map-tooltip{display:flex;flex-direction:column;gap:2px;position:absolute;bottom:-8px;transform:translateY(100%);background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:10px 14px;box-shadow:var(--shadow-md);font-size:.78rem;z-index:10;white-space:nowrap;left:50%;translate:-50% 0}.map-tooltip strong{font-size:.82rem}.map-tooltip span{color:var(--text-soft);font-size:.72rem}.paywall-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#2d2a2680;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fade-in .25s ease}.paywall-card{background:var(--surface);border-radius:20px;padding:32px 28px;max-width:380px;width:100%;text-align:center;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-md)}.paywall-card h3{font-family:var(--font-serif);font-size:1.4rem}.paywall-card p{font-size:.88rem;color:var(--text-soft);line-height:1.55}@media (max-width: 600px){.screen{padding:32px 14px env(safe-area-inset-bottom,20px)}.metric-row{grid-template-columns:repeat(2,1fr)}.feedback-cols{grid-template-columns:1fr}.step-prompt-row{grid-template-columns:repeat(2,1fr)}.booth-hud{padding:12px}.roulette-window{height:100px}.roulette-title{font-size:1.3rem}.reading-body{padding:20px 16px}.map-cell{width:22px;height:22px;border-radius:5px}.map-grid,.map-col{gap:3px}.map-day-labels{width:26px;gap:3px}.map-day-label{height:22px;font-size:.52rem}.squad-map-cell{width:12px;height:12px}.squad-hub-card.large{max-width:100%;max-height:90vh;padding:20px 16px}.challenge-row{gap:8px}.challenge-number{width:20px;height:20px;font-size:.6rem}.challenge-info strong{font-size:.75rem}.challenge-dot{width:8px;height:8px}}.mode-switcher{display:flex;align-items:center;gap:0;background:#2d2a260f;border-radius:12px;padding:3px;width:100%;max-width:380px;overflow-x:auto}.mode-tab{flex:1;min-width:0;padding:10px 16px;border:none;border-radius:10px;background:transparent;font-family:var(--font-display);font-size:.82rem;font-weight:500;color:var(--text-soft);cursor:pointer;transition:all .2s;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:6px;opacity:.6}.mode-tab:hover{opacity:.85}.mode-tab.active{background:var(--surface);color:var(--text);font-weight:700;box-shadow:var(--shadow-sm);opacity:1}.mode-tab.squad-tab.active{background:#ede5f7;color:#5b21b6;font-weight:700;box-shadow:0 1px 4px #5b21b61f;opacity:1}.mode-tab-new{color:#8b5cf6;flex:0;opacity:.7}.mode-tab-new:hover{background:#8b5cf60f;opacity:1}.mode-tab-dots{display:flex;gap:2px;flex-shrink:0}.mode-dot{width:7px;height:7px;border-radius:50%;display:inline-block}.app-shell.squad-mode{--bg: #f3eef8;--surface: #faf7ff;--surface-read: #f7f3fc;--line: rgba(100, 60, 150, .1);--accent: #8b5cf6;--accent-hover: #7c3aed}.squad-cta{width:100%;max-width:380px;display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#f3eef8,#ede5f7);border:1px solid rgba(139,92,246,.15);border-radius:var(--radius);padding:14px 18px;cursor:pointer;transition:border-color .2s,transform .15s;font-family:var(--font-display);text-align:left}.squad-cta:hover{border-color:#8b5cf6;transform:translateY(-1px)}.squad-cta-icon{width:38px;height:38px;border-radius:10px;background:#8b5cf61f;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#8b5cf6}.squad-cta-text{display:flex;flex-direction:column;gap:2px}.squad-cta-title{font-weight:700;font-size:.88rem;color:var(--text)}.squad-cta-sub{font-size:.72rem;color:var(--text-soft)}.squad-active-card{width:100%;max-width:380px;display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#ede5f7,#e4daf5);border:1.5px solid rgba(139,92,246,.25);border-radius:var(--radius);padding:14px 18px;cursor:pointer;transition:border-color .2s,transform .15s;font-family:var(--font-display);text-align:left}.squad-active-card:hover{border-color:#8b5cf6;transform:translateY(-1px)}.squad-active-left{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.squad-active-name{font-weight:700;font-size:.9rem;color:#5b21b6}.squad-active-meta{font-family:var(--font-mono);font-size:.65rem;color:#7c3aed;letter-spacing:.03em}.squad-active-dots{display:flex;gap:4px;flex-shrink:0}.squad-active-dots .squad-member-dot{width:12px;height:12px;border:2px solid rgba(255,255,255,.7)}.squad-active-label{font-family:var(--font-mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.1em;color:#8b5cf6;background:#8b5cf61a;padding:3px 8px;border-radius:6px;flex-shrink:0}.screen-squad{background:linear-gradient(180deg,#f3eef8,#ede5f7);min-height:100dvh;position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;overflow-y:auto;padding:48px 20px 40px;align-items:center;max-width:100%}.screen-squad>*{max-width:420px;width:100%}.squad-back{position:absolute;top:20px;left:20px;display:flex;align-items:center;gap:6px;background:#ffffffb3;border:1px solid rgba(139,92,246,.12);border-radius:10px;padding:8px 14px;cursor:pointer;font-family:var(--font-mono);font-size:.75rem;color:#5b21b6;transition:background .2s}.squad-back:hover{background:#ffffffe6}.squad-empty-icon{width:80px;height:80px;border-radius:20px;background:#8b5cf614;display:flex;align-items:center;justify-content:center}.squad-empty-title{font-family:var(--font-serif);font-size:1.6rem;color:#2d2a26}.squad-empty-desc{font-size:.9rem;color:var(--text-soft);line-height:1.6;max-width:340px;text-align:center}.squad-page-header{text-align:center}.squad-page-header h2{font-family:var(--font-serif);font-size:1.5rem;color:#2d2a26;margin:0}.squad-hub-theme{font-family:var(--font-mono);font-size:.72rem;color:#7c3aed;letter-spacing:.06em;text-transform:uppercase}.squad-members-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center}.squad-member-badge{display:flex;align-items:center;gap:6px;background:var(--bg);border-radius:20px;padding:5px 12px;font-size:.8rem;font-weight:600}.squad-member-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.creator-tag{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-soft)}.squad-invite-btn{padding:5px 12px;font-size:.75rem}.squad-hub-actions{display:flex;justify-content:center;padding-top:8px;border-top:1px solid var(--line);margin-top:4px}.squad-practice-map{width:100%;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative}.squad-legend{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.legend-item{display:flex;align-items:center;gap:5px;font-size:.72rem;font-family:var(--font-mono);color:var(--text-soft)}.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.squad-map-cell{width:16px;height:16px;border-radius:3px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;overflow:hidden;cursor:pointer;transition:transform .1s;background:var(--line)}.squad-map-cell:hover{transform:scale(1.4)}.squad-map-cell.empty{background:var(--line);cursor:default}.squad-map-cell .quadrant{display:block;min-width:0;min-height:0}.squad-challenges{width:100%;display:flex;flex-direction:column;gap:8px;align-items:center}.challenge-list{display:flex;flex-direction:column;gap:4px;width:100%}.challenge-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#fff9;border-radius:10px}.challenge-row:nth-child(odd){background:#fff6}.challenge-number{width:24px;height:24px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.65rem;font-weight:700;color:var(--text-soft);flex-shrink:0}.challenge-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.challenge-info strong{font-size:.8rem}.challenge-info span{font-size:.68rem;color:var(--text-soft)}.challenge-dots{display:flex;gap:4px;flex-shrink:0}.challenge-dot{width:10px;height:10px;border-radius:50%;transition:background .2s}.challenge-dot.done{box-shadow:0 0 4px #00000026}.challenge-crown{font-size:.9rem;flex-shrink:0}.squad-titles{display:flex;flex-direction:column;gap:4px;width:100%}.title-row{display:flex;align-items:center;gap:8px;font-size:.8rem;padding:6px 12px;background:#ffffff80;border-radius:10px}.title-name{font-weight:600}.speaker-title{font-family:var(--font-mono);font-size:.68rem;color:var(--text-soft);letter-spacing:.04em}.crown-count{margin-left:auto;font-family:var(--font-mono);font-size:.68rem;color:var(--text-soft)}.squad-create,.squad-create-done{display:flex;flex-direction:column;gap:12px;text-align:center}.squad-create h3,.squad-create-done h3{font-family:var(--font-serif);font-size:1.3rem}.squad-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-soft);margin-top:4px}.input-field{border:1px solid var(--line);border-radius:var(--radius);background:var(--bg);padding:12px 16px;font-family:var(--font-display);font-size:.95rem;color:var(--text);width:100%;outline:none;transition:border-color .2s}.input-field:focus{border-color:var(--accent)}.input-field::placeholder{color:var(--text-soft)}.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.theme-pill{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:10px;font-family:var(--font-display);font-size:.82rem;font-weight:600;color:var(--text);cursor:pointer;transition:border-color .2s,background .2s}.theme-pill:hover{border-color:var(--accent)}.theme-pill.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface))}.color-grid{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.color-dot{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s}.color-dot:hover{transform:scale(1.15)}.color-dot.selected{border-color:var(--text);transform:scale(1.15)}.color-dot.taken{opacity:.2;cursor:not-allowed}.invite-link-box{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px}.invite-link-box code{flex:1;font-family:var(--font-mono);font-size:.72rem;color:var(--text);word-break:break-all}.invite-link-box .btn-ghost{padding:6px 12px;font-size:.72rem;flex-shrink:0}.squad-join-theme{font-family:var(--font-mono);font-size:.75rem;color:var(--text-soft);letter-spacing:.06em;text-transform:uppercase}.squad-join-members{font-size:.85rem;color:var(--text-soft)}.squad-member-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.squad-member-chip{display:flex;align-items:center;gap:6px;border:1px solid;border-radius:20px;padding:5px 12px;font-size:.8rem;font-weight:600;background:var(--surface)}
