:root{--bg:#fff;--surface:#fff;--surface-2:#f8f6ef;--surface-3:#efede3;--border:#e6e6e6;--border-strong:#d5d2c5;--border-soft:#f0eee5;--ink:#111;--ink-2:#3a3a3a;--muted:#6b6b6b;--muted-2:#9a9a9a;--accent:#0b996e;--accent-ink:#fff;--premium:#e08f1d;--premium-soft:#fff4df;--premium-ink:#6b4111;--accent-soft:#d7fec8;--accent-hover:#006a42;--accent-deep:#00563a;--easy:#0b996e;--easy-soft:#d7fec8;--medium:#d97706;--medium-soft:#fef3c7;--hard:#dc2626;--hard-soft:#fee2e2;--done:#0b996e;--attempted:#d97706;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;--shadow-sm:0 1px 2px #1111110a;--shadow-md:0 4px 12px #1111110f, 0 1px 3px #1111110a;--shadow-lg:0 16px 40px #1111111a, 0 4px 12px #1111110a;--sans:"Onest", -apple-system, BlinkMacSystemFont, "SF Pro Display", system-ui, sans-serif;--mono:"JetBrains Mono", "SF Mono", ui-monospace, monospace;--sidenav-w:232px;--topbar-h:52px;--safe-top:env(safe-area-inset-top,0px);--safe-right:env(safe-area-inset-right,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px)}[data-theme=dark]{--bg:#0b0f0d;--surface:#131816;--surface-2:#1b201d;--surface-3:#242a26;--border:#232925;--border-strong:#3a4441;--border-soft:#1f2421;--ink:#fafafa;--ink-2:#dadbd7;--muted:#98a19c;--muted-2:#6e756f;--accent:#10b57f;--accent-soft:#04332a;--accent-hover:#0dcc8e;--accent-deep:#006a42;--premium:#f2a93d;--premium-soft:#3a2a10;--premium-ink:#ffe6bd;--easy:#10b57f;--easy-soft:#04332a;--medium-soft:#3a2710;--hard-soft:#3a1414;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 16px 40px #000000a6}[data-theme=sepia]{--bg:#f4ecd8;--surface:#fbf6e6;--surface-2:#efe3c4;--surface-3:#e2d3ae;--border:#d7c7a0;--border-strong:#b79f70;--border-soft:#e8dcbe;--ink:#5b4636;--ink-2:#6e5640;--muted:#8a7558;--muted-2:#a89070;--accent:#8b5a2b;--accent-ink:#fbf6e6;--accent-soft:#f2e2c7;--accent-hover:#6b3f1a;--accent-deep:#4a2a0f;--premium:#a86f1c;--premium-soft:#f5e4c2;--premium-ink:#4a2f0a;--easy:#6b7f2b;--easy-soft:#e8e5c8;--medium:#a86f1c;--medium-soft:#f2e2c7;--hard:#993d2a;--hard-soft:#f2d6cc;--done:#6b7f2b;--attempted:#a86f1c;--shadow-sm:0 1px 2px #5b46360f;--shadow-md:0 4px 12px #5b46361a;--shadow-lg:0 16px 40px #5b463629}[data-theme=slate]{--bg:#14171a;--surface:#1b1f24;--surface-2:#232830;--surface-3:#2c3239;--border:#2f343c;--border-strong:#4a5058;--border-soft:#1f2329;--ink:#e8eaed;--ink-2:#bcc0c7;--muted:#8a8f98;--muted-2:#5d6169;--accent:#14b783;--accent-soft:#0e2e25;--accent-hover:#2dcf9a;--accent-deep:#0b7a58;--premium:#e8a93d;--premium-soft:#2e1f08;--premium-ink:#ffe6bd;--easy:#14b783;--easy-soft:#0e2e25;--medium:#e8a93d;--medium-soft:#2e1f08;--hard:#e25555;--hard-soft:#2e1010;--done:#14b783;--attempted:#e8a93d;--shadow-sm:0 1px 2px #00000073;--shadow-md:0 4px 14px #0000008c;--shadow-lg:0 20px 48px #000000b3}[data-theme=mist]{--bg:#f4f6f8;--surface:#fff;--surface-2:#eaeef2;--surface-3:#dde3e9;--border:#d5dce3;--border-strong:#b6bfca;--border-soft:#e5eaef;--ink:#1a2330;--ink-2:#3a4654;--muted:#6b7785;--muted-2:#97a0ac;--accent:#0b996e;--accent-soft:#def6ec;--accent-hover:#006a42;--accent-deep:#00563a;--premium:#c77a0e;--premium-soft:#ffeacc;--premium-ink:#573006;--easy:#0b996e;--easy-soft:#def6ec;--medium:#c77a0e;--medium-soft:#ffeacc;--hard:#c13838;--hard-soft:#fce0e0;--done:#0b996e;--attempted:#c77a0e;--shadow-sm:0 1px 2px #1a23300d;--shadow-md:0 4px 12px #1a233014;--shadow-lg:0 16px 40px #1a23301f}[data-theme=midnight]{--bg:#000;--surface:#050505;--surface-2:#0c0c0c;--surface-3:#161616;--border:#1f1f1f;--border-strong:#3a3a3a;--border-soft:#141414;--ink:#e8e8e8;--ink-2:#bfbfbf;--muted:#8a8a8a;--muted-2:#5c5c5c;--accent:#00c896;--accent-soft:#002e22;--accent-hover:#15e2ac;--accent-deep:#007a5c;--premium:#e08f1d;--premium-soft:#2e1d04;--premium-ink:#ffe6bd;--easy:#00c896;--easy-soft:#002e22;--medium:#e08f1d;--medium-soft:#2e1d04;--hard:#e04545;--hard-soft:#2e0808;--done:#00c896;--attempted:#e08f1d;--shadow-sm:0 1px 2px #000c;--shadow-md:0 4px 14px #000000d9;--shadow-lg:0 20px 48px #000000e6}[data-theme=coffee]{--bg:#1f1410;--surface:#2a1c17;--surface-2:#36251e;--surface-3:#432e25;--border:#4a3225;--border-strong:#6b493a;--border-soft:#2f2018;--ink:#f2e8da;--ink-2:#d4c3ae;--muted:#a38e72;--muted-2:#74624c;--accent:#c9a77d;--accent-ink:#1f1410;--accent-soft:#3d2f22;--accent-hover:#e4c29c;--accent-deep:#8a6d4a;--premium:#d9a23b;--premium-soft:#3a2a0e;--premium-ink:#ffe4a8;--easy:#93b073;--easy-soft:#1f2a14;--medium:#d9a23b;--medium-soft:#3a2a0e;--hard:#c9663d;--hard-soft:#3a1810;--done:#93b073;--attempted:#d9a23b;--shadow-sm:0 1px 2px #00000073;--shadow-md:0 4px 14px #0000008c;--shadow-lg:0 20px 48px #000000b3}[data-theme=graphite]{--bg:#1c1c1e;--surface:#232325;--surface-2:#2c2c2e;--surface-3:#383839;--border:#3a3a3c;--border-strong:#545458;--border-soft:#28282a;--ink:#f2f2f3;--ink-2:#c7c7cc;--muted:#8e8e93;--muted-2:#636366;--accent:#0bb67e;--accent-soft:#0f2c24;--accent-hover:#1ace92;--accent-deep:#08825a;--premium:#e8a93d;--premium-soft:#2e1f08;--premium-ink:#ffe6bd;--easy:#0bb67e;--easy-soft:#0f2c24;--medium:#e8a93d;--medium-soft:#2e1f08;--hard:#e25555;--hard-soft:#2e1010;--done:#0bb67e;--attempted:#e8a93d;--shadow-sm:0 1px 2px #00000073;--shadow-md:0 4px 14px #0000008c;--shadow-lg:0 20px 48px #000000b3}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}body{overflow-x:hidden}::selection{background:var(--accent);color:var(--accent-ink)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border:2px solid var(--bg);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}input,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}#app{grid-template-columns:var(--sidenav-w) 1fr;min-height:100vh;display:grid}@media (max-width:960px){#app{grid-template-columns:1fr}}.sidenav{border-right:1px solid var(--border);background:var(--surface);z-index:80;flex-direction:column;gap:18px;height:100vh;padding:14px 12px;display:flex;position:sticky;top:0}@media (max-width:960px){.sidenav{z-index:110;width:min(280px,84vw);box-shadow:var(--shadow-lg);transition:transform .22s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidenav[data-open=true]{transform:translate(0)}}.brand{cursor:pointer;align-items:center;gap:9px;padding:4px 8px;display:flex}.brand-mark{background:var(--ink);width:26px;height:26px;color:var(--bg);border-radius:7px;flex-shrink:0;place-items:center;display:grid}.brand-name{letter-spacing:-.015em;color:var(--ink);font-size:15px;font-weight:700}.brand-tag{font-family:var(--mono);background:var(--accent);color:var(--accent-ink);letter-spacing:.04em;vertical-align:1px;border-radius:3px;margin-left:4px;padding:1px 5px;font-size:9px;font-weight:600;display:inline-flex}.nav-section{flex-direction:column;gap:1px;display:flex}.nav-section-title{color:var(--muted-2);letter-spacing:.04em;text-transform:uppercase;margin-top:12px;padding:8px 10px 4px;font-size:11px;font-weight:600}.nav-item+.nav-section-title{margin-top:16px}.nav-item{color:var(--ink-2);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:9px;padding:7px 10px;font-size:13.5px;font-weight:500;transition:background .12s,color .12s;display:flex}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item[data-active=true]{background:var(--accent-soft);color:var(--accent)}.nav-icon{color:currentColor;opacity:.85;flex-shrink:0;width:16px;height:16px;display:inline-flex}.nav-count{font-family:var(--mono);color:var(--muted-2);margin-left:auto;font-size:10.5px}.nav-item[data-active=true] .nav-count{color:var(--accent);opacity:.7}.sidenav-scroll{flex-direction:column;flex:auto;gap:4px;min-height:0;padding-top:4px;display:flex;overflow-y:auto}.sidenav-foot{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;flex-shrink:0;margin-top:auto;padding:12px}.sidenav-foot-row{align-items:center;gap:10px;margin-bottom:8px;display:flex}.sidenav-avatar{background:var(--accent);width:30px;height:30px;color:var(--accent-ink);border-radius:50%;place-items:center;font-size:12px;font-weight:600;display:grid}.sidenav-name{color:var(--ink);font-size:12.5px;font-weight:600;line-height:1}.sidenav-plan{color:var(--muted);font-size:11px;font-family:var(--mono);margin-top:3px}.sidenav-upgrade{text-align:center;background:var(--ink);width:100%;color:var(--bg);cursor:pointer;border-radius:6px;padding:7px 8px;font-size:11.5px;font-weight:600;display:block}.main{flex-direction:column;min-width:0;display:flex}.topbar{z-index:50;background:color-mix(in oklab, var(--bg) 88%, transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);height:var(--topbar-h);align-items:center;gap:10px;padding:9px 18px;display:flex;position:sticky;top:0}.crumbs{color:var(--muted);align-items:center;gap:6px;min-width:0;font-size:12.5px;display:flex}.crumbs em{color:var(--muted-2);font-style:normal}.crumbs span.current{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.crumbs a{cursor:pointer}.crumbs a:hover{color:var(--ink)}.topbar-spacer{flex:1}.searchbox{border:1px solid var(--border);background:var(--surface);cursor:pointer;text-align:left;width:280px;color:var(--muted);border-radius:6px;outline:none;align-items:center;gap:7px;padding:6px 10px;font-family:inherit;transition:border-color .12s,background .12s;display:flex}.searchbox:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.searchbox:hover{background:var(--surface-2);border-color:var(--border-strong)}.searchbox-placeholder{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;overflow:hidden}.search-modal{z-index:1000;display:none;position:fixed;inset:0}.search-modal[data-open=true]{display:block}.search-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080a0c8c;animation:.15s both searchFadeIn;position:absolute;inset:0}.search-modal-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:min(620px,100vw - 32px);max-height:70vh;animation:.18s cubic-bezier(.2,.7,.3,1) both searchModalIn;display:flex;position:absolute;top:12vh;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 28px 60px -16px #080a0c66}@keyframes searchFadeIn{0%{opacity:0}to{opacity:1}}@keyframes searchModalIn{0%{opacity:0;transform:translate(-50%)translateY(-8px)scale(.985)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.search-modal-head{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 16px;display:flex}.search-modal-icon{color:var(--muted);flex-shrink:0}#searchModalInput{color:var(--ink);background:0 0;border:0;outline:0;flex:1;font-family:inherit;font-size:15px}#searchModalInput::placeholder{color:var(--muted)}.search-modal-kbd{font-family:var(--mono);border:1px solid var(--border);color:var(--muted);background:var(--surface-2);border-radius:4px;padding:3px 6px;font-size:10.5px}.search-modal-results{flex:1;min-height:80px;padding:8px;overflow-y:auto}.search-modal-group-label{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:10px 12px 6px;font-size:10.5px;font-weight:700}.search-modal-empty{text-align:center;color:var(--muted);padding:28px 16px;font-size:13px}.search-modal-item{cursor:pointer;text-align:left;width:100%;color:inherit;background:0 0;border:0;border-radius:10px;grid-template-columns:32px minmax(0,1fr) auto auto;align-items:center;gap:12px;padding:10px 12px;font-family:inherit;transition:background .12s;display:grid}.search-modal-item.is-active{background:color-mix(in srgb, var(--accent) 8%, var(--surface-2))}.search-modal-item-ic{background:var(--surface-2);width:32px;height:32px;color:var(--ink-2);border-radius:8px;flex-shrink:0;place-items:center;display:grid}.search-modal-item.is-active .search-modal-item-ic{background:color-mix(in srgb, var(--accent) 14%, var(--surface));color:var(--accent)}.search-modal-item-body{flex-direction:column;gap:3px;min-width:0;display:flex}.search-modal-item-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.search-modal-item-sub{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}.search-modal-item-kind{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--surface-2);border-radius:4px;padding:3px 7px;font-size:9.5px;font-weight:700}.search-modal-item.is-active .search-modal-item-kind{background:color-mix(in srgb, var(--accent) 14%, var(--surface));color:var(--accent)}.search-modal-item-arrow{color:var(--muted);opacity:0;transition:opacity .12s,transform .12s}.search-modal-item.is-active .search-modal-item-arrow{opacity:1;color:var(--accent);transform:translate(2px)}.search-modal-foot{border-top:1px solid var(--border);color:var(--muted);background:var(--surface-2);align-items:center;gap:16px;padding:10px 16px;font-size:11px;display:flex}.search-modal-foot kbd{font-family:var(--mono);border:1px solid var(--border);background:var(--surface);color:var(--ink-2);border-radius:3px;margin:0 4px 0 0;padding:2px 5px;font-size:10px}.search-modal-foot span{align-items:center;display:inline-flex}@media (max-width:640px){.search-modal-card{max-height:88vh;top:6vh}.search-modal-foot{display:none}}.searchbox:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.searchbox input{background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:13px}.searchbox kbd{font-family:var(--mono);border:1px solid var(--border);color:var(--muted);background:var(--surface-2);border-radius:3px;padding:1.5px 5px;font-size:10px}.iconbtn{border:1px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--ink-2);border-radius:6px;place-items:center;transition:border-color .12s,background .12s;display:grid}.iconbtn:hover{border-color:var(--border-strong);background:var(--surface-2)}.mobile-trigger{border:1px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--ink-2);border-radius:6px;justify-content:center;align-items:center;display:none}@media (max-width:960px){.mobile-trigger{display:flex}.searchbox{flex:1;width:auto;min-width:0}.searchbox kbd,.crumbs{display:none}}.scrim{z-index:100;background:#0a0a0f80;display:none;position:fixed;inset:0}.scrim[data-show=true]{display:block}.view{flex-direction:column;flex:auto;min-width:0;display:flex}.btn{background:var(--surface);color:var(--ink-2);border:1px solid var(--border);white-space:nowrap;cursor:pointer;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:500;transition:all .12s;display:inline-flex}.btn:hover{border-color:var(--border-strong);background:var(--surface-2)}.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ink{background:var(--ink);color:var(--bg);border-color:var(--ink)}.btn-ink:hover{background:var(--ink-2);border-color:var(--ink-2)}.btn-lg{padding:9px 14px;font-size:13.5px}.btn-sm{padding:4px 9px;font-size:12px}.btn[disabled]{opacity:.5;cursor:not-allowed}.home-content{width:100%;max-width:1380px;margin:0 auto;padding:24px 26px 60px}.home-hero{flex-wrap:wrap;justify-content:space-between;align-items:end;gap:18px;margin-bottom:22px;display:flex}.home-hero h1{letter-spacing:-.02em;color:var(--ink);font-size:22px;font-weight:600;line-height:1.2}.home-hero p{color:var(--muted);margin-top:4px;font-size:13px;font-weight:400}.topic-filters{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;padding:10px 12px;display:flex}.chip{background:var(--surface-2);color:var(--ink-2);cursor:pointer;border:1px solid #0000;border-radius:99px;padding:4px 10px;font-size:12.5px;font-weight:500;transition:all .12s}.chip:hover{background:var(--surface-3)}.chip[data-active=true]{background:var(--ink);color:var(--bg)}.card-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.module-section{margin-top:32px}.module-section:first-of-type{margin-top:8px}.module-header{border-bottom:1px solid var(--border-soft);align-items:baseline;gap:12px;margin-bottom:14px;padding:0 0 12px;display:flex}.module-eyebrow{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3,var(--ink-2));align-items:center;gap:6px;font-size:10.5px;font-weight:600;display:inline-flex}.module-eyebrow .dot{background:var(--accent);border-radius:50%;width:6px;height:6px}.module-title{letter-spacing:-.01em;color:var(--ink);margin:0;font-size:18px;font-weight:600}.module-count{font-family:var(--mono);color:var(--ink-2);margin-left:auto;font-size:11.5px}.topic-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;gap:14px;padding:16px;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.topic-card:hover{border-color:color-mix(in srgb, var(--accent) 40%, var(--border));box-shadow:0 2px 10px color-mix(in srgb, var(--ink) 5%, transparent)}.topic-card.is-complete{border-color:color-mix(in srgb, var(--accent) 28%, var(--border));background:color-mix(in srgb, var(--accent) 2.5%, var(--surface))}.topic-card-head{align-items:center;gap:12px;min-width:0;display:flex}.topic-card-icon{background:color-mix(in srgb, var(--accent) 12%, var(--surface));width:36px;height:36px;color:var(--accent);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.topic-card-icon svg{width:16px;height:16px}.topic-card-head-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.topic-card-title{letter-spacing:-.015em;color:var(--ink);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:15px;font-weight:700;line-height:1.3;overflow:hidden}.topic-card-meta{color:var(--muted);font-size:11.5px;font-weight:500}.topic-card-badge{background:var(--accent);width:22px;height:22px;color:var(--accent-ink);border-radius:999px;flex-shrink:0;place-items:center;display:grid}.topic-card-badge svg{width:12px;height:12px}.topic-card-progress{flex-direction:column;gap:5px;display:flex}.topic-card-progress-track{background:color-mix(in srgb, var(--ink) 7%, var(--surface-2));border-radius:999px;height:3px;position:relative;overflow:hidden}.topic-card-progress-fill{background:var(--accent);border-radius:999px;transition:width .3s;position:absolute;top:0;bottom:0;left:0}.topic-card-progress-meta{justify-content:space-between;align-items:center;gap:10px;display:flex}.topic-card-progress-label{color:var(--muted);font-size:11px;font-weight:500}.topic-card-progress.is-complete .topic-card-progress-label{color:var(--accent-hover);font-weight:600}.topic-card-progress-pct{color:var(--ink-2);font-variant-numeric:tabular-nums;font-size:11px;font-weight:700}.topic-card-progress.is-complete .topic-card-progress-pct{color:var(--accent)}.topic-card-actions{border-top:1px dashed var(--border);grid-template-columns:minmax(0,1.2fr) minmax(0,1fr) minmax(0,1fr);gap:6px;padding-top:12px;display:grid}.topic-card-btn{color:var(--ink-2);font:inherit;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:4px;padding:8px 6px;font-size:11.5px;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex;overflow:hidden}.topic-card-btn svg{flex-shrink:0;width:13px;height:13px}.topic-card-btn-ghost{color:var(--ink-2)}.topic-card-btn-ghost svg{opacity:.65}.topic-card-btn-ghost:hover{background:var(--surface-2);color:var(--ink)}.topic-card-btn-ghost:hover svg{opacity:1}.topic-card-btn-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:700}.topic-card-btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.topic-card-btn-full{grid-column:1/-1}@media (max-width:520px){.topic-card{gap:12px;padding:14px}.topic-card-actions{grid-template-columns:1fr}}.notes-view,.practice-view,.viz-view,.home-view{flex-direction:column;flex:auto;min-width:0;display:flex}.layout{min-height:calc(100vh - var(--topbar-h));flex:1;grid-template-columns:252px 1fr;display:grid}@media (max-width:960px){.layout{grid-template-columns:1fr}}.sidebar{border-right:1px solid var(--border);background:var(--surface);top:var(--topbar-h);height:calc(100vh - var(--topbar-h));z-index:60;flex-direction:column;transition:transform .24s;display:flex;position:sticky;overflow:hidden}@media (max-width:960px){.sidebar{top:var(--topbar-h);width:min(280px,84vw);height:calc(100vh - var(--topbar-h));box-shadow:var(--shadow-lg);position:fixed;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}}.sidebar-back{color:var(--muted);cursor:pointer;border-bottom:1px solid var(--border-soft);-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:6px;padding:12px 14px;font-size:12px;font-weight:500;transition:color .12s;display:flex}.sidebar-back:hover{color:var(--ink)}.sidebar-back svg{transition:transform .12s}.sidebar-back:hover svg{transform:translate(-2px)}.sidebar-search{background:var(--surface-2);border:1px solid #0000;border-radius:6px;flex-shrink:0;align-items:center;gap:7px;margin:12px 12px 4px;padding:6px 10px;transition:all .14s;display:flex}.sidebar-search:focus-within{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.sidebar-search svg{color:var(--muted);flex-shrink:0}.sidebar-search input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:12.5px}.sidebar-search input::placeholder{color:var(--muted)}.sidebar-nav{flex:auto;padding:8px 10px 16px;overflow-y:auto}.nav-tree{margin:0;padding:0;list-style:none}.nav-tree .nav-item{background:0 0;border-radius:0;padding:0;display:block}.nav-tree .nav-item:hover{background:0 0}.nav-tree .nav-item.hidden{display:none}.nav-topic-header{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:baseline;margin-bottom:8px;padding:4px 10px 10px;display:flex}.nav-topic-title{color:var(--ink);letter-spacing:-.01em;font-size:14px;font-weight:600}.nav-topic-count{font-family:var(--mono);color:var(--muted-2);font-size:10.5px}.nav-children{flex-direction:column;gap:1px;margin:0;padding:0;list-style:none;display:flex}.nav-link,.sidebar-link{color:var(--ink-2);cursor:pointer;border-radius:5px;align-items:center;gap:9px;padding:6px 10px;font-size:12.5px;line-height:1.4;transition:background .1s,color .1s;display:flex;position:relative}.nav-link:hover,.sidebar-link:hover{background:var(--surface-2);color:var(--ink)}.nav-link.active,.sidebar-link.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.nav-num{font-family:var(--mono);border:1px solid var(--border);background:var(--surface);width:18px;height:18px;color:var(--muted);border-radius:4px;flex-shrink:0;place-items:center;font-size:10px;display:grid}.nav-link.active .nav-num,.sidebar-link.active .nav-num{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.nav-dot{background:var(--muted-2);border-radius:50%;flex-shrink:0;width:6px;height:6px;margin:0 6px}.nav-link.active .nav-dot,.sidebar-link.active .nav-dot{background:var(--accent)}.nav-text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sidebar-overlay{inset:var(--topbar-h) 0 0 0;z-index:55;background:#0a0a0f73;display:none;position:fixed}.sidebar-overlay.visible{display:block}.content{width:100%;max-width:820px;margin:0 auto;padding:28px 36px 64px}@media (max-width:760px){.content{padding:22px 18px 56px}}.content-topbar{justify-content:flex-end;margin-bottom:14px;display:flex}.content-practice-btn{background:var(--accent);color:var(--accent-ink);border:1px solid var(--accent);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:7px 12px;font-size:12.5px;font-weight:500;transition:background .12s;display:inline-flex}.content-practice-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.note-section{color:var(--ink-2);font-size:14.5px;line-height:1.65}.note-section h1{letter-spacing:-.025em;color:var(--ink);align-items:center;gap:12px;margin:0 0 16px;font-size:28px;font-weight:600;line-height:1.2;display:flex}.note-section h2{letter-spacing:-.015em;color:var(--ink);align-items:center;gap:10px;margin:32px 0 10px;font-size:19px;font-weight:600;display:flex}.note-section h3{color:var(--ink);align-items:center;gap:8px;margin:20px 0 6px;font-size:15px;font-weight:600;display:flex}.note-section .heading-icon{background:var(--surface-2);border:1px solid var(--border-soft);color:var(--accent);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.note-section h1 .heading-icon{border-radius:8px;width:28px;height:28px}.note-section h2 .heading-icon{width:24px;height:24px}.note-section h3 .heading-icon{border-radius:6px;width:20px;height:20px}.note-section .heading-icon svg{width:14px;height:14px}.note-section h3 .heading-icon svg{width:12px;height:12px}.note-section .heading-text{display:inline}.note-section .heading-icon-advantages{color:#16a34a;background:color-mix(in oklab, #16a34a 12%, var(--surface-2));border-color:color-mix(in oklab, #16a34a 26%, var(--border-soft))}.note-section .heading-icon-disadvantages{color:#dc2626;background:color-mix(in oklab, #dc2626 12%, var(--surface-2));border-color:color-mix(in oklab, #dc2626 26%, var(--border-soft))}.note-section .heading-icon-flow{color:#0ea5e9;background:color-mix(in oklab, #0ea5e9 12%, var(--surface-2));border-color:color-mix(in oklab, #0ea5e9 26%, var(--border-soft))}.note-section .heading-icon-example{color:#0891b2;background:color-mix(in oklab, #06b6d4 12%, var(--surface-2));border-color:color-mix(in oklab, #06b6d4 26%, var(--border-soft))}.note-section .heading-icon-takeaway{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}.note-section .heading-icon-interview{color:#7c3aed;background:color-mix(in oklab, #7c3aed 14%, var(--surface-2));border-color:color-mix(in oklab, #7c3aed 28%, var(--border-soft))}.note-section .heading-icon-tradeoff{color:#db2777;background:color-mix(in oklab, #db2777 12%, var(--surface-2));border-color:color-mix(in oklab, #db2777 26%, var(--border-soft))}.note-section .heading-icon-performance{color:#d97706;background:color-mix(in oklab, #f59e0b 14%, var(--surface-2));border-color:color-mix(in oklab, #f59e0b 28%, var(--border-soft))}.note-section .heading-icon-overview{color:var(--accent)}.note-section h4,.note-section h5,.note-section h6{color:var(--ink);margin:16px 0 4px;font-size:13.5px;font-weight:600}.note-section p{color:var(--ink-2);margin:0 0 12px}.note-section ul,.note-section ol{margin:0 0 14px;padding-left:22px}.note-section li{color:var(--ink-2);margin-bottom:5px;line-height:1.6}.note-section strong{color:var(--ink);font-weight:600}.note-section em{font-style:italic}.note-section a{color:var(--accent);border-bottom:1px dashed var(--accent)}.note-section a:hover{border-bottom-style:solid}.note-section img{border:1px solid var(--border);background:var(--surface);max-width:100%;height:auto;box-shadow:var(--shadow-sm);border-radius:12px;margin:18px auto;display:block}.note-section .note-figure{overscroll-behavior-inline:contain;-webkit-overflow-scrolling:touch;margin:22px 0;overflow-x:auto}.note-section .note-figure img{margin:0 auto}.note-section .note-figure img[src*="/system-design-assets/generated/"],.note-section .note-figure img[src*="/dbms-assets/generated/"],.note-section .note-figure img[src*="/os-assets/generated/"],.note-section .note-figure img[src*="/cn-assets/generated/"]{width:100%;max-width:100%;height:auto;display:block}.note-section .note-figure figcaption{text-align:center;color:var(--ink-3,var(--ink-2));margin-top:8px;font-size:12px;line-height:1.5}.note-section code:not(.hljs):not([class*=language-]){font-family:var(--mono);background:var(--surface-2);color:var(--ink);border:1px solid var(--border-soft);border-radius:3px;padding:1.5px 5px;font-size:12.5px}.note-section blockquote{border:1px solid var(--border-soft);background:var(--surface);color:var(--ink-2);border-radius:8px;margin:14px 0;padding:10px 14px}.section-divider{background:var(--border);border:none;height:1px;margin:28px 0}.note-section .callout{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);border-radius:12px;margin:22px 0;overflow:hidden}.note-section .callout-head{background:var(--surface-2);border-bottom:1px solid var(--border-soft);align-items:center;gap:10px;padding:10px 14px;display:flex}.note-section .callout-title{font-family:var(--sans);letter-spacing:.09em;text-transform:uppercase;color:var(--ink);font-size:11px;font-weight:700}.note-section .callout-icon{background:var(--surface-3,var(--surface));border:1px solid var(--border-soft);width:26px;height:26px;color:var(--accent);border-radius:7px;justify-content:center;align-items:center;display:inline-flex}.note-section .callout-icon svg{width:14px;height:14px}.note-section .callout-body{color:var(--ink-2);padding:14px 16px;line-height:1.7}.note-section .callout-body>:first-child{margin-top:0}.note-section .callout-body>:last-child{margin-bottom:0}.note-section .callout-body p{margin:0 0 10px}.note-section .callout-body ul,.note-section .callout-body ol{margin:0 0 10px;padding-left:20px}.note-section .callout-body li{margin-bottom:4px}.note-section .callout-body code{background:var(--surface-2)}.note-section .callout-note .callout-icon{color:var(--ink-2);background:var(--surface-2)}.note-section .callout-tip .callout-icon{color:#15803d;background:#16a34a29;background:lab(58.835% -51.0809 35.4288/.16);border-color:#16a34a4d;border-color:lab(58.835% -51.0809 35.4288/.3)}.note-section .callout-tip .callout-head{background:color-mix(in oklab, #16a34a 6%, var(--surface-2))}.note-section .callout-warning .callout-icon{color:#b45309;background:#f59e0b2e;background:lab(72.7914% 26.933 75.434/.18);border-color:#f59e0b52;border-color:lab(72.7914% 26.933 75.434/.32)}.note-section .callout-warning .callout-head{background:color-mix(in oklab, #f59e0b 7%, var(--surface-2))}.note-section .callout-info .callout-icon{color:#0369a1;background:#0ea5e929;background:lab(63.352% -17.6081 -44.8632/.16);border-color:#0ea5e94d;border-color:lab(63.352% -17.6081 -44.8632/.3)}.note-section .callout-info .callout-head{background:color-mix(in oklab, #0ea5e9 7%, var(--surface-2))}.note-section .callout-key .callout-icon{color:#7e22ce;background:#a855f729;background:lab(52.7991% 56.2742 -68.7519/.16);border-color:#a855f74d;border-color:lab(52.7991% 56.2742 -68.7519/.3)}.note-section .callout-key .callout-head{background:color-mix(in oklab, #a855f7 6%, var(--surface-2))}.note-section .callout-takeaway .callout-icon{color:var(--accent-ink);background:var(--accent);border-color:var(--accent)}.note-section .callout-takeaway .callout-head{background:color-mix(in oklab, var(--accent) 8%, var(--surface-2))}.note-section .callout-takeaway .callout-title{color:var(--ink)}.note-section .callout-interview .callout-icon{color:#fff;background:linear-gradient(135deg,#7c3aed,#4f46e5);border-color:#7c3aed66;border-color:lab(42.2333% 56.9752 -80.606/.4)}.note-section .callout-interview .callout-head{background:color-mix(in oklab, #7c3aed 7%, var(--surface-2))}.note-section .callout-example .callout-icon{color:#0e7490;background:#06b6d429;background:lab(67.6998% -31.5985 -26.6758/.16);border-color:#06b6d44d;border-color:lab(67.6998% -31.5985 -26.6758/.3)}.note-section .callout-example .callout-head{background:color-mix(in oklab, #06b6d4 7%, var(--surface-2))}.note-section h1 .viz-btn,.note-section h2 .viz-btn,.note-section h3 .viz-btn{font-size:11px;font-family:var(--sans);background:var(--accent-soft);color:var(--accent);border:1px solid color-mix(in oklab, var(--accent) 30%, transparent);cursor:pointer;white-space:nowrap;border-radius:5px;align-items:center;gap:5px;padding:4px 9px;font-weight:500;text-decoration:none;display:inline-flex}.note-section h1 .viz-btn:hover,.note-section h2 .viz-btn:hover,.note-section h3 .viz-btn:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.table-wrapper{border:1px solid var(--border);background:var(--surface);border-radius:8px;margin:14px 0;overflow-x:auto}.table-wrapper table{border-collapse:collapse;width:100%;font-size:13px}.table-wrapper th{background:var(--surface-2);text-align:left;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);padding:10px 14px;font-size:12px;font-weight:600}.table-wrapper td{border-bottom:1px solid var(--border-soft);color:var(--ink-2);vertical-align:top;padding:10px 14px}.table-wrapper tr:last-child td{border-bottom:none}.table-wrapper tr:hover td{background:var(--surface-2)}.page-nav{border-top:1px solid var(--border);margin-top:40px;padding-top:20px}.page-nav-count{font-size:11px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;display:block}.page-nav-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (max-width:600px){.page-nav-row{grid-template-columns:1fr}}.page-nav-btn{border:1px solid var(--border);background:var(--surface);text-align:left;cursor:pointer;border-radius:8px;align-items:center;gap:12px;width:100%;padding:12px 14px;transition:border-color .14s,transform .14s;display:flex}.page-nav-btn:hover{border-color:var(--accent);transform:translateY(-1px)}.page-nav-btn.next{text-align:right;justify-content:flex-end}.page-nav-btn svg{color:var(--muted);flex-shrink:0}.page-nav-btn:hover svg{color:var(--accent)}.page-nav-label{flex-direction:column;min-width:0;display:flex}.page-nav-hint{color:var(--muted);font-size:11px}.page-nav-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.code-window{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#18181b;border-radius:8px;margin:16px 0;overflow:hidden}.code-titlebar{background:#1f1f23;border-bottom:1px solid #2d2d33;align-items:center;gap:10px;padding:7px 12px;display:flex}.code-dots{gap:6px;display:flex}.code-dots .dot{border-radius:50%;width:10px;height:10px;display:inline-block}.code-dots .dot.red{background:#ff5f57}.code-dots .dot.yellow{background:#febc2e}.code-dots .dot.green{background:#28c840}.code-lang{font-family:var(--mono);color:#a1a1aa;font-size:11px;font-weight:500}.copy-btn{font-family:var(--mono);color:#a1a1aa;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:5px;margin-left:auto;padding:3px 8px;font-size:11px;display:inline-flex}.copy-btn:hover{color:#fff;background:#2d2d33}.copy-btn.copied{color:#4ade80}.copy-btn svg{width:12px;height:12px}.code-body{font-family:var(--mono);color:#e4e4e7;background:#18181b;margin:0;padding:14px 16px;font-size:12.5px;line-height:1.7;overflow-x:auto}.code-body code{font:inherit;color:inherit;background:0 0;border:none;padding:0}.code-body code,.code-body code *{background:0 0!important;border-color:#0000!important}.hljs{color:#e4e4e7;background:0 0}.hljs-keyword,.hljs-selector-tag{color:#c084fc}.hljs-built_in{color:#93c5fd}.hljs-type,.hljs-class{color:#5eead4}.hljs-string,.hljs-attr{color:#86efac}.hljs-number,.hljs-literal{color:#fcd34d}.hljs-title,.hljs-function,.hljs-name{color:#60a5fa}.hljs-comment,.hljs-quote{color:#71717a;font-style:italic}.hljs-variable,.hljs-template-variable{color:#f87171}.hljs-meta,.hljs-tag,.hljs-punctuation{color:#a78bfa}.hljs-symbol{color:#fb923c}.hljs-params{color:#e4e4e7}.hljs-property{color:#93c5fd}.code-tabs-group{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#18181b;border-radius:8px;margin:16px 0;overflow:hidden}.code-tabs-bar{background:#1f1f23;border-bottom:1px solid #2d2d33;align-items:center;gap:2px;padding:0 6px;display:flex}.code-tab-btn{font-family:var(--mono);color:#a1a1aa;cursor:pointer;background:0 0;border-bottom:2px solid #0000;padding:9px 12px;font-size:11px;transition:color .12s,border-color .12s}.code-tab-btn:hover{color:#fff}.code-tab-btn[data-active=true]{color:#fff;border-bottom-color:var(--accent)}.code-tab-copy{font-family:var(--mono);color:#a1a1aa;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:5px;margin-left:auto;padding:3px 8px;font-size:11px;display:inline-flex}.code-tab-copy:hover{color:#fff;background:#2d2d33}.code-tab-copy.copied{color:#4ade80}.code-tab-pane{display:none}.code-tab-pane[data-active=true]{display:block}.code-tabs-group .code-window{box-shadow:none;border:none;border-radius:0;margin:0}.code-tabs-group .code-titlebar{display:none}.practice-page{width:100%;padding:24px 28px 60px}@media (max-width:760px){.practice-page{padding:20px 16px 48px}}.practice-header{flex-direction:column;gap:4px;margin-bottom:22px;display:flex}.practice-back{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-self:flex-start;align-items:center;gap:6px;margin-bottom:8px;padding:5px 10px 5px 6px;font-size:12px;transition:color .12s,background .12s;display:inline-flex}.practice-back:hover{color:var(--ink);background:var(--surface-2)}.practice-back svg{transition:transform .12s}.practice-back:hover svg{transform:translate(-2px)}.practice-title{letter-spacing:-.02em;color:var(--ink);font-size:24px;font-weight:600}.practice-subtitle{color:var(--muted);font-size:13px}.practice-note{background:var(--accent-soft);border:1px solid color-mix(in oklab, var(--accent) 25%, transparent);color:var(--ink-2);border-radius:8px;margin-bottom:18px;padding:10px 14px;font-size:13px}.practice-note p{margin:0}.pq-section{margin-bottom:22px}.pq-section-head{align-items:center;gap:8px;margin-bottom:8px;padding:8px 4px;display:flex}.pq-section-dot{background:var(--muted-2);border-radius:50%;width:8px;height:8px}.pq-section-dot.easy{background:var(--easy)}.pq-section-dot.medium{background:var(--medium)}.pq-section-dot.hard{background:var(--hard)}.pq-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--ink);font-size:12px;font-weight:600}.pq-section-count{font-family:var(--mono);color:var(--muted);margin-left:auto;font-size:11px}.pq-list{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.pq-row{border-bottom:1px solid var(--border-soft);align-items:center;gap:12px;padding:11px 16px;transition:background 80ms;display:flex}.pq-row:last-child{border-bottom:none}.pq-row:hover{background:var(--surface-2)}.pq-row-info{flex:1;min-width:0}.pq-row-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:500;overflow:hidden}.pq-row-actions{flex-shrink:0;gap:6px;display:flex}.pq-action-btn{border:1px solid var(--border);background:var(--surface);width:30px;height:30px;color:var(--muted);cursor:pointer;border-radius:6px;place-items:center;transition:all .12s;display:grid}.pq-action-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.pq-action-go:hover{color:var(--accent)}.interview-page{width:100%;padding:24px 28px 60px}@media (max-width:760px){.interview-page{padding:20px 16px 48px}}.interview-header{margin-bottom:22px}.interview-title{letter-spacing:-.02em;color:var(--ink);margin-top:8px;font-size:24px;font-weight:600}.interview-subtitle{color:var(--muted);font-size:13px}.interview-list{flex-direction:column;gap:10px;display:flex}.iv-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px 18px;transition:border-color .14s}.iv-item:hover{border-color:var(--border-strong)}.iv-question{color:var(--ink);letter-spacing:-.005em;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:15px;font-weight:600;line-height:1.4;display:flex}.iv-num{font-family:var(--mono);color:var(--muted);flex-shrink:0;margin-top:1px;font-size:12.5px;font-weight:600}.iv-q-text{flex:1}.iv-difficulty{font-family:var(--mono);text-transform:uppercase;letter-spacing:.04em;border-radius:4px;flex-shrink:0;padding:2px 7px;font-size:10.5px;font-weight:600}.iv-difficulty.easy{background:var(--easy-soft);color:var(--easy)}.iv-difficulty.medium,.iv-difficulty.med{background:var(--medium-soft);color:var(--medium)}.iv-difficulty.hard{background:var(--hard-soft);color:var(--hard)}.iv-answer{border-left:2px solid var(--border-soft);padding-left:24px;font-size:13.5px}.iv-answer-body p{color:var(--ink-2);margin:0 0 10px;line-height:1.65}.iv-answer-body p:last-child{margin-bottom:0}.iv-answer-body code:not(.hljs):not([class*=language-]){font-family:var(--mono);background:var(--surface-2);color:var(--ink);border:1px solid var(--border-soft);border-radius:3px;padding:1px 5px;font-size:12px}.iv-answer-body strong{color:var(--ink);font-weight:600}.iv-notion-answer{flex-direction:column;gap:6px;display:flex}.iv-answer-line{border-radius:6px;align-items:flex-start;gap:10px;padding:6px 8px;display:flex}.iv-answer-line.complexity{background:var(--accent-soft)}.iv-answer-line.formula{background:var(--surface-2);border:1px solid var(--border-soft)}.iv-answer-line.callout{background:var(--medium-soft)}.iv-line-icon{width:18px;height:18px;font-size:11px;font-family:var(--mono);color:var(--muted);background:var(--surface);border-radius:4px;flex-shrink:0;place-items:center;margin-top:1px;font-weight:700;display:grid}.iv-answer-line.complexity .iv-line-icon{color:var(--accent)}.iv-answer-line.callout .iv-line-icon{color:var(--medium)}.iv-line-text{color:var(--ink-2);flex:1;line-height:1.6}.viz-content{flex:1;min-height:100%;display:block}.viz-page{display:block}.viz-empty{text-align:center;background:var(--surface);border:1px solid var(--border-soft);border-radius:14px;max-width:480px;margin:24px auto 40px;padding:40px 24px}.viz-empty-icon{background:var(--accent-soft);width:64px;height:64px;color:var(--accent);border-radius:14px;place-items:center;margin:0 auto 18px;display:grid}.viz-empty-icon svg{width:30px;height:30px}.viz-empty h2{letter-spacing:-.02em;color:var(--ink);margin-bottom:8px;font-size:22px;font-weight:600}.viz-empty p{color:var(--muted);margin-bottom:0;font-size:13.5px}.viz-cta-btn{background:var(--accent);color:var(--accent-ink);border:1px solid var(--accent);font-family:var(--font);letter-spacing:-.005em;cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:7px;padding:7px 14px;font-size:12.5px;font-weight:500;text-decoration:none;transition:background .12s,border-color .12s,transform 80ms;display:inline-flex}.viz-cta-btn svg{flex-shrink:0}.viz-cta-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:var(--accent-ink)}.viz-cta-btn:active{transform:translateY(1px)}.viz-page .pq-row{gap:14px}.viz-page .pq-row.is-locked .pq-row-actions{display:flex}.viz-cta-btn-locked{background:var(--premium-soft);border-color:color-mix(in srgb, var(--premium) 36%, transparent);color:var(--premium);cursor:pointer;font-weight:600}.viz-cta-btn-locked:hover{background:color-mix(in srgb, var(--premium) 14%, var(--premium-soft));border-color:var(--premium);color:var(--premium)}.study-eyebrow{font-family:var(--mono);color:var(--muted);letter-spacing:.05em;text-transform:uppercase;align-items:center;gap:9px;margin-bottom:12px;font-size:11px;display:flex}.study-eyebrow .dot{background:var(--accent);border-radius:50%;width:6px;height:6px}.study-actions{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;margin:0 0 24px;padding:0 0 18px;display:flex}.mobile-syllabus-btn{display:none}@media (max-width:960px){.mobile-syllabus-btn{display:inline-flex}}.code-tabs-container{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#18181b;border-radius:8px;margin:16px 0;overflow:hidden}.code-tabs-bar{background:#1f1f23;border-bottom:1px solid #2d2d33;align-items:center;gap:12px;min-height:38px;padding:0 10px 0 12px;display:flex}.code-tabs-header{flex:1;align-items:center;gap:2px;display:flex;overflow-x:auto}.code-tab{font-family:var(--mono);color:#a1a1aa;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:9px 12px;font-size:11px;transition:color .12s,border-color .12s}.code-tab:hover{color:#fff}.code-tab.active{color:#fff;border-bottom-color:var(--accent)}.tabs-copy-btn{margin-left:auto}.code-tab-panel{display:none}.code-tab-panel.active{display:block}.code-window.in-tabs{box-shadow:none;border:none;border-radius:0;margin:0}.code-window.in-tabs .code-titlebar{display:none}.prob-loading{text-align:center;color:var(--muted);padding:60px 24px;font-size:13.5px}.skel{--skel-base:color-mix(in srgb, var(--ink) 7%, var(--surface));--skel-shine:color-mix(in srgb, var(--ink) 14%, var(--surface));background:linear-gradient(90deg, var(--skel-base) 0%, var(--skel-shine) 50%, var(--skel-base) 100%);background-size:200% 100%;border-radius:6px;animation:1.4s ease-in-out infinite skel-shimmer;display:block}@keyframes skel-shimmer{0%{background-position:-150% 0}to{background-position:150% 0}}@media (prefers-reduced-motion:reduce){.skel{animation:none}}.skel-line{border-radius:6px;width:100%;height:12px}.skel-line-sm{height:10px}.skel-line-lg{height:16px}.skel-pill{border-radius:999px;height:22px}.skel-circle{border-radius:50%}.skel-block{width:100%}.skel-text-block{flex-direction:column;gap:8px;display:flex}.skel-page{flex-direction:column;gap:18px;padding:24px 28px 60px;display:flex}@media (max-width:760px){.skel-page{gap:14px;padding:20px 16px 48px}}.skel-head{flex-direction:column;gap:10px;padding-bottom:4px;display:flex}.skel-head .skel-title{border-radius:8px;width:clamp(160px,32%,280px);height:26px}.skel-head .skel-sub{border-radius:6px;width:clamp(220px,52%,460px);height:13px}.skel-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.skel-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:12px;min-height:160px;padding:16px;display:flex}.skel-card .skel-card-head{align-items:center;gap:12px;display:flex}.skel-card .skel-card-icon{border-radius:10px;flex:0 0 38px;width:38px;height:38px}.skel-card .skel-card-text{flex-direction:column;flex:1;gap:6px;display:flex}.skel-card .skel-card-title{width:70%;height:14px}.skel-card .skel-card-meta{width:42%;height:10px}.skel-card .skel-card-bar{border-radius:999px;width:100%;height:6px;margin-top:2px}.skel-card .skel-card-actions{gap:8px;margin-top:auto;display:flex}.skel-card .skel-card-btn{border-radius:8px;flex:1;height:32px}.skel-card .skel-card-btn.is-ghost{flex:0 0 38px}.skel-rows{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden}.skel-row{border-bottom:1px solid var(--border-soft);align-items:center;gap:14px;padding:14px 18px;display:flex}.skel-row:last-child{border-bottom:0}.skel-row .skel-row-tag{border-radius:6px;flex:0 0 22px;width:22px;height:22px}.skel-row .skel-row-title{width:38%;height:12px}.skel-row .skel-row-meta{width:14%;height:10px}.skel-row .skel-row-spacer{flex:1}.skel-row .skel-row-pill{border-radius:999px;width:80px;height:22px}.skel-row .skel-row-cta{border-radius:8px;width:92px;height:32px}@media (max-width:760px){.skel-row{gap:10px;padding:12px 14px}.skel-row .skel-row-meta{display:none}.skel-row .skel-row-pill{width:56px}.skel-row .skel-row-cta{width:64px}}.skel-detail{flex-direction:column;gap:22px;max-width:980px;margin:0 auto;padding:24px 28px 60px;display:flex}@media (max-width:760px){.skel-detail{gap:16px;padding:18px 16px 44px}}.skel-detail .skel-back{border-radius:8px;width:110px;height:30px}.skel-detail .skel-hero{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:12px;padding:20px;display:flex}.skel-detail .skel-hero .skel-hero-top{align-items:center;gap:14px;display:flex}.skel-detail .skel-hero .skel-hero-logo{border-radius:10px;flex:0 0 44px;width:44px;height:44px}.skel-detail .skel-hero .skel-hero-title{width:38%;height:20px}.skel-detail .skel-hero .skel-hero-sub{width:28%;height:12px}.skel-detail .skel-hero-pills{flex-wrap:wrap;gap:8px;display:flex}.skel-detail .skel-hero-pills .skel-pill{width:80px}.skel-detail .skel-body{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;padding:20px;display:flex}.skel-detail .skel-body .skel-line:first-child{width:86%}.skel-detail .skel-body .skel-line:nth-child(2){width:96%}.skel-detail .skel-body .skel-line:nth-child(3){width:78%}.skel-detail .skel-body .skel-line:nth-child(4){width:92%}.skel-detail .skel-body .skel-line:nth-child(5){width:64%}.skel-notes-content{flex-direction:column;width:100%;display:flex}.skel-notes-topbar{justify-content:space-between;align-items:center;gap:10px;min-width:0;margin-bottom:12px;display:flex}.skel-notes-topbar .skel-eyebrow{border-radius:4px;width:clamp(160px,48%,340px);height:11px}.skel-notes-topbar .skel-syllabus-btn{border-radius:6px;flex-shrink:0;width:88px;height:32px;display:none}@media (max-width:960px){.skel-notes-topbar .skel-syllabus-btn{display:block}}.skel-notes-actions{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;margin:0 0 24px;padding:0 0 18px;display:flex}.skel-notes-actions .skel-action-btn{border-radius:6px;width:104px;height:34px}.skel-notes-actions .skel-action-btn.is-primary{width:112px}.skel-notes-actions .skel-action-btn:nth-child(3){width:96px}.skel-notes-article{flex-direction:column;gap:10px;display:flex}.skel-notes-article .skel-title{border-radius:8px;width:min(74%,520px);height:32px;margin-bottom:4px}.skel-notes-article .skel-line:first-of-type{width:98%}.skel-notes-article .skel-line:nth-of-type(2){width:94%}.skel-notes-article .skel-line:nth-of-type(3){width:88%}.skel-notes-article .skel-line.is-short{width:62%}.skel-notes-article .skel-code-block{--skel-base:#18181b;--skel-shine:#27272a;border:1px solid #2d2d33;border-radius:8px;width:100%;height:168px;margin:6px 0 10px}.skel-notes-article .skel-line:nth-of-type(5){width:91%}.skel-notes-article .skel-line:nth-of-type(6){width:85%}.skel-notes-article .skel-line:nth-of-type(7){width:58%}.skel-notes-complete{border:1px solid var(--border);background:linear-gradient(180deg, var(--surface), var(--surface-2));border-radius:14px;justify-content:space-between;align-items:center;gap:16px;margin:28px 0 24px;padding:16px 18px;display:flex}.skel-notes-complete-text{flex-direction:column;flex:auto;gap:8px;min-width:0;display:flex}.skel-notes-complete .skel-complete-eyebrow{border-radius:4px;width:120px;height:10px}.skel-notes-complete .skel-complete-title{border-radius:6px;width:min(70%,280px);height:14px}.skel-notes-complete .skel-complete-btn{border-radius:999px;flex-shrink:0;width:148px;height:40px}.skel-notes-pagenav{border-top:1px solid var(--border);margin-top:40px;padding-top:20px}.skel-notes-pagenav .skel-pagenav-count{border-radius:4px;width:108px;height:10px;margin-bottom:10px}.skel-notes-pagenav-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (max-width:600px){.skel-notes-pagenav-row{grid-template-columns:1fr}.skel-notes-pagenav-row .skel-pagenav-btn.is-next{display:none}}.skel-notes-pagenav-row .skel-pagenav-btn{border:1px solid var(--border);background:var(--surface);border-radius:8px;height:56px}.skel-sidebar .skel-sidebar-topic{border-radius:6px;width:68%;height:14px}.skel-sidebar .skel-sidebar-count{border-radius:4px;flex-shrink:0;width:28px;height:10px}.skel-sidebar-link{border-radius:5px;align-items:center;gap:9px;padding:6px 10px;display:flex}.skel-sidebar-link.is-active{background:var(--accent-soft)}.skel-sidebar-link .skel-nav-num{border-radius:4px;flex-shrink:0;width:18px;height:18px}.skel-sidebar-link .skel-nav-text{border-radius:4px;flex:auto;max-width:88%;height:11px}.skel-sidebar .nav-children .nav-item:first-child .skel-nav-text{max-width:82%}.skel-sidebar .nav-children .nav-item:nth-child(2) .skel-nav-text{max-width:74%}.skel-sidebar .nav-children .nav-item:nth-child(3) .skel-nav-text{max-width:88%}.skel-sidebar .nav-children .nav-item:nth-child(4) .skel-nav-text{max-width:66%}.skel-sidebar .nav-children .nav-item:nth-child(5) .skel-nav-text{max-width:78%}.skel-sidebar .nav-children .nav-item:nth-child(6) .skel-nav-text{max-width:70%}.skel-sidebar .nav-children .nav-item:nth-child(7) .skel-nav-text{max-width:84%}.skel-sidebar .nav-children .nav-item:nth-child(8) .skel-nav-text{max-width:62%}@media (max-width:760px){.skel-notes-complete{flex-direction:column;align-items:stretch;gap:12px}.skel-notes-complete .skel-complete-btn{width:100%;height:44px}.skel-notes-actions .skel-action-btn{flex:calc(50% - 4px);min-width:0}}.skel-dash{flex-direction:column;gap:18px;padding:24px 28px 60px;display:flex}@media (max-width:760px){.skel-dash{gap:14px;padding:20px 16px 44px}}.skel-dash .skel-hero-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:12px;padding:22px;display:flex}.skel-dash .skel-hero-card .skel-h{width:44%;height:26px}.skel-dash .skel-hero-card .skel-line{width:64%;height:12px}.skel-dash .skel-hero-card .skel-line+.skel-line{width:38%}.skel-dash .skel-stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;display:grid}.skel-dash .skel-stat{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:8px;padding:14px;display:flex}.skel-dash .skel-stat .skel-stat-icon{border-radius:8px;width:32px;height:32px}.skel-dash .skel-stat .skel-stat-value{width:56%;height:22px}.skel-dash .skel-stat .skel-stat-label{width:72%;height:10px}.skel-verify{justify-content:center;align-items:center;padding:60px 24px;display:flex}.skel-verify-card{background:var(--surface);border:1px solid var(--border);min-width:280px;box-shadow:0 12px 30px -22px color-mix(in srgb, var(--ink) 40%, transparent);border-radius:14px;align-items:center;gap:14px;padding:22px 24px;display:flex}.skel-spinner{border:2px solid color-mix(in srgb, var(--ink) 18%, transparent);border-top-color:color-mix(in srgb, var(--ink) 64%, transparent);border-radius:50%;flex:0 0 18px;width:18px;height:18px;animation:.8s linear infinite skel-spin}@keyframes skel-spin{to{transform:rotate(360deg)}}.skel-verify-text{flex-direction:column;gap:4px;display:flex}.skel-verify-text .t1{color:var(--ink);font-size:14px;font-weight:600}.skel-verify-text .t2{color:var(--ink-2);font-size:12px}.prob-page{flex-direction:column;gap:18px;padding:24px 28px 60px;display:flex}@media (max-width:760px){.prob-page{gap:14px;padding:20px 16px 48px}}.prob-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:14px;display:flex}.prob-h1{letter-spacing:-.025em;color:var(--ink);margin:0 0 4px;font-size:28px;font-weight:700}.prob-sub{color:var(--muted);font-size:13px;font-family:var(--mono)}.prob-head-actions{gap:8px;display:flex}.prob-cta-btn{border:1px solid var(--border);background:var(--surface);color:var(--ink);cursor:pointer;border-radius:8px;align-items:center;gap:7px;padding:8px 14px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.prob-cta-btn.ghost:hover{border-color:var(--border-strong);background:var(--surface-2)}.prob-cta-btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.prob-cta-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.prob-filterbar{border:1px solid var(--border);background:var(--surface);border-radius:12px;flex-wrap:wrap;align-items:center;gap:16px 22px;padding:10px 14px;display:flex}.prob-fgroup{align-items:center;gap:6px;display:inline-flex}.prob-flabel{color:var(--muted);margin-right:4px;font-size:12.5px}.prob-pill{height:26px;color:var(--ink-2);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;padding:0 11px;font-size:12.5px;font-weight:500;transition:background .1s,color .1s;display:inline-flex}.prob-pill:hover{background:var(--surface-2);color:var(--ink)}.prob-pill.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}.prob-pill-easy.active{background:var(--easy);color:var(--accent-ink);border-color:var(--easy)}.prob-pill-medium.active{background:var(--medium);color:var(--accent-ink);border-color:var(--medium)}.prob-pill-hard.active{background:var(--hard);color:var(--accent-ink);border-color:var(--hard)}.prob-pill-easy{color:var(--easy)}.prob-pill-medium{color:var(--medium)}.prob-pill-hard{color:var(--hard)}.prob-select{border:1px solid var(--border);background:var(--surface);height:28px;color:var(--ink);cursor:pointer;border-radius:7px;padding:0 26px 0 10px;font-family:inherit;font-size:12.5px}.cs-select{border:1px solid var(--border);background:var(--surface);height:32px;color:var(--ink);font:500 12.5px var(--sans);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:0 10px 0 12px;transition:border-color .12s,box-shadow .12s,background .12s;display:inline-flex}.cs-select:hover{border-color:var(--border-strong);background:var(--surface-2)}.cs-select[data-cs-open=true]{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-soft)}.cs-select-label{text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.cs-select-chev{color:var(--muted);flex-shrink:0;transition:transform .18s,color .12s}.cs-select[data-cs-open=true] .cs-select-chev{color:var(--accent);transform:rotate(180deg)}.cs-menu{z-index:220;background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:2px;max-width:320px;padding:4px;animation:.14s both csIn;display:flex;position:fixed;box-shadow:0 14px 40px #0000002e,0 2px 6px #0000000f}@keyframes csIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cs-menu-search{border-bottom:1px solid var(--border-soft);color:var(--muted);align-items:center;gap:6px;margin-bottom:4px;padding:6px 8px;display:flex}.cs-menu-search svg{flex-shrink:0}.cs-menu-search input{font:13px var(--sans);color:var(--ink);background:0 0;border:0;outline:0;flex:1;min-width:120px}.cs-menu-search input::placeholder{color:var(--muted-2)}.cs-menu-list{flex-direction:column;gap:1px;max-height:320px;padding:2px;display:flex;overflow-y:auto}.cs-menu-list::-webkit-scrollbar{width:8px}.cs-menu-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:8px}.cs-menu-item{color:var(--ink);font:500 13px var(--sans);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:7px;justify-content:space-between;align-items:center;gap:8px;padding:7px 10px;transition:background .1s,color .1s;display:flex}.cs-menu-item:hover{background:var(--surface-2)}.cs-menu-item.selected{background:var(--accent-soft);color:var(--accent)}.cs-menu-item-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.cs-menu-check{color:var(--accent);flex-shrink:0}.cs-menu-empty{text-align:center;color:var(--muted);padding:14px 10px;font-size:12.5px}.prob-search{border:1px solid var(--border);background:var(--surface);min-width:240px;height:32px;color:var(--muted);border-radius:8px;align-items:center;gap:6px;margin-left:auto;padding:0 10px;display:inline-flex}.prob-search:focus-within{border-color:var(--accent);color:var(--ink);box-shadow:0 0 0 3px var(--accent-soft)}.prob-search input{font:13px var(--sans);color:var(--ink);background:0 0;border:0;outline:0;flex:1}.prob-search input::placeholder{color:var(--muted-2)}.prob-table{border:1px solid var(--border);background:var(--surface);border-radius:12px;overflow:hidden}.prob-thead,.prob-row{grid-template-columns:44px minmax(0,1fr) 130px 140px;align-items:center;gap:14px;padding:12px 18px;display:grid}.prob-actions{justify-content:flex-end;align-items:center;gap:6px;display:inline-flex}.prob-viz-empty{width:28px;height:1px;display:inline-block}.prob-thead{color:var(--muted);letter-spacing:.05em;border-bottom:1px solid var(--border);background:var(--surface-2);font-size:11px;font-weight:600}.prob-row{border-bottom:1px solid var(--border-soft);color:var(--ink);cursor:pointer;font-size:13.5px;transition:background .1s}.prob-row:hover{background:var(--surface-2)}.prob-row:last-child{border-bottom:0}.prob-num{justify-content:flex-start;align-items:center;display:flex}.prob-title-cell{flex-direction:column;gap:4px;min-width:0;display:flex}.prob-title{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:13.5px;font-weight:500;overflow:hidden}.prob-tags{flex-wrap:wrap;gap:6px;display:flex}.prob-tag{font-family:var(--mono);background:var(--surface-2);color:var(--muted);border-radius:4px;padding:1.5px 6px;font-size:10.5px}.prob-diff{font-size:12.5px;font-weight:500}.prob-diff-easy{color:var(--easy)}.prob-diff-medium{color:var(--medium)}.prob-diff-hard{color:var(--hard)}.prob-go{border:1px solid var(--border);background:var(--surface);width:28px;height:28px;color:var(--muted);cursor:pointer;border-radius:7px;place-items:center;padding:0;transition:color .1s,border-color .1s,background .1s;display:inline-grid}.prob-viz-btn{border:1px solid var(--accent);background:var(--accent);height:28px;color:var(--surface);cursor:pointer;border-radius:7px;align-items:center;gap:6px;padding:0 10px;font-size:11.5px;font-weight:600;transition:opacity .15s;display:inline-flex}.prob-viz-icon{display:none}.prob-go:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.prob-viz-btn:hover{opacity:.85}.prob-viz-menu{z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:1px;min-width:200px;max-width:280px;padding:6px;animation:.14s both fadeUp;display:flex;position:fixed;box-shadow:0 12px 32px #0000002e}.prob-viz-menu-head{letter-spacing:.05em;color:var(--muted);text-transform:uppercase;padding:6px 8px 4px;font-size:10.5px;font-weight:600}.prob-viz-item{color:var(--ink);border-radius:7px;justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .1s,color .1s;display:flex}.prob-viz-item:hover{background:var(--accent-soft);color:var(--accent)}.prob-viz-item-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.prob-empty{text-align:center;color:var(--muted);padding:36px 16px;font-size:13px}.prob-pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding-top:4px;display:flex}.prob-page-info{color:var(--muted);font-size:12.5px;font-family:var(--mono)}.prob-page-nav{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.prob-page-btn{border:1px solid var(--border);background:var(--surface);min-width:32px;height:32px;color:var(--ink-2);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;gap:5px;padding:0 9px;font-size:12.5px;font-weight:500;transition:background .1s,border-color .1s,color .1s;display:inline-flex}.prob-page-btn:hover:not(:disabled){border-color:var(--border-strong);background:var(--surface-2);color:var(--ink)}.prob-page-btn.active{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.prob-page-btn:disabled{opacity:.4;cursor:not-allowed}.prob-page-btn.nav{padding:0 11px}.prob-page-ellipsis{color:var(--muted);align-items:center;padding:0 4px;font-size:13px;display:inline-flex}@media (max-width:760px){.prob-thead,.prob-row{grid-template-columns:36px minmax(0,1fr) 70px;gap:10px;padding:10px 12px}.prob-diff,.prob-thead>span:nth-child(3){display:none}.prob-search{flex:100%;min-width:0;margin-left:0}.prob-page-btn{min-width:30px;height:30px;font-size:12px}.prob-pagination{justify-content:center}.prob-viz-text{display:none}.prob-viz-icon{display:block}.prob-viz-btn{justify-content:center;width:28px;padding:0}}.co-back{border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;border-radius:8px;align-self:flex-start;align-items:center;gap:6px;margin-bottom:4px;padding:6px 10px 6px 8px;font-size:12.5px;transition:color .12s,border-color .12s,background .12s;display:inline-flex}.co-back:hover{color:var(--ink);border-color:var(--border-strong);background:var(--surface-2)}.co-hero{align-items:center;gap:16px;padding-bottom:4px;display:flex}.co-hero-body{flex-direction:column;gap:4px;display:flex}.co-hero .prob-h1{margin:0}.co-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.co-card{border:1px solid var(--border);background:var(--surface);text-align:left;cursor:pointer;font:inherit;color:inherit;border-radius:12px;align-items:center;gap:12px;padding:14px;transition:border-color .12s,transform .12s,box-shadow .12s;display:flex;position:relative}.co-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 6px 18px #0000000f}.co-card.is-locked{border-color:color-mix(in srgb, var(--premium) 28%, var(--border));background:linear-gradient(180deg, color-mix(in srgb, var(--premium-soft) 55%, var(--surface)) 0%, var(--surface) 70%)}.co-card.is-locked:hover{border-color:var(--premium);box-shadow:0 6px 18px color-mix(in srgb, var(--premium) 18%, transparent)}.co-card.is-locked .co-card-go{background:var(--premium-soft);border:1px solid color-mix(in srgb, var(--premium) 36%, transparent);width:28px;height:28px;color:var(--premium);border-radius:50%;justify-content:center;align-items:center}.co-card.is-locked .co-card-go svg{width:13px;height:13px}.co-card.is-locked .co-card-name{color:color-mix(in srgb, var(--ink) 72%, transparent)}.co-card.is-locked .topic-card-lock{display:none}.co-card-body{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.co-card-name{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.co-card-meta{color:var(--muted);font-size:12px;font-family:var(--mono)}.co-card-go{color:var(--muted-2);display:inline-flex}.co-card:hover .co-card-go{color:var(--accent)}.co-logo{object-fit:contain;background:var(--surface-2);border:1px solid var(--border-soft);border-radius:10px;flex-shrink:0;width:44px;height:44px;padding:4px}.co-logo-fallback{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft);place-items:center;padding:0;font-size:13px;font-weight:600;display:inline-grid}.prob-cta-btn.ghost.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.cp-detail{flex-direction:column;gap:20px;padding:24px 28px 60px;display:flex}@media (max-width:760px){.cp-detail{padding:20px 16px 48px}}.cp-detail-head{flex-direction:column;gap:10px;display:flex}.cp-detail-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.cp-detail-title{letter-spacing:-.02em;color:var(--ink);margin:0;font-size:26px;font-weight:700}.cp-section{flex-direction:column;gap:8px;padding-top:4px;display:flex}.cp-section-h{letter-spacing:.06em;color:var(--muted);text-transform:uppercase;margin:0;font-size:11px;font-weight:600}.cp-html-body{color:var(--ink);font-size:14px;line-height:1.65}.cp-html-body h1,.cp-html-body h2,.cp-html-body h3,.cp-html-body h4,.cp-html-body h5{color:var(--ink);margin:14px 0 6px;font-weight:600}.cp-html-body h4{color:var(--ink-2);font-size:14.5px;font-weight:500;line-height:1.55}.cp-html-body h5{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:16px;font-size:12px}.cp-html-body p{margin:8px 0}.cp-html-body ul,.cp-html-body ol{margin:8px 0;padding-left:22px}.cp-html-body li{margin:4px 0}.cp-html-body code{font-family:var(--mono);background:var(--surface-2);color:var(--ink);border-radius:5px;padding:1.5px 6px;font-size:12.5px}.cp-html-body pre{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;margin:10px 0;padding:12px 14px;overflow-x:auto}.cp-html-body pre code{color:var(--ink);white-space:pre;background:0 0;padding:0;font-size:12.5px}.cp-html-body img{border-radius:8px;max-width:100%;height:auto;margin:8px 0}.cp-html-body strong{color:var(--ink)}.cp-html-body em{color:var(--ink-2)}.cp-asked-by{flex-wrap:wrap;gap:8px;display:flex}.cp-chip{background:var(--surface-2);border:1px solid var(--border-soft);color:var(--ink-2);border-radius:999px;align-items:center;gap:6px;padding:4px 10px 4px 4px;font-size:12px;display:inline-flex}.cp-chip .co-logo{background:var(--surface);border:0;width:20px;height:20px;padding:2px}.iv-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;display:grid}.iv-card{text-align:left;background:var(--surface);border:1px solid var(--border);cursor:pointer;font:inherit;color:inherit;border-radius:12px;flex-direction:column;gap:10px;padding:16px;transition:border-color .12s,transform .12s,box-shadow .12s;display:flex;position:relative}.iv-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 6px 18px #0000000f}.iv-card.is-locked{border-color:color-mix(in srgb, var(--premium) 28%, var(--border));background:linear-gradient(180deg, color-mix(in srgb, var(--premium-soft) 55%, var(--surface)) 0%, var(--surface) 70%)}.iv-card.is-locked:hover{border-color:var(--premium);box-shadow:0 6px 18px color-mix(in srgb, var(--premium) 18%, transparent)}.iv-card.is-locked .iv-card-top{padding-right:36px}.iv-card.is-locked .iv-card-title,.iv-card.is-locked .iv-card-meta,.iv-card.is-locked .iv-card-stats{color:color-mix(in srgb, var(--ink) 70%, transparent)}.iv-card-top{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.iv-card-title{color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:14.5px;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.iv-card-meta{color:var(--muted);flex-direction:column;gap:3px;font-size:12.5px;display:flex}.iv-card-meta strong{color:var(--ink-2);font-weight:600}.iv-card-stats{color:var(--muted);font-size:11.5px;font-family:var(--mono);border-top:1px solid var(--border-soft);flex-wrap:wrap;gap:14px;padding-top:10px;display:flex}.iv-card-stats strong{color:var(--ink);font-weight:600}.iv-outcome{letter-spacing:.02em;text-transform:uppercase;border-radius:999px;align-items:center;padding:2.5px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.iv-outcome-good{background:color-mix(in srgb, var(--easy) 18%, transparent);color:var(--easy)}.iv-outcome-bad{background:color-mix(in srgb, var(--hard) 18%, transparent);color:var(--hard)}.iv-outcome-neutral{background:var(--surface-2);color:var(--muted);border:1px solid var(--border)}.iv-pill{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--border-soft);border-radius:999px;padding:2.5px 9px;font-size:11.5px}.iv-pill.subtle{color:var(--muted)}.iv-date{color:var(--muted);font-size:11.5px;font-family:var(--mono);margin-left:auto}.iv-detail{flex-direction:column;gap:22px;padding:24px 28px 60px;display:flex}@media (max-width:760px){.iv-detail{gap:18px;padding:20px 16px 48px}}.iv-detail-head{border:1px solid var(--border);background:linear-gradient(135deg, var(--surface) 0%, var(--surface-2) 100%);border-radius:14px;flex-direction:column;gap:14px;padding:22px;display:flex}.iv-detail-head-top{align-items:center;gap:14px;display:flex}.iv-detail-company{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:2px;font-size:12px;font-weight:600}.iv-detail-title{letter-spacing:-.02em;color:var(--ink);margin:0;font-size:22px;font-weight:700;line-height:1.3}.iv-detail-tags{flex-wrap:wrap;gap:8px;display:flex}.iv-detail-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px 18px;margin:4px 0 0;display:grid}.iv-detail-grid>div{flex-direction:column;gap:1px;display:flex}.iv-detail-grid dt{letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:600}.iv-detail-grid dd{color:var(--ink);margin:0;font-size:13px}.iv-section{flex-direction:column;gap:10px;display:flex}.iv-section h2{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0;font-size:13px;font-weight:700}.iv-paragraph{color:var(--ink);margin:0;font-size:14px;line-height:1.6}.iv-paragraph.subtle{color:var(--ink-2)}.iv-paragraph strong{color:var(--ink)}.iv-rounds{flex-direction:column;gap:10px;display:flex}.iv-round{border:1px solid var(--border);background:var(--surface);border-radius:10px;grid-template-columns:36px 1fr;gap:14px;padding:14px;display:grid}.iv-round-num{background:var(--accent-soft);width:36px;height:36px;color:var(--accent);border-radius:8px;place-items:center;font-size:14px;font-weight:700;display:grid}.iv-round-body{flex-direction:column;gap:6px;display:flex}.iv-round-head{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.iv-round-head h4{color:var(--ink);margin:0;font-size:14.5px;font-weight:600}.iv-round-meta{color:var(--muted);flex-wrap:wrap;gap:14px;font-size:12.5px;display:flex}.iv-problems{flex-direction:column;gap:14px;display:flex}.iv-problem{border:1px solid var(--border);background:var(--surface);border-radius:12px;flex-direction:column;gap:10px;padding:16px;display:flex}.iv-problem-head{align-items:flex-start;gap:12px;display:flex}.iv-problem-num{background:var(--accent-soft);width:36px;height:36px;color:var(--accent);font-size:12.5px;font-weight:700;font-family:var(--mono);border-radius:8px;flex-shrink:0;place-items:center;display:grid}.iv-problem-title{color:var(--ink);margin:0 0 4px;font-size:15px;font-weight:600;line-height:1.4}.iv-problem-details{border-top:1px solid var(--border-soft);margin-top:4px;padding-top:10px}.iv-problem-details>summary{cursor:pointer;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);align-items:center;gap:6px;padding:4px 0;font-size:12px;font-weight:600;list-style:none;display:flex}.iv-problem-details>summary::-webkit-details-marker{display:none}.iv-problem-details>summary:before{content:"▸";color:var(--muted-2);transition:transform .15s;display:inline-block}.iv-problem-details[open]>summary:before{transform:rotate(90deg)}.iv-problem-details>summary:hover{color:var(--ink)}.iv-problem-details>div{padding-top:8px}@keyframes fadeUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.22s both fadeUp}@keyframes spin{to{transform:rotate(360deg)}}.brand-mark-img{background:0 0;border-radius:8px;place-items:center;width:28px;height:28px;display:grid;overflow:hidden}.brand-mark-img img{object-fit:contain;width:100%;height:100%;display:block}.dash-shell{flex-direction:column;gap:clamp(36px,5vw,52px);width:100%;max-width:1320px;margin:0 auto;padding:20px clamp(16px,3vw,28px) 64px;display:flex}.dash-shell-slim{gap:clamp(28px,4vw,40px)}.dash-page-head{flex-direction:column;gap:12px;max-width:880px;padding:4px 2px 0;display:flex}.dash-page-title{letter-spacing:-.02em;text-wrap:balance;color:var(--ink);margin:0;font-size:clamp(28px,3.6vw,40px);font-weight:800;line-height:1.12}.dash-page-sub{color:var(--ink-2);text-wrap:pretty;max-width:70ch;margin:0;font-size:clamp(14px,1.3vw,16px)}.dash-section-flush{gap:16px}.dash-link{color:var(--accent);border-bottom:1px dashed color-mix(in srgb, var(--accent) 50%, transparent);font-weight:600;text-decoration:none}.dash-link:hover{border-bottom-style:solid}.dash-welcome{flex-direction:column;gap:8px;margin-top:2px;padding:4px 4px 0;display:flex}.dash-welcome-greet{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);align-items:center;gap:9px;margin:0;font-size:clamp(12px,1vw,13px);font-weight:600;display:inline-flex}.dash-welcome-dot{background:var(--accent);width:7px;height:7px;box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent);border-radius:50%;flex-shrink:0;animation:2.4s ease-in-out infinite dashDotPulse;display:inline-block}@keyframes dashDotPulse{0%,to{box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent)}50%{box-shadow:0 0 0 7px color-mix(in srgb, var(--accent) 6%, transparent)}}.dash-welcome-title{letter-spacing:-.02em;color:var(--ink);text-wrap:balance;margin:0;font-size:clamp(22px,2.4vw,32px);font-weight:600;line-height:1.15}.dash-welcome-name{background:linear-gradient(120deg, var(--accent) 0%, color-mix(in srgb, var(--accent) 55%, var(--ink)) 100%);color:#0000;-webkit-background-clip:text;background-clip:text;padding:0 2px 6px;font-weight:800;display:inline-block;position:relative}.dash-welcome-wave{width:calc(100% - 4px);height:6px;color:color-mix(in srgb, var(--accent) 75%, transparent);pointer-events:none;position:absolute;bottom:0;left:2px;right:2px;overflow:visible}.dash-welcome-wave path{stroke-dasharray:240;stroke-dashoffset:240px;animation:1.2s cubic-bezier(.4,0,.2,1) .25s forwards dashWaveDraw}@keyframes dashWaveDraw{to{stroke-dashoffset:0}}@media (prefers-reduced-motion:reduce){.dash-welcome-dot{animation:none}.dash-welcome-wave path{stroke-dashoffset:0;animation:none}}.dash-quickrow{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}@media (max-width:940px){.dash-quickrow{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.dash-qpill-text{grid-column:1/-1}}@media (max-width:360px){.dash-quickrow{grid-template-columns:1fr;gap:10px}.dash-qpill-text{grid-column:auto}}.dash-qpill{--t:var(--accent);border:1px solid color-mix(in srgb, var(--t) 22%, var(--border));background:radial-gradient(120% 100% at 0% 0%, color-mix(in srgb, var(--t) 12%, transparent), transparent 60%), linear-gradient(180deg, color-mix(in srgb, var(--t) 4%, var(--surface)), var(--surface));cursor:pointer;text-align:left;color:inherit;isolation:isolate;border-radius:20px;flex-direction:column;gap:18px;min-height:132px;padding:20px clamp(18px,2vw,24px);font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s;display:flex;position:relative;overflow:hidden}.dash-qpill:before{content:"";background:radial-gradient(closest-side, color-mix(in srgb, var(--t) 22%, transparent), transparent 70%);pointer-events:none;z-index:0;opacity:.85;border-radius:50%;width:140px;height:140px;position:absolute;top:-40px;right:-40px}.dash-qpill>*{z-index:1;position:relative}.dash-qpill[data-tone=green]{--t:var(--accent)}.dash-qpill[data-tone=amber]{--t:#f59e0b}.dash-qpill[data-tone=blue]{--t:#3b82f6}.dash-qpill[data-tone=violet]{--t:#8b5cf6}.dash-qpill[data-tone=rose]{--t:#f43f5e}.dash-qpill:hover{border-color:color-mix(in srgb, var(--t) 50%, var(--border-strong));box-shadow:0 12px 32px -16px color-mix(in srgb, var(--t) 50%, transparent)}.dash-qpill-head{align-items:center;gap:10px;display:flex}.dash-qpill-ic{background:color-mix(in srgb, var(--t) 18%, var(--surface));border:1px solid color-mix(in srgb, var(--t) 28%, var(--border));width:40px;height:40px;color:var(--t);border-radius:12px;flex-shrink:0;place-items:center;display:grid}.dash-qpill-ic svg{width:20px;height:20px}.dash-qpill-lbl{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);font-size:11.5px;font-weight:700}.dash-qpill-foot{justify-content:space-between;align-items:flex-end;gap:12px;min-width:0;display:flex}.dash-qpill-num{letter-spacing:-.028em;color:var(--ink);align-items:baseline;gap:6px;min-width:0;font-size:clamp(28px,3.4vw,38px);font-weight:800;line-height:1;display:inline-flex}.dash-qpill-num b{font-weight:800}.dash-qpill-num em{color:var(--ink-2);letter-spacing:0;font-size:.42em;font-style:normal;font-weight:600}.dash-qpill-num-text{flex-direction:column;flex:1;align-items:flex-start;gap:4px;min-width:0;display:flex}.dash-qpill-num-text b{letter-spacing:-.01em;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:clamp(15px,1.5vw,18px);font-weight:700;line-height:1.2;display:block;overflow:hidden}.dash-qpill-num-text em{color:var(--ink-2);letter-spacing:.04em;text-transform:capitalize;font-size:11.5px;font-weight:600}.dash-qpill-arrow{background:var(--surface);border:1px solid var(--border);width:38px;height:38px;color:var(--ink);border-radius:50%;flex-shrink:0;place-items:center;transition:transform .2s,background .2s,border-color .2s,color .2s;display:grid}.dash-qpill-arrow svg{width:16px;height:16px}.dash-qpill:hover .dash-qpill-arrow{background:var(--t);border-color:var(--t);color:#fff;transform:translate(2px,-2px)rotate(-8deg)}@media (max-width:600px){.dash-qpill{border-radius:16px;gap:14px;min-height:auto;padding:14px}.dash-qpill:before{width:110px;height:110px;top:-30px;right:-30px}.dash-qpill-ic{border-radius:10px;width:34px;height:34px}.dash-qpill-ic svg{width:17px;height:17px}.dash-qpill-lbl{letter-spacing:.07em;font-size:9.5px}.dash-qpill-num{gap:4px;font-size:24px}.dash-qpill-num em{font-size:.46em}.dash-qpill-num-text b{font-size:13px}.dash-qpill-num-text em{font-size:10.5px}.dash-qpill-arrow{width:32px;height:32px}.dash-qpill-arrow svg{width:13px;height:13px}}@media (max-width:420px){.dash-qpill{gap:12px;padding:12px}.dash-qpill-head{gap:8px}.dash-qpill-ic{border-radius:9px;width:30px;height:30px}.dash-qpill-ic svg{width:15px;height:15px}.dash-qpill-lbl{font-size:9px}.dash-qpill-num{font-size:21px}.dash-qpill-num-text b{font-size:12.5px}.dash-qpill-arrow{width:28px;height:28px}.dash-qpill-arrow svg{width:12px;height:12px}}.dash-last-empty-block{border:1px dashed var(--border);background:var(--surface);border-radius:16px;flex-direction:column;align-items:flex-start;gap:14px;padding:clamp(20px,3vw,28px);display:flex}.dash-last-empty-block p{color:var(--ink-2);margin:0}.dash-empty-msg{color:var(--ink-2);margin:0;padding:14px 0 4px;font-size:14px}.dash-eyebrow,.dash-eyebrow-sm{letter-spacing:.06em;text-transform:uppercase;border-radius:999px;align-items:center;gap:7px;width:fit-content;padding:5px 11px 5px 8px;font-size:11px;font-weight:700;display:inline-flex}.dash-eyebrow{background:color-mix(in srgb, var(--accent) 10%, var(--surface));border:1px solid color-mix(in srgb, var(--accent) 30%, var(--border));color:var(--accent)}.dash-eyebrow-sm{background:var(--surface-2);border:1px solid var(--border);color:var(--ink-2)}.dash-eyebrow svg,.dash-eyebrow-sm svg{width:12px;height:12px}.dash-eyebrow-ic{place-items:center;display:inline-grid}.dash-info-btn{width:16px;height:16px;color:color-mix(in srgb, var(--ink) 45%, transparent);cursor:help;background:0 0;border:0;border-radius:50%;justify-content:center;align-items:center;margin-left:2px;padding:0;display:inline-flex;position:relative}.dash-info-btn:hover,.dash-info-btn:focus-visible{color:var(--ink);outline:none}.dash-info-btn svg{width:12px;height:12px;display:block}.dash-info-tip{background:var(--ink);width:220px;color:var(--bg);letter-spacing:normal;text-transform:none;text-align:left;white-space:normal;opacity:0;pointer-events:none;z-index:30;box-shadow:0 10px 28px -16px color-mix(in srgb, var(--ink) 80%, transparent);border-radius:8px;flex-direction:column;gap:3px;padding:9px 11px;font-size:11.5px;font-weight:500;line-height:1.4;transition:opacity .14s,transform .14s;display:flex;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(2px)}.dash-info-tip strong{font-size:11.5px;font-weight:700}.dash-info-tip b{font-weight:700}.dash-info-tip:before{content:"";border:5px solid #0000;border-bottom-color:var(--ink);width:0;height:0;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.dash-info-btn:hover .dash-info-tip,.dash-info-btn:focus-visible .dash-info-tip{opacity:1;transform:translate(-50%)translateY(0)}@media (max-width:540px){.dash-info-tip{width:180px;left:auto;right:-8px;transform:translateY(2px)}.dash-info-tip:before{left:auto;right:12px;transform:none}.dash-info-btn:hover .dash-info-tip,.dash-info-btn:focus-visible .dash-info-tip{transform:translateY(0)}}.dash-hero{border:1px solid var(--border);background:radial-gradient(60% 100% at 100% 0%, color-mix(in srgb, var(--accent) 12%, transparent) 0%, transparent 60%), linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);isolation:isolate;border-radius:22px;position:relative;overflow:hidden}.dash-hero-glow{background:radial-gradient(closest-side, color-mix(in srgb, var(--accent) 45%, transparent), transparent 70%);filter:blur(80px);opacity:.45;pointer-events:none;z-index:0;width:420px;height:420px;position:absolute;top:-140px;right:-100px}.dash-hero-grid{background-image:linear-gradient(to right, color-mix(in srgb, var(--ink) 5%, transparent) 1px, transparent 1px), linear-gradient(to bottom, color-mix(in srgb, var(--ink) 5%, transparent) 1px, transparent 1px);pointer-events:none;z-index:0;opacity:.5;background-size:36px 36px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(70% 80% at 30%,#000 30%,#0000 80%);mask-image:radial-gradient(70% 80% at 30%,#000 30%,#0000 80%)}.dash-hero-inner{z-index:1;grid-template-columns:minmax(0,1fr) minmax(260px,340px);align-items:center;gap:clamp(28px,4vw,40px);padding:clamp(28px,4vw,44px) clamp(24px,4vw,44px);display:grid;position:relative}.dash-hero-left{flex-direction:column;gap:14px;min-width:0;display:flex}.dash-hero-greet{color:var(--muted);letter-spacing:-.005em;margin:0;font-size:clamp(13px,1.4vw,14.5px);font-weight:600}.dash-hero-title{letter-spacing:-.028em;color:var(--ink);text-wrap:balance;max-width:22ch;margin:-4px 0 0;font-size:clamp(26px,3.2vw,38px);font-weight:700;line-height:1.12}.dash-hero-title span{background:linear-gradient(120deg, var(--accent) 0%, var(--accent-hover) 60%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.dash-hero-sub{color:var(--ink-2);text-wrap:pretty;max-width:56ch;margin:0;font-size:clamp(13.5px,1.3vw,15px);line-height:1.6}.dash-hero-sub b{color:var(--ink);font-weight:700}.dash-hero-actions{flex-wrap:wrap;gap:10px;margin-top:6px;display:flex}.dash-hero-right{grid-template-columns:1fr 1fr;align-self:stretch;gap:10px;display:grid}.dash-stat-card{background:color-mix(in srgb, var(--surface) 70%, transparent);border:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:12px;flex-direction:column;justify-content:center;gap:4px;min-height:78px;padding:14px 16px;display:flex}.dash-stat-num{letter-spacing:-.025em;color:var(--ink);font-size:clamp(20px,2.4vw,26px);font-weight:700;line-height:1}.dash-stat-lbl{color:var(--muted);letter-spacing:.07em;text-transform:uppercase;font-size:10.5px;font-weight:700;line-height:1.3}@media (max-width:920px){.dash-hero-inner{grid-template-columns:1fr;gap:24px}.dash-hero-right{grid-template-columns:repeat(4,1fr)}.dash-hero-title{max-width:none}}@media (max-width:560px){.dash-hero-right{grid-template-columns:repeat(2,1fr)}.dash-stat-card{min-height:70px;padding:12px 14px}}.dash-cta{font-family:var(--sans);cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:13.5px;font-weight:600;text-decoration:none;transition:background .18s,color .18s,border-color .18s,box-shadow .18s;display:inline-flex}.dash-cta svg{width:14px;height:14px;transition:transform .2s}.dash-cta:hover svg{transform:translate(3px)}.dash-cta-primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}.dash-cta-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:var(--accent-ink);box-shadow:0 6px 22px color-mix(in srgb, var(--accent) 28%, transparent)}.dash-cta-ghost{background:var(--surface);color:var(--ink);border-color:var(--border-strong)}.dash-cta-ghost:hover{background:var(--surface-2);border-color:var(--ink)}.dash-cta.is-locked{cursor:pointer;border-color:color-mix(in srgb, var(--premium) 36%, transparent);background:var(--premium-soft);color:var(--premium);box-shadow:none}.dash-cta.is-locked:hover{background:color-mix(in srgb, var(--premium) 14%, var(--premium-soft));border-color:var(--premium);color:var(--premium);box-shadow:0 6px 22px color-mix(in srgb, var(--premium) 22%, transparent)}.dash-cta.is-locked svg{width:13px;height:13px;transform:none!important}.dash-cta-primary.is-locked{background:var(--premium);color:#fff;border-color:var(--premium)}.dash-cta-primary.is-locked:hover{filter:brightness(1.06);background:var(--premium);color:#fff;border-color:var(--premium)}.dash-cta-primary.is-locked svg{color:#fff}@media (max-width:480px){.dash-cta{justify-content:center;width:100%}.dash-hero-actions{flex-direction:column;align-items:stretch}}.dash-section{flex-direction:column;gap:18px;scroll-margin-top:78px;display:flex}.dash-section-head{flex-direction:column;align-items:flex-start;gap:6px;display:flex}.dash-section-title{letter-spacing:-.02em;color:var(--ink);text-wrap:balance;max-width:760px;margin:0;font-size:clamp(19px,2vw,23px);font-weight:700;line-height:1.2}.dash-section-sub{color:var(--muted);text-wrap:pretty;max-width:720px;margin:0;font-size:clamp(13px,1.2vw,14px);font-weight:500;line-height:1.5}[data-tone=green]{--t:var(--accent)}[data-tone=blue]{--t:#2563eb}[data-tone=violet]{--t:#7c3aed}[data-tone=amber]{--t:#d97706}[data-tone=rose]{--t:#db2777}[data-tone=teal]{--t:#0d9488}[data-tone=indigo]{--t:#4f46e5}[data-tone=cyan]{--t:#0891b2}[data-tone=slate]{--t:var(--ink-2)}.dash-recent-grid{flex-direction:column;gap:10px;display:flex}.dash-recent{border:1px solid var(--border);background:var(--surface);cursor:pointer;text-align:left;color:inherit;--t:var(--accent);border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:12px 16px;font-family:inherit;transition:border-color .2s;display:grid;position:relative;overflow:hidden}.dash-recent[data-tone=green]{--t:var(--accent)}.dash-recent[data-tone=blue]{--t:#2563eb}.dash-recent[data-tone=violet]{--t:#7c3aed}.dash-recent[data-tone=amber]{--t:#d97706}.dash-recent[data-tone=rose]{--t:#db2777}.dash-recent[data-tone=teal]{--t:#0d9488}.dash-recent[data-tone=indigo]{--t:#4f46e5}.dash-recent[data-tone=cyan]{--t:#0891b2}.dash-recent[data-tone=slate]{--t:var(--ink-2)}.dash-recent:hover{border-color:color-mix(in srgb, var(--t) 55%, var(--border-strong))}.dash-recent-ic{background:color-mix(in srgb, var(--t) 18%, var(--surface));border:1px solid color-mix(in srgb, var(--t) 30%, var(--border));width:38px;height:38px;color:var(--t);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.dash-recent-ic svg{width:18px;height:18px}.dash-recent-content{flex-direction:column;gap:3px;min-width:0;display:flex}.dash-recent-type{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:700}.dash-recent-title{letter-spacing:-.012em;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:14.5px;font-weight:600;line-height:1.35;overflow:hidden}.dash-recent-status{display:none}.dash-recent-status-dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 18%, transparent);border-radius:50%}.dash-recent-suggest .dash-recent-status-dot{border:1.5px solid var(--muted-2);box-shadow:none;background:0 0}.dash-recent-foot{border-top:none;flex-shrink:0;align-items:center;gap:10px;padding-top:0;display:inline-flex}.dash-recent-action{color:var(--muted);letter-spacing:.01em;font-size:12px;font-weight:600;transition:color .2s}.dash-recent:hover .dash-recent-action{color:var(--accent)}.dash-recent-arrow{background:var(--surface-2);border:1px solid var(--border);width:28px;height:28px;color:var(--ink-2);border-radius:999px;flex-shrink:0;place-items:center;transition:background .2s,color .2s,border-color .2s;display:grid}.dash-recent-arrow svg{width:13px;height:13px}.dash-recent:hover .dash-recent-arrow{background:color-mix(in srgb, var(--t) 15%, var(--surface-2));color:var(--t);border-color:color-mix(in srgb, var(--t) 35%, var(--border))}.dash-recent-suggest{background:var(--surface)}@media (max-width:480px){.dash-recent{gap:10px;padding:11px 12px}.dash-recent-ic{border-radius:9px;width:34px;height:34px}.dash-recent-ic svg{width:16px;height:16px}.dash-recent-title{font-size:13.5px}.dash-recent-action{display:none}.dash-recent-type{font-size:9.5px}}.dash-progress-grid{grid-template-columns:minmax(0,1fr) minmax(0,1.2fr) minmax(0,1fr);gap:14px;margin-top:8px;display:grid}.dash-progress-grid-2{grid-template-columns:minmax(0,1fr) minmax(0,1.6fr)}.dash-progress-grid-stacked{grid-template-columns:minmax(0,1fr) minmax(0,1.4fr)}.dash-progress-last{margin-top:14px}@media (max-width:1040px){.dash-progress-grid:not(.dash-progress-grid-stacked):not(.dash-progress-grid-2){grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.dash-progress-grid:not(.dash-progress-grid-stacked):not(.dash-progress-grid-2)>.dash-streak-card{grid-column:1/-1}}@media (max-width:860px){.dash-progress-grid-2{grid-template-columns:1fr}}@media (max-width:760px){.dash-progress-grid,.dash-progress-grid-stacked{grid-template-columns:1fr}}.dash-progress-last .dash-prog-card{flex-flow:wrap;align-items:center;gap:clamp(14px,2vw,20px);padding:14px clamp(14px,1.6vw,18px)}.dash-progress-last .dash-prog-head{border-right:1px solid var(--border);flex:none;margin:0;padding-right:clamp(14px,2vw,22px)}.dash-progress-last .dash-last{flex-direction:row;flex:280px;align-items:center;gap:clamp(10px,1.4vw,16px);min-width:0}.dash-progress-last .dash-last-row{flex:none}.dash-progress-last .dash-last-title{white-space:nowrap;text-overflow:ellipsis;flex:auto;margin:0;font-size:14.5px;overflow:hidden}.dash-progress-last .dash-last-tags{flex:0 auto;margin:0}.dash-progress-last .dash-prog-cta{align-self:center;margin:0}.dash-progress-last .dash-last-empty{flex-flow:wrap;align-items:center;gap:8px}@media (max-width:760px){.dash-progress-last .dash-prog-card{flex-direction:column;align-items:stretch;gap:12px;padding:14px 16px}.dash-progress-last .dash-prog-head{border-right:none;flex:none;padding:0}.dash-progress-last .dash-last{flex-direction:column;flex:none;align-items:flex-start;gap:8px}.dash-progress-last .dash-last-row{width:100%}.dash-progress-last .dash-last-title{white-space:normal;flex:none;width:100%}.dash-progress-last .dash-last-tags{flex-wrap:wrap}.dash-progress-last .dash-prog-cta{justify-content:center;align-self:stretch}}.dash-prog-card{--t:var(--accent);border:1px solid var(--border);background:var(--surface);border-radius:18px;flex-direction:column;gap:14px;min-width:0;padding:clamp(18px,2.4vw,22px);display:flex;position:relative;overflow:hidden}.dash-prog-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.dash-prog-meta{font-family:var(--mono);letter-spacing:.04em;color:var(--muted);font-size:11.5px;font-weight:700}.dash-prog-cta{align-self:flex-start;margin-top:auto}.dash-solved-card{gap:14px;padding:clamp(14px,1.6vw,18px);container:solvedcard/inline-size}.dash-solved-body{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:clamp(14px,2.5vw,24px);padding:4px 2px;display:grid}@media (min-width:721px){@container solvedcard (max-width:380px){.dash-solved-body{grid-template-columns:1fr;justify-items:stretch;gap:14px}.dash-solved-rings{justify-self:center;width:clamp(110px,50%,140px)}.dash-solved-list{width:100%}}}@media (min-width:761px) and (max-width:1100px){.dash-progress-grid-2 .dash-solved-body{grid-template-columns:1fr;justify-items:stretch;gap:14px}.dash-progress-grid-2 .dash-solved-rings{justify-self:center;width:clamp(110px,16vw,140px)}.dash-progress-grid-2 .dash-solved-list{width:100%}}@media (max-width:720px){.dash-solved-body{grid-template-columns:auto minmax(0,1fr)!important;align-items:center!important;gap:14px!important}.dash-solved-rings{justify-self:center!important;width:clamp(100px,26vw,130px)!important}.dash-solved-num{font-size:20px!important}.dash-solved-of{margin-top:1px!important;font-size:10px!important}.dash-solved-list{gap:8px!important;width:100%!important}.dash-solved-item{padding:6px 10px!important}.dash-solved-item-name{font-size:12.5px!important}.dash-solved-item-pct{font-size:10px!important}.dash-solved-item-count{font-size:12px!important}.dash-solved-item-count strong{font-size:13.5px!important}}.dash-solved-rings{aspect-ratio:1;flex-shrink:0;width:clamp(120px,11vw,150px);position:relative}.dash-solved-rings-svg{width:100%;height:100%;display:block}.dash-solved-rings-text{pointer-events:none;text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.dash-solved-num{letter-spacing:-.04em;color:var(--ink);font-feature-settings:"tnum" on, "lnum" on;font-size:clamp(24px,2.6vw,30px);font-weight:800;line-height:1}.dash-solved-of{font-family:var(--mono);color:var(--muted);letter-spacing:.01em;margin-top:4px;font-size:11px;font-weight:500}.dash-solved-list{flex-direction:column;gap:10px;min-width:0;margin:0;padding:0;list-style:none;display:flex}.dash-solved-item{--c:var(--ink);background:var(--surface-2);border-radius:10px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;column-gap:10px;padding:8px 10px;transition:background .2s;display:grid}.dash-solved-item:hover{background:color-mix(in srgb, var(--c) 8%, var(--surface))}.dash-solved-item.dash-diff-easy{--c:#0b996e}.dash-solved-item.dash-diff-medium{--c:#d97706}.dash-solved-item.dash-diff-hard{--c:#dc2626}.dash-solved-item-dot{background:var(--c);width:8px;height:8px;box-shadow:0 0 0 3px color-mix(in srgb, var(--c) 14%, transparent);border-radius:50%;flex-shrink:0}.dash-solved-item-text{flex-direction:column;gap:1px;min-width:0;display:flex}.dash-solved-item-name{color:var(--ink);letter-spacing:-.005em;font-size:13px;font-weight:600;line-height:1.2}.dash-solved-item-pct{font-family:var(--mono);color:var(--c);letter-spacing:.02em;font-size:10.5px;font-weight:500;line-height:1.2}.dash-solved-item-count{font-family:var(--mono);color:var(--muted);white-space:nowrap;font-feature-settings:"tnum" on, "lnum" on;text-align:right;font-size:12.5px}.dash-solved-item-count strong{color:var(--ink);margin-right:1px;font-size:14.5px;font-weight:600}.dash-solved-item-count em{color:var(--muted-2);margin:0 2px;font-style:normal;font-weight:400}@media (max-width:720px){.dash-solved-body{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:14px}.dash-solved-rings{justify-self:center;width:clamp(100px,26vw,130px)}.dash-solved-num{font-size:20px}.dash-solved-of{margin-top:1px;font-size:10px}.dash-solved-list{gap:8px;width:100%}.dash-solved-item{padding:6px 10px}.dash-solved-item-name{font-size:12.5px}.dash-solved-item-pct{font-size:10px}.dash-solved-item-count{font-size:12px}.dash-solved-item-count strong{font-size:13.5px}}@media (max-width:420px){.dash-solved-rings{width:92px}.dash-solved-num{font-size:18px}}.dash-streak-card{gap:14px}.dash-streak-row{flex-wrap:wrap;align-items:stretch;gap:clamp(16px,2.4vw,28px);display:flex}.dash-streak-stat{color:#d97706;align-items:baseline;gap:6px;display:inline-flex}.dash-streak-num{letter-spacing:-.03em;color:#d97706;font-feature-settings:"tnum" on, "lnum" on;font-size:clamp(32px,3.6vw,40px);font-weight:800;line-height:1}.dash-streak-unit{letter-spacing:.04em;text-transform:uppercase;color:#d97706;font-size:12px;font-weight:700}.dash-streak-meta{border-left:1px solid var(--border);flex-direction:column;gap:2px;padding-left:clamp(14px,2vw,22px);display:flex}.dash-streak-meta-num{letter-spacing:-.02em;color:var(--ink);font-feature-settings:"tnum" on, "lnum" on;font-size:clamp(18px,2vw,22px);font-weight:800;line-height:1}.dash-streak-meta-lbl{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:10.5px;font-weight:600}.dash-yr-wrap{flex-direction:column;gap:6px;min-width:0;margin-top:auto;display:flex}.dash-yr-months{grid-template-columns:repeat(var(--yr-cols,53), minmax(0, 1fr));letter-spacing:.06em;color:var(--muted);text-transform:uppercase;height:14px;font-size:9.5px;font-weight:700;display:grid}.dash-yr-month{white-space:nowrap;align-self:end;overflow:hidden}.dash-yr-cells{grid-template-columns:repeat(var(--yr-cols,53), minmax(0, 1fr));grid-template-rows:repeat(7,auto);grid-auto-flow:column;gap:3px;min-width:0;display:grid}.dash-yr-cell-empty{aspect-ratio:1;visibility:hidden}.dash-heat{aspect-ratio:1;background:color-mix(in srgb, var(--ink) 5%, var(--surface));border:1px solid var(--border);border-radius:2px;min-width:0;display:block}.dash-heat[data-lvl="1"]{background:color-mix(in srgb, #d97706 22%, var(--surface-2));border-color:color-mix(in srgb, #d97706 28%, var(--border))}.dash-heat[data-lvl="2"]{background:color-mix(in srgb, #d97706 45%, var(--surface-2));border-color:color-mix(in srgb, #d97706 50%, var(--border))}.dash-heat[data-lvl="3"]{background:color-mix(in srgb, #d97706 70%, var(--surface-2));border-color:color-mix(in srgb, #d97706 72%, var(--border))}.dash-heat[data-lvl="4"]{background:#d97706;border-color:#d97706}.dash-yr-foot{justify-content:flex-end;align-items:center;margin-top:4px;display:flex}.dash-yr-legend{color:var(--muted);letter-spacing:.02em;align-items:center;gap:4px;font-size:10px;display:inline-flex}.dash-yr-legend .dash-heat{aspect-ratio:1;flex-shrink:0;width:10px;height:10px}.dash-yr-legend-lbl{margin:0 4px}@media (max-width:720px){.dash-yr-months{height:12px;font-size:9px}.dash-yr-cells{gap:2px}}@media (max-width:480px){.dash-streak-row{gap:14px}.dash-streak-meta{padding-left:14px}}.dash-last{flex-direction:column;gap:8px;display:flex}.dash-last-empty p{color:var(--ink-2);margin:0;font-size:13.5px}.dash-last-empty p.dim{color:var(--muted);font-size:12.5px}.dash-last-row{align-items:center;gap:10px;display:flex}.dash-last-diff{letter-spacing:.06em;text-transform:uppercase;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--border);border-radius:999px;padding:3px 8px;font-size:10.5px;font-weight:700}.dash-last-diff-easy{color:#0b996e;background:color-mix(in srgb, #0b996e 12%, var(--surface));border-color:color-mix(in srgb, #0b996e 30%, var(--border))}.dash-last-diff-medium{color:#d97706;background:color-mix(in srgb, #d97706 12%, var(--surface));border-color:color-mix(in srgb, #d97706 30%, var(--border))}.dash-last-diff-hard{color:#dc2626;background:color-mix(in srgb, #dc2626 12%, var(--surface));border-color:color-mix(in srgb, #dc2626 30%, var(--border))}.dash-last-time{color:var(--muted);letter-spacing:.02em;font-size:11.5px;font-weight:600}.dash-last-title{letter-spacing:-.015em;color:var(--ink);margin:0;font-size:16px;font-weight:700;line-height:1.3}.dash-last-tags{flex-wrap:wrap;gap:4px;display:flex}.dash-last-tags span{font-family:var(--mono);color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:2px 7px;font-size:10.5px;font-weight:600}.dash-topic-card{padding:clamp(18px,2.4vw,22px)}.dash-topic-list{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px clamp(20px,3vw,32px);margin:0;padding:0;list-style:none;display:grid}@media (max-width:760px){.dash-topic-list{grid-template-columns:1fr}}.dash-topic-row{cursor:pointer;border-radius:8px;grid-template-columns:minmax(0,1.4fr) minmax(80px,2fr) auto auto;align-items:center;gap:10px;min-width:0;padding:6px 8px;transition:background .15s;display:grid}.dash-topic-row:hover{background:var(--surface-2)}.dash-topic-name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:13px;font-weight:600;overflow:hidden}.dash-topic-bar{background:var(--surface-2);border-radius:999px;height:6px;display:block;position:relative;overflow:hidden}.dash-topic-bar>span{background:var(--accent);border-radius:999px;transition:width .4s;position:absolute;inset:0 auto 0 0}.dash-topic-frac{font-family:var(--mono);color:var(--ink);font-size:11.5px;font-weight:700}.dash-topic-frac em{color:var(--muted);font-style:normal;font-weight:500}.dash-topic-pct{font-family:var(--mono);color:var(--accent);text-align:right;min-width:38px;font-size:11px;font-weight:700}.dash-course-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:12px;display:grid}.dash-course-row{--t:var(--accent);border:1px solid var(--border);background:var(--surface);cursor:pointer;text-align:left;color:inherit;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:14px 16px;font-family:inherit;transition:border-color .2s;display:grid}.dash-course-row[data-tone=green]{--t:var(--accent)}.dash-course-row[data-tone=blue]{--t:#2563eb}.dash-course-row[data-tone=violet]{--t:#7c3aed}.dash-course-row[data-tone=amber]{--t:#d97706}.dash-course-row[data-tone=rose]{--t:#db2777}.dash-course-row[data-tone=teal]{--t:#0d9488}.dash-course-row[data-tone=indigo]{--t:#4f46e5}.dash-course-row[data-tone=cyan]{--t:#0891b2}.dash-course-row:hover{border-color:color-mix(in srgb, var(--t) 55%, var(--border-strong))}.dash-course-ic{background:color-mix(in srgb, var(--t) 18%, var(--surface));border:1px solid color-mix(in srgb, var(--t) 30%, var(--border));width:40px;height:40px;color:var(--t);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.dash-course-ic svg{width:18px;height:18px}.dash-course-info{flex-direction:column;gap:6px;min-width:0;display:flex}.dash-course-title{letter-spacing:-.012em;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:14.5px;font-weight:600;overflow:hidden}.dash-course-meta{color:var(--muted);letter-spacing:.01em;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:500;overflow:hidden}.dash-course-bar{background:var(--surface-2);border-radius:999px;height:5px;margin-top:2px;display:block;position:relative;overflow:hidden}.dash-course-bar>span{background:var(--t);border-radius:999px;transition:width .4s;position:absolute;inset:0 auto 0 0}.dash-course-pct{font-family:var(--mono);color:var(--t);text-align:right;flex-shrink:0;min-width:40px;font-size:12px;font-weight:700}@media (max-width:480px){.dash-course-row{gap:12px;padding:12px 14px}.dash-course-ic{width:36px;height:36px}.dash-course-ic svg{width:16px;height:16px}.dash-course-title{font-size:13.5px}.dash-course-meta{font-size:10.5px}}.prob-solve-btn{border:1.5px solid var(--border-strong);background:var(--surface);color:#0000;cursor:pointer;border-radius:50%;place-items:center;width:20px;height:20px;transition:all .2s;display:grid}.prob-solve-btn:hover{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 5%, var(--surface))}.prob-solve-btn.is-solved{background:var(--accent);border-color:var(--accent);color:var(--surface)}.prob-solve-btn.is-solved:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.prob-row.is-solved .prob-title{color:var(--accent)}.dash-explore-grid{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1fr);gap:12px;display:grid}@media (max-width:1040px){.dash-explore-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.dash-explore-lg{grid-column:1/-1}}@media (max-width:620px){.dash-explore-grid{grid-template-columns:1fr}}.dash-explore{--t:var(--accent);border:1px solid var(--border);background:var(--surface);text-align:left;color:inherit;cursor:pointer;isolation:isolate;border-radius:18px;flex-direction:column;gap:10px;min-width:0;min-height:220px;padding:clamp(18px,2.4vw,24px);font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s;display:flex;position:relative;overflow:hidden}.dash-explore:before{content:"";background:radial-gradient(120% 120% at 100% 0%, color-mix(in srgb, var(--t) 10%, transparent), transparent 55%);z-index:-1;transition:opacity .2s;position:absolute;inset:0}.dash-explore:hover{border-color:color-mix(in srgb, var(--t) 50%, var(--border-strong));box-shadow:0 12px 30px color-mix(in srgb, var(--t) 12%, transparent)}.dash-explore-head{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.dash-explore-ic{background:color-mix(in srgb, var(--t) 14%, var(--surface));width:44px;height:44px;color:var(--t);border-radius:12px;place-items:center;display:grid}.dash-explore-ic svg{width:22px;height:22px}.dash-explore-pill{color:var(--t);background:color-mix(in srgb, var(--t) 14%, var(--surface));border:1px solid color-mix(in srgb, var(--t) 30%, var(--border));letter-spacing:.02em;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}.dash-explore-pill span{font-weight:800}.dash-explore-title{letter-spacing:-.015em;color:var(--ink);margin:0;font-size:19px;font-weight:700;line-height:1.25}.dash-explore-sub{color:var(--muted);flex-grow:1;margin:0;font-size:13.5px;line-height:1.55}.dash-explore-tags{flex-wrap:wrap;gap:6px;display:flex}.dash-explore-tags span{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--border);border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600}.dash-explore-cta{color:var(--t);letter-spacing:-.005em;align-items:center;gap:6px;font-size:13px;font-weight:700;display:inline-flex}.dash-explore-cta svg{width:15px;height:15px;transition:transform .18s}.dash-explore:hover .dash-explore-cta svg{transform:translate(4px)}.dash-explore-lg .dash-explore-title{font-size:22px}.dash-rm-shell{gap:clamp(16px,2vw,24px)}.dash-rm-hero{flex-direction:column;gap:6px;margin:0 0 4px;padding:4px 4px 0;display:flex}.dash-rm-hero-greet{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);align-self:flex-start;align-items:center;gap:9px;margin:0;font-size:clamp(12px,1vw,13px);font-weight:600;display:inline-flex}.dash-rm-hero-dot{background:var(--accent);width:7px;height:7px;box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent);border-radius:50%;flex-shrink:0;animation:2.4s ease-in-out infinite dashDotPulse;display:inline-block}.dash-rm-hero-title{letter-spacing:-.02em;color:var(--ink);text-wrap:balance;margin:0;font-size:clamp(22px,2.4vw,32px);font-weight:600;line-height:1.15}.dash-rm-hero-accent{background:linear-gradient(120deg, var(--accent) 0%, color-mix(in srgb, var(--accent) 55%, var(--ink)) 100%);color:#0000;-webkit-background-clip:text;background-clip:text;padding:0 2px 6px;font-weight:800;display:inline-block;position:relative}.dash-rm-hero-wave{width:calc(100% - 4px);height:6px;color:color-mix(in srgb, var(--accent) 75%, transparent);pointer-events:none;position:absolute;bottom:0;left:2px;right:2px;overflow:visible}.dash-rm-hero-wave path{stroke-dasharray:240;stroke-dashoffset:240px;animation:1.2s cubic-bezier(.4,0,.2,1) .25s forwards dashWaveDraw}.dash-rm-hero-sub{color:var(--muted);text-wrap:pretty;max-width:64ch;margin:2px 0 0;font-size:clamp(13px,1.1vw,14px);font-weight:400;line-height:1.55}@media (prefers-reduced-motion:reduce){.dash-rm-hero-dot{animation:none}.dash-rm-hero-wave path{stroke-dashoffset:0;animation:none}}.dash-rm-overview{background:radial-gradient(120% 100% at 0% 0%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 60%), var(--surface);border:1px solid color-mix(in srgb, var(--accent) 18%, var(--border));isolation:isolate;border-radius:20px;flex-direction:column;gap:16px;padding:clamp(16px,2vw,20px);display:flex;position:relative;overflow:hidden}.dash-rm-overview:before{content:"";background:radial-gradient(closest-side, color-mix(in srgb, var(--accent) 20%, transparent), transparent 70%);filter:blur(24px);pointer-events:none;z-index:0;width:200px;height:200px;position:absolute;top:-60px;right:-60px}.dash-rm-ov-main,.dash-rm-ov-bar,.dash-rm-ov-stats{z-index:1;position:relative}.dash-rm-ov-main{align-items:center;gap:clamp(14px,1.8vw,18px);min-width:0;display:flex}.dash-rm-ov-ring{--deg:0deg;--size:64px;width:var(--size);height:var(--size);background:conic-gradient(var(--accent) 0 var(--deg), color-mix(in srgb, var(--ink) 7%, var(--surface)) var(--deg) 360deg);border-radius:50%;flex-shrink:0;place-items:center;transition:--deg .8s;display:grid;position:relative}.dash-rm-ov-ring:before{content:"";background:var(--surface);border-radius:50%;position:absolute;inset:6px}.dash-rm-ov-ring-num{letter-spacing:-.02em;color:var(--ink);font-feature-settings:"tnum" on, "lnum" on;font-size:clamp(16px,1.8vw,20px);font-weight:600;line-height:1;position:relative}.dash-rm-ov-ring-num i{color:var(--muted);margin-left:1px;font-size:.6em;font-style:normal;font-weight:500}.dash-rm-ov-headline{flex-direction:column;gap:2px;min-width:0;display:flex}.dash-rm-ov-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:10.5px;font-weight:600}.dash-rm-ov-title{letter-spacing:-.015em;color:var(--ink);text-wrap:pretty;margin:0;font-size:clamp(16px,1.8vw,20px);font-weight:600;line-height:1.25}.dash-rm-ov-sub{color:var(--muted);margin:0;font-size:12.5px;font-weight:400;line-height:1.4}.dash-rm-ov-bar{background:color-mix(in srgb, var(--ink) 6%, var(--surface));border-radius:999px;height:5px;overflow:hidden}.dash-rm-ov-bar-fill{background:linear-gradient(90deg, color-mix(in srgb, var(--accent) 75%, white), var(--accent));height:100%;box-shadow:0 0 12px -2px color-mix(in srgb, var(--accent) 50%, transparent);border-radius:999px;transition:width .8s cubic-bezier(.4,0,.2,1);display:block;position:relative}.dash-rm-ov-stats{background:color-mix(in srgb, var(--ink) 6%, var(--surface));border-radius:12px;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;display:grid;overflow:hidden}.dash-rm-ov-stat{background:var(--surface);flex-direction:column;align-items:flex-start;gap:2px;min-width:0;padding:10px 14px;display:flex}.dash-rm-ov-stat-num{letter-spacing:-.02em;color:var(--ink);font-feature-settings:"tnum" on, "lnum" on;font-size:clamp(18px,2vw,22px);font-weight:600;line-height:1}.dash-rm-ov-stat-lbl{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:10.5px;font-weight:500}@media (max-width:720px){.dash-rm-ov-main{gap:12px}.dash-rm-ov-ring{--size:56px}.dash-rm-ov-stats{grid-template-columns:repeat(2,1fr)}}.dash-rm-stages{flex-direction:column;gap:14px;margin:0;padding:0;list-style:none;display:flex}.dash-rm-stage{--t:var(--accent);background:var(--surface);border:1px solid var(--border);border-radius:24px;flex-direction:column;gap:12px;padding:clamp(20px,2.4vw,24px);transition:transform .35s,box-shadow .35s,border-color .35s;display:flex;position:relative}.dash-rm-stage:hover{border-color:color-mix(in srgb, var(--t) 22%, var(--border-strong));box-shadow:0 24px 48px -28px color-mix(in srgb, var(--t) 35%, transparent);transform:translateY(-2px)}.dash-rm-stage[data-tone=green]{--t:var(--accent)}.dash-rm-stage[data-tone=blue]{--t:#2563eb}.dash-rm-stage[data-tone=violet]{--t:#7c3aed}.dash-rm-stage[data-tone=amber]{--t:#d97706}.dash-rm-stage[data-tone=rose]{--t:#db2777}.dash-rm-stage[data-tone=cyan]{--t:#0891b2}.dash-rm-stage-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.dash-rm-stage-meta{font-family:var(--mono);letter-spacing:.06em;color:var(--muted);text-transform:uppercase;align-items:center;gap:8px;font-size:11.5px;font-weight:500;display:inline-flex}.dash-rm-stage-num{background:color-mix(in srgb, var(--t) 10%, var(--surface));min-width:28px;height:22px;color:var(--t);letter-spacing:.04em;border-radius:999px;justify-content:center;align-items:center;padding:0 8px;font-size:11px;font-weight:500;display:inline-flex}.dash-rm-stage-dot{opacity:.4}.dash-rm-stage-time{color:var(--muted)}.dash-rm-stage-ic{background:color-mix(in srgb, var(--t) 9%, var(--surface));width:42px;height:42px;color:var(--t);border-radius:14px;flex-shrink:0;place-items:center;transition:background .3s;display:grid}.dash-rm-stage:hover .dash-rm-stage-ic{background:color-mix(in srgb, var(--t) 14%, var(--surface))}.dash-rm-stage-ic svg{width:19px;height:19px}.dash-rm-stage-title{letter-spacing:-.022em;color:var(--ink);text-wrap:pretty;margin:0;font-size:clamp(22px,2.4vw,28px);font-weight:600;line-height:1.2}.dash-rm-stage-desc{color:var(--ink-2);text-wrap:pretty;max-width:64ch;margin:0;font-size:14.5px;font-weight:400;line-height:1.6}.dash-rm-stage-progress{flex-direction:column;gap:6px;margin:2px 0 4px;display:flex}.dash-rm-stage-progress-head{justify-content:space-between;align-items:center;gap:10px;font-size:12px;font-weight:600;display:flex}.dash-rm-stage-progress-lbl{color:var(--muted);letter-spacing:.01em}.dash-rm-stage-progress-pct{font-family:var(--mono);color:var(--t);font-weight:700}.dash-rm-stage-progress-bar{background:var(--surface-2);border-radius:999px;height:5px;position:relative;overflow:hidden}.dash-rm-stage-progress-bar>span{background:var(--t);border-radius:999px;transition:width .4s;position:absolute;inset:0 auto 0 0}.dash-rm-stage-skills{flex-wrap:wrap;gap:6px;margin-bottom:2px;display:flex}.dash-rm-stage-skills span{letter-spacing:.005em;color:var(--ink-2);background:var(--surface-2);border-radius:999px;align-items:center;padding:4px 11px;font-size:11.5px;font-weight:400;display:inline-flex}.dash-rm-stage-resources{background:var(--surface-2);border-radius:16px;flex-direction:column;margin:2px 0 0;padding:0;list-style:none;display:flex;overflow:hidden}.dash-rm-stage-resources>li+li{border-top:1px solid color-mix(in srgb, var(--ink) 6%, var(--surface))}.dash-rm-resource{--rt:var(--t);color:inherit;cursor:pointer;background:0 0;grid-template-columns:36px minmax(0,1fr) auto;align-items:center;gap:14px;padding:14px 16px;text-decoration:none;transition:background .25s;display:grid}.dash-rm-resource:hover{background:color-mix(in srgb, var(--rt) 6%, var(--surface))}.dash-rm-resource[data-tone=green]{--rt:var(--accent)}.dash-rm-resource[data-tone=blue]{--rt:#2563eb}.dash-rm-resource[data-tone=violet]{--rt:#7c3aed}.dash-rm-resource[data-tone=amber]{--rt:#d97706}.dash-rm-resource[data-tone=rose]{--rt:#db2777}.dash-rm-resource[data-tone=teal]{--rt:#0d9488}.dash-rm-resource[data-tone=indigo]{--rt:#4f46e5}.dash-rm-resource[data-tone=cyan]{--rt:#0891b2}.dash-rm-resource[data-tone=slate]{--rt:var(--ink-2)}.dash-rm-resource-ic{background:color-mix(in srgb, var(--rt) 10%, var(--surface));width:36px;height:36px;color:var(--rt);border-radius:11px;flex-shrink:0;place-items:center;display:grid}.dash-rm-resource-ic svg{width:17px;height:17px}.dash-rm-resource-text{flex-direction:column;gap:2px;min-width:0;display:flex}.dash-rm-resource-name{letter-spacing:-.005em;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.dash-rm-resource-meta{color:var(--muted);font-size:12px;font-weight:400}.dash-rm-resource-arrow{background:var(--surface);width:28px;height:28px;color:var(--ink-2);border-radius:999px;place-items:center;transition:transform .3s,background .3s,color .3s;display:grid}.dash-rm-resource-arrow svg{width:12px;height:12px}.dash-rm-resource:hover .dash-rm-resource-arrow{background:var(--rt);color:#fff;transform:translate(3px)}@media (max-width:720px){.dash-rm-stage{gap:14px;padding:22px}.dash-rm-stage-ic{border-radius:12px;width:38px;height:38px}.dash-rm-stage-ic svg{width:17px;height:17px}.dash-rm-resource{grid-template-columns:32px minmax(0,1fr) auto;gap:12px;padding:12px 14px}.dash-rm-resource-ic{border-radius:10px;width:32px;height:32px}.dash-rm-resource-ic svg{width:15px;height:15px}}.dash-rm-tips{border:1px solid var(--border);background:var(--surface);border-radius:24px;flex-direction:column;gap:18px;margin-top:0;padding:clamp(22px,2.6vw,30px);display:flex}.dash-rm-tips-head{flex-direction:column;gap:6px;display:flex}.dash-rm-tips-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:500}.dash-rm-tips-title{letter-spacing:-.022em;color:var(--ink);margin:0;font-size:clamp(20px,2.2vw,26px);font-weight:600;line-height:1.2}.dash-rm-tips-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,220px),1fr));gap:10px;display:grid}.dash-rm-tip{background:var(--surface-2);border-radius:16px;flex-direction:column;gap:8px;padding:16px 18px 14px;transition:background .25s,transform .25s;display:flex}.dash-rm-tip:hover{background:color-mix(in srgb, var(--accent) 5%, var(--surface));transform:translateY(-1px)}.dash-rm-tip-num{font-family:var(--mono);letter-spacing:.08em;color:var(--accent);align-self:flex-start;font-size:11px;font-weight:500}.dash-rm-tip h4{letter-spacing:-.008em;color:var(--ink);margin:0;font-size:14.5px;font-weight:600;line-height:1.3}.dash-rm-tip p{color:var(--muted);text-wrap:pretty;margin:0;font-size:12.5px;font-weight:400;line-height:1.55}.cert-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);align-items:center;gap:6px;font-size:11px;font-weight:700;display:inline-flex}.cert-eyebrow svg{width:14px;height:14px;color:var(--accent);flex-shrink:0}.cert-lead{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:clamp(28px,4vw,44px);padding:0;display:grid}.cert-lead-text{flex-direction:column;gap:16px;display:flex}.cert-lead-title{letter-spacing:-.022em;color:var(--ink);text-wrap:balance;margin:0;font-size:clamp(24px,2.6vw,30px);font-weight:600;line-height:1.18}.cert-lead-sub{color:var(--ink-2);max-width:48ch;margin:0;font-size:clamp(13.5px,1.1vw,14.5px);line-height:1.6}.cert-perks{flex-direction:column;gap:10px;margin:4px 0 0;padding:0;list-style:none;display:flex}.cert-perks li{color:var(--ink-2);align-items:center;gap:10px;font-size:13.5px;font-weight:500;display:inline-flex}.cert-perks svg{width:16px;height:16px;color:var(--accent);background:color-mix(in srgb, var(--accent) 14%, var(--surface));box-sizing:content-box;border-radius:999px;flex-shrink:0;padding:2px}.cert-mini-steps{background:var(--surface-2);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;margin:6px 0 0;padding:14px 16px;list-style:none;display:flex}.cert-mini-steps li{color:var(--ink);align-items:center;gap:12px;font-size:13.5px;font-weight:500;display:flex}.cert-mini-step-num{width:22px;height:22px;font-family:var(--mono);color:var(--accent);background:color-mix(in srgb, var(--accent) 14%, var(--surface));border:1px solid color-mix(in srgb, var(--accent) 24%, var(--border));border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.cert-lead-actions{flex-wrap:wrap;gap:10px;margin-top:8px;display:flex}@media (max-width:480px){.cert-lead-actions{flex-direction:column;align-items:stretch}.cert-lead-actions .dash-cta{justify-content:center;width:100%}}.cert-figure{background:var(--surface);border:1px solid var(--border);width:100%;max-width:480px;box-shadow:0 18px 40px -24px color-mix(in srgb, var(--accent) 22%, transparent), 0 4px 12px -8px color-mix(in srgb, var(--ink) 10%, transparent);border-radius:16px;justify-self:end;margin:0;padding:clamp(12px,1.5vw,16px)}.cert-figure img{border-radius:8px;width:100%;height:auto;display:block}.cert-figure figcaption{text-align:center;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-top:10px;font-size:10.5px;font-weight:700}.cert-section-head{flex-direction:column;gap:10px;margin-bottom:clamp(18px,2.4vw,28px);display:flex}.cert-section-title{letter-spacing:-.022em;color:var(--ink);text-wrap:balance;margin:0;font-size:clamp(22px,2.4vw,28px);font-weight:600;line-height:1.2}.cert-steps{grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(14px,1.6vw,20px);margin:0;padding:0;list-style:none;display:grid}.cert-step{background:var(--surface);border:1px solid var(--border);border-radius:18px;flex-direction:column;gap:12px;padding:clamp(20px,2.2vw,26px);display:flex}.cert-step-num{width:36px;height:36px;font-family:var(--mono);letter-spacing:.04em;color:var(--accent);background:color-mix(in srgb, var(--accent) 14%, var(--surface));border:1px solid color-mix(in srgb, var(--accent) 24%, var(--border));border-radius:10px;justify-content:center;align-items:center;font-size:12.5px;font-weight:700;display:inline-flex}.cert-step-title{letter-spacing:-.012em;color:var(--ink);margin:0;font-size:16px;font-weight:600}.cert-step-desc{color:var(--muted);margin:0;font-size:13.5px;line-height:1.6}.cert-cta{background:radial-gradient(120% 120% at 0% 0%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 60%), var(--surface);border:1px solid color-mix(in srgb, var(--accent) 18%, var(--border));border-radius:20px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:clamp(20px,3vw,32px);padding:clamp(22px,2.6vw,30px);display:flex}.cert-cta-text{flex-direction:column;gap:6px;min-width:0;display:flex}.cert-cta-title{letter-spacing:-.018em;color:var(--ink);margin:0;font-size:clamp(18px,1.8vw,22px);font-weight:600}.cert-cta-sub{color:var(--muted);margin:0;font-size:13.5px;line-height:1.55}.cert-cta-actions{flex-wrap:wrap;gap:10px;display:flex}@media (max-width:920px){.cert-lead{grid-template-columns:1fr;gap:28px}.cert-figure{order:-1;justify-self:center;max-width:540px;margin:0 auto}.cert-steps{grid-template-columns:1fr}}@media (max-width:480px){.cert-cta{text-align:left;flex-direction:column;align-items:stretch}.cert-cta-actions{flex-direction:column}.cert-cta-actions .dash-cta{justify-content:center;width:100%}}.dash-quick-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,180px),1fr));gap:10px;display:grid}.dash-quick{--t:var(--accent);border:1px solid var(--border);background:var(--surface);cursor:pointer;text-align:left;color:inherit;border-radius:12px;align-items:center;gap:12px;padding:14px;font-family:inherit;transition:border-color .18s,background .18s;display:flex}.dash-quick:hover{border-color:color-mix(in srgb, var(--t) 40%, var(--border-strong));background:color-mix(in srgb, var(--t) 4%, var(--surface))}.dash-quick-ic{background:color-mix(in srgb, var(--t) 14%, var(--surface));width:36px;height:36px;color:var(--t);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.dash-quick-ic svg{width:17px;height:17px}.dash-quick-text{flex-direction:column;line-height:1.3;display:flex}.dash-quick-text b{color:var(--ink);letter-spacing:-.005em;font-size:13.5px;font-weight:700}.dash-quick-text em{color:var(--muted);font-size:11.5px;font-style:normal;font-weight:500}.section-complete{border:1px solid var(--border);background:linear-gradient(180deg, var(--surface), var(--surface-2));box-shadow:0 2px 6px color-mix(in srgb, var(--ink) 4%, transparent);border-radius:14px;justify-content:space-between;align-items:center;gap:16px;margin:28px 0 24px;padding:16px 18px;display:flex}.section-complete-text{flex-direction:column;gap:3px;min-width:0;display:flex}.section-complete-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:10.5px;font-weight:700}.section-complete-title{color:var(--ink);letter-spacing:-.005em;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:700;overflow:hidden}.section-complete-btn{border:1px solid color-mix(in srgb, var(--accent) 40%, var(--border));background:var(--surface);color:var(--accent-hover);font:inherit;cursor:pointer;border-radius:999px;flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:700;transition:background .15s,color .15s,border-color .15s,transform .12s;display:inline-flex}.section-complete-btn:hover{background:color-mix(in srgb, var(--accent) 10%, var(--surface))}.section-complete-btn:active{transform:translateY(1px)}.section-complete-icon{border:1.5px solid color-mix(in srgb, var(--accent) 50%, var(--border));background:var(--surface);color:#0000;border-radius:999px;place-items:center;width:20px;height:20px;transition:background .15s,color .15s,border-color .15s;display:grid}.section-complete-btn.is-complete{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);box-shadow:0 6px 14px color-mix(in srgb, var(--accent) 24%, transparent)}.section-complete-btn.is-complete:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.section-complete-btn.is-complete .section-complete-icon{background:var(--accent-ink);border-color:var(--accent-ink);color:var(--accent)}.sidebar-link{position:relative}.sidebar-link .nav-check{color:var(--accent);flex-shrink:0;margin-left:auto}.sidebar-link.is-complete .nav-text{color:var(--ink-2)}.sidebar-link.is-complete .nav-num{color:var(--accent);border-color:color-mix(in srgb, var(--accent) 40%, var(--border));background:color-mix(in srgb, var(--accent) 10%, var(--surface))}.sidebar-link.is-complete .nav-dot{background:var(--accent)}@media (max-width:560px){.section-complete{flex-direction:column;align-items:stretch;gap:12px}.section-complete-btn{justify-content:center}.section-complete-title{white-space:normal}}.upgrade-modal{z-index:1000;font-family:var(--sans);justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.upgrade-modal[data-open=true]{display:flex}.upgrade-backdrop{-webkit-backdrop-filter:blur(6px);background:#080b0e9e;position:absolute;inset:0}.upgrade-card{z-index:2;background:var(--surface);border:1px solid var(--border);border-radius:18px;width:min(460px,100%);padding:28px 26px 22px;animation:.18s ease-out both upgradeModalIn;position:relative;box-shadow:0 24px 60px #00000047}@keyframes upgradeModalIn{0%{opacity:0;transform:translateY(-8px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}.upgrade-close{border:1px solid var(--border);background:var(--bg);width:28px;height:28px;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:12px;right:12px}.upgrade-close:hover{background:var(--surface-2)}.upgrade-lead{flex-direction:column;gap:8px;display:flex}.upgrade-badge{letter-spacing:.06em;color:var(--accent);background:color-mix(in srgb, var(--accent) 14%, transparent);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent);text-transform:uppercase;border-radius:999px;align-self:flex-start;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.upgrade-title{letter-spacing:-.01em;color:var(--text);margin:4px 0 0;font-size:22px;font-weight:700}.upgrade-body{color:var(--muted);margin:0;font-size:13.5px;line-height:1.55}.upgrade-perks{color:var(--text);flex-direction:column;gap:10px;margin:18px 0 22px;padding:0;font-size:13px;list-style:none;display:flex}.upgrade-perks li{align-items:flex-start;gap:10px;line-height:1.45;display:flex}.upgrade-perks li svg{color:var(--accent);flex-shrink:0;margin-top:2px}.upgrade-actions{flex-direction:column;gap:8px;display:flex}.upgrade-cta{appearance:none;color:var(--surface);background:var(--accent);cursor:pointer;border:0;border-radius:12px;padding:12px 16px;font-size:14px;font-weight:600;transition:transform .15s,filter .15s}.upgrade-cta:hover{filter:brightness(1.05);transform:translateY(-1px)}.upgrade-dismiss{appearance:none;border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:12px;padding:10px 16px;font-size:13px}.upgrade-dismiss:hover{color:var(--text);background:var(--surface-2)}.upgrade-foot{color:var(--muted);text-align:center;letter-spacing:.02em;margin:14px 0 0;font-size:11.5px}.lock-chip{width:22px;height:22px;color:var(--premium);background:var(--premium-soft);border:1px solid color-mix(in srgb, var(--premium) 36%, transparent);white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.lock-chip svg{width:11px;height:11px}.topic-card.is-locked{border-color:color-mix(in srgb, var(--premium) 28%, var(--border));background:linear-gradient(180deg, color-mix(in srgb, var(--premium-soft) 55%, var(--surface)) 0%, var(--surface) 70%);position:relative}.topic-card.is-locked:hover{border-color:var(--premium);box-shadow:0 6px 18px color-mix(in srgb, var(--premium) 18%, transparent)}.topic-card.is-locked .topic-card-title{color:color-mix(in srgb, var(--ink) 78%, transparent)}.topic-card.is-locked .topic-card-meta{color:color-mix(in srgb, var(--ink) 55%, transparent)}.topic-card-lock{background:var(--premium-soft);border:1px solid color-mix(in srgb, var(--premium) 36%, transparent);width:26px;height:26px;color:var(--premium);z-index:3;border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:10px;right:10px}.topic-card-lock svg{width:12px;height:12px}.topic-card-lock span,.lock-chip span,.prob-row-lock span,.pq-row-lock span{display:none}.sidebar-link.is-locked .nav-text{color:var(--muted)}.sidebar-link.is-locked .nav-lock{color:var(--premium);align-items:center;margin-left:auto;display:inline-flex}.sidebar-link.is-locked .nav-lock svg{width:12px;height:12px}.sidebar-link.is-locked:hover .nav-text,.sidebar-link.is-locked:hover .nav-lock{color:var(--premium)}.section-locked-banner{text-align:center;background:linear-gradient(180deg, color-mix(in srgb, var(--premium) 10%, transparent), transparent);border:1px solid color-mix(in srgb, var(--premium) 28%, transparent);border-radius:16px;flex-direction:column;align-items:center;gap:12px;margin:18px 0;padding:36px 28px;display:flex}.section-locked-banner-icon{background:var(--premium-soft);border:1px solid color-mix(in srgb, var(--premium) 36%, transparent);width:48px;height:48px;color:var(--premium);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.section-locked-banner-title{color:var(--text);margin:0;font-size:16px;font-weight:700}.section-locked-banner-sub{color:var(--muted);max-width:480px;margin:0;font-size:13px;line-height:1.55}.section-locked-banner-btn{appearance:none;background:var(--premium);color:#fff;cursor:pointer;border:0;border-radius:10px;padding:10px 18px;font-size:13px;font-weight:600;transition:filter .15s,transform .15s}.section-locked-banner-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}.prob-row.is-locked{background:linear-gradient(90deg, color-mix(in srgb, var(--premium-soft) 70%, var(--surface)) 0%, var(--surface) 65%);border-left:2px solid color-mix(in srgb, var(--premium) 60%, transparent)}.prob-row.is-locked:hover{background:linear-gradient(90deg, color-mix(in srgb, var(--premium-soft) 90%, var(--surface)) 0%, color-mix(in srgb, var(--surface-2) 92%, var(--surface)) 70%)}.prob-row.is-locked .prob-title{color:color-mix(in srgb, var(--ink) 72%, transparent)}.prob-row.is-locked .prob-go,.prob-row.is-locked .prob-viz-btn,.prob-row.is-locked .prob-solve-btn{opacity:.4;pointer-events:none}.prob-row-lock{width:20px;height:20px;color:var(--premium);background:var(--premium-soft);border:1px solid color-mix(in srgb, var(--premium) 36%, transparent);vertical-align:middle;border-radius:999px;justify-content:center;align-items:center;margin-left:8px;display:inline-flex}.prob-row-lock svg{width:10px;height:10px}.pq-row.is-locked{background:linear-gradient(90deg, color-mix(in srgb, var(--premium-soft) 70%, var(--surface)) 0%, var(--surface) 65%);border-left:2px solid color-mix(in srgb, var(--premium) 60%, transparent)}.pq-row.is-locked:hover{background:linear-gradient(90deg, color-mix(in srgb, var(--premium-soft) 90%, var(--surface)) 0%, color-mix(in srgb, var(--surface-2) 92%, var(--surface)) 70%)}.pq-row.is-locked .pq-row-title{color:color-mix(in srgb, var(--ink) 72%, transparent)}.pq-row.is-locked .pq-row-actions{display:none}.pq-row-lock{width:28px;height:28px;color:var(--premium);background:var(--premium-soft);border:1px solid color-mix(in srgb, var(--premium) 36%, transparent);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.pq-row-lock svg{width:12px;height:12px}.iv-item.is-locked .iv-answer{filter:blur(3px);-webkit-user-select:none;user-select:none;position:relative}.iv-item.is-locked{border-color:color-mix(in srgb, var(--premium) 28%, var(--border));background:linear-gradient(180deg, color-mix(in srgb, var(--premium-soft) 55%, var(--surface)) 0%, var(--surface) 70%);position:relative}.iv-item.is-locked:hover{border-color:var(--premium);box-shadow:0 6px 18px color-mix(in srgb, var(--premium) 18%, transparent)}.iv-item.is-locked:after{content:"";background:var(--premium-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23E08F1D' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='11' width='18' height='11' rx='2'/><path d='M7 11V7a5 5 0 0 1 10 0v4'/></svg>") center no-repeat;border:1px solid color-mix(in srgb, var(--premium) 36%, transparent);pointer-events:none;background-size:12px 12px;border-radius:999px;width:24px;height:24px;position:absolute;top:18px;right:18px}.upgrade-badge{color:var(--premium)!important;background:var(--premium-soft)!important;border-color:color-mix(in srgb, var(--premium) 36%, transparent)!important}.upgrade-perks li svg{color:var(--premium)!important}.upgrade-cta{background:var(--premium)!important;color:#fff!important}.auth-modal{z-index:1000;font-family:var(--sans);justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.auth-modal[data-open=true]{display:flex}.auth-backdrop{-webkit-backdrop-filter:blur(4px);background:#0b14107a;animation:.18s ease-out authFadeIn;position:absolute;inset:0}.auth-card{background:var(--surface);border-radius:24px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);width:min(100%,880px);max-height:calc(100vh - 40px);animation:.22s cubic-bezier(.2,.8,.2,1) authPopIn;display:grid;position:relative;overflow:hidden;box-shadow:0 30px 80px #0b141047}@keyframes authFadeIn{0%{opacity:0}to{opacity:1}}@keyframes authPopIn{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-close{z-index:2;background:var(--surface);width:32px;height:32px;color:var(--ink-2);cursor:pointer;border:0;border-radius:999px;place-items:center;transition:color .15s,transform .15s;display:grid;position:absolute;top:16px;right:16px;box-shadow:0 2px 8px #0b14101a}.auth-close:hover{color:var(--ink);transform:rotate(90deg)}.auth-aside{background:radial-gradient(420px 280px at 50% 45%, color-mix(in srgb, var(--accent) 14%, var(--surface)), transparent 70%), linear-gradient(180deg, #f1fbf5, #e6f6ec);place-items:center;padding:32px;display:grid;position:relative}.auth-illustration{object-fit:contain;filter:drop-shadow(0 18px 30px #0b996e2e);width:100%;max-width:320px;height:auto}.auth-main{background:var(--surface);flex-direction:column;justify-content:center;padding:48px 44px;display:flex;overflow-y:auto}.auth-head{flex-direction:column;gap:8px;margin-bottom:28px;display:flex}.auth-title{font-family:var(--sans);letter-spacing:-.035em;color:var(--ink);margin:0;font-size:30px;font-weight:800;line-height:1.15}.auth-sub{color:var(--muted);margin:0;font-size:14px;line-height:1.55}.auth-form{gap:14px;display:grid}.auth-input{background:#f4f6fa;border:1px solid #0000;border-radius:14px;align-items:center;gap:12px;padding:0 16px;transition:border-color .15s,box-shadow .15s,background .15s;display:flex}.auth-input:focus-within{background:var(--surface);border-color:color-mix(in srgb, var(--accent) 55%, transparent);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent)}.auth-input-ic{width:18px;height:18px;color:var(--muted);flex-shrink:0;place-items:center;display:grid}.auth-input input{min-width:0;color:var(--ink);font-family:var(--sans);background:0 0;border:0;outline:none;flex:1;padding:15px 0;font-size:14px;font-weight:500}.auth-input input::placeholder{color:var(--muted-2);font-weight:400}.auth-input-action{width:30px;height:30px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;place-items:center;transition:color .15s,background .15s;display:grid}.auth-input-action:hover{color:var(--accent-hover);background:color-mix(in srgb, var(--accent) 10%, transparent)}.auth-message{color:#0000;min-height:16px;margin:0;font-size:12.5px;font-weight:600;transition:color .15s}.auth-message[data-tone=error]{color:#dc2626}.auth-message[data-tone=success]{color:var(--accent-hover)}.auth-submit{background:var(--accent);width:100%;color:var(--accent-ink);font-family:var(--sans);letter-spacing:.005em;cursor:pointer;box-shadow:0 8px 20px color-mix(in srgb, var(--accent) 28%, transparent);border:0;border-radius:14px;justify-content:center;align-items:center;gap:10px;margin-top:6px;padding:15px 18px;font-size:15px;font-weight:700;transition:background .18s,transform .12s,box-shadow .18s;display:inline-flex;position:relative}.auth-submit:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 12px 24px color-mix(in srgb, var(--accent) 34%, transparent)}.auth-submit:active:not(:disabled){transform:translateY(1px)}.auth-submit:disabled{cursor:progress;opacity:.85}.auth-submit-spinner{border:2px solid #ffffff8c;border-top-color:#fff;border-radius:999px;width:15px;height:15px;animation:.8s linear infinite authSpin;display:none}.auth-submit[data-loading=true] .auth-submit-label{opacity:.85}.auth-submit[data-loading=true] .auth-submit-spinner{display:inline-block}@keyframes authSpin{to{transform:rotate(360deg)}}[data-theme=dark] .auth-aside{background:radial-gradient(420px 280px at 50% 45%, color-mix(in srgb, var(--accent) 22%, var(--surface-2)), transparent 70%), linear-gradient(180deg, var(--surface-2), var(--surface-3))}[data-theme=dark] .auth-input{background:var(--surface-2)}[data-theme=dark] .auth-input:focus-within{background:var(--surface)}[data-theme=dark] .auth-close{background:var(--surface-2)}@media (max-width:760px){.auth-card{grid-template-columns:1fr;max-width:440px}.auth-aside{padding:28px}.auth-illustration{max-width:220px}.auth-main{padding:32px 26px}.auth-title{font-size:24px}}.theme-popover{z-index:200;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);opacity:0;border-radius:14px;width:280px;padding:14px;transition:opacity .14s,transform .14s;display:none;position:fixed;transform:translateY(6px)}.theme-popover[data-open=true]{opacity:1;display:block;transform:translateY(0)}.theme-popover-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:10px;display:flex}.theme-popover-title{color:var(--ink);letter-spacing:.02em;font-size:13px;font-weight:700}.theme-popover-hint{color:var(--muted);font-size:11px}.theme-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.theme-swatch{border:1.5px solid var(--border);background:var(--surface-2);cursor:pointer;text-align:left;font:inherit;color:inherit;border-radius:10px;flex-direction:column;gap:6px;padding:8px;transition:border-color .12s,transform .12s,box-shadow .12s;display:flex}.theme-swatch:hover{border-color:var(--border-strong);transform:translateY(-1px)}.theme-swatch[data-active=true]{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.theme-swatch-preview{border:1px solid var(--border-soft);border-radius:6px;align-items:center;gap:4px;height:30px;padding:5px 7px;display:flex}.theme-swatch-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.theme-swatch-bar{border-radius:2px;flex:1;height:4px}.theme-swatch-name{color:var(--ink);justify-content:space-between;align-items:center;gap:4px;font-size:11.5px;font-weight:600;display:flex}.theme-swatch-check{color:var(--accent);opacity:0;font-size:10px}.theme-swatch[data-active=true] .theme-swatch-check{opacity:1}.theme-popover-backdrop{z-index:199;-webkit-backdrop-filter:blur(3px);opacity:0;background:#080a0c73;transition:opacity .16s;display:none;position:fixed;inset:0}.theme-popover-backdrop[data-open=true]{opacity:1;display:block}@media (max-width:960px){.theme-popover{z-index:200;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;border-radius:16px;width:min(320px,100vw - 24px);max-height:min(72vh,100vh - 72px);padding:12px;overflow:auto;box-shadow:0 24px 56px #00000047}.theme-popover[data-open=true]{transform:none}.theme-popover-head{z-index:1;background:var(--surface);margin-bottom:10px;padding-bottom:8px;position:sticky;top:0}.theme-popover-hint{display:none}.theme-grid{grid-template-columns:1fr 1fr;gap:8px}.theme-swatch{padding:7px}.theme-swatch-preview{height:26px}.theme-swatch-name{font-size:11px}}@media (max-width:420px){.theme-popover{width:calc(100vw - 20px);max-height:min(78vh,100vh - 64px)}.theme-grid{gap:6px}}.menu-hint-backdrop{z-index:118;-webkit-backdrop-filter:blur(2px);opacity:0;background:#080a0c6b;transition:opacity .18s;display:none;position:fixed;inset:0}.menu-hint-backdrop[data-open=true]{opacity:1;display:block}body.menu-hint-active{touch-action:none;overflow:hidden}.menu-hint{z-index:119;pointer-events:none;display:none;position:fixed}.menu-hint[data-open=true]{pointer-events:auto;animation:.24s cubic-bezier(.2,.8,.2,1) both menuHintIn;display:block}@keyframes menuHintIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.mobile-trigger.menu-hint-target{z-index:120;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);position:relative}.menu-hint-bubble{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);pointer-events:auto;border-radius:14px;padding:14px 14px 12px;position:relative}.menu-hint-arrow{background:var(--surface);border-left:1px solid var(--border);border-top:1px solid var(--border);width:14px;height:14px;position:absolute;top:-7px;transform:rotate(45deg)}.menu-hint[data-placement=above] .menu-hint-arrow{top:auto;bottom:-7px;transform:rotate(225deg)}.menu-hint-title{color:var(--ink);letter-spacing:-.01em;margin:0 0 6px;font-size:14px;font-weight:700}.menu-hint-body{color:var(--ink-2);margin:0 0 12px;font-size:12.5px;line-height:1.45}.menu-hint-body strong{color:var(--accent);font-weight:700}.menu-hint-btn{background:var(--accent);width:100%;color:var(--accent-ink,#fff);font:inherit;cursor:pointer;border:0;border-radius:9px;justify-content:center;align-items:center;padding:9px 14px;font-size:12.5px;font-weight:600;transition:filter .12s;display:inline-flex}.menu-hint-btn:hover{filter:brightness(1.05)}@media (min-width:961px){.menu-hint,.menu-hint-backdrop{display:none!important}body.menu-hint-active{touch-action:auto;overflow:auto}}html{-moz-text-size-adjust:100%;text-size-adjust:100%}button,.iconbtn,.mobile-trigger,.nav-item,.sidebar-link,.searchbox{-webkit-tap-highlight-color:transparent;touch-action:manipulation}button:focus-visible,.iconbtn:focus-visible,.mobile-trigger:focus-visible,.searchbox:focus-visible,.nav-item:focus-visible,.sidebar-link:focus-visible,.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mobile-page-title{min-width:0;color:var(--ink);letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;flex:auto;font-size:13px;font-weight:600;display:none;overflow:hidden}.searchbox-placeholder-short{display:none}@media (max-width:960px){.mobile-page-title:not(:empty){display:block}.topbar{padding-top:calc(9px + var(--safe-top));padding-left:calc(12px + var(--safe-left));padding-right:calc(12px + var(--safe-right));min-height:calc(var(--topbar-h) + var(--safe-top));gap:8px;height:auto}.topbar-spacer{flex:0 0 0;width:0;min-width:0;overflow:hidden}.sidenav{padding-top:calc(14px + var(--safe-top));padding-left:calc(12px + var(--safe-left));padding-bottom:calc(14px + var(--safe-bottom));height:100dvh}.sidebar{top:calc(var(--topbar-h) + var(--safe-top));height:calc(100dvh - var(--topbar-h) - var(--safe-top));padding-bottom:var(--safe-bottom)}.sidebar-overlay{top:calc(var(--topbar-h) + var(--safe-top))}.layout{min-height:calc(100dvh - var(--topbar-h) - var(--safe-top))}}@media (max-width:640px){.topbar{padding-left:calc(10px + var(--safe-left));padding-right:calc(10px + var(--safe-right))}.searchbox-placeholder-full{display:none}.searchbox-placeholder-short{display:inline}.note-section h1{gap:8px;font-size:22px}.note-section h2{margin-top:24px;font-size:17px}.note-section h3{font-size:14px}.content{padding:18px 14px 52px}.study-actions .btn{flex:calc(50% - 4px);justify-content:center;min-width:0}.study-actions .btn span{text-overflow:ellipsis;overflow:hidden}}@media (max-width:400px){.searchbox-placeholder{display:none}.searchbox{justify-content:center;max-width:44px;padding:8px 10px}.searchbox svg{margin:0}.mobile-page-title{max-width:34vw;font-size:12px}}@media (pointer:coarse){.iconbtn,.mobile-trigger{width:44px;height:44px}.nav-item,.sidebar-link{min-height:44px;padding-top:10px;padding-bottom:10px}.menu-hint-btn{min-height:44px}.page-nav-btn{min-height:52px;padding:12px 14px}}.study-topbar{justify-content:space-between;align-items:center;gap:10px;min-width:0;margin-bottom:12px;display:flex}.study-eyebrow-inline{text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;margin-bottom:0;overflow:hidden}@media (max-width:960px){.mobile-syllabus-btn{flex-shrink:0;min-height:36px;padding:6px 10px;font-size:11px}}@media (max-width:480px){.study-eyebrow-inline{letter-spacing:.03em;font-size:10px}.mobile-syllabus-btn span{display:none}.mobile-syllabus-btn{padding:8px 10px}}.note-section table{-webkit-overflow-scrolling:touch;border-collapse:collapse;max-width:100%;margin:14px 0;display:block;overflow-x:auto}.note-section table thead,.note-section table tbody,.note-section table tr{table-layout:auto;width:100%;display:table}.note-section th,.note-section td{border:1px solid var(--border);text-align:left;padding:8px 10px;font-size:13px}@media (max-width:640px){.note-section th,.note-section td{padding:6px 8px;font-size:12px}}.upgrade-modal,.auth-modal{padding:max(16px, calc(12px + var(--safe-top))) max(16px, calc(12px + var(--safe-right))) max(16px, calc(12px + var(--safe-bottom))) max(16px, calc(12px + var(--safe-left)));align-items:flex-end}@media (min-width:520px){.upgrade-modal,.auth-modal{align-items:center}}.upgrade-card,.auth-card{max-height:calc(100dvh - 24px - var(--safe-top) - var(--safe-bottom));overscroll-behavior:contain;-webkit-overflow-scrolling:touch;overflow-y:auto}@media (max-width:520px){.upgrade-card{border-radius:16px 16px 0 0;padding:22px 18px 18px}.auth-main{padding:24px 20px 28px}.auth-title{font-size:22px}}.search-modal-card{max-height:calc(100dvh - 12vh - var(--safe-top) - var(--safe-bottom))}@media (max-width:360px){.menu-hint-bubble{border-radius:12px;padding:12px 12px 10px}.menu-hint-title{font-size:13px}.menu-hint-body{font-size:12px}}@media (max-height:480px) and (orientation:landscape){.menu-hint-bubble{padding:10px 12px}.menu-hint-body{margin-bottom:8px}.auth-card,.upgrade-card{max-height:calc(100dvh - 16px)}}@media (max-width:480px){.home-content,.dash-hero,.prob-page,.iv-detail,.cp-detail{padding-left:max(14px, calc(12px + var(--safe-left)));padding-right:max(14px, calc(12px + var(--safe-right)))}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
