:root{--bg:#0d1117;--bg-elevated:#161b22;--border:#30363d;--text:#e6edf3;--muted:#8b949e;--accent:#ff3b3b;--accent-rgb:255,59,59;--accent-blue-rgb:34,198,212;--accent-warm-rgb:255,146,43;--accent-green:#3fb950;--danger:#f85149;--sidebar-width:280px;--scrollbar-size:7px;--scrollbar-thumb:rgba(var(--accent-rgb),0.38);--font:"Segoe UI",system-ui,-apple-system,sans-serif;--mono:ui-monospace,"Cascadia Code","SF Mono",Consolas,monospace}.brand-wordmark{font-family:"Syne",var(--font);font-weight:800;letter-spacing:-.03em;line-height:1.05;color:var(--text);font-synthesis:none}.brand-wordmark-accent{color:var(--accent)}.brand-wordmark--nav{font-size:1.0625rem;font-weight:700;letter-spacing:-.055em;line-height:1.15;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.platform-home{height:auto;min-height:100vh;overflow-x:hidden}.h-nav{position:-webkit-sticky;position:sticky;top:0;z-index:100;padding:0 1.5rem;height:3.25rem;border-bottom:1px solid var(--border);background:rgba(13,17,23,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.h-nav,.h-nav-right{display:flex;align-items:center}.h-nav-right{margin-left:auto;gap:.75rem}.h-nav-brand{display:flex;align-items:center;gap:.55rem;text-decoration:none;color:var(--text);transition:opacity .2s}.h-nav-brand:hover{opacity:.75}.h-nav-sublabel{font-family:var(--font);font-size:.65rem;font-weight:500;letter-spacing:.04em;opacity:.88}.h-nav-brand--home{gap:.65rem}.h-nav-logo{flex-shrink:0;width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);object-fit:cover}.h-hero{position:relative;padding:6rem 1.5rem 5.5rem;overflow:hidden;background-image:linear-gradient(rgba(48,54,61,.2) 1px,transparent 0),linear-gradient(90deg,rgba(48,54,61,.2) 1px,transparent 0);background-size:40px 40px;background-color:var(--bg)}.h-hero:before{content:"";position:absolute;top:-20%;right:-10%;width:50%;height:130%;background:radial-gradient(ellipse at center,rgba(255,59,59,.05) 0,transparent 65%);pointer-events:none}.h-hero-inner{position:relative;max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;grid-column-gap:4rem;column-gap:4rem;grid-row-gap:2.5rem;row-gap:2.5rem;align-items:start}.h-copy-top{grid-row:1}.h-copy-bottom,.h-copy-top{grid-column:1;display:flex;flex-direction:column;gap:2rem}.h-copy-bottom{grid-row:2}.h-eyebrow{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.38em;color:var(--muted);opacity:.6;margin:0}.h-title{font-family:"Syne",var(--font);font-size:clamp(3.4rem,7vw,5.8rem);font-weight:800;line-height:.9;letter-spacing:-.03em;color:var(--text);margin:0}.h-title-accent{color:var(--accent)}.h-body{display:flex;flex-direction:column;gap:.9rem;max-width:38rem}.h-body p{margin:0;font-size:1rem;font-weight:300;line-height:1.75;color:var(--muted)}.h-actions{display:flex;align-items:center;gap:2rem;padding-top:.5rem}.h-cta-primary{display:inline-flex;align-items:center;gap:1rem;font-size:.68rem;font-weight:900;text-transform:uppercase;letter-spacing:.35em;color:var(--accent);text-decoration:none;transition:transform .3s ease}.h-cta-primary:hover{transform:translateX(5px)}.h-cta-rule{width:3.75rem;height:2px;background:var(--accent);transition:width .45s ease;flex-shrink:0}.h-cta-primary:hover .h-cta-rule{width:5.25rem}.h-visual{grid-column:2;grid-row:1/span 2;align-self:center;position:relative}.h-status-chip{position:absolute;top:-1.75rem;right:-.75rem;display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:.75rem;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:10;animation:h-chip-float 6s ease-in-out infinite}.h-status-dot{width:7px;height:7px;border-radius:50%;background:#3fb950;animation:h-status-pulse 2s ease-in-out infinite;flex-shrink:0}.h-status-text{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--muted);white-space:nowrap}.h-orb-panel{position:relative;aspect-ratio:1/1;max-width:460px;margin:0 auto;background:rgba(22,27,34,.55);border:1px solid var(--border);border-radius:2rem;overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center}.h-grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(48,54,61,.3) 1px,transparent 0),linear-gradient(90deg,rgba(48,54,61,.3) 1px,transparent 0);background-size:28px 28px;pointer-events:none}.h-orb{position:absolute;border-radius:50%;filter:blur(60px)}.h-orb--1{width:55%;height:55%;background:rgba(255,59,59,.18);top:10%;left:10%;animation:h-orb-drift 8s ease-in-out infinite}.h-orb--2{width:45%;height:45%;background:rgba(59,130,246,.14);bottom:10%;right:10%;animation:h-orb-drift 10s ease-in-out infinite reverse}.h-orb--3{width:35%;height:35%;background:rgba(16,185,129,.1);top:40%;left:40%;animation:h-orb-drift 6s ease-in-out 2s infinite}.h-orb-label{position:relative;z-index:2;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.45rem .6rem;max-width:90%;text-align:center}.h-orb-label-line{font-family:var(--mono);font-size:clamp(.7rem,2vw,1rem);font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);opacity:.7}.h-orb-label-accent{color:var(--accent);opacity:1}.h-orb-label-sep{font-family:var(--mono);font-size:.75rem;color:var(--border);opacity:.8}.h-courses{background:var(--bg-elevated);border-top:1px solid var(--border);padding:5rem 1.5rem 6rem}.h-container{max-width:1160px;margin:0 auto}.h-section-header{margin-bottom:3.5rem;display:flex;flex-direction:column;gap:.75rem}.h-section-title{font-family:"Syne",var(--font);font-size:clamp(1.8rem,4vw,2.75rem);font-weight:800;color:var(--text);letter-spacing:-.025em;margin:0}.h-section-sub{font-size:.9rem;font-weight:300;color:var(--muted);line-height:1.6;max-width:44rem;margin:0}.h-course-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1rem;gap:1rem;align-items:stretch}.h-course-card{display:flex;flex-direction:column;gap:.85rem;padding:1.75rem 1.5rem 1.4rem;background:var(--bg);border:1px solid var(--border);border-radius:1rem;text-decoration:none;color:var(--text);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;position:relative;overflow:hidden;height:100%;min-height:0}.h-course-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);opacity:0;transition:opacity .25s ease;border-radius:1rem 0 0 1rem}.h-course-card--live:hover{transform:translateY(-4px);border-color:hsla(0,0%,100%,.12);box-shadow:0 16px 40px rgba(0,0,0,.4)}.h-course-card--live:hover:before{opacity:1}.h-course-card--soon{opacity:.5;cursor:default;border-style:dashed}.h-course-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.h-course-meta{display:flex;flex-direction:column;gap:.35rem}.h-course-tag{display:inline-block;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;padding:.2rem .55rem;border-radius:3px;width:-moz-fit-content;width:fit-content}.h-course-tag--live{background:rgba(63,185,80,.12);color:#3fb950;border:1px solid rgba(63,185,80,.3)}.h-course-tag--soon{background:hsla(212,9%,58%,.1);color:var(--muted);border:1px solid var(--border)}.h-course-lang{font-size:.6rem;font-weight:600;font-family:var(--mono);color:var(--muted);opacity:.7;letter-spacing:.05em}.h-course-icon{width:40px;height:40px;flex-shrink:0;color:var(--accent);opacity:.8;transition:opacity .2s}.h-course-card--live:hover .h-course-icon{opacity:1}.h-course-icon--muted{color:var(--muted);opacity:.3}.h-course-title{font-family:"Syne",var(--font);font-size:1.25rem;font-weight:700;color:var(--text);margin:0;line-height:1.15}.h-course-desc,.h-course-title--muted{color:var(--muted)}.h-course-desc{font-size:.82rem;font-weight:300;line-height:1.6;margin:0;flex-grow:1}.h-course-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid rgba(48,54,61,.6);margin-top:auto}.h-course-stats{display:flex;align-items:center;gap:.4rem;font-size:.62rem;font-weight:600;font-family:var(--mono);color:var(--muted);opacity:.65;text-transform:uppercase;letter-spacing:.06em}.h-course-stat-sep,.h-course-stats--muted{opacity:.4}.h-course-cta{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);opacity:0;transition:opacity .2s ease,transform .25s ease;display:inline-block;white-space:nowrap}.h-course-card--live:hover .h-course-cta{opacity:1;transform:translateX(2px)}@keyframes h-orb-drift{0%,to{transform:translate(0) scale(1)}33%{transform:translate(8%,-6%) scale(1.05)}66%{transform:translate(-5%,8%) scale(.97)}}@keyframes h-status-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.88)}}@keyframes h-chip-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media (max-width:1024px){.h-course-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:860px){.h-hero-inner{grid-template-columns:1fr;row-gap:2.5rem}.h-copy-bottom,.h-copy-top,.h-visual{grid-column:1;grid-row:auto}.h-visual{align-self:auto;display:flex;flex-direction:column;align-items:stretch;gap:.75rem;max-width:440px;margin:0 auto;width:100%}.h-status-chip{position:relative;top:auto;right:auto;align-self:flex-end}.h-title{font-size:clamp(3rem,11vw,4.5rem)}}@media (max-width:580px){.h-hero{padding:3.5rem 1.25rem 4rem}.h-courses{padding:3.5rem 1.25rem 4.5rem}.h-course-grid{grid-template-columns:1fr}.h-nav{padding:0 1.25rem}.h-orb-panel{aspect-ratio:unset;height:200px}}.opencv-landing{height:auto;min-height:100vh;overflow-x:hidden}.l-nav{position:-webkit-sticky;position:sticky;top:0;z-index:100;justify-content:space-between;padding:0 1.5rem;height:3.25rem;border-bottom:1px solid var(--border);background:rgba(13,17,23,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.l-nav,.l-nav-brand{display:flex;align-items:center}.l-nav-brand{gap:.55rem;text-decoration:none;color:var(--text);transition:opacity .2s}.l-nav-brand:hover{opacity:.75}.l-nav-logo{flex-shrink:0;width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);object-fit:cover}.l-nav-enter{display:inline-flex;align-items:center;gap:.4rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);text-decoration:none;padding:.4rem .9rem;border:1px solid rgba(255,59,59,.35);border-radius:4px;transition:background .2s,border-color .2s}.l-nav-enter:hover{background:rgba(255,59,59,.08);border-color:var(--accent)}.l-nav-arrow{transition:transform .25s ease;display:inline-block}.l-nav-enter:hover .l-nav-arrow{transform:translateX(3px)}.l-nav-right{display:flex;align-items:center;gap:1.25rem}.l-nav-courses-link{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);text-decoration:none;transition:color .2s ease}.l-nav-courses-link:hover{color:var(--text)}.l-hero{position:relative;padding:5rem 1.5rem;overflow:hidden;background-image:linear-gradient(rgba(48,54,61,.25) 1px,transparent 0),linear-gradient(90deg,rgba(48,54,61,.25) 1px,transparent 0);background-size:32px 32px;background-color:var(--bg)}.l-hero:before{content:"";position:absolute;top:-30%;right:-5%;width:55%;height:110%;background:radial-gradient(ellipse at center,rgba(255,59,59,.055) 0,transparent 68%);pointer-events:none}.l-hero-inner{position:relative;max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;grid-column-gap:4rem;column-gap:4rem;grid-row-gap:2.5rem;row-gap:2.5rem;align-items:start}.l-copy-top{grid-row:1}.l-copy-bottom,.l-copy-top{grid-column:1;display:flex;flex-direction:column;gap:2rem}.l-copy-bottom{grid-row:2}.l-eyebrow{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.38em;color:var(--muted);opacity:.6}.l-title{font-family:"Syne",var(--font);font-size:clamp(3.2rem,7vw,5.5rem);font-weight:800;line-height:.92;letter-spacing:-.03em;color:var(--text);margin:0}.l-title-accent{color:var(--accent);display:inline}.l-body{display:flex;flex-direction:column;gap:.9rem;max-width:38rem}.l-body p{margin:0;font-size:1rem;font-weight:300;line-height:1.75;color:var(--muted)}.l-actions{display:flex;flex-wrap:wrap;align-items:center;gap:2rem;padding-top:.5rem}.l-cta-primary{display:inline-flex;align-items:center;gap:1rem;font-size:.68rem;font-weight:900;text-transform:uppercase;letter-spacing:.35em;color:var(--accent);text-decoration:none;transition:transform .3s ease}.l-cta-primary:hover{transform:translateX(5px)}.l-cta-rule{width:3.75rem;height:2px;background:var(--accent);transition:width .45s ease;flex-shrink:0}.l-cta-primary:hover .l-cta-rule{width:5.25rem}.l-cta-secondary{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--muted);text-decoration:none;transition:color .2s ease}.l-cta-secondary:hover{color:var(--text)}.l-visual{grid-column:2;grid-row:1/span 2;align-self:center;position:relative}.l-status-chip{position:absolute;top:-1.75rem;right:-.75rem;display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:.75rem;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:10;animation:chip-float 6s ease-in-out infinite}.l-status-dot{width:7px;height:7px;border-radius:50%;background:#3fb950;animation:status-pulse 2s ease-in-out infinite;flex-shrink:0}.l-status-text{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--muted);white-space:nowrap}.pipeline-panel{position:relative;background:rgba(22,27,34,.6);border:1px solid var(--border);border-radius:2rem;padding:2rem;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);overflow:hidden;aspect-ratio:1/1;max-width:460px;margin:0 auto}.pipeline-panel:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 40%,rgba(255,59,59,.04) 0,transparent 60%);pointer-events:none}.pipeline-svg{width:100%;height:100%;overflow:visible;display:block}.pipeline-hint{position:absolute;bottom:1.25rem;left:0;right:0;text-align:center;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.25em;color:var(--muted);opacity:.3;animation:hint-pulse 3s ease-in-out infinite}.pipe-edge{stroke:var(--border);stroke-width:.35;stroke-dasharray:2 2.5;opacity:.25;transition:stroke .4s ease,opacity .4s ease,stroke-width .4s ease,stroke-dasharray .3s ease}.pipe-edge--active{stroke:var(--accent);stroke-width:.9;stroke-dasharray:none;opacity:.65}.pipe-node{cursor:pointer;animation:pipe-float 3.5s ease-in-out infinite}.pipe-circle{fill:var(--bg);stroke:var(--node-color);stroke-width:1.5;transition:fill .35s ease,filter .35s ease,r .25s ease}.pipe-node--active .pipe-circle{fill:var(--node-color);filter:drop-shadow(0 0 6px var(--node-color))}.pipe-node--connected .pipe-circle{fill:hsla(0,0%,100%,.04);filter:drop-shadow(0 0 3px var(--node-color))}.pipe-label{font-family:var(--mono);font-size:3.75px;font-weight:700;text-anchor:middle;fill:var(--muted);text-transform:uppercase;letter-spacing:.4px;opacity:.4;pointer-events:none;transition:fill .3s ease,opacity .3s ease}.pipe-node--active .pipe-label,.pipe-node--connected .pipe-label{fill:var(--text);opacity:1}.l-curriculum{background:var(--bg-elevated);border-top:1px solid var(--border);padding:5rem 1.5rem 6rem}.l-container{max-width:1160px;margin:0 auto}.l-section-header{margin-bottom:3.5rem;display:flex;flex-direction:column;gap:.75rem}.l-section-title{font-family:"Syne",var(--font);font-size:clamp(1.8rem,4vw,2.75rem);font-weight:800;color:var(--text);letter-spacing:-.025em;margin:0}.l-section-sub{font-size:.9rem;font-weight:300;color:var(--muted);line-height:1.6;max-width:44rem;margin:0}.phase-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1rem;gap:1rem}.phase-card{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem 1.4rem 1.25rem;background:var(--bg);border:1px solid var(--border);border-radius:.75rem;text-decoration:none;color:var(--text);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;position:relative;overflow:hidden}.phase-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--card-accent,var(--accent));opacity:0;transition:opacity .25s ease;border-radius:.75rem 0 0 .75rem}.phase-card:hover{transform:translateY(-3px);border-color:hsla(0,0%,100%,.12);box-shadow:0 12px 32px rgba(0,0,0,.35)}.phase-card:hover:before{opacity:1}.phase-card-header{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.phase-number{font-family:var(--mono);font-size:2rem;font-weight:700;line-height:1;color:var(--card-accent,var(--accent));letter-spacing:-.05em;opacity:.8;transition:opacity .2s}.phase-card:hover .phase-number{opacity:1}.phase-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);background:hsla(0,0%,100%,.05);border:1px solid var(--border);padding:.2rem .5rem;border-radius:3px;white-space:nowrap}.phase-card-title{font-family:"Syne",var(--font);font-size:1rem;font-weight:700;color:var(--text);margin:0;line-height:1.2}.phase-card-desc{font-size:.8rem;font-weight:300;color:var(--muted);line-height:1.55;margin:0;flex-grow:1}.phase-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.5rem;border-top:1px solid rgba(48,54,61,.6);margin-top:auto}.phase-weeks{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);opacity:.6;font-family:var(--mono)}.phase-cta-arrow{font-size:.9rem;color:var(--card-accent,var(--accent));opacity:0;transition:opacity .2s ease,transform .25s ease;display:inline-block}.phase-card:hover .phase-cta-arrow{opacity:1;transform:translateX(3px)}@keyframes pipe-float{0%,to{transform:translateY(0)}50%{transform:translateY(-1.2px)}}@keyframes status-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.88)}}@keyframes chip-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes hint-pulse{0%,to{opacity:.3}50%{opacity:.12}}@media (max-width:1024px){.phase-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:860px){.l-hero-inner{grid-template-columns:1fr;row-gap:2.5rem}.l-copy-bottom,.l-copy-top,.l-visual{grid-column:1;grid-row:auto}.l-visual{align-self:auto;display:flex;flex-direction:column;align-items:stretch;gap:.75rem;max-width:440px;margin:0 auto;width:100%}.l-status-chip{position:relative;top:auto;right:auto;align-self:flex-end}.l-title{font-size:clamp(3rem,11vw,4.5rem)}}@media (max-width:580px){.l-hero{padding:3.5rem 1.25rem 4rem}.l-curriculum{padding:3.5rem 1.25rem 4.5rem}.phase-grid{grid-template-columns:1fr}.l-nav{padding:0 1.25rem}.pipeline-panel{aspect-ratio:unset;height:200px}}.app{min-height:100vh;height:100vh;max-height:100vh}.app,.sidebar{display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);flex-shrink:0;border-right:1px solid var(--border);background:var(--bg-elevated);flex-direction:column}.brand{padding:1rem 1rem .75rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.brand-text{min-width:0}.brand h1{margin:0;font-size:1.15rem;font-weight:600}.brand-home-link{display:flex;align-items:center;gap:.55rem;color:inherit;text-decoration:none;min-width:0;transition:opacity .2s ease}.brand-home-link:hover{opacity:.75}.brand-title{display:flex;align-items:center;gap:.55rem;min-width:0}.brand-logo{width:34px;height:34px;flex:0 0 34px;flex-shrink:0;border-radius:8px;background:var(--bg);border:1px solid var(--border);object-fit:cover}.brand-title .brand-wordmark{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tagline{margin:.25rem 0 0;font-size:.8rem;color:var(--muted)}.tagline-opencv-link,.tagline-track-link{color:var(--muted);font-weight:inherit;text-decoration:none;transition:color .2s ease}.tagline-opencv-link:hover,.tagline-track-link:hover{color:var(--text);text-decoration:underline}.sidebar-toggle{flex-shrink:0;padding:.25rem .55rem;border-radius:6px;font-size:.7rem;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;align-self:flex-start}.sidebar-toggle:hover{background:#21262d}.sidebar-drawer-head{display:none}.brand-collapsed-logo{display:none;align-items:center;justify-content:center;flex-shrink:0;color:inherit}.brand-logo--rail{width:28px;height:28px;flex:0 0 28px;border-radius:6px;display:block;overflow:hidden;object-position:center}@media (min-width:961px){.sidebar{transition:width .2s ease,min-width .2s ease}.sidebar.sidebar--collapsed{width:3rem;min-width:3rem}.sidebar.sidebar--collapsed .brand{flex-direction:column;gap:.45rem;justify-content:center;padding:.5rem .35rem;border-bottom-color:transparent}.sidebar.sidebar--collapsed .brand-text{display:none}.sidebar.sidebar--collapsed .brand-collapsed-logo{display:flex;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.sidebar.sidebar--collapsed .lesson-nav,.sidebar.sidebar--collapsed .sidebar-auth{display:none}.sidebar.sidebar--collapsed .sidebar-toggle{align-self:center;font-size:1.1rem;line-height:1;padding:.4rem .35rem}}@media (max-width:960px){.sidebar-toggle{display:none}.sidebar-close-btn{display:inline-flex}.brand-collapsed-logo{display:none!important}}.sidebar-close-btn{display:none;align-items:center;justify-content:center;flex-shrink:0;width:2rem;height:2rem;padding:0;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:1.25rem;line-height:1;cursor:pointer;font-family:inherit}.sidebar-close-btn:hover{background:#21262d}.lesson-nav{flex:1 1;overflow-y:auto;overflow-x:hidden;padding:.5rem 0 1rem;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent}.lesson-nav::-webkit-scrollbar{width:var(--scrollbar-size)}.lesson-nav::-webkit-scrollbar-track{margin:6px 0;background:transparent;border-radius:100px}.lesson-nav::-webkit-scrollbar-thumb{border-radius:100px;border:2px solid transparent;background-clip:padding-box;background-image:linear-gradient(180deg,rgba(var(--accent-rgb),.5) 0,rgba(var(--accent-blue-rgb),.35) 100%);box-shadow:inset 0 0 0 1px hsla(0,0%,100%,.06)}.lesson-nav::-webkit-scrollbar-thumb:hover{background-image:linear-gradient(180deg,rgba(var(--accent-rgb),.72) 0,rgba(var(--accent-blue-rgb),.5) 100%)}.lesson-nav::-webkit-scrollbar-thumb:active{background-image:linear-gradient(180deg,rgba(var(--accent-blue-rgb),.55) 0,rgba(var(--accent-rgb),.45) 100%)}.phase{margin-top:.75rem}.phase-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:.35rem 1rem}.lesson-btn{display:block;width:100%;text-align:left;padding:.5rem 1rem .5rem 1.25rem;background:transparent;color:var(--text);font-size:.85rem;cursor:pointer;border:none;border-left:3px solid transparent;font-family:inherit}.lesson-btn:hover{background:linear-gradient(90deg,rgba(var(--accent-rgb),.12),rgba(var(--accent-blue-rgb),.08))}.lesson-btn.active{border-left-color:var(--accent);background:linear-gradient(90deg,rgba(var(--accent-rgb),.16),rgba(var(--accent-blue-rgb),.1))}.lesson-btn .wk{color:var(--muted);font-size:.75rem;margin-right:.35rem}.main{flex:1 1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow-x:hidden;overflow-y:auto;padding-bottom:max(.75rem,env(safe-area-inset-bottom,0px))}.code-tab-preamble{flex-shrink:0;padding:.45rem .9rem .65rem;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.code-tab-preamble.theory-inner h3,.code-tab-preamble.theory-inner h3.lab-lesson-subhead{margin-top:0}.theory-body--code{display:flex;flex-direction:column;flex:1 1;min-height:0;overflow:visible}.workspace.workspace--in-panel{flex:1 1;min-height:0;position:relative;border:1px solid var(--border);border-top:none;border-bottom:none;border-radius:0;overflow:visible;background:var(--bg);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.045),0 12px 40px rgba(0,0,0,.42)}.workspace.workspace--in-panel .editor-pane{min-height:clamp(360px,48vh,720px)}@media (min-width:961px){.workspace.workspace--in-panel{grid-template-rows:minmax(min(460px,54vh),auto)}}.toolbar{flex-shrink:0;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg)}.toolbar,.toolbar-left{display:flex;align-items:center}.toolbar-left{gap:.65rem;min-width:0;flex:1 1}.toolbar-heading{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .5rem;min-width:0}.toolbar-menu-btn{display:none;align-items:center;justify-content:center;flex-shrink:0;width:2.5rem;height:2.5rem;padding:0;border-radius:8px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font-size:1.15rem;line-height:1;cursor:pointer;font-family:inherit}.toolbar-menu-btn:hover{background:#21262d}.lab-header-brand{display:none;flex-shrink:0;min-width:0;padding:0;border:none;margin:0;align-items:flex-start}.lab-header-brand .brand-text{min-width:0}.lab-header-brand .brand-title{margin:0}.lab-header-brand .brand-home-link{align-items:center}.lab-header-brand-tagline{margin:.2rem 0 0}@media (max-width:380px){.lab-header-brand-tagline{display:none}}@media (min-width:961px){.sidebar-drawer-head{display:none!important}}@media (max-width:960px){.sidebar-brand-panel{display:none!important}.lab-header-brand{display:flex}.sidebar-drawer-head{display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:.5rem;padding:.65rem 1rem;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.sidebar-drawer-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}}.toolbar-left h2{margin:0;font-size:1.1rem;font-weight:600}.badge{display:inline-block;margin-left:.5rem;font-size:.75rem;color:var(--muted)}.toolbar-actions{display:flex;align-items:center;gap:.5rem}.btn{padding:.45rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;border:1px solid var(--border);font-family:inherit}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-primary.btn-run--busy{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;background:#21262d;border-color:#484f58;color:var(--text)}.btn-primary.btn-run--busy:before{content:"";width:.85rem;height:.85rem;border:2px solid rgba(230,237,243,.25);border-top-color:rgba(230,237,243,.9);border-radius:50%;flex-shrink:0;animation:btn-run-spin .65s linear infinite}@keyframes btn-run-spin{to{transform:rotate(1turn)}}.btn-primary.btn-run--busy:hover:not(:disabled){filter:brightness(1.05)}.btn-primary.btn-run--busy:disabled{opacity:1;cursor:wait}.btn-primary.btn-run--busy:disabled:hover{filter:none}.btn-secondary{background:var(--bg-elevated);color:var(--text)}.btn-secondary:hover:not(:disabled){background:#21262d}.status{font-size:.8rem;color:var(--muted);min-width:5rem}.status.ok{color:var(--accent-green)}.status.err{color:var(--danger)}.lesson-at-a-glance{flex-shrink:0;border-bottom:1px solid var(--border);background:var(--bg);padding:.65rem 1rem .75rem}.lesson-at-a-glance[hidden]{display:none!important}.at-a-glance-inner{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem 1.5rem;gap:1rem 1.5rem;max-width:100%}@media (max-width:720px){.at-a-glance-inner{grid-template-columns:1fr}}.at-a-glance-block[hidden]{display:none!important}.at-a-glance-heading{margin:0 0 .4rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600}.at-a-glance-body{font-size:.85rem;line-height:1.5;color:var(--text)}.at-a-glance-body ul{margin:0;padding-left:1.15rem}.at-a-glance-body li{margin-bottom:.35rem}.at-a-glance-body li:last-child{margin-bottom:0}.at-a-glance-body code{font-family:var(--mono);font-size:.82em;background:var(--bg-elevated);padding:.1em .35em;border-radius:4px}.theory{display:flex;flex-direction:column;min-height:0;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.theory:not(.theory--workspace){flex:0 0 auto}.theory.theory--workspace{flex:1 1;min-height:0;overflow:visible;border-bottom:none}.theory-tab-bar{flex-shrink:0;flex-wrap:wrap}.theory-tab-panel-title{margin:0 0 .5rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600}.theory-inner .lab-phase-intro{margin-bottom:.75rem;padding:.65rem .75rem;border:1px solid rgba(var(--accent-rgb),.42);background:rgba(var(--accent-rgb),.06);border-radius:4px}.theory-inner .lab-phase-intro--footer{margin-top:1rem;margin-bottom:0}.theory-inner .lab-intro-hook{margin:0 0 .65rem}.theory-inner .lab-intro-pipeline{margin:0 0 .75rem;padding:.5rem .65rem .52rem;border-radius:4px;border:1px solid rgba(var(--accent-blue-rgb),.45);background:linear-gradient(135deg,rgba(var(--accent-blue-rgb),.12) 0,rgba(var(--accent-blue-rgb),.04) 100%);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.035);font-size:.87rem;line-height:1.52;color:color-mix(in srgb,var(--text) 93%,var(--muted) 7%)}.theory-inner .lab-intro-pipeline strong:first-child{color:var(--text);font-weight:650}.theory-inner .lab-intro-anchor{margin:0 0 .85rem;padding:.55rem .7rem;border-radius:4px;border:1px solid rgba(var(--accent-warm-rgb),.52);background:rgba(var(--accent-warm-rgb),.11);font-size:.88rem}.theory-inner .lab-intro-anchor code{font-size:.9em}.theory-inner .lab-intro-why{margin:0 0 .85rem;font-size:.88rem;line-height:1.55;color:color-mix(in srgb,var(--text) 94%,var(--muted) 6%)}.theory-inner .lab-intro-why strong:first-child{color:var(--text);font-weight:650}.theory-inner .lab-intro-subhead{margin:.65rem 0 .35rem;font-size:.82rem;font-weight:600;color:var(--text);letter-spacing:.02em}.theory-inner .lab-intro-subhead:first-of-type{margin-top:0}.theory-inner h3.lab-lesson-subhead{margin:1.1rem 0 .35rem;font-size:.82rem;font-weight:500;color:#97a0a6;color:color-mix(in srgb,var(--muted) 82%,rgb(var(--accent-blue-rgb)) 18%);letter-spacing:.02em}.theory-inner h3.lab-lesson-subhead.lab-lesson-subhead--rule{padding-bottom:.4rem;margin-bottom:.45rem;border-bottom:1px solid rgba(var(--accent-rgb),.22)}.theory-inner h3.lab-lesson-subhead.lab-lesson-subhead--pill{display:inline-block;margin-top:1.2rem;padding:.22rem .55rem;border-radius:6px;background:rgba(var(--accent-rgb),.07);border:1px solid rgba(var(--accent-rgb),.18)}.theory-inner h3.lab-lesson-subhead.lab-lesson-subhead--dot{display:flex;align-items:center;gap:.45rem}.theory-inner h3.lab-lesson-subhead.lab-lesson-subhead--dot:before{content:"";flex:0 0 6px;width:6px;height:6px;border-radius:50%;background:rgba(var(--accent-blue-rgb),.55)}.theory-inner h3.lab-lesson-subhead.lab-lesson-subhead--caps{font-size:.72rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.theory-inner .lab-intro-bullets{margin:.25rem 0 .65rem;padding-left:1.2rem}.theory-inner .lab-intro-bullets li{margin:.2rem 0}.theory-inner .lab-intro-prereq{margin:.35rem 0 .85rem;padding:.45rem .6rem;border-radius:4px;border:1px solid var(--border);background:var(--bg-elevated);font-size:.84rem;color:var(--muted)}.theory-inner .lab-intro-story{margin:.35rem 0 0;line-height:1.6}.theory-inner .lab-bench-note{margin:.65rem 0 .85rem;padding:.5rem .65rem .55rem;border-radius:4px;border:1px solid rgba(248,81,73,.55);background:rgba(248,81,73,.1);font-size:.86rem;line-height:1.48;color:color-mix(in srgb,var(--text) 92%,var(--muted) 8%)}.theory-inner .lab-bench-note strong:first-child{color:var(--text);font-weight:650}.theory-inner .lab-lesson-why{margin:.5rem 0 .85rem;padding:.5rem .65rem .55rem;border-radius:4px;border:1px solid rgba(167,139,250,.45);background:rgba(139,92,246,.09);font-size:.88rem;line-height:1.5;color:color-mix(in srgb,var(--text) 93%,var(--muted) 7%)}.theory-inner .lab-lesson-why strong:first-child{color:var(--text);font-weight:650}.theory-body{min-height:0}.theory:not(.theory--workspace) .theory-body{overflow:visible}.theory:not(.theory--workspace) .theory-body:not(.theory-body--code){min-height:min(8rem,40vh)}.theory-inner{padding:1rem 1.25rem;font-size:.9rem;line-height:1.55}.theory:not(.theory--workspace) .theory-body:has(.theory-inner--paywall){min-height:min(70vh,48rem)}.theory-inner--paywall{position:relative;overflow:hidden;min-height:min(70vh,48rem);width:100%;align-self:stretch}.theory-inner--paywall:not(:has(.lab-paywall-panel-cta)){display:flex;align-items:center;justify-content:center}.theory-inner--paywall:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 110% 65% at 50% -5%,rgba(var(--accent-rgb),.2),transparent 52%),radial-gradient(ellipse 55% 45% at 95% 40%,rgba(var(--accent-blue-rgb),.09),transparent 50%),linear-gradient(168deg,color-mix(in srgb,var(--bg-elevated) 90%,var(--bg)) 0,var(--bg) 55%,color-mix(in srgb,var(--bg) 94%,#08080a) 100%)}.theory-tab-bar--paywall{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.theory-tab-bar--paywall .editor-tab:not(.editor-tab--active){opacity:.48}.theory-inner--paywall-teaser .lab-paywall-teaser-read{position:absolute;top:1rem;left:1.25rem;right:1.25rem;z-index:1;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;max-height:min(26vh,14rem);overflow:hidden;mask-image:linear-gradient(180deg,#000 0,#000 58%,transparent);-webkit-mask-image:linear-gradient(180deg,#000 0,#000 58%,transparent)}.lab-paywall-teaser-section--intro{margin-bottom:1rem}.lab-paywall-teaser-section--lesson{margin-bottom:0}.lab-paywall-teaser-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 .45rem;font-family:var(--mono);opacity:.88}.lab-paywall-teaser-sharp{padding:0 0 .75rem;font-size:.9rem;line-height:1.55;color:var(--text)}.lab-paywall-teaser-blur{position:relative;padding:0 0 .35rem;max-height:min(28vh,15rem);overflow:hidden}.lab-paywall-teaser-blur-content{padding:0 0 .75rem;font-size:.9rem;line-height:1.55;color:var(--text);filter:blur(5px);opacity:.48;transform:translateZ(0);max-height:min(26vh,14rem);overflow:hidden;mask-image:linear-gradient(180deg,#000 0,#000 55%,transparent);-webkit-mask-image:linear-gradient(180deg,#000 0,#000 55%,transparent)}.lab-paywall-teaser-read .lab-demo-embed,.lab-paywall-teaser-read .lab-lesson-video-embed{pointer-events:none}.lab-paywall-teaser-sharp .lab-demo-embed,.lab-paywall-teaser-sharp .lab-lesson-video-embed{outline:2px dashed rgba(var(--accent-rgb),.42);outline-offset:3px}.lab-paywall-teaser-sharp .lab-demo-embed iframe,.lab-paywall-teaser-sharp .lab-lesson-video-embed iframe{filter:blur(3px);opacity:.62}.lab-paywall-teaser-blur-content .lab-demo-embed,.lab-paywall-teaser-blur-content .lab-lesson-video-embed{outline:2px dashed rgba(var(--accent-rgb),.5);outline-offset:4px;margin-top:.5rem;margin-bottom:.75rem}.lab-paywall-teaser-blur-content .lab-demo-embed iframe,.lab-paywall-teaser-blur-content .lab-lesson-video-embed iframe{pointer-events:none!important}.theory-inner--paywall .lab-paywall-preview-ellipsis{margin:.5rem 0 0;color:var(--muted);font-style:italic}.theory-inner--paywall .lab-paywall-panel-cta{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);z-index:2;display:flex;justify-content:center;width:100%;margin:0;padding:0;pointer-events:auto}.lab-paywall-panel{position:relative;z-index:1;width:100%;max-width:26rem;display:flex;flex-direction:column;gap:1.5rem;padding:2rem 2.25rem;border-radius:14px;border:1px solid rgba(var(--accent-rgb),.28);background:linear-gradient(180deg,rgba(var(--accent-rgb),.075) 0,rgba(var(--accent-rgb),0) 55%),var(--bg-elevated);box-shadow:0 8px 40px rgba(0,0,0,.35),inset 0 1px 0 hsla(0,0%,100%,.04)}.lab-paywall-brand{display:flex;align-items:center;gap:.75rem}.lab-paywall-logo{border-radius:8px;border:1px solid var(--border);background:var(--bg);flex-shrink:0}.lab-paywall-brand-text{display:flex;flex-direction:column;gap:.1rem}.lab-paywall-wordmark{font-family:"Syne",var(--font);font-size:1rem;font-weight:800;letter-spacing:-.055em;line-height:1.1;color:var(--text);-webkit-font-smoothing:antialiased}.lab-paywall-wordmark-accent{color:var(--accent)}.lab-paywall-sublabel{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);opacity:.55;font-family:var(--mono)}.lab-paywall-intro{display:flex;flex-direction:column;gap:.6rem}.lab-paywall-heading{font-family:"Syne",var(--font);font-size:clamp(1.45rem,4vw,1.8rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;color:var(--text);margin:0;-webkit-font-smoothing:antialiased}.lab-paywall-body{font-size:.875rem;line-height:1.6;color:var(--muted);margin:0;max-width:34ch}.lab-paywall-ctas{display:flex;flex-direction:column;gap:.6rem}.lab-paywall-subscribe-btn,.theory-inner .lab-paywall-subscribe-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.82rem 1rem;background:var(--accent);border:none;border-radius:8px;color:#fff!important;font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;text-decoration:none;cursor:pointer;transition:opacity .18s ease,transform .15s ease}.lab-paywall-subscribe-btn:hover{opacity:.88;transform:translateY(-1px)}.lab-paywall-subscribe-btn:active{transform:translateY(0);opacity:1}.lab-paywall-auth-wrap{width:100%}.lab-paywall-signin-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text);background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color .2s ease,background .2s ease}.lab-paywall-signin-btn:hover{border-color:hsla(0,0%,100%,.14);background:rgba(48,54,61,.5)}.lab-paywall-auth-wrap .nav-user-chip{width:100%;justify-content:center;padding:.8rem 1rem;border-radius:8px;font-size:.72rem}.lab-paywall-explore{padding-top:.9rem;margin-top:.15rem;border-top:1px solid rgba(var(--accent-rgb),.14);text-align:center}.lab-paywall-explore-link,.theory-inner .lab-paywall-explore-link{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;font-family:var(--mono);font-size:.74rem;font-weight:600;letter-spacing:.02em;color:var(--muted)!important;text-decoration:none!important;transition:color .18s ease}.lab-paywall-explore-link:hover,.theory-inner .lab-paywall-explore-link:hover{color:var(--accent)!important}.lab-paywall-explore-link:focus-visible{outline:2px solid rgba(var(--accent-rgb),.45);outline-offset:3px;border-radius:4px}.lab-paywall-explore-arrow{font-size:.85em;opacity:.65;transition:transform .18s ease,opacity .18s ease}.lab-paywall-explore-link:hover .lab-paywall-explore-arrow{transform:translateX(2px);opacity:1}.theory-inner h2{margin:1.25rem 0 .5rem;font-size:1.12rem;font-weight:650;line-height:1.35;letter-spacing:-.01em;color:var(--text)}.theory-inner h2:first-child{margin-top:0}.theory-inner h3{margin:1.15rem 0 .45rem;font-size:1rem;font-weight:650;line-height:1.35;letter-spacing:.01em;color:var(--text)}.theory-inner h3.lab-lesson-section{margin-top:1.35rem;padding:.35rem 0 .35rem .65rem;border-left:3px solid rgba(var(--accent-rgb),.85);font-size:1.02rem;font-weight:700}.theory-inner h3.lab-lesson-section:first-child{margin-top:0}.theory-inner h4{margin:.85rem 0 .35rem;font-size:.78rem;font-weight:600;color:var(--muted);letter-spacing:.02em;text-transform:uppercase}.theory-inner p{margin:.5rem 0}.theory-inner ul{margin:.35rem 0 .75rem 1.25rem}.theory-inner code{font-family:var(--mono);font-size:.82em;background:var(--bg);padding:.1rem .35rem;border-radius:4px}.lab-api-ref{margin:.35rem 0 .75rem;padding:0}.lab-api-ref dt{margin:.85rem 0 .2rem;font-weight:600;font-size:.86rem}.lab-api-ref dt:first-child{margin-top:0}.lab-api-ref dd{margin:0 0 0 .75rem;padding:0;color:var(--muted);font-size:.86rem;line-height:1.45}.lab-lesson-video{margin:0 0 1rem;padding:0}.lab-lesson-video video{display:block;width:100%;max-height:min(42vh,28rem);border-radius:10px;border:1px solid var(--border);background:#000}.lab-lesson-video figcaption{margin:.5rem 0 0;font-size:.82rem;color:var(--muted);line-height:1.45}.lab-video-error{margin:0;padding:.85rem 1rem;background:color-mix(in srgb,var(--danger) 12%,transparent);color:var(--text);font-size:.9rem;line-height:1.4}.lab-lesson-video-embed,.lab-video-error{border-radius:10px;border:1px solid var(--border)}.lab-lesson-video-embed{margin:0 0 1rem;overflow:hidden}.lab-lesson-video-embed iframe{display:block;width:100%;min-height:12rem}.lab-demo-embed{position:relative;margin:.75rem 0 1.25rem;padding:0;border:1px solid #30363d;border-radius:10px;background:#0d1117;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.18),0 0 0 1px hsla(0,0%,100%,.04)}.lab-demo-embed:before{content:"Line-by-line preview";display:block;padding:.4rem .75rem .35rem;font-size:.68rem;font-weight:650;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:hsla(0,0%,100%,.035);border-bottom:1px solid hsla(0,0%,100%,.06)}.lab-demo-embed iframe{display:block;width:100%;min-height:560px;height:clamp(560px,64vh,920px)!important;border:0;border-radius:0;vertical-align:top;background:#0d1117}.lab-apis-inline-note{margin:0;font-size:.86rem;line-height:1.45;color:var(--muted)}.lab-example-row{position:relative;display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-start;margin:.65rem 0 1rem;padding:.5rem .85rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg)}.theory-inner .lab-code{font-family:var(--mono);font-size:.78rem;line-height:1.45;margin:0;padding:.65rem .75rem;border-radius:6px;background:#0d1117;color:#e6edf3;overflow-x:auto;flex:1 1 240px;min-width:min(100%,240px)}.theory-inner .lab-code code{font-family:inherit;font-size:inherit;background:none;padding:0}.lab-example-figure{margin:0;flex:0 0 auto}.lab-example-figure img{display:block;max-width:100%;height:auto;border-radius:6px;border:1px solid var(--border)}.lab-example-figure figcaption{margin-top:.4rem;font-size:.78rem;color:var(--muted)}.editor-tab-bar{display:flex;flex-shrink:0;gap:0;padding:0 .5rem;border-bottom:1px solid var(--border);background:var(--bg)}.editor-tab{position:relative;padding:.45rem .75rem;font-size:.78rem;font-weight:500;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:0;background:transparent;color:var(--muted);cursor:pointer;font-family:inherit;text-transform:none;letter-spacing:0}.editor-tab:hover{color:var(--text);background:rgba(var(--accent-rgb),.06)}.editor-tab--active{color:var(--text);border-bottom-color:var(--accent);background:var(--bg-elevated)}.editor-readonly-banner{flex-shrink:0;padding:.35rem .75rem;font-size:.78rem;line-height:1.4;color:var(--text);background:rgba(var(--accent-rgb),.12);border-bottom:1px solid var(--border)}.editor-readonly-banner strong{font-weight:600}.editor-mount--readonly{opacity:.97}.placeholder{color:var(--muted);margin:0}.workspace{flex:1 1;display:grid;grid-template-columns:1fr 1fr;min-height:0}@media (max-width:960px){.toolbar-menu-btn{display:inline-flex}.sidebar-backdrop{position:fixed;top:var(--lab-toolbar-h,5.25rem);left:0;right:0;bottom:0;z-index:250;background:rgba(1,4,9,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.app{flex-direction:row}.sidebar{position:fixed;top:var(--lab-toolbar-h,5.25rem);left:0;bottom:0;height:auto;max-height:calc(100dvh - var(--lab-toolbar-h, 5.25rem));width:min(100vw - 2.5rem,var(--sidebar-width));max-width:20rem;z-index:300;flex:none;border-right:1px solid var(--border);border-bottom:none;transform:translateX(-100%);transition:transform .22s ease;box-shadow:6px 0 28px rgba(0,0,0,.45);padding-left:env(safe-area-inset-left,0)}.sidebar.sidebar--drawer-open{transform:translateX(0);pointer-events:auto}.sidebar:not(.sidebar--drawer-open){pointer-events:none}.main{flex:1 1;min-width:0;width:100%}.workspace{grid-template-columns:minmax(0,1fr);grid-template-rows:auto auto}.pane-footer--editor{border-bottom-right-radius:12px}}@media (max-width:960px) and (prefers-reduced-motion:reduce){.sidebar{transition:none}}.editor-pane,.output-pane{display:flex;flex-direction:column;min-width:0;min-height:0;border-right:1px solid var(--border)}.output-pane{border-right:none;align-self:start;width:100%;overflow:visible}.output-pane-stack{flex:0 0 auto;width:100%;min-width:0;display:flex;flex-direction:column;overflow:visible}.output-console-section,.output-image-section{display:flex;flex-direction:column;min-height:0}.output-console-section{flex:0 0 auto;max-height:clamp(100px,min(40vh,220px),240px);border-bottom:1px solid var(--border)}@media (max-height:720px){.output-console-section{max-height:min(58vh,340px)}}@media (min-width:961px) and (max-height:820px){.theory-body--code,.theory.theory--workspace,.workspace.workspace--in-panel{flex:0 0 auto;min-height:auto}.output-console-section{max-height:none}.console-scroll{max-height:min(65vh,480px);min-height:120px}}.output-image-section{flex:0 0 auto;min-height:auto}.console-scroll{flex:1 1 auto;min-height:0;overflow:auto;background:var(--bg)}@media (max-width:960px){.theory-body--code,.theory.theory--workspace,.workspace.workspace--in-panel{flex:0 0 auto;min-height:auto}.editor-mount{min-height:clamp(200px,36vh,400px);flex:0 0 auto}.output-body{flex:0 0 auto;min-height:auto;overflow:visible}.output-console-section{max-height:none}.console-scroll{max-height:min(72vh,560px);min-height:min(160px,28vh)}}.image-output-scroll{flex:0 0 auto;min-width:0;overflow:visible;background:var(--bg)}.pane-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;padding:.4rem .75rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--border);background:var(--bg)}.pane-header .hint{font-weight:400;text-transform:none;letter-spacing:0;margin-left:.35rem;opacity:.85}.pane-header-left{min-width:0;display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.pane-header--console,.pane-header--image-output,.pane-header--output{justify-content:flex-start}.pane-header-label{font-weight:600;color:var(--muted)}.run-outcome{display:inline-block;padding:.12rem .5rem;font-size:.65rem;font-weight:600;text-transform:none;letter-spacing:.02em;border-radius:999px;border:1px solid var(--border)}.run-outcome--ok{color:var(--accent-green);border-color:rgba(63,185,80,.45);background:rgba(63,185,80,.12);font-size:.78rem;line-height:1;padding:.14rem .42rem}.run-outcome--err{color:var(--danger);border-color:rgba(248,81,73,.45);background:rgba(248,81,73,.1)}.run-outcome--pending{color:rgba(230,237,243,.88);border-color:rgba(230,237,243,.22);background:rgba(230,237,243,.07)}.pane-header--code{justify-content:flex-start}.pane-footer{display:flex;align-items:center;justify-content:flex-end;flex-shrink:0;flex-wrap:wrap;gap:.75rem;padding:.45rem .75rem;border-top:none;box-shadow:inset 0 1px 0 var(--border);background:var(--bg)}.pane-footer--editor{justify-content:flex-start;border-bottom:none;border-bottom-left-radius:12px;box-shadow:inset 0 1px 0 var(--border),inset 0 -1px 0 var(--border)}.pane-footer-run{flex:1 1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:.2rem}.pane-footer--editor .pane-footer-status--neutral{text-align:left;text-transform:none;letter-spacing:0;font-size:.8rem;color:var(--muted)}.pane-footer--editor .pane-footer-status--soft-warn{font-size:.76rem;line-height:1.35;font-weight:600;color:color-mix(in srgb,#d4a017 90%,var(--text) 10%)}.lesson-check-pass{display:inline-flex;align-items:center;gap:.3rem;margin-top:.15rem;font-size:.78rem;font-weight:600;color:var(--accent-green)}.pane-footer--editor .pane-header-actions{flex:0 0 auto;margin-left:auto}.pane-header-context{display:inline-block;padding:.12rem .45rem;font-size:.65rem;font-weight:600;text-transform:none;letter-spacing:.02em;border-radius:999px;border:1px solid var(--border)}.pane-header-context--example{color:rgba(255,146,43,.95);border-color:rgba(255,146,43,.45);background:rgba(255,146,43,.1)}.pane-header-context--practice{color:var(--accent-green);border-color:rgba(63,185,80,.45);background:rgba(63,185,80,.1)}.pane-header-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-wrap:wrap;justify-content:flex-end}.pane-header-actions .btn{padding:.25rem .6rem;font-size:.75rem;text-transform:none;letter-spacing:0}.pane-header-actions .status{min-width:0;text-align:right;text-transform:none;letter-spacing:0}.pane-header-actions .status:empty{display:none}.pane-header-actions .status:not(:empty){min-width:4.25rem}.editor-mount{flex:1 1;min-width:0;min-height:clamp(300px,40vh,560px);width:100%;max-width:100%;overflow:hidden}.workspace.workspace--in-panel .editor-mount{flex:1 1;min-height:clamp(300px,42vh,640px)}.editor-mount .monaco-editor,.editor-mount .monaco-editor .overflow-guard{max-width:100%}.editor-mount .monaco-editor .overflow-guard{overscroll-behavior-y:contain}.output-body{flex:1 1;min-width:0;overflow:auto;display:flex;flex-direction:column;min-height:min(280px,max(120px,28vh))}.output-text{margin:0;padding:.75rem 1rem;font-family:var(--mono);font-size:.8rem;white-space:pre-wrap;word-break:break-word;color:var(--text);background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0}.console-scroll .output-text{border-bottom:none}.nba-panel{display:flex;align-items:flex-start;gap:.5rem;padding:.4rem .75rem;font-size:.8rem;background:var(--bg);border-bottom:1px solid var(--border);color:var(--muted);flex-shrink:0}.nba-panel .nba-text{min-width:0;line-height:1.45;text-transform:none;letter-spacing:0}.nba-panel.nba-panel--running:empty{min-height:3.5rem;box-sizing:border-box}.nba-steps{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;line-height:1.35}.nba-step{font-weight:500;color:var(--muted)}.nba-step--active{font-weight:600;color:var(--text)}.nba-step--done{color:var(--accent-green);opacity:.85}.nba-step-sep{color:var(--border);-webkit-user-select:none;-moz-user-select:none;user-select:none}.nba-panel[hidden]{display:none}.nba-icon{font-size:.85rem;color:var(--accent);flex-shrink:0}.nba-panel--ok .nba-icon{color:var(--accent-green)}.nba-panel--err .nba-icon{color:var(--danger)}.nba-panel--err .nba-text,.nba-panel--ok .nba-text{color:var(--text)}.output-images{padding:.65rem .75rem .75rem;display:flex;flex-direction:column;align-items:stretch;gap:.35rem;min-width:0;max-width:100%;box-sizing:border-box}.output-images:empty{display:none}.output-images figure{margin:0;max-width:100%;min-width:0}.output-images figcaption{font-size:.7rem;color:var(--muted);margin-top:.25rem;word-break:break-all}.gallery-main img,.output-images img{max-width:100%;width:auto;height:auto;max-height:min(44vh,420px);object-fit:contain;border:1px solid var(--border);border-radius:4px;display:block;margin-inline:auto;background:var(--bg)}.gallery-main{padding:.35rem 0 .15rem;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.gallery-main figcaption{font-size:.7rem;color:var(--muted);margin-top:.35rem;word-break:break-all}.gallery-thumbs{display:flex;overflow-x:auto;gap:.5rem;padding:.35rem 0 .15rem;width:100%;min-width:0;flex-shrink:0;scrollbar-gutter:stable}.gallery-thumb{flex-shrink:0;width:72px;height:56px;padding:0;border:2px solid transparent;border-radius:4px;background:var(--bg-elevated);cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center}.gallery-thumb img{width:100%;height:100%;object-fit:cover;border-radius:2px;display:block}.gallery-thumb:hover{border-color:var(--muted)}.gallery-thumb--active{border-color:var(--accent)}.image-preview-modal{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:9999}.image-preview-modal[hidden]{display:none}.image-preview-dialog{position:relative;width:min(96vw,1200px);min-width:min(96vw,1200px);max-width:min(96vw,1200px);max-height:94vh;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:.75rem .75rem .5rem;flex-direction:column;gap:.5rem;cursor:default}.image-preview-dialog,.image-preview-stage{display:flex;overflow:hidden;box-sizing:border-box}.image-preview-stage{width:100%;flex:0 0 auto;height:min(72vh,640px);min-height:min(72vh,640px);align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--border);border-radius:6px;cursor:zoom-in}.image-preview-stage.is-zoomed{cursor:-webkit-grab;cursor:grab}.image-preview-stage.is-dragging{cursor:-webkit-grabbing;cursor:grabbing}.image-preview-img{display:block;width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;transform-origin:center center;transition:transform .12s ease-out;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:auto;image-rendering:auto}.image-preview-cap{margin:0;font-size:.78rem;color:var(--muted);word-break:break-all}.image-preview-close{top:.35rem;right:.45rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);font-size:1.1rem}.image-preview-close,.image-preview-nav{position:absolute;width:2rem;height:2rem;color:var(--text);line-height:1;cursor:pointer;z-index:4}.image-preview-nav{top:50%;transform:translateY(-50%);border:1px solid var(--border);border-radius:999px;background:rgba(13,17,23,.9);font-size:1.25rem}.image-preview-prev{left:.65rem}.image-preview-next{right:.65rem}.image-preview-thumbs{display:flex;gap:.4rem;overflow-x:auto;padding:.2rem 0 .35rem;min-height:62px}.image-preview-thumb{flex-shrink:0;width:72px;height:56px;border:2px solid transparent;border-radius:4px;background:var(--bg);padding:0;cursor:pointer;overflow:hidden}.image-preview-thumb img{width:100%;height:100%;object-fit:cover;display:block}.image-preview-thumb--active{border-color:var(--accent)}.output-guide{position:relative;z-index:1;margin:.75rem 0 0;padding:.75rem 1rem;border-top:none;border-bottom:1px solid var(--border);background:rgba(63,185,80,.06);border-left:3px solid rgba(63,185,80,.5);flex:0 1 auto;min-height:0;max-height:min(32vh,260px);overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable}.output-guide[hidden]{display:none}.output-guide-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.output-guide-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}.output-guide-toggle{padding:.25rem .5rem;border-radius:6px;font-size:.75rem;cursor:pointer;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font-family:inherit}.output-guide-toggle:hover{background:#21262d}.output-guide-body{margin-top:.65rem;font-size:.88rem;line-height:1.55}.output-guide-body h3{margin:0 0 .35rem;font-size:.88rem;font-weight:600;color:var(--text)}.output-guide-body ul{margin:.35rem 0 0;padding-left:1.25rem}.output-guide-body code{font-family:var(--mono);font-size:.82em;background:var(--bg);padding:.1rem .35rem;border-radius:4px}.theory-inner a{color:var(--accent)}.lesson-hints{margin-top:1rem;padding:.65rem .75rem .5rem;border-left:3px solid rgba(var(--accent-rgb),.45);background:linear-gradient(90deg,rgba(var(--accent-rgb),.085),rgba(var(--accent-warm-rgb),.06),rgba(var(--accent-blue-rgb),.055));border-radius:0 4px 4px 0}.lesson-hints-title{margin:0 0 .45rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}.lesson-hints ul{margin:0;padding-left:1.2rem;color:var(--text);font-size:.88rem;line-height:1.5}.lesson-hints li{margin:.25rem 0}.sidebar-auth .nav-user-chip{width:100%;justify-content:center}.tool-embed-frame{width:100%;flex:1 1;border:none;min-height:500px;display:block}.lesson-lock{display:inline-flex;align-items:center;justify-content:center;margin-right:.2rem;vertical-align:-.15em;color:var(--accent)}.lesson-lock-svg{display:block;flex-shrink:0;opacity:.95}.lens-app{min-height:100vh;height:100vh;max-height:100vh;background:var(--bg);color:var(--text);font-family:var(--font)}.lens-app,.lens-sidebar{display:flex;overflow:hidden}.lens-sidebar{width:var(--sidebar-width);flex-shrink:0;border-right:1px solid var(--border);background:var(--bg-elevated);flex-direction:column;transition:width .22s ease,opacity .22s ease}.lens-sidebar--collapsed{width:0;opacity:0;pointer-events:none;border-right:none}.lens-brand{padding:1rem 1rem .75rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;flex-shrink:0}.lens-brand-link{display:flex;align-items:center;gap:.55rem;color:inherit;text-decoration:none;min-width:0;transition:opacity .2s ease}.lens-brand-link:hover{opacity:.75}.lens-brand-logo{width:34px;height:34px;flex:0 0 34px;border-radius:8px;background:var(--bg);border:1px solid var(--border);object-fit:cover}.lens-brand-wordmark{font-family:"Syne",var(--font);font-weight:800;font-size:1.0625rem;letter-spacing:-.055em;line-height:1.15;color:var(--text)}.lens-brand-accent{color:var(--accent)}.lens-brand-sub{margin:.2rem 0 0;font-size:.72rem;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.lens-toggle{flex-shrink:0;padding:.25rem .55rem;border-radius:6px;font-size:.7rem;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;align-self:flex-start}.lens-toggle:hover{background:#21262d}.lens-list{flex:1 1;overflow-y:auto;padding:.75rem 0 1rem;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent}.lens-list::-webkit-scrollbar{width:var(--scrollbar-size)}.lens-list::-webkit-scrollbar-track{background:transparent}.lens-list::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(var(--accent-rgb),.22) 0,rgba(var(--accent-rgb),.44) 50%,rgba(var(--accent-rgb),.22) 100%);border-radius:4px}.lens-topic-group{margin-bottom:.25rem}.lens-topic-label{padding:.45rem 1rem .3rem;font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.lens-exhibit-btn{display:block;width:100%;padding:.55rem 1rem .55rem 1.1rem;text-align:left;background:transparent;border:none;border-left:3px solid transparent;color:var(--text);font-family:inherit;font-size:.875rem;cursor:pointer;line-height:1.35;transition:background .15s ease,border-color .15s ease,color .15s ease}.lens-exhibit-btn:hover{background:rgba(var(--accent-rgb),.06);border-left-color:rgba(var(--accent-rgb),.4)}.lens-exhibit-btn--active{background:rgba(var(--accent-rgb),.1);border-left-color:var(--accent);color:var(--text)}.lens-exhibit-btn-title{display:block;font-weight:500}.lens-exhibit-btn-tagline{display:block;font-size:.75rem;color:var(--muted);margin-top:.15rem;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.lens-main{flex:1 1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.lens-toolbar{display:flex;align-items:center;gap:.75rem;padding:0 1rem;height:44px;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.lens-toolbar-breadcrumb{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:.4rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lens-toolbar-sep{color:var(--border)}.lens-toolbar-topic{color:var(--accent);font-weight:600}.lens-toolbar-title{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lens-content{flex:1 1;display:flex;overflow:hidden}.lens-theory{width:380px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;padding:1.5rem 1.4rem 2rem;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent}.lens-theory::-webkit-scrollbar{width:var(--scrollbar-size)}.lens-theory::-webkit-scrollbar-track{background:transparent}.lens-theory::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(var(--accent-rgb),.22) 0,rgba(var(--accent-rgb),.44) 50%,rgba(var(--accent-rgb),.22) 100%);border-radius:4px}.lens-theory-header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.lens-theory-topic-chip{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:4px;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:rgba(var(--accent-rgb),.12);color:var(--accent);border:1px solid rgba(var(--accent-rgb),.25);margin-bottom:.6rem}.lens-theory-title{margin:0 0 .4rem;font-size:1.35rem;font-weight:700;line-height:1.2;font-family:"Syne",var(--font);letter-spacing:-.02em}.lens-theory-tagline{margin:0;font-size:.875rem;color:var(--muted);line-height:1.55}.lens-concepts{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.lens-concept-chip{padding:.2rem .55rem;border-radius:4px;font-size:.7rem;font-weight:500;background:var(--bg);color:var(--muted);border:1px solid var(--border);line-height:1.4}.lens-theory-body{font-size:.9rem;line-height:1.7;color:var(--text)}.lens-theory-body h2{font-size:1.05rem;font-weight:700;margin:0 0 .75rem;line-height:1.3;color:var(--text)}.lens-theory-body h3{font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);margin:1.4rem 0 .6rem}.lens-theory-body p{margin:0 0 .85rem}.lens-theory-body ol,.lens-theory-body ul{margin:0 0 .85rem;padding-left:1.4rem}.lens-theory-body li{margin-bottom:.4rem}.lens-theory-body dl{margin:0 0 .85rem}.lens-theory-body dt{font-weight:600;color:var(--accent);margin-top:.75rem}.lens-theory-body dd{margin:.15rem 0 .4rem;color:var(--muted);font-size:.87rem;line-height:1.6}.lens-theory-body code{font-family:var(--mono);font-size:.82em;background:var(--bg);border:1px solid var(--border);padding:.1em .35em;border-radius:3px;color:rgba(var(--accent-blue-rgb),1)}.lens-theory-body em{color:rgba(var(--accent-warm-rgb),1);font-style:normal}.lens-theory-body strong{color:var(--text);font-weight:600}.lens-viz{flex:1 1;min-width:0;overflow:hidden;position:relative;background:var(--bg)}.lens-viz-iframe{display:block;width:100%;height:100%;border:none;background:var(--bg)}.lens-viz-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--muted);font-size:.875rem}.lens-viz-spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:lens-spin .75s linear infinite}@keyframes lens-spin{to{transform:rotate(1turn)}}.lens-loading-state{padding:1.5rem 1rem;font-size:.85rem;color:var(--muted);text-align:center}@media (max-width:1100px){.lens-theory{width:320px}}@media (max-width:860px){.lens-sidebar{width:0;opacity:0;pointer-events:none;border-right:none;position:absolute;z-index:100;height:100%}.lens-sidebar--mobile-open{width:var(--sidebar-width);opacity:1;pointer-events:auto;box-shadow:4px 0 24px rgba(0,0,0,.5)}.lens-content{flex-direction:column}.lens-theory{width:100%;max-height:42vh;border-right:none;border-bottom:1px solid var(--border)}.lens-viz{flex:1 1;min-height:300px}}.site-footer{border-top:1px solid var(--border);background:var(--bg);padding:1.1rem 1.5rem}.site-footer-inner{max-width:1160px;margin:0 auto;display:flex;align-items:center;gap:.6rem}.site-footer-text{font-weight:600;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;opacity:.5}.site-footer-sep,.site-footer-text{font-size:.65rem;color:var(--muted)}.site-footer-sep{opacity:.3}.site-footer-link{font-size:.65rem;font-weight:600;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);opacity:.5;text-decoration:none;transition:opacity .2s ease,color .2s ease}.site-footer-link:hover{opacity:1;color:var(--text)}.h-nav-brand-name{font-size:.9rem;font-weight:600;letter-spacing:-.01em}.h-nav-sublabel{font-size:.52rem;font-weight:600;font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);opacity:0;margin-left:.1rem;transition:opacity .25s ease;white-space:nowrap}.h-nav-brand:hover .h-nav-sublabel{opacity:.45}@media (max-width:580px){.h-nav-sublabel{display:none}}.nav-user-chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:.35rem .75rem;cursor:pointer;background:none;transition:border-color .2s ease,color .2s ease}.nav-user-chip:hover{border-color:hsla(0,0%,100%,.14);color:var(--text)}.nav-user-label{opacity:.7;max-width:7rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-sign-in-btn{display:inline-flex;align-items:center;gap:.35rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);background:none;border:1px solid var(--border);border-radius:4px;padding:.4rem .85rem;cursor:pointer;transition:color .2s ease,border-color .2s ease,background .2s ease;flex-shrink:0}.nav-sign-in-btn:hover{color:var(--text);border-color:hsla(0,0%,100%,.14);background:rgba(48,54,61,.5)}.sidebar-auth{padding:.85rem 1rem 1rem;border-top:1px solid var(--border)}.sidebar-sign-in-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);opacity:.65;background:none;border:1px solid var(--border);border-radius:4px;padding:.55rem 1rem;cursor:pointer;transition:color .2s ease,opacity .2s ease,border-color .2s ease}.sidebar-sign-in-btn:hover{color:var(--text);opacity:1;border-color:hsla(0,0%,100%,.12)}.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:8000;opacity:0;pointer-events:none;transition:opacity .3s ease}.auth-overlay--visible{opacity:1;pointer-events:all}.auth-panel{position:fixed;top:0;right:0;width:min(420px,100vw);height:100vh;height:100dvh;max-height:100dvh;background:var(--bg-elevated);border-left:1px solid var(--border);box-shadow:-12px 0 40px rgba(0,0,0,.35);z-index:8001;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.auth-panel--open{transform:translateX(0)}.auth-panel-header{display:flex;justify-content:flex-end;padding:calc(.75rem + env(safe-area-inset-top, 0px)) 1rem .25rem;flex-shrink:0}.auth-panel-close{background:none;border:1px solid transparent;color:var(--muted);font-size:1.35rem;line-height:1;cursor:pointer;padding:.25rem .55rem;border-radius:4px;transition:color .2s ease,border-color .2s ease,background .2s ease}.auth-panel-close:hover{color:var(--text);border-color:var(--border);background:rgba(48,54,61,.5)}.auth-panel-close:focus-visible{outline:2px solid rgba(255,59,59,.65);outline-offset:2px}.auth-panel-body{padding:0 1.75rem calc(2rem + env(safe-area-inset-bottom, 0px));display:flex;flex-direction:column;gap:1.25rem;flex:1 1}.auth-logo{display:flex;align-items:center;gap:.55rem}.auth-logo-img{border-radius:6px;border:1px solid var(--border);background:var(--bg)}.auth-logo-name{font-size:.9rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.auth-intro{display:flex;flex-direction:column;gap:.5rem}.auth-heading{font-family:"Syne",var(--font);font-size:clamp(1.45rem,5vw,1.9rem);font-weight:800;color:var(--text);margin:0;letter-spacing:-.03em;line-height:1.12}.auth-sub{font-size:.875rem;color:var(--muted);font-weight:300;margin:0;line-height:1.55;max-width:32ch}.auth-google-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.8rem 1rem;background:var(--bg);border:1px solid var(--border);border-radius:.5rem;color:var(--text);font-size:.85rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:border-color .2s ease,background .2s ease}.auth-google-btn:hover{border-color:hsla(0,0%,100%,.14);background:rgba(48,54,61,.6)}.auth-google-btn:focus-visible{outline:2px solid rgba(255,59,59,.55);outline-offset:2px}.auth-divider{display:flex;align-items:center;gap:.75rem;color:var(--muted);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.5}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:var(--border)}.auth-form{gap:1rem}.auth-field,.auth-form{display:flex;flex-direction:column}.auth-field{gap:.4rem}.auth-field label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.auth-field input{width:100%;box-sizing:border-box;background:var(--bg);border:1px solid var(--border);border-radius:.5rem;padding:.7rem .9rem;color:var(--text);font-size:.9rem;font-family:var(--font);outline:none;transition:border-color .2s ease}.auth-field input::placeholder{color:hsla(212,9%,58%,.4)}.auth-field input:focus{border-color:var(--accent)}.auth-submit{width:100%;padding:.8rem 1rem;background:var(--accent);border:none;border-radius:.5rem;color:#fff;font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;cursor:pointer;transition:opacity .2s ease;margin-top:.25rem}.auth-submit:hover:not(:disabled){opacity:.86}.auth-submit:focus-visible{outline:2px solid hsla(0,0%,100%,.35);outline-offset:2px}.auth-submit:disabled{opacity:.55;cursor:not-allowed}.auth-toggle{display:flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--muted)}.auth-toggle-btn{background:none;border:none;color:var(--accent);font-size:.8rem;font-weight:700;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:3px;transition:opacity .2s ease}.auth-toggle-btn:hover{opacity:.75}.auth-forgot{text-align:center;margin-top:.15rem}.auth-forgot-link{font-size:.72rem;color:var(--muted);text-decoration:none;opacity:.5;transition:opacity .2s ease}.auth-forgot-link:hover{opacity:1}.auth-error{font-size:.78rem;color:var(--accent);background:rgba(255,59,59,.08);border:1px solid rgba(255,59,59,.2);border-radius:.4rem;padding:.55rem .75rem;margin:0;line-height:1.45}*,:after,:before{box-sizing:border-box}body,html{margin:0;min-height:100%;font-family:var(--font);background:var(--bg);color:var(--text)}