:root,[data-theme=light]{--primary: #1faf96;--on-primary: #ffffff;--primary-container: #c3ffd4;--on-primary-container: #033e1d;--secondary: #e8744f;--on-secondary: #ffffff;--secondary-container: #fbeeec;--on-secondary-container: #4c2214;--tertiary: #7a8e61;--tertiary-container: #e5fbce;--on-tertiary-container: #2a3220;--error: #de1102;--on-error: #ffffff;--error-container: #ffedec;--on-error-container: #6e0400;--background: #f6f7f9;--surface: #ffffff;--surface-low: #f1f1f1;--surface-mid: #fafafa;--surface-high: #ffffff;--on-surface: #1a1c20;--on-surface-variant: #656565;--outline: #b7b7b7;--outline-variant: #e4e4e4;--warn: #f6bc1a;--shadow: 0 1px 2px rgba(0, 0, 0, .04), 0 4px 16px rgba(0, 0, 0, .06)}[data-theme=dark]{--primary: #1faf96;--on-primary: #00210f;--primary-container: #0e8345;--on-primary-container: #c3ffd4;--secondary: #e8744f;--on-secondary: #200b05;--secondary-container: #4c2214;--on-secondary-container: #f6d8d3;--tertiary: #aac588;--tertiary-container: #2a3220;--on-tertiary-container: #e5fbce;--error: #ff7573;--on-error: #2c0100;--error-container: #6e0400;--on-error-container: #ffedec;--background: #0e0f11;--surface: #16181c;--surface-low: #111214;--surface-mid: #1a1c20;--surface-high: #22252b;--on-surface: #f1f1f1;--on-surface-variant: #9b9ca6;--outline: #5a5c66;--outline-variant: #3a3d47;--warn: #dea916;--shadow: 0 1px 2px rgba(0, 0, 0, .3), 0 8px 24px rgba(0, 0, 0, .4)}@font-face{font-family:Satoshi;src:url(/fonts/Satoshi-Variable.woff2) format("woff2"),url(/fonts/Satoshi-Variable.woff) format("woff");font-weight:300 900;font-style:normal;font-display:swap}@font-face{font-family:Satoshi;src:url(/fonts/Satoshi-VariableItalic.woff2) format("woff2"),url(/fonts/Satoshi-VariableItalic.woff) format("woff");font-weight:300 900;font-style:italic;font-display:swap}*{box-sizing:border-box}.theme-transition,.theme-transition *,.theme-transition *:before,.theme-transition *:after{transition:background-color .5s ease,color .5s ease,border-color .5s ease,fill .5s ease,stroke .5s ease,box-shadow .5s ease!important}html,body,#root{height:100%;margin:0}html,body{overflow-x:hidden;max-width:100%}body{font-family:Satoshi,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--background);color:var(--on-surface);-webkit-font-smoothing:antialiased;letter-spacing:-.01em}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit;color:inherit}button{cursor:pointer;background:none;border:none;touch-action:manipulation}.ico{display:inline-block;width:var(--ico-size, 20px);height:var(--ico-size, 20px);flex:none;background-color:currentColor;-webkit-mask:var(--ico-url) center / contain no-repeat;mask:var(--ico-url) center / contain no-repeat}.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;border:none;border-radius:10px;padding:9px 16px;font-size:14px;font-weight:600;background:var(--primary);color:var(--on-primary);transition:filter .15s,opacity .15s}.btn:hover{filter:brightness(1.05)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.secondary{background:var(--secondary);color:var(--on-secondary)}.btn.ghost{background:var(--surface-low);color:var(--on-surface);border:1px solid var(--outline-variant)}.btn.sm{padding:6px 12px;font-size:13px;border-radius:8px}.btn.block{width:100%}.shell{display:grid;grid-template-columns:230px 1fr;height:100vh;height:100dvh}.sidebar{background:var(--surface-low);border-right:1px solid var(--outline-variant);padding:0 16px 14px;display:flex;flex-direction:column;gap:3px}.brand{display:flex;align-items:center;padding:0 0 101px}.brand-logo{width:218px;height:auto;display:block}.nav{display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:15px;padding:14px;border-radius:10px;color:var(--on-surface);font-weight:500;font-size:18px;border-top:2px solid transparent;border-bottom:2px solid transparent}.nav-item:hover{background:var(--surface)}.nav-item.active{background:#1faf9629;color:var(--primary);font-weight:700;border-radius:0;margin:-4px -16px;padding:18px 30px;border-top-color:#1faf9673;border-bottom-color:#1faf9673}.nav-item.active span{font-weight:700}.nav-item.active:hover{background:#1faf9629}.nav-item.disabled{color:var(--on-surface);opacity:.4;cursor:not-allowed}.nav-item.disabled:hover{background:none}.nav-item.logout{border:none;background:none;text-align:left;width:100%;color:var(--on-surface-variant)}.nav-spacer{flex:1}.main{display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;align-items:center;gap:16px;padding:21.5px 28px;border-bottom:1px solid var(--outline-variant);background:var(--surface)}.hamburger,.topbar-logo,.nav-backdrop{display:none}.search{flex:1;max-width:620px;display:flex;align-items:center;gap:8px;background:var(--surface-low);border:1px solid var(--outline-variant);border-radius:10px;padding:9px 14px;color:var(--on-surface-variant);font-size:14px}.search input{border:none;background:none;outline:none;color:var(--on-surface);width:100%}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}.theme-toggle{position:relative;display:inline-flex;align-items:center;justify-content:space-between;width:60px;height:30px;padding:0 8px;border-radius:999px;background:var(--surface-low);border:1px solid var(--outline-variant)}.theme-toggle .ico{position:relative;z-index:1;color:var(--on-surface-variant)}.theme-toggle .tt-knob{position:absolute;top:3px;width:22px;height:22px;border-radius:50%;background:var(--surface);box-shadow:var(--shadow);transition:left .2s ease}.theme-toggle.light .tt-knob{left:3px}.theme-toggle.dark .tt-knob{left:33px}.icon-btn{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;background:none;border:none;color:var(--on-surface-variant)}.icon-btn:hover{background:var(--surface-low)}.icon-btn.on{background:var(--surface-low);color:var(--on-surface)}.menu-wrap{position:relative;display:flex}.avatar-btn{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;padding:0;overflow:hidden;background:var(--surface);border:1px solid var(--outline-variant)}.avatar-btn img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.avatar-btn:hover{box-shadow:0 0 0 2px var(--primary-container)}.dropdown{position:absolute;right:0;top:calc(100% + 10px);z-index:40;background:var(--surface);border:1px solid var(--outline-variant);border-radius:14px;box-shadow:var(--shadow);animation:dropIn .14s ease;transform-origin:top right}@keyframes dropIn{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:none}}.inbox{width:300px;padding:6px}.inbox-head{font-size:13px;font-weight:700;padding:10px 12px 8px;color:var(--on-surface)}.inbox-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:30px 12px 34px;color:var(--on-surface-variant)}.inbox-empty .ico{opacity:.5}.inbox-empty span{font-size:13px}.profile-menu{width:300px;padding:22px 22px 16px;text-align:center}.pm-avatar-row{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:14px}.pm-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:1px solid var(--outline-variant)}.pm-cyc{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:none;border:none;color:var(--on-surface-variant)}.pm-cyc:hover{background:var(--surface-low);color:var(--on-surface)}.ico.flip{transform:scaleX(-1)}.pm-name{font-size:20px;font-weight:700;letter-spacing:-.01em}.pm-joined{font-size:12px;color:var(--on-surface-variant);margin-top:3px}.pm-divider{position:relative;height:1px;background:var(--outline-variant);margin:18px 3px}.pm-divider span{position:absolute;top:50%;width:5px;height:5px;border-radius:50%;background:var(--outline);transform:translateY(-50%)}.pm-divider span:first-child{left:0}.pm-divider span:last-child{right:0}.pm-info{display:flex;flex-direction:column;gap:12px;margin:0 0 18px;font-size:14.5px;color:var(--on-surface)}.pm-info p{margin:0}.pm-info b{font-weight:700}.pm-info .pm-email{word-break:break-all}.pm-edit{display:inline-flex;align-items:center;gap:7px;margin:0 auto 14px;background:none;border:none;color:var(--on-surface-variant);font-size:13px;font-weight:600}.pm-edit:hover{color:var(--on-surface)}.pm-logout{width:100%;padding:11px;border-radius:10px;border:1px solid var(--outline-variant);background:var(--surface);color:var(--error);font-weight:700;font-size:14px}.pm-logout:hover{background:var(--error-container);border-color:var(--error-container)}.cookie-bar{position:fixed;left:16px;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));z-index:90;margin:0 auto;max-width:520px;display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--outline-variant);border-radius:18px;box-shadow:0 12px 40px #0000002e;padding:16px 18px;animation:cookieIn .35s cubic-bezier(.2,.9,.3,1.2)}@keyframes cookieIn{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}.cookie-bar-icon{flex:none;display:grid;place-items:center;width:44px;height:44px;border-radius:50%;background:var(--primary-container);color:var(--primary)}.cookie-text{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.cookie-text strong{font-size:14.5px;font-weight:700}.cookie-text span{font-size:12.5px;color:var(--on-surface-variant);line-height:1.5}.cookie-bar-link{color:var(--primary);font-weight:600;text-decoration:none;white-space:nowrap}.cookie-bar-link:hover{text-decoration:underline}.cookie-bar-actions{flex:none;display:flex;align-items:center;gap:8px}.cookie-bar-btn{flex:none;padding:9px 18px;border-radius:999px;align-self:center}@media (max-width: 560px){.cookie-bar{flex-wrap:wrap;gap:12px 14px;text-align:left}.cookie-bar-actions{flex:1 1 100%}.cookie-bar-btn{flex:1 1 0}}.content{overflow-y:auto;overflow-x:hidden;padding:28px 40px 36px;flex:1;min-width:0}.page-head{text-align:center;margin-bottom:34px}.page-head h1{margin:0 0 6px;font-size:31px;font-weight:800;letter-spacing:-.02em}.page-head p{margin:0;color:var(--on-surface-variant);font-size:15px}.card{background:var(--surface);border:1px solid var(--outline-variant);border-radius:16px;box-shadow:var(--shadow)}.dash{max-width:1080px;margin:0 auto}.banner{position:relative;display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--outline-variant);border-radius:16px;box-shadow:var(--shadow);padding:16px 20px 16px 22px;margin-bottom:20px;overflow:hidden}.banner-accent{position:absolute;left:0;top:12px;bottom:12px;width:4px;border-radius:0 4px 4px 0;background:var(--secondary)}.banner-icon{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--surface-low);color:var(--on-surface);flex:none}.banner-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.banner-text strong{font-size:16px;font-weight:700}.banner-text span{font-size:12px;color:var(--on-surface-variant)}.banner-btn{flex:none;background:var(--secondary);color:#fff;font-size:13px;font-weight:600;padding:8px 16px;border-radius:10px}.banner-btn:hover{filter:brightness(1.05)}.welcome{text-align:center;margin-bottom:16px}.welcome h1{margin:0 0 4px;font-size:30px;font-weight:800;letter-spacing:-.02em}.welcome p{margin:0;color:var(--on-surface-variant);font-size:17px;font-weight:700}.dash-section{background:var(--surface);border:1px solid var(--outline);border-radius:18px;box-shadow:var(--shadow);margin-bottom:18px}.dash-section-head{padding:18px 22px;border-bottom:1px solid var(--outline-variant)}.dash-section-head h3{margin:0;font-size:17px;font-weight:700}.quest-row{display:flex;align-items:center;gap:14px;width:calc(100% - 36px);margin:16px 18px;padding:16px 18px;background:var(--surface);border:1px solid var(--outline-variant);border-radius:14px;text-align:left;transition:border-color .15s}.quest-row:hover{border-color:var(--primary)}.quest-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--outline);flex:none}.quest-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.quest-text strong{font-size:15px;font-weight:700}.quest-text span{font-size:13px;color:var(--on-surface-variant)}.quest-go{display:grid;place-items:center;width:40px;height:40px;color:var(--on-surface-variant);flex:none}.goal-card{display:flex;align-items:center;gap:22px;padding:24px 28px;margin-bottom:18px;background:var(--surface);border:1px solid var(--outline);border-radius:20px;box-shadow:var(--shadow)}.goal-tile{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;flex:none}.goal-tile.mock{background:#1faf96;color:var(--on-primary)}.goal-tile.pyq{background:#eb744f;color:var(--on-secondary)}.goal-main{flex:1;min-width:0}.goal-main h3{margin:8px 0 6px;font-size:20px;font-weight:700;letter-spacing:-.01em}.goal-main p{margin:0;color:var(--on-surface-variant);font-size:14px;line-height:1.5;max-width:560px}.pill{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:3px 10px;border-radius:999px;color:#fff}.pill.mock{background:#1faf96;color:var(--on-primary)}.pill.pyq{background:#eb744f;color:var(--on-secondary)}.continue{display:inline-flex;align-items:center;gap:10px;flex:none;border:none;border-radius:12px;padding:12px 18px;font-size:15px;font-weight:600;color:#fff;transition:filter .15s}.continue:hover{filter:brightness(1.08)}.continue.mock{background:#1faf96;color:var(--on-primary)}.continue.pyq{background:#16181c;color:#fff}.continue.comingsoon{background:var(--secondary);color:var(--on-secondary);opacity:1;cursor:default}.continue.comingsoon:hover{filter:none}.continue .chev{display:grid;place-items:center;width:20px;height:20px}.stat-row{display:flex;gap:18px;margin-top:44px}.stat{flex:1;display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--surface);border:1px solid var(--outline-variant);border-radius:14px;box-shadow:var(--shadow)}.stat-ico{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--surface-low);color:var(--on-surface-variant);flex:none}.stat-lbl{font-size:13px;color:var(--on-surface-variant)}.stat-val{font-size:22px;font-weight:700;margin-top:2px}.cookie-pill{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:999px;background:var(--surface);border:1px solid var(--outline-variant);color:var(--on-surface-variant);font-size:14px;font-weight:700;white-space:nowrap}.dash-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:22px;align-items:start}.dash-main{display:flex;flex-direction:column;gap:16px;min-width:0}.dash-main .stat-row{margin:0}.dash-main .dash-section,.dash-main .goal-card{margin-bottom:0}.dash-rail{display:flex;flex-direction:column;gap:16px}.stat-card{position:relative;flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:2px;min-height:100px;background:var(--surface);border:1px solid var(--outline-variant);border-radius:16px;box-shadow:var(--shadow);padding:18px 20px;font:inherit;text-align:left;width:100%;color:inherit}button.stat-card{cursor:pointer;transition:border-color .15s}button.stat-card:hover{border-color:var(--primary)}.level-card .lvl-num{font-size:24px;font-weight:800;letter-spacing:-.02em;margin:4px 0 2px}.stat-sub{font-size:12px;color:var(--on-surface-variant)}.stat-badge{position:absolute;top:14px;right:14px;display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:transparent;border:1px solid var(--outline-variant);color:var(--on-surface)}.progress-head{display:flex;justify-content:space-between;align-items:center}.progress-num{font-size:13px;font-weight:700;color:var(--primary)}.lvl-bar{height:10px;border-radius:999px;background:var(--surface-low);overflow:hidden;margin:14px 0 8px}.lvl-bar-fill{display:block;height:100%;border-radius:999px;background:var(--primary);transition:width .3s ease}.streak-card{align-items:center;text-align:center;color:#f5a623}.streak-star{display:block;margin:0 auto}.streak-card .streak-num{font-size:24px;font-weight:800;color:var(--on-surface);margin-top:4px;line-height:1}.streak-card .streak-lbl{font-size:12px;color:var(--on-surface-variant);margin-top:2px}.dash-section-head{display:flex;align-items:center;justify-content:space-between}.cookie-badge{display:inline-flex;align-items:center;font-size:12px;font-weight:700;color:var(--on-surface);background:transparent;border:1.5px solid var(--secondary);padding:3px 10px;border-radius:999px}.cookie-badge.sm{font-size:10px;padding:1px 7px;margin-left:8px;vertical-align:middle;color:var(--on-surface)}.quest-radio.done{background:var(--primary);border-color:var(--primary)}.promo-card{background:var(--surface);border:1px solid var(--outline);border-radius:18px;box-shadow:var(--shadow);padding:16px;text-align:center}.promo-thumb{height:116px;border-radius:12px;display:grid;place-items:center;margin-bottom:12px;background:linear-gradient(135deg,#1faf96,#0e7c6b);color:#fff}.promo-cap{font-size:13px;color:var(--on-surface-variant);margin-bottom:12px}.promo-btn{width:100%;border:none;border-radius:10px;padding:10px;font-size:14px;font-weight:600;background:var(--primary);color:#fff}.promo-btn.comingsoon{background:var(--surface-low);color:var(--on-surface-variant);cursor:default}.rail-card{background:var(--surface);border:1px solid var(--outline);border-radius:18px;box-shadow:var(--shadow);padding:16px 18px}.yt-rail{padding:14px 14px 12px}.yt-thumb{display:block;width:100%;aspect-ratio:16/9;border-radius:10px;overflow:hidden;position:relative;background:var(--surface-low) center/cover no-repeat;text-decoration:none;animation:ytEnter .35s ease}@keyframes ytEnter{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.yt-thumb-play{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:28px;color:#fff;background:#00000047;transition:background .15s}.yt-thumb:hover .yt-thumb-play{background:#0000007a}.yt-title{font-size:14px;font-weight:800;text-align:center;line-height:1.4;margin:12px 4px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;animation:ytEnter .35s ease}.yt-continue{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;border-radius:12px;padding:11px 16px;font-size:14px;font-weight:700;background:var(--primary);color:var(--on-primary);text-decoration:none;transition:filter .15s}.yt-continue:hover{filter:brightness(1.06)}.yt-continue-ico{display:grid;place-items:center;width:20px;height:20px}.yt-arrow{background:none;border:none;font-size:20px;font-weight:700;color:var(--on-surface-variant);cursor:pointer;padding:0 4px;border-radius:6px;flex:none;line-height:1}.yt-arrow:hover{color:var(--on-surface)}.yt-dots{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:12px}.yt-dot{width:6px;height:6px;border-radius:50%;background:var(--outline-variant);border:none;cursor:pointer;padding:0;transition:background .2s}.yt-dot.active{background:var(--primary)}.rail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.rail-head h4{margin:0;font-size:16px;font-weight:700}.rail-link{color:var(--primary);font-size:13px;font-weight:600;padding:4px 10px;border-radius:8px;transition:background .15s}.rail-link:hover{background:var(--primary-container)}.lb-rail-body{display:flex;flex-direction:column;gap:4px}.lb-rail-row{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:10px;font-size:13px}.lb-rail-row.me{background:transparent;box-shadow:inset 0 0 0 1.5px var(--primary)}.lb-rank{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--surface-low);font-size:11px;font-weight:700;flex:none}.lb-rank.r1{background:#ffd54a;color:#5a4500}.lb-rank.r2{background:#d7dce1;color:#3a3f44}.lb-rank.r3{background:#f0b27a;color:#5a3210}.lb-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.lb-score{font-size:12px;color:var(--on-surface-variant);flex:none;white-space:nowrap}.lb-foot{margin-top:12px;padding-top:12px;border-top:1px solid var(--outline-variant);font-size:13px;color:var(--on-surface-variant);text-align:center}.back-btn{display:inline-flex;align-items:center;gap:6px;margin-bottom:14px;font-size:14px;font-weight:600;color:var(--on-surface-variant)}.back-btn:hover{color:var(--primary)}.lb-cta{display:inline-flex;align-items:center;gap:8px;margin:0 0 22px}.ob-hint{display:block;margin-top:8px;font-size:12px;color:var(--on-surface-variant)}.ob-field{width:300px;max-width:100%}.ob-field-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;padding:0 2px;font-size:12px;min-height:16px}.ob-status{color:var(--on-surface-variant)}.ob-status.ok{color:var(--primary);font-weight:600}.ob-status.bad{color:var(--error);font-weight:600}.ob-count{margin-left:auto;color:var(--on-surface-variant);font-variant-numeric:tabular-nums}.ob-count.bad{color:var(--error);font-weight:600}.ob-input.invalid{border-color:var(--error)}.ob-input.invalid:focus{border-color:var(--error)}.table-card{padding:8px 20px;max-width:1000px;margin:0 auto}.row-head,.row{display:grid;grid-template-columns:2.4fr 1fr 1.2fr .8fr 1fr;align-items:center;padding:16px 8px;gap:8px}.row-head{color:var(--on-surface-variant);font-size:12px;font-weight:600;border-bottom:1px solid var(--outline-variant)}.row{border-bottom:1px solid var(--outline-variant);font-size:14px}.row:last-child{border-bottom:none}.row .cell-muted{color:var(--on-surface-variant)}.cell-flex{display:flex;align-items:center;gap:8px}.cell-status{display:flex;align-items:center;gap:9px;color:var(--on-surface-variant);font-size:13px}.tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:transparent;color:var(--primary);border:1.5px solid var(--primary)}.tag.attempts{background:var(--surface-low);color:var(--on-surface-variant);border:none}.diamond{width:11px;height:11px;transform:rotate(45deg);border-radius:2px;display:inline-block}.diamond.available{background:var(--warn)}.diamond.completed{background:var(--primary)}.diamond.locked{background:transparent;border:1.5px solid var(--outline)}.diamond.in_progress{background:var(--secondary)}.center-page{min-height:100vh;min-height:100dvh;display:grid;place-items:center;background:var(--background);padding:24px}.auth-card{width:100%;max-width:420px;padding:40px 32px;text-align:center}.auth-card h1{font-size:26px;margin:0 0 6px}.auth-card .sub{color:var(--on-surface-variant);font-size:13px;margin-bottom:24px}.auth-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;border:1px solid var(--outline);background:var(--surface);color:var(--on-surface);padding:12px;border-radius:10px;font-weight:600;margin-bottom:12px}.auth-btn:hover{background:var(--surface-low)}.progress-top{height:4px;background:var(--primary);border-radius:999px;transition:width .3s}.field{width:100%;padding:12px 14px;border:1px solid var(--outline);border-radius:10px;background:var(--surface);color:var(--on-surface);font-size:14px;outline:none}.field:focus{border-color:var(--primary)}.choice{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;border:1px solid var(--outline-variant);border-radius:10px;margin-bottom:10px;background:var(--surface)}.choice.selected{border-color:var(--primary);background:var(--primary-container);color:var(--on-primary-container)}.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.player{min-height:100vh;min-height:100dvh;background:var(--background)}.player-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:1px solid var(--outline-variant);background:var(--surface)}.player-bar .status{color:var(--on-surface-variant);font-size:13px}.player-body{max-width:720px;margin:36px auto;padding:0 20px}.palette-bar{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--outline-variant);border-radius:12px;padding:12px 16px;margin-bottom:28px}.pal{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:13px;font-weight:700;border:1.5px solid var(--outline-variant);color:var(--on-surface-variant);position:relative;overflow:hidden;flex-shrink:0}.pal.current{background:var(--primary);color:#fff;border-color:var(--primary);outline:2.5px solid var(--primary);outline-offset:2px}.pal.answered{background:var(--primary);color:#fff;border-color:var(--primary)}.pal.review{background:#7c3aed;color:#fff;border-color:#7c3aed}.pal.answered.review{background:#7c3aed;border-color:#7c3aed}.pal.answered.review:after{content:"";position:absolute;bottom:0;right:0;width:0;height:0;border-style:solid;border-width:0 0 14px 14px;border-color:transparent transparent var(--primary) transparent}.pal.visited{background:#f97316;color:#fff;border-color:#f97316}.timer{margin-left:auto;font-variant-numeric:tabular-nums;font-weight:700;font-size:16px}.q-prompt{font-size:15px;line-height:1.6;margin-bottom:24px}.q-prompt .qno{font-weight:700;margin-right:6px}.q-image{display:block;max-width:100%;max-height:360px;width:auto;border-radius:12px;border:1px solid var(--outline-variant);margin:4px auto 24px}.options-title{text-align:center;font-weight:700;margin:8px 0 16px}.options{display:flex;flex-direction:column;gap:12px;max-width:560px;margin:0 auto}.option{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:10px;border:1px solid var(--outline-variant);background:var(--surface);width:100%;box-sizing:border-box;min-height:56px;text-align:left;margin-bottom:10px}.option .option-text{flex:1}.option:hover{border-color:var(--primary)}.option.selected{border-color:var(--primary);background:var(--primary-container);color:var(--on-primary-container)}.option .radio{width:16px;height:16px;border-radius:50%;border:2px solid var(--outline);flex:none}.option.selected .radio{border-color:var(--primary);background:var(--primary);box-shadow:inset 0 0 0 3px var(--primary-container)}.player-actions{display:flex;justify-content:space-between;margin-top:24px;padding-bottom:32px}.player-actions-bar{position:sticky;bottom:0;z-index:20;background:var(--background);border-top:1px solid var(--outline-variant);padding:10px 28px;display:flex;justify-content:space-between;align-items:center;gap:10px}.exam{display:grid;grid-template-columns:2fr 1fr 280px;gap:18px;padding:20px 28px;align-items:start}.exam .panel{background:var(--surface);border:1px solid var(--outline-variant);border-radius:14px;padding:18px}.exam .panel:first-child{display:flex;flex-direction:column}.exam .imgbox{width:100%;background:var(--surface-low);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--on-surface-variant);margin-top:12px;padding:10px;flex:1}.exam .imgbox .q-image{margin:0;max-height:65vh;width:100%;object-fit:contain}.opt-image{display:block;max-width:100%;max-height:160px;width:auto;border-radius:8px;border:1px solid var(--outline-variant);margin:8px 0 0}.pimg-wrap{position:relative;display:block;cursor:crosshair;overflow:visible}.pimg-wrap.zoom-active{z-index:45}.pimg-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#0000008c;pointer-events:none;animation:pimgFade .15s ease}@keyframes pimgFade{0%{opacity:0}to{opacity:1}}.pimg-mag-icon{position:absolute;top:8px;right:8px;z-index:5;background:#0000008c;color:#fff;border-radius:6px;padding:5px 6px;line-height:0;pointer-events:none;opacity:0;transition:opacity .15s}.pimg-wrap:hover .pimg-mag-icon{opacity:1}.pimg-lens-rect{position:absolute;pointer-events:none;z-index:6;border:2px solid rgba(255,255,255,.85);background:#ffffff26;box-shadow:0 0 0 1px #00000040}.pimg-zoom-panel{position:absolute;left:calc(100% + 12px);top:0;width:500px;height:500px;z-index:50;border:1px solid var(--outline-variant);border-radius:10px;overflow:hidden;background-repeat:no-repeat;box-shadow:0 8px 32px #00000040;pointer-events:none}.rev-options{display:flex;flex-direction:column;gap:10px}.rev-options .option{cursor:default;align-items:flex-start}.rev-options .option:hover{border-color:var(--outline-variant)}.option.correct{border-color:var(--primary);border-width:1.5px;background:transparent;color:var(--on-surface)}.option.wrong{border-color:var(--error);background:color-mix(in srgb,var(--error) 12%,transparent)}.rev-flags{display:flex;gap:6px;flex:none}.rev-tag{font-size:11px;font-weight:700;padding:2px 7px;border-radius:999px;white-space:nowrap}.rev-tag.ok{background:var(--primary);color:var(--on-primary)}.rev-qtag{font-size:11px;font-weight:700;padding:2px 10px;border-radius:999px;background:transparent;color:var(--on-surface);border:1.5px solid var(--primary)}.rev-tag.you{background:var(--on-surface);color:var(--surface);font-weight:800}.rev-options .option.user-pick{outline:2px solid currentColor;outline-offset:-2px}.rev-nat{display:flex;gap:10px;flex-wrap:wrap}.rev-pill{padding:8px 14px;border-radius:10px;border:1px solid var(--outline-variant);font-size:14px}.rev-pill.ok{border-color:var(--primary);border-width:1.5px;background:transparent;color:var(--primary);font-weight:600}.rev-pill.bad{border-color:var(--error);background:color-mix(in srgb,var(--error) 12%,transparent)}.rev-solution{margin-top:16px;padding-top:14px;border-top:1px solid var(--outline-variant)}.rev-palette{grid-template-columns:repeat(auto-fill,minmax(34px,1fr));max-width:none}.pal.right{background:var(--primary);color:#fff;border-color:var(--primary)}.pal.wrong{background:var(--error);color:#fff;border-color:var(--error)}.rev-palette .pal.current{background:#f59e0b;color:#000;border-color:#f59e0b;outline-color:#f59e0b}.rev-palette .pal.dormant{opacity:.42}.rev-palette .pal.marked:after{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 13px 13px 0;border-color:transparent #7c3aed transparent transparent}.review-layout{display:grid;grid-template-columns:1fr 260px;gap:18px;align-items:start}.review-sidebar{position:sticky;top:16px}.deepdive tfoot td{padding:12px 10px}.mock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:16px}.mock-box{text-align:left;background:var(--surface);border:1px solid var(--outline-variant);border-radius:16px;padding:18px;cursor:pointer;transition:transform .12s,box-shadow .12s,border-color .12s}.mock-box:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 8px 24px #00000014}.mock-box-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px}.mock-box-title{font-weight:700;font-size:15px}.mock-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}.mock-badge.done{background:var(--primary-container);color:var(--on-primary-container)}.mock-badge.pending{background:color-mix(in srgb,var(--warn) 18%,transparent);color:var(--warn)}.mock-badge.wip{background:color-mix(in srgb,var(--secondary) 18%,transparent);color:var(--secondary)}.mock-box-score{font-size:30px;font-weight:800;color:var(--primary);line-height:1.1}.mock-box-max{font-size:15px;font-weight:600;color:var(--on-surface-variant)}.mock-box-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;margin:14px 0 12px}.mock-box-stats>div{display:flex;flex-direction:column}.mock-box-stats span{font-size:11px;color:var(--on-surface-variant)}.mock-box-stats strong{font-size:13px}.mock-box-cta{font-weight:600;font-size:13px;color:var(--primary)}.timer-box{text-align:center;padding:18px}.timer-box .big{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums}.timer-box .lbl{font-size:12px;color:var(--on-surface-variant)}.palette-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:16px}.pal-sec-nav{display:flex;align-items:center;justify-content:space-between;margin-top:10px}.pal-sec-label{font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--on-surface)}.pal-sec-arrow{background:none;border:none;font-size:18px;font-weight:700;color:var(--on-surface);cursor:pointer;padding:2px 8px;border-radius:6px;line-height:1}.pal-sec-arrow:disabled{opacity:.25;cursor:default}.pal-sec-arrow:not(:disabled):hover{background:var(--surface-low)}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.keypad button,.keypad .wide{padding:12px;border-radius:8px;border:1px solid var(--outline-variant);background:var(--surface);color:var(--on-surface);font-size:16px;font-weight:600}.keypad .wide{grid-column:span 3}.analytics{max-width:940px;margin:0 auto}.page-head.left{text-align:left;margin-bottom:22px}.page-head.left h1{font-size:28px;font-weight:800;letter-spacing:-.02em;margin:0 0 4px}.page-head.left p{font-size:14px}.an-card{background:var(--surface);border:1px solid var(--outline-variant);border-radius:18px;box-shadow:var(--shadow);padding:22px}.an-gk{display:grid;grid-template-columns:320px 1fr;gap:28px;align-items:stretch;margin-bottom:18px}.an-gk-info{display:flex;flex-direction:column}.an-gk-info .an-btn{margin-top:auto}.an-gk-right{display:flex;flex-direction:column}.an-panel-title{font-size:15px;font-weight:700;margin-bottom:8px}.an-mod{display:flex;flex-direction:column}.an-mod-head{display:flex;align-items:center;gap:12px}.an-tile{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;flex:none}.an-tile.teal{background:#1faf96;color:var(--on-primary)}.an-tile.green{background:#9ccb8e;color:#1f3d18}.an-tile.orange{background:#eb744f;color:var(--on-secondary)}.an-pill{font-size:12px;font-weight:600;padding:6px 14px;border-radius:999px}.an-pill.teal{background:#1faf96;color:var(--on-primary)}.an-pill.green{background:#9ccb8e;color:#1f3d18}.an-pill.orange{background:#eb744f;color:var(--on-secondary)}.an-mod-title{margin:16px 0;font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--on-surface)}.an-stats{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;margin-bottom:18px}.an-stat{border:1px solid var(--outline-variant);border-radius:12px;padding:12px 14px;text-align:center}.an-stat-lbl{font-size:12px;color:var(--on-surface-variant)}.an-stat-val{font-size:20px;font-weight:800;margin-top:4px}.an-stat-val.primary{color:var(--primary)}.an-stat-val.secondary{color:var(--secondary)}.an-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;padding:13px;font-size:15px;font-weight:700;transition:filter .15s}.an-btn:hover{filter:brightness(1.05)}.an-btn.teal{background:#1faf96;color:var(--on-primary)}.an-btn.green{background:#9ccb8e;color:#1f3d18}.an-btn.orange{background:#eb744f;color:var(--on-secondary)}.an-btn.comingsoon{cursor:default}.an-btn.comingsoon:hover{filter:none}.bellcurve{width:100%;height:190px;display:block}.bc-grid{stroke:var(--outline-variant);stroke-width:1}.bc-area{fill:#1faf9629}.bc-line{fill:none;stroke:var(--primary);stroke-width:2}.hist{display:flex;flex-direction:column}.linegraph{width:100%;height:200px;display:block}.lg-grid{stroke:var(--outline-variant);stroke-width:1}.lg-area{fill:#1faf9624}.lg-line{fill:none;stroke:var(--primary);stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}.lg-dot{fill:var(--surface);stroke:var(--primary);stroke-width:2;transition:r .1s ease}.lg-dot.mine{fill:var(--primary);stroke:var(--primary)}.lg-dot.on{fill:var(--primary)}.lg-x{fill:var(--on-surface-variant);font-size:12px;font-weight:600}.lg-tip-box{fill:var(--surface);stroke:var(--outline-variant);stroke-width:1;filter:drop-shadow(0 4px 12px rgba(0,0,0,.18))}.lg-tip-pct{fill:var(--on-surface);font-size:12.5px;font-weight:800}.lg-tip-sub{fill:var(--on-surface-variant);font-size:11px;font-weight:600}.hist-foot{display:flex;justify-content:space-between;font-size:12px;color:var(--on-surface-variant);border-top:1px solid var(--outline-variant);padding-top:8px;margin-top:4px}.scrollbox{overflow-y:auto;margin-top:6px}.scrollbox.sprees{max-height:300px}.scrollbox.board{max-height:460px}.lrow{display:grid;align-items:center;gap:10px;padding:13px 6px;border-bottom:1px solid var(--outline-variant);font-size:14px}.lrow:last-child{border-bottom:none}.lrow.spree{grid-template-columns:1.6fr 1fr .8fr 1fr}.lrow.head{grid-template-columns:.6fr 2fr .8fr .8fr;color:var(--on-surface-variant);font-size:12px;font-weight:600;border-bottom:1px solid var(--outline-variant)}.lrow.board-row{grid-template-columns:.6fr 2fr .8fr .8fr}.lrow.board-row.me{background:#1faf961f;border-radius:8px}.lrow .rank{font-weight:700}.locked-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--on-surface-variant);background:var(--surface-low);padding:5px 10px;border-radius:999px}.lb-sep{text-align:center;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--on-surface-variant);padding:10px 0 6px;border-top:1px dashed var(--outline-variant);margin-top:4px}.an-duo{display:grid;grid-template-columns:1fr 1fr;gap:18px}.coming-soon{max-width:520px;margin:8vh auto 0;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}.coming-soon .cs-tile{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:var(--surface-low);color:var(--primary);border:1px solid var(--outline-variant)}.coming-soon h1{font-size:26px;font-weight:700;color:var(--on-surface)}.coming-soon p{font-size:15px;line-height:1.6;color:var(--on-surface-variant)}.coming-soon .cs-btn{margin-top:8px;display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:12px;background:var(--primary);color:#fff;font-size:14px;font-weight:600}.coming-soon .cs-btn:hover{filter:brightness(1.06)}.resources{max-width:900px;margin:0 auto}.res-tabs{display:flex;gap:8px;margin-bottom:24px}.res-tab{padding:6px 18px;border-radius:999px;font-size:14px;font-weight:600;border:1.5px solid var(--outline-variant);background:none;color:var(--on-surface-variant);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.res-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.res-tab:not(.active):hover{border-color:var(--primary);color:var(--primary)}.res-content h1{font-size:28px;font-weight:800;margin:0 0 10px}.res-desc{font-size:15px;line-height:1.65;color:var(--on-surface-variant);margin:0 0 12px}.res-bullets{margin:0 0 28px;padding-left:20px;font-size:15px;line-height:1.65}.res-bullets li{margin-bottom:4px}.res-diagram{text-align:center}.res-diagram img{max-width:100%;height:auto;border-radius:14px}.partb-roadmap{position:relative;max-width:880px;margin:40px auto 0}.partb-roadmap:before{content:"";position:absolute;top:26px;bottom:92px;left:50%;transform:translate(-50%);width:3px;border-radius:3px;background:var(--primary);z-index:0}.pb-row{position:relative;display:grid;grid-template-columns:1fr 52px 1fr;column-gap:30px;align-items:start;min-height:196px;margin-bottom:20px}.pb-node{grid-column:2;grid-row:1;justify-self:center;z-index:2;width:52px;height:52px;border-radius:50%;color:var(--on-primary);display:grid;place-items:center;font-size:19px;font-weight:800;background:radial-gradient(circle at 32% 28%,#36c9ad,var(--primary) 72%);box-shadow:0 4px 12px #00000052}.pb-side-label{grid-row:1;align-self:start;margin-top:12px;font-size:19px;font-weight:800;letter-spacing:-.01em;color:var(--on-surface)}.pb-row.card-left .pb-side-label{grid-column:3;justify-self:start}.pb-row.card-right .pb-side-label{grid-column:1;justify-self:end;text-align:right}.pb-card{grid-row:1;width:320px;max-width:100%;z-index:1;position:relative;background:var(--surface);border:1px solid var(--outline-variant);border-radius:18px;padding:18px 20px;box-shadow:var(--shadow);transition:border-color .18s,box-shadow .18s}.pb-card:hover{border-color:var(--primary);box-shadow:0 10px 26px #00000029}.pb-row.card-left .pb-card{grid-column:1;justify-self:end}.pb-row.card-right .pb-card{grid-column:3;justify-self:start}.pb-badge{font-size:10px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--on-surface-variant);background:transparent;border:1px solid var(--outline);padding:4px 11px;border-radius:999px;display:inline-block;margin-bottom:12px}.pb-card h3{font-size:15.5px;font-weight:800;letter-spacing:-.01em;margin:0 0 7px;line-height:1.35}.pb-card p{font-size:12.5px;color:var(--on-surface-variant);margin:0 0 14px;line-height:1.55}.pb-view-btn{font-size:12.5px;font-weight:700;color:var(--on-primary);background:var(--primary);border:none;padding:9px 16px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:filter .15s}.pb-view-btn:hover{filter:brightness(1.06)}.pb-chev{display:inline-block;transition:transform .18s;font-size:10px}.pb-chev.open{transform:rotate(180deg)}.pb-topics{display:grid;grid-template-rows:0fr;transition:grid-template-rows .32s ease}.pb-topics.open{grid-template-rows:1fr}.pb-topics-clip{overflow:hidden}.pb-topics-list{margin-top:14px;padding-top:12px;border-top:1px solid var(--outline-variant);display:flex;flex-direction:column;gap:4px}.pb-topic-card{display:flex;gap:10px;align-items:center;text-decoration:none;padding:6px;border-radius:10px;transition:background .15s}.pb-topic-card:hover{background:var(--surface-low)}.pb-topic-thumb{width:82px;height:48px;border-radius:8px;flex:none;overflow:hidden;background:var(--surface-low) center/cover no-repeat;display:grid;place-items:center}.pb-topic-thumb.video{background-color:#000}.pb-topic-thumb.video svg{opacity:.9}.pb-topic-thumb.yt{background:red}.pb-topic-thumb.web{background:var(--primary)}.pb-topic-meta{display:flex;flex-direction:column;gap:3px;min-width:0}.pb-topic-title{font-size:12px;font-weight:600;color:var(--on-surface);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pb-topic-src{font-size:10.5px;color:var(--on-surface-variant);display:flex;align-items:center}.pb-end-node{display:flex;flex-direction:column;align-items:center;width:100%}.pb-end-circle{width:60px;height:60px;border-radius:50%;color:var(--on-primary);z-index:2;display:grid;place-items:center;font-weight:800;font-size:14px;position:relative;background:radial-gradient(circle at 32% 28%,#36c9ad,var(--primary) 72%);box-shadow:0 4px 12px #00000052}.pb-end-label{font-size:14px;font-weight:800;color:var(--on-surface);margin-top:14px;padding-bottom:34px}.report{max-width:1040px;margin:0 auto}.report h2{text-align:center}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:22px 0}.kpi{padding:18px}.kpi .lbl{font-size:12px;color:var(--on-surface-variant)}.kpi .num{font-size:26px;font-weight:800;margin-top:6px}.kpi .num small{font-size:14px;color:var(--on-surface-variant);font-weight:600}.section-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.deepdive{width:100%;border-collapse:collapse}.deepdive th,.deepdive td{text-align:left;padding:12px 10px;font-size:13px;border-bottom:1px solid var(--outline-variant)}.deepdive th{color:var(--on-surface-variant);font-weight:600}.bar{height:8px;border-radius:999px;background:var(--surface-low);overflow:hidden}.bar>span{display:block;height:100%;background:var(--primary)}.locked-note{padding:22px;text-align:center;color:var(--on-surface-variant);border:1px dashed var(--outline);border-radius:14px}.review{max-width:1000px;margin:0 auto}.review-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px}.review-head h1{margin:0 0 2px;font-size:24px;font-weight:800;letter-spacing:-.02em}.review-head p{font-size:13px}.review-chips{display:flex;gap:8px;flex:none}.rchip{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:700;padding:5px 11px;border-radius:999px;border:1px solid var(--outline-variant)}.rchip.correct{color:var(--primary)}.rchip.wrong{color:var(--secondary)}.rchip.skip{color:var(--on-surface-variant)}.review-card{background:var(--surface);border:1px solid var(--outline-variant);border-radius:18px;box-shadow:var(--shadow);padding:22px;margin-top:6px}.review-palette{display:flex;align-items:center;gap:10px;background:var(--surface-low);border-radius:12px;padding:12px 16px;margin-bottom:24px}.rpal{width:34px;height:34px;border-radius:9px;border:1px solid var(--outline-variant);background:var(--surface);font-weight:700;font-size:14px;color:var(--on-surface-variant)}.rpal.correct{background:var(--primary);color:#fff;border-color:var(--primary)}.rpal.wrong{background:var(--secondary);color:#fff;border-color:var(--secondary)}.rpal.current{box-shadow:0 0 0 2px var(--surface-low),0 0 0 4px var(--on-surface)}.review-palette .timer{margin-left:auto;font-weight:700;font-variant-numeric:tabular-nums}.review-q{display:flex;gap:8px;font-size:16px;line-height:1.6;margin-bottom:22px;padding:0 4px}.review-q .qno{font-weight:800;flex:none}.review-options{display:flex;flex-direction:column;gap:12px;max-width:560px;margin:0 auto 18px}.review-opt{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:10px;border:1px solid var(--outline-variant);background:var(--surface);font-size:15px}.review-opt .ro-mark{width:19px;height:19px;display:grid;place-items:center;border-radius:50%;border:2px solid var(--outline);flex:none}.review-opt.correct{border-color:var(--primary);background:#1faf9614}.review-opt.correct .ro-mark{border-color:var(--primary);color:var(--primary)}.review-opt.wrong{border-color:var(--secondary);background:#eb744f14}.review-opt.wrong .ro-mark{border-color:var(--secondary);color:var(--secondary)}.correct-callout{display:flex;align-items:center;gap:8px;max-width:560px;margin:0 auto 22px;padding:11px 14px;border-radius:10px;background:#1faf961a;color:var(--primary);font-weight:600;font-size:14px}.explain{margin-bottom:16px}.explain h4{margin:0 0 6px;font-size:15px;font-weight:700}.explain p{margin:0;color:var(--on-surface-variant);font-size:14px;line-height:1.6}.why-list{margin:0;padding-left:18px}.why-list li{color:var(--on-surface-variant);font-size:14px;line-height:1.6;margin-bottom:6px}.why-list strong{color:var(--on-surface)}.review-actions{display:flex;justify-content:space-between;margin-top:20px}.guest-unlock{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:0 0 22px;padding:16px 18px;border-radius:14px;background:var(--surface-low);border:1px solid var(--outline-variant)}.guest-unlock strong{display:block;font-size:15px;margin-bottom:3px}.guest-unlock p{margin:0;color:var(--on-surface-variant);font-size:13px;line-height:1.5;max-width:460px}.guest-unlock .btn{white-space:nowrap;flex-shrink:0}.review-locked{display:flex;align-items:center;flex-wrap:wrap;gap:8px;max-width:560px;margin:0 auto 22px;padding:11px 14px;border-radius:10px;background:var(--surface-low);border:1px dashed var(--outline-variant);color:var(--on-surface-variant);font-size:14px}.review-locked .linklike{background:none;border:none;padding:0;cursor:pointer;color:var(--primary);font-weight:700;font-size:14px}.review-locked .linklike:hover{text-decoration:underline}.muted{color:var(--on-surface-variant)}.spinner-page{display:grid;place-items:center;height:100vh;height:100dvh;color:var(--on-surface-variant)}.section-title{font-weight:700;margin:6px 0 12px}.ob-page{min-height:100vh;min-height:100dvh;background:var(--surface);display:flex;flex-direction:column;align-items:center;padding:0 24px 60px}.ob-progress{position:fixed;top:0;left:0;height:6px;background:var(--primary);border-radius:0 6px 6px 0;transition:width .3s ease;z-index:10}.ob-logo{display:flex;align-items:center;margin-top:40px}.ob-logo img{height:48px;width:auto}.ob-body{width:100%;max-width:560px;display:flex;flex-direction:column;align-items:center;text-align:center;margin-top:86px}.ob-title{font-size:clamp(32px,5vw,48px);font-weight:800;letter-spacing:-.03em;line-height:1.05;margin:0}.ob-sub{color:var(--on-surface-variant);font-size:15px;margin-top:12px;line-height:1.5}.ob-field-wrap{margin-top:48px;width:100%;display:flex;justify-content:center}.ob-input{width:300px;max-width:100%;padding:14px 16px;border:1px solid var(--outline);border-radius:12px;background:var(--surface);color:var(--on-surface);font-size:15px;outline:none}.ob-input:focus{border-color:var(--primary)}.ob-options{margin-top:48px;width:100%;max-width:300px;display:flex;flex-direction:column;gap:14px}.ob-options.grid{max-width:560px;display:grid;grid-template-columns:1fr 1fr;gap:14px 18px}.ob-opt{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border:1px solid var(--outline-variant);border-radius:12px;background:var(--surface);color:var(--on-surface);font-size:15px;box-shadow:0 1px 2px #0000000a;text-align:left}.ob-opt:hover{border-color:var(--outline)}.ob-opt.selected{border-color:var(--primary)}.ob-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--outline);flex:none}.ob-opt.selected .ob-radio{border-color:var(--primary);background:var(--primary);box-shadow:inset 0 0 0 3px var(--surface)}.ob-btn{margin-top:48px;width:300px;max-width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:12px;padding:15px;font-size:15px;font-weight:600;background:var(--primary);color:#fff;transition:filter .15s}.ob-btn:hover{filter:brightness(1.06)}.ob-btn:disabled{opacity:.5;cursor:not-allowed}.ob-form{margin-top:36px;width:300px;max-width:100%;display:flex;flex-direction:column;gap:14px}.ob-form .ob-input{width:100%}.ob-form-btn{margin-top:10px;width:100%}.ob-err{color:var(--error);font-size:13px;line-height:1.4}.ob-auth{margin-top:44px;width:320px;max-width:100%;display:flex;flex-direction:column;align-items:center;gap:22px}.ob-auth-label{font-size:13px;color:var(--on-surface-variant);margin:18px 0 8px}.ob-oauth{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;border:1px solid var(--outline);border-radius:12px;background:var(--surface);color:var(--on-surface);font-size:15px;font-weight:600}.ob-oauth:hover{background:var(--surface-low)}.ob-oauth:disabled{opacity:.6;cursor:not-allowed}.gsi-wrap{display:flex;justify-content:center;min-height:44px;color-scheme:light}.ob-create{margin-top:22px;font-size:14px;color:var(--on-surface-variant)}.ob-create button{color:var(--primary);font-weight:600;background:none;border:none;padding:0;font-size:14px;cursor:pointer}.ob-create button:hover{text-decoration:underline}.ob-rule{display:flex;align-items:center;gap:0;width:300px;max-width:100%;margin:48px auto 12px}.ob-rule .line{flex:1;height:1px;background:var(--outline-variant)}.ob-rule .dot{width:5px;height:5px;border-radius:50%;background:var(--outline);flex:none}.ob-foot{text-align:center;color:var(--on-surface-variant);font-size:13px;line-height:1.5}.ob-dev{margin-top:34px;text-align:center}.ob-dev-toggle{background:none;border:none;color:var(--on-surface-variant);font-size:12px;text-decoration:underline;cursor:pointer}.ob-dev-row{display:flex;flex-direction:column;align-items:center;gap:10px}.ob-input.dev{width:260px;padding:10px 12px;font-size:13px}.ob-btn.dev{margin-top:0;width:260px;padding:11px;font-size:13px;background:var(--surface-low);color:var(--on-surface);border:1px solid var(--outline-variant)}.guest{min-height:100vh;min-height:100dvh;background:var(--background);display:flex;flex-direction:column}.guest-top{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 28px;background:var(--surface);border-bottom:1px solid var(--outline-variant)}.guest-brand img{height:34px;width:auto;display:block}.guest-top-right{display:flex;align-items:center;gap:14px}.guest-body{max-width:1000px;margin:0 auto;padding:30px 28px 60px}.guest-grid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:22px;align-items:start}.guest-cta{text-align:center}.guest-cta .promo-thumb{color:#fff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#00000080;display:grid;place-items:center;padding:24px;animation:dropIn .15s ease}.modal{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--outline-variant);border-radius:18px;box-shadow:var(--shadow);padding:28px;text-align:center;animation:dropIn .18s ease}.modal-icon{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;margin:0 auto 14px;background:var(--primary-container);color:var(--on-primary-container)}.modal h3{margin:0 0 8px;font-size:20px;font-weight:800;letter-spacing:-.01em}.modal p{margin:0;color:var(--on-surface-variant);font-size:14px;line-height:1.6}.modal-actions{display:flex;gap:10px;margin-top:22px}.modal-actions .btn{flex:1}.ob-skip{display:block;margin:0 auto;background:none;border:none;color:var(--primary);font-size:14px;font-weight:600}.ob-skip:hover{text-decoration:underline}.cookie-page{max-width:1080px;margin:0 auto}.cx-hero{position:relative;overflow:hidden;display:flex;align-items:center;border-radius:22px;padding:44px 48px;margin-bottom:30px;background:linear-gradient(105deg,#fff,#dff6e7 50%,#1faf96 122%)}.cx-hero-text{position:relative;z-index:1;max-width:60%}.cx-hero h1{margin:0 0 14px;font-size:46px;font-weight:800;letter-spacing:-.02em;color:#1a1c20}.cx-hero p{margin:0;font-size:16px;line-height:1.6;color:#5b635e;max-width:580px}.cx-cookie{position:absolute;right:40px;bottom:-24px;width:210px;height:210px;color:#1faf96;opacity:.9}.cx-h2{margin:0 0 18px;font-size:30px;font-weight:800;letter-spacing:-.02em}.cx-earn{display:grid;grid-template-columns:1fr 1fr 280px;gap:20px;margin-bottom:30px;align-items:stretch}.cx-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--outline-variant);border-radius:18px;box-shadow:var(--shadow);padding:24px}.cx-card-ico{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--primary);color:#fff;margin-bottom:18px}.cx-card h3{margin:0 0 10px;font-size:21px;font-weight:800;letter-spacing:-.01em}.cx-card p{margin:0;color:var(--on-surface-variant);font-size:15px;line-height:1.6}.cx-earn-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-top:auto;padding-top:24px}.cx-earn-amt{display:flex;align-items:center;gap:10px}.cx-amt{font-size:34px;font-weight:800;color:var(--primary);letter-spacing:-.02em;line-height:1}.cx-amt-lbl{font-size:14px;color:var(--on-surface);line-height:1.3}.cx-earn-max{text-align:right;color:var(--secondary);font-size:14px;line-height:1.3}.cx-earn-max strong{display:block;font-weight:800}.cx-earn-max span{color:var(--on-surface-variant)}.cx-card.golden{background:var(--primary);color:#fff;border-color:var(--primary)}.cx-card.golden h3{color:#fff}.cx-card.golden p{color:#ffffffeb;font-size:14px}.cx-card.golden p+p{margin-top:14px}.cx-levels{background:var(--surface);border:1px solid var(--outline-variant);border-radius:20px;box-shadow:var(--shadow);padding:30px 40px 42px}.cx-levels-head{text-align:center;margin-bottom:38px}.cx-levels-head h2{margin:0;font-size:30px;font-weight:800;letter-spacing:-.02em}.cx-levels-sub{display:inline-block;margin-top:6px;font-size:14px;color:var(--on-surface-variant)}.cx-stepper{position:relative;display:flex;overflow-x:auto;padding:6px 4px 10px;cursor:grab;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.cx-stepper::-webkit-scrollbar{display:none}.cx-stepper.dragging{cursor:grabbing;scroll-behavior:auto}.cx-stepper.dragging *{pointer-events:none;-webkit-user-select:none;user-select:none}.cx-step{position:relative;z-index:1;flex:0 0 128px;display:flex;flex-direction:column;align-items:center;gap:9px;padding-top:6px}.cx-step:not(:first-child):before{content:"";position:absolute;top:28px;left:-40px;width:80px;height:4px;background:var(--surface-low);border-radius:999px;z-index:0}.cx-step.reached:not(:first-child):before{background:var(--primary)}.cx-node{position:relative;z-index:1;display:grid;place-items:center;width:48px;height:48px;border-radius:50%;background:var(--surface);border:3px solid var(--outline-variant);color:var(--on-surface-variant);font-size:19px;font-weight:800;transition:transform .2s ease}.cx-step.reached .cx-node{border-color:var(--primary);color:var(--primary)}.cx-step.locked .cx-node{opacity:.65}.cx-step.current{z-index:2}.cx-step.current .cx-node{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 5px var(--primary-container);transform:scale(1.12)}.cx-step strong{font-size:15px;font-weight:800}.cx-step.locked strong{color:var(--on-surface-variant)}.cx-step-cap{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--on-surface-variant)}.cx-here{margin-top:2px;font-size:11px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--primary);background:var(--primary-container);padding:2px 8px;border-radius:999px}.cx-drag-hint{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:16px;font-size:12px;color:var(--on-surface-variant)}@media (max-width: 768px){.shell{grid-template-columns:1fr}.partb-roadmap{max-width:460px;margin-top:24px}.partb-roadmap:before{left:26px;transform:none;top:26px;bottom:24px}.pb-row.card-left,.pb-row.card-right{grid-template-columns:52px 1fr;column-gap:18px;row-gap:12px;min-height:auto;margin-bottom:26px}.pb-row .pb-node{grid-column:1;grid-row:1;justify-self:center}.pb-row.card-left .pb-side-label,.pb-row.card-right .pb-side-label{grid-column:2;grid-row:1;justify-self:start;text-align:left;align-self:center;margin-top:0}.pb-row.card-left .pb-card,.pb-row.card-right .pb-card{grid-column:2;grid-row:2;justify-self:stretch;width:100%}.pb-view-btn{width:100%;justify-content:space-between}.pb-end-node{display:grid;grid-template-columns:52px 1fr;column-gap:18px;justify-items:start;align-items:center}.pb-end-circle{grid-column:1;justify-self:center}.pb-end-label{grid-column:2;align-self:center;margin:0;padding:0}.sidebar{position:fixed;top:0;left:0;bottom:0;width:248px;z-index:60;padding-top:24px;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow);overflow-y:auto}.brand{padding-bottom:40px}.sidebar.open{transform:none}.nav-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:#00000073;animation:dropIn .15s ease}.topbar{padding:10px 12px;gap:8px}.hamburger{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:none;border:none;color:var(--on-surface);flex:none}.hamburger:hover{background:var(--surface-low)}.topbar-logo{display:flex;align-items:center;flex:none}.topbar-logo img{height:38px;width:auto;display:block}.topbar-right{gap:6px}.cookie-pill{height:30px;padding:0 10px;font-size:13px}.theme-toggle{width:52px;height:28px}.theme-toggle.dark .tt-knob{left:27px}.theme-toggle .tt-knob{width:20px;height:20px}.icon-btn{width:34px;height:34px}.content{padding:20px 16px 36px}.page-head{margin-bottom:24px}.page-head h1{font-size:25px}.page-head.left h1{font-size:23px}.dropdown{max-width:calc(100vw - 20px)}.inbox,.profile-menu{width:min(300px,calc(100vw - 20px))}.dash-grid{grid-template-columns:minmax(0,1fr);gap:16px}.dash-rail{min-width:0}.stat-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.stat-card{min-height:92px;padding:16px}.level-card{order:1}.streak-card{order:2}.progress-card{order:3;grid-column:1 / -1}.level-card .lvl-num{font-size:21px}.promo-card{display:none}.welcome{margin-bottom:18px}.welcome h1{font-size:24px}.welcome p{font-size:15px}.banner{flex-wrap:wrap;padding:16px 16px 16px 20px;gap:10px 12px;margin-bottom:24px}.banner-icon{width:40px;height:40px}.banner-text{flex:1 1 0;min-width:140px}.banner-btn{flex:1 1 100%;text-align:center}.goal-card{flex-wrap:wrap;gap:14px 16px;padding:18px}.goal-main{flex:1 1 100%;order:2}.goal-tile{order:1}.goal-card .continue{order:3;width:100%;justify-content:center}.table-card{max-width:100%;padding:0;background:none;border:none;box-shadow:none}.row-head{display:none}.row{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;background:var(--surface);border:1px solid var(--outline-variant);border-radius:14px;padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}.row:last-child{border-bottom:1px solid var(--outline-variant)}.row .cell-flex{flex-basis:100%;font-weight:600}.row>div:last-child{flex-basis:100%;text-align:left!important}.row>div:last-child .btn{width:100%}.row .locked-pill{width:100%;justify-content:center}.an-card{padding:18px 16px}.an-gk{grid-template-columns:minmax(0,1fr);gap:18px}.an-gk-right{display:none}.an-duo,.section-2{grid-template-columns:minmax(0,1fr)}.kpi-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.an-mod-title{font-size:20px;margin:14px 0}.scrollbox.sprees{max-height:none}.lrow.spree{display:flex;flex-wrap:wrap;align-items:center;gap:6px 14px;border:1px solid var(--outline-variant);border-radius:12px;padding:14px;margin-bottom:10px}.lrow.spree:last-child{border-bottom:1px solid var(--outline-variant)}.lrow.spree .cell-flex{flex:1 1 100%}.lrow.spree>div:last-child{margin-left:auto}.lrow.spree>div:last-child .btn{white-space:nowrap}.lrow.head,.lrow.board-row{grid-template-columns:.5fr 1.6fr .7fr .7fr;gap:8px;padding:12px 4px}.lrow.board-row .cell-flex{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-bar{padding:14px 16px}.player-body{margin:22px auto;padding:0 16px calc(96px + env(safe-area-inset-bottom))}.player-actions{gap:12px;margin-top:28px}.player-actions .btn{flex:1;min-height:50px;font-size:15px;padding:12px 16px}.review{padding:0}.review-head{flex-direction:column;gap:12px;align-items:flex-start}.review-card{padding:18px 16px}.review-palette{flex-wrap:wrap;gap:8px}.review-palette .timer{margin-left:auto}.exam{grid-template-columns:1fr;padding:16px;gap:14px}.review-layout{grid-template-columns:1fr}.review-sidebar{position:static}.player-actions-bar{padding:10px 16px}.cx-hero{padding:26px 20px;margin-bottom:22px}.cx-hero-text{max-width:100%}.cx-hero h1{font-size:30px;margin-bottom:10px}.cx-hero p{font-size:14px}.cx-cookie{width:110px;height:110px;right:-10px;bottom:-16px;opacity:.35}.cx-h2{font-size:23px}.cx-earn{grid-template-columns:minmax(0,1fr);gap:14px;margin-bottom:22px}.cx-levels{padding:22px 18px 26px}.cx-levels-head{margin-bottom:24px}.cx-levels-head h2{font-size:23px}.cx-stepper{flex-direction:column;gap:16px}.cx-track{display:none}.cx-step{flex-direction:row;align-items:center;gap:12px;width:100%}.cx-node{width:38px;height:38px;font-size:16px}.cx-step strong{font-size:15px}.cx-step .cx-step-cap{margin-left:auto}.guest-top{padding:12px 16px}.guest-brand img{height:30px}.guest-top-right{gap:10px}.guest-top-right .btn{padding:8px 12px;font-size:13px}.guest-body{padding:22px 16px 48px}.guest-grid{grid-template-columns:minmax(0,1fr);gap:16px}.modal-actions{flex-direction:column-reverse}}@media (max-width: 460px){.topbar-logo img{height:34px}.mail-wrap{display:none}.kpi-row{grid-template-columns:1fr 1fr}.lrow.head,.lrow.board-row{grid-template-columns:.5fr 1.5fr .6fr .7fr;font-size:13px}.lb-rail-row{font-size:12.5px}}.footer{border-top:1px solid var(--outline-variant);background:var(--background);margin-top:auto}.footer-inner{max-width:1100px;margin:0 auto;padding:32px 28px;display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}.footer-brand{display:flex;flex-direction:column;gap:16px}.footer-logo{height:88px;width:auto}.footer-copy{font-size:13px;color:var(--on-surface-variant)}.footer-cols{display:flex;gap:72px;flex-wrap:wrap}.footer-col{display:flex;flex-direction:column;gap:12px}.footer-col h4{margin:0 0 2px;font-size:14px;font-weight:700;color:var(--on-surface)}.footer-col a{font-size:14px;color:var(--on-surface-variant);text-decoration:none}.footer-col a:hover{color:var(--primary)}@media (max-width: 640px){.footer-inner{gap:28px;padding:28px 20px}.footer-cols{gap:44px}}.ob-page.has-footer{padding-bottom:0}.ob-page.has-footer>.footer{align-self:stretch;margin:auto -24px 0}.pm-links{display:flex;flex-direction:column;align-items:center;gap:6px;margin:12px 0 4px;font-size:12px;color:var(--on-surface-variant)}.pm-links-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px 8px}.pm-links a{color:var(--on-surface-variant);text-decoration:none}.pm-links a:hover{color:var(--primary)}.pm-links .sep{opacity:.5}.legal-page{min-height:100vh;display:flex;flex-direction:column;background:var(--background)}.legal-header{border-bottom:1px solid var(--outline-variant)}.legal-header-inner{max-width:820px;margin:0 auto;padding:18px 28px}.legal-header img{height:30px;width:auto;display:block}.legal-body{flex:1;max-width:820px;width:100%;margin:0 auto;padding:40px 28px 64px}.legal-body h1{margin:0 0 6px;font-size:28px;font-weight:800;letter-spacing:-.02em}.legal-updated{margin:0 0 28px;font-size:13px;color:var(--on-surface-variant)}.legal-content h2{margin:28px 0 8px;font-size:18px;font-weight:700}.legal-content h3{margin:18px 0 6px;font-size:15px;font-weight:700}.legal-content p{margin:0 0 14px;font-size:15px;line-height:1.7;color:var(--on-surface-variant)}.legal-content ul{margin:0 0 14px;padding-left:20px}.legal-content li{font-size:15px;line-height:1.7;color:var(--on-surface-variant);margin-bottom:6px}.legal-content a{color:var(--primary);text-decoration:none}.legal-content a:hover{text-decoration:underline}.legal-content strong{color:var(--on-surface)}.legal-placeholder{padding:16px 18px;border:1px dashed var(--outline-variant);border-radius:12px;background:var(--surface-low);color:var(--on-surface-variant);font-size:14px;line-height:1.6}
