*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafaf7;--surface:#f4f2ed;--surface2:#ece9e1;--border:#ddd9cf;--border-light:#f0eed8;--text:#1c1714;--text-secondary:#4a4238;--text-2:#3d3428;--text-3:#8a7d6e;--muted:#8a7d6e;--muted2:#c4bcb0;--accent:#059669;--accent-dim:#05966914;--accent-glow:#05966938;--on-accent:#fff;--green:#16a34a;--green-dim:#16a34a14;--green-glow:#16a34a33;--on-green:#fff;--red:#dc2626;--red-dim:#dc26260f;--sidebar-bg:#0c1511;--sidebar-text:#607868;--sidebar-muted:#283830;--sidebar-active:#10b981;--sidebar-border:#182a20;--topbar-bg:#0c1511;--topbar-border:#182a20;--topbar-text:#90b89a;--term-green:#0f8;--mono:"JetBrains Mono", "Fira Code", monospace;--sans:"Syne", system-ui, sans-serif;--body:"Source Sans 3", system-ui, sans-serif;--display:"IBM Plex Serif", Georgia, serif;--radius-sm:5px;--radius:9px;--radius-lg:14px}[data-theme=dark]{--bg:#100d08;--surface:#1a1510;--surface2:#231e17;--border:#342b1f;--border-light:#1a1510;--text:#f0e8d8;--text-secondary:#a09080;--text-2:#c0a88a;--text-3:#786758;--muted:#6b5e50;--muted2:#3d3328;--accent:#10b981;--accent-dim:#10b9811a;--accent-glow:#10b98147;--on-accent:#fff;--green:#22c55e;--green-dim:#22c55e1a;--green-glow:#22c55e40;--on-green:#000;--red:#f87171;--red-dim:#f8717114;--sidebar-bg:#060e0a;--sidebar-text:#4a6858;--sidebar-muted:#1a2c22;--sidebar-active:#10b981;--sidebar-border:#102018;--topbar-bg:#060e0a;--topbar-border:#102018;--topbar-text:#7aa88a}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--body);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:18px;line-height:1.75;transition:background .2s,color .2s}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.topbar{background:var(--topbar-bg);border-bottom:1px solid var(--topbar-border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 28px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-logo{font-family:var(--sans);color:var(--accent);letter-spacing:.14em;text-transform:uppercase;font-size:11px;font-weight:700}.topbar-back{font-family:var(--body);color:var(--topbar-text);opacity:.7;font-size:13px;transition:opacity .15s}.topbar-back:hover{opacity:1;text-decoration:none}.topbar-practice-label{font-family:var(--body);color:var(--topbar-text);opacity:.6;letter-spacing:.02em;font-size:12px;font-weight:500;position:absolute;left:50%;transform:translate(-50%)}.topbar-right{align-items:center;gap:20px;display:flex}.topbar-user{font-family:var(--mono);color:var(--topbar-text);opacity:.5;letter-spacing:.04em;font-size:11px}.accent-picker{align-items:center;gap:7px;display:flex}.accent-swatch{background:var(--swatch-color);cursor:pointer;border:2px solid #0000;border-radius:50%;width:14px;height:14px;padding:0;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s;position:relative;box-shadow:0 0 #0000}.accent-swatch:after{content:"";border:1.5px solid #0000;border-radius:50%;transition:border-color .18s;position:absolute;inset:-4px}.accent-swatch:hover{box-shadow:0 0 8px var(--swatch-color);transform:scale(1.3)}.accent-swatch.active{box-shadow:0 0 10px var(--swatch-color);transform:scale(1.15)}.accent-swatch.active:after{border-color:var(--swatch-color)}.topbar-sep{background:#ffffff1a;flex-shrink:0;width:1px;height:18px}.theme-toggle{background:#ffffff0f;border:1px solid #ffffff14;border-radius:20px;align-items:center;gap:4px;padding:3px;display:flex}.theme-btn{cursor:pointer;color:#ffffff59;background:0 0;border:none;border-radius:16px;justify-content:center;align-items:center;width:26px;height:22px;padding:0;transition:color .15s,background .15s;display:flex}.theme-btn:hover{color:#ffffffb3}.theme-btn.active{color:#ffffffe6;background:#ffffff1f}.layout{min-height:100vh;padding-top:56px;display:flex}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);z-index:101;flex-shrink:0;width:264px;padding:16px 0 56px;position:fixed;top:56px;bottom:0;overflow-y:auto;box-shadow:4px 0 32px #00000059,1px 0 #ffffff08}.sidebar:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff0f,#0000);height:1px;margin-bottom:8px;display:block;position:sticky;top:0}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff24}.sidebar-section{margin-bottom:2px}.sidebar-section+.sidebar-section{border-top:1px solid #ffffff0d;margin-top:4px;padding-top:4px}.sidebar-module{cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;margin:1px 8px;padding:10px 12px;text-decoration:none;transition:background .14s,box-shadow .14s,border-color .14s;display:flex}.mod-num{font-family:var(--mono);letter-spacing:.1em;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;min-width:26px;height:20px;font-size:9.5px;transition:background .14s,color .14s;display:flex}.mod-title{font-family:var(--sans);letter-spacing:.01em;font-size:12.5px;font-weight:600;line-height:1.3;transition:color .14s}.sidebar-module:not(.sidebar-locked):not(.active) .mod-num{color:var(--sidebar-text);background:#ffffff0d}.sidebar-module:not(.sidebar-locked):not(.active) .mod-title{color:var(--topbar-text)}.sidebar-module:not(.sidebar-locked):not(.active):hover{background:#ffffff0f;border-color:#ffffff14}.sidebar-module:not(.sidebar-locked):not(.active):hover .mod-title{color:var(--sidebar-active)}.sidebar-module:not(.sidebar-locked):not(.active):hover .mod-num{color:var(--topbar-text);background:#ffffff14}.sidebar-module:not(.sidebar-locked).active{background:var(--accent-dim);border-color:var(--accent-glow);box-shadow:inset 3px 0 0 var(--sidebar-active), 0 2px 12px #00000040, 0 0 20px var(--accent-dim)}.sidebar-module:not(.sidebar-locked).active .mod-num{color:var(--sidebar-active);background:#ffffff14;font-weight:700}.sidebar-module:not(.sidebar-locked).active .mod-title{color:#f0fff8;font-weight:700}.sidebar-module.sidebar-locked:not(.active) .mod-num{color:#ffffffa6;background:#ffffff1c}.sidebar-module.sidebar-locked:not(.active) .mod-title{color:#ffffff8c}.sidebar-module.sidebar-locked:not(.active):hover{background:#ffffff0d}.sidebar-module.sidebar-locked:not(.active):hover .mod-title{color:#ffffffb8}.sidebar-module.sidebar-locked.active{background:#ef44441f;border-color:#ef444440;box-shadow:inset 3px 0 #ef4444,0 2px 12px #00000040}.sidebar-module.sidebar-locked.active .mod-num{color:#fca5a5;background:#ef444426;font-weight:700}.sidebar-module.sidebar-locked.active .mod-title{color:#fee2e2;font-weight:700}.sidebar-module.sidebar-locked .mod-title:after{content:" ·";color:#ffffff40;margin-left:2px}.sidebar-module.sidebar-locked:after{content:"🔒";opacity:.88;flex-shrink:0;margin-left:auto;font-size:10px}.sidebar-lessons{opacity:0;flex-direction:column;max-height:0;padding:0;transition:max-height .25s cubic-bezier(.4,0,.2,1),opacity .2s;display:flex;overflow:hidden}.sidebar-lessons.open{opacity:1;max-height:500px;padding:2px 0 6px}.sidebar-lessons.open:before{display:none}.sidebar-lesson{font-family:var(--body);border:1px solid #0000;border-radius:6px;justify-content:space-between;align-items:center;gap:8px;margin:1px 8px 1px 20px;padding:7px 10px 7px 22px;font-size:12.5px;font-weight:400;line-height:1.35;text-decoration:none;transition:background .12s,color .12s,border-color .12s;display:flex;position:relative}.sidebar-lesson:before{content:"";border-radius:50%;flex-shrink:0;width:5px;height:5px;transition:background .12s,box-shadow .12s;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.sidebar-lesson:after{content:"";pointer-events:none;background:#ffffff0d;width:1px;position:absolute;top:-4px;bottom:-4px;left:10px}.sidebar-lesson:last-child:after{display:none}.sidebar-lesson:not(.sidebar-lesson-locked){color:var(--sidebar-text);cursor:pointer}.sidebar-lesson:not(.sidebar-lesson-locked):before{background:#ffffff1f}.sidebar-lesson:not(.sidebar-lesson-locked):hover{color:var(--topbar-text);background:#ffffff0d;border-color:#ffffff12;text-decoration:none}.sidebar-lesson:not(.sidebar-lesson-locked):hover:before{background:#ffffff4d}.sidebar-lesson.active:not(.sidebar-lesson-locked){color:#f0fff8;background:var(--accent-dim);border-color:var(--accent-glow);font-weight:500}.sidebar-lesson.active:not(.sidebar-lesson-locked):before{background:var(--sidebar-active);box-shadow:0 0 6px var(--sidebar-active)}.sidebar-lesson:not(.sidebar-lesson-locked).done:before{background:var(--green)}.sidebar-lesson .check{color:var(--green);opacity:0;flex-shrink:0;font-size:9px;transition:opacity .15s}.sidebar-lesson.done .check{opacity:1}.sidebar-lesson.sidebar-lesson-locked{color:#ffffff14;pointer-events:none;cursor:default}.sidebar-lesson.sidebar-lesson-locked:before{background:#ffffff0f}.sidebar-lesson.sidebar-lesson-locked .check{display:none}.main{flex:1;justify-content:center;align-items:flex-start;margin-left:264px;display:flex}.main-content{width:100%;max-width:720px;padding:56px 48px 96px}.lesson-header{margin-bottom:32px;padding-bottom:8px;position:relative}.lesson-num-ghost{font-family:var(--display);color:#0000;-webkit-text-stroke:1px #0596690f;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;font-size:9rem;font-weight:800;line-height:1;position:absolute;top:-20px;left:-8px}.lesson-eyebrow{font-family:var(--body);color:var(--accent);letter-spacing:.1em;text-transform:uppercase;z-index:1;align-items:center;gap:10px;margin-bottom:16px;font-size:11px;font-weight:600;display:flex;position:relative}h1.lesson-title{font-family:var(--display);letter-spacing:-.01em;color:var(--text);z-index:1;font-size:2.5rem;font-weight:600;line-height:1.15;position:relative}h1.lesson-title .accent{color:var(--accent)}.prose{max-width:100%}.prose h2{font-family:var(--display);color:var(--text);letter-spacing:.01em;margin:52px 0 20px;font-size:1.4rem;font-weight:600;line-height:1.3}.prose p{color:var(--text-secondary);margin-bottom:24px;font-size:19px;line-height:1.85}.prose ul{flex-direction:column;gap:12px;margin:0 0 28px;list-style:none;display:flex}.prose ul li{color:var(--text-secondary);gap:12px;font-size:1rem;line-height:1.7;display:flex}.prose ul li:before{content:"→";color:var(--accent);font-family:var(--mono);flex-shrink:0;margin-top:4px;font-size:.82rem}.callout{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;color:var(--text-secondary);margin:36px 0;padding:18px 24px;font-size:.97rem;line-height:1.75}.callout strong{color:var(--accent);font-weight:600}.pull-quote{background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:var(--radius);margin:48px 0;padding:28px 36px;position:relative}.pull-quote p{font-family:var(--sans);color:var(--text);margin:0;font-size:1.2rem;font-weight:600;line-height:1.6}.pull-quote cite{color:var(--muted);font-size:12px;font-style:normal;font-family:var(--body);letter-spacing:.04em;margin-top:12px;display:block}.vis-compare{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);grid-template-columns:1fr 36px 1fr;margin:44px 0;display:grid;overflow:hidden}.vis-side{flex-direction:column;align-items:center;gap:14px;padding:28px 24px 24px;display:flex}.vis-side--agent{background:var(--bg)}.vis-side-label{font-family:var(--body);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);align-self:flex-start;font-size:11px;font-weight:600}.vis-side--agent .vis-side-label{color:var(--accent)}.vis-node{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--mono);color:var(--text-secondary);letter-spacing:.04em;padding:8px 20px;font-size:.78rem;font-weight:700}.vis-node--person{border-color:var(--muted2)}.vis-node--ai{border-color:var(--muted)}.vis-node--agent{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.vis-node--result{border-color:var(--green);color:var(--green);background:var(--green-dim)}.vis-chat-connector{flex-direction:column;align-items:center;gap:2px;display:flex}.vis-arr{font-family:var(--mono);color:var(--muted);font-size:.78rem;animation:2s ease-in-out infinite pulse-arrows}.vis-arr:nth-child(2){animation-delay:1s}@keyframes pulse-arrows{0%,to{opacity:.25}50%{opacity:1}}.vis-chat-loop-note{font-family:var(--body);color:var(--red);opacity:.7;font-size:11px;font-weight:500;animation:2s ease-in-out infinite pulse-arrows}.vis-agent-flow{flex-direction:column;align-items:center;gap:10px;width:100%;display:flex}.vis-single-arrow{flex-direction:column;align-items:center;gap:3px;display:flex}.arr-big{color:var(--accent);opacity:.6;font-size:1.2rem}.vis-tools-row{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.vis-tool{font-family:var(--body);color:var(--text-secondary);background:var(--surface2);border:1px solid var(--border);opacity:0;border-radius:4px;padding:4px 10px;font-size:11px;font-weight:500;animation:.4s forwards appear-tool}.vis-tool:first-child{animation-delay:.6s}.vis-tool:nth-child(2){animation-delay:1s}.vis-tool:nth-child(3){animation-delay:1.4s}.vis-tool:nth-child(4){animation-delay:1.8s}@keyframes appear-tool{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.vis-bottom-note{font-family:var(--body);color:var(--muted);text-align:center;margin-top:4px;font-size:12px;line-height:1.5}.vis-side--agent .vis-bottom-note{color:var(--green);font-weight:500}.vis-vs-col{border-left:1px solid var(--border);border-right:1px solid var(--border);background:var(--surface);justify-content:center;align-items:center;display:flex}.vis-vs-text{font-family:var(--sans);color:var(--muted2);letter-spacing:.15em;writing-mode:vertical-rl;text-transform:uppercase;font-size:9px;font-weight:700}.vis-chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin:44px 0;padding:28px 28px 20px}.vis-chart-title{font-family:var(--body);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-size:11px;font-weight:600}.chart-svg{width:100%;height:auto;display:block;overflow:visible}.chart-legend-accent{stroke:var(--accent);fill:var(--accent)}.chart-axis{stroke:var(--border);stroke-width:1.5px}.chart-grid{stroke:var(--border);stroke-width:1px;stroke-dasharray:4 4}.chart-label{fill:#8a7d6e;font-family:JetBrains Mono,monospace;font-size:9px}.chart-legend{font-family:"Source Sans 3",sans-serif;font-size:10px;font-weight:500}.chart-line-chat{fill:none;stroke:#8a7d6e;stroke-width:2px;stroke-dasharray:700;stroke-dashoffset:700px;transition:stroke-dashoffset 1.4s cubic-bezier(.4,0,.2,1)}.chart-line-agent{fill:none;stroke:var(--accent);stroke-width:2.5px;stroke-dasharray:700;stroke-dashoffset:700px;transition:stroke-dashoffset 1.6s cubic-bezier(.4,0,.2,1) .3s}.chart-ceiling{stroke:var(--border);stroke-width:1px;stroke-dasharray:5 5;opacity:0;transition:opacity .5s 1.4s}.chart-animated .chart-line-chat,.chart-animated .chart-line-agent{stroke-dashoffset:0}.chart-animated .chart-ceiling{opacity:1}.stats-row{border:1px solid var(--border);border-radius:var(--radius);background:var(--border);grid-template-columns:repeat(3,1fr);gap:1px;margin:44px 0;display:grid;overflow:hidden}.stat-item{background:var(--surface);text-align:center;padding:28px 20px}.stat-number{font-family:var(--sans);color:var(--accent);letter-spacing:.01em;font-size:2.4rem;font-weight:800;line-height:1.1;display:block}.stat-label{font-family:var(--body);letter-spacing:.04em;color:var(--muted);margin-top:8px;font-size:12px;font-weight:500;line-height:1.5;display:block}.reveal{opacity:0;transition:opacity .5s,transform .5s;transform:translateY(18px)}.reveal.visible{opacity:1;transform:translateY(0)}.code-block{border-radius:var(--radius-sm);font-family:var(--mono);color:#8a7a68;background:#0a130f;border:1px solid #1a2e22;margin:24px 0;padding:18px 22px;font-size:.82rem;line-height:1.7;position:relative;overflow-x:auto}.code-block code{color:#e8dcc8}.code-block .copy-btn{color:#5a4e3e;font-family:var(--mono);cursor:pointer;letter-spacing:.06em;text-transform:uppercase;background:#ffffff0f;border:none;border-radius:4px;padding:4px 10px;font-size:9px;transition:color .15s,background .15s;position:absolute;top:10px;right:10px}.code-block .copy-btn:hover{color:#e8dcc8;background:#ffffff1a}.progress-bar{background:var(--border);border-radius:2px;height:3px;margin-bottom:48px}.progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .5s}.lesson-nav{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:64px;padding-top:28px;display:flex}.lesson-nav a{font-family:var(--body);letter-spacing:.03em;color:var(--muted);font-size:13px;font-weight:500;transition:color .15s}.lesson-nav a:hover{color:var(--accent);text-decoration:none}.lesson-nav a.lesson-nav-next{opacity:.3;pointer-events:none}.lesson-nav a.lesson-nav-next.unlocked{opacity:1;pointer-events:auto}.practice-launch{background:var(--sidebar-bg);border-radius:var(--radius-lg);border:1px solid var(--sidebar-border);margin:56px 0;position:relative;overflow:hidden}.practice-launch:before{content:"";background:var(--accent);height:3px;transition:background .4s;position:absolute;top:0;left:0;right:0}.practice-launch.done:before{background:var(--green)}.practice-launch-header{border-bottom:1px solid var(--sidebar-border);justify-content:space-between;align-items:center;padding:16px 28px;display:flex}.practice-label{font-family:var(--sans);color:var(--accent);letter-spacing:.06em;font-size:13px;font-weight:700}.practice-status-pill{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:10px;transition:all .3s;display:inline-flex}.practice-status-pill.pending{color:#5a4e40;background:#5a4e4026;border:1px solid #5a4e4033}.practice-status-pill.pending:before{content:"";background:#5a4e40;border-radius:50%;flex-shrink:0;width:5px;height:5px}.practice-status-pill.done{color:var(--green);background:var(--green-dim);border:1px solid var(--green-glow);font-weight:600}.practice-launch-body{flex-direction:column;gap:20px;padding:22px 28px 28px;display:flex}.practice-launch-body p{color:#6b5e50;flex:1;margin:0;font-size:.93rem;line-height:1.6}.practice-items{flex-direction:column;flex:1;gap:14px;display:flex}.practice-item{align-items:flex-start;gap:14px;display:flex}.practice-item-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;text-align:center;border-radius:4px;flex-shrink:0;width:64px;margin-top:2px;padding:4px 0;font-size:9px;font-weight:700;line-height:1.4}.practice-item-label--action{background:var(--accent);color:#fff}.practice-item-label--result{color:#8a7d6e;background:#8a7d6e24;border:1px solid #8a7d6e38}.practice-item-text{color:#8a7d6e;font-size:.9rem;line-height:1.65}.btn-practice-launch{background:var(--accent);color:var(--on-accent);font-family:var(--sans);letter-spacing:.02em;border-radius:var(--radius-sm);box-shadow:0 4px 20px var(--accent-glow);justify-content:center;align-items:center;gap:10px;padding:16px 32px;font-size:15px;font-weight:700;transition:filter .15s,box-shadow .15s,transform .12s;display:flex}.btn-practice-launch:hover{filter:brightness(1.08);box-shadow:0 8px 32px var(--accent-glow);text-decoration:none;transform:translateY(-2px)}.quiz-section{margin:64px 0 0}.quiz-banner{background:var(--sidebar-bg);border:1px solid var(--sidebar-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;align-items:center;gap:20px;padding:24px 32px;display:flex;position:relative;overflow:hidden}.quiz-banner:before{content:"";pointer-events:none;background-image:radial-gradient(circle,#ffffff0a 1px,#0000 1px);background-size:22px 22px;position:absolute;inset:0}.quiz-banner-icon{font-family:var(--sans);color:var(--accent);z-index:1;opacity:.85;flex-shrink:0;font-size:3rem;font-weight:800;line-height:1;position:relative}.quiz-banner-text{z-index:1;position:relative}.quiz-banner-title{font-family:var(--sans);color:#f0e8d8;margin:0 0 5px;font-size:1.05rem;font-weight:700;line-height:1.3}.quiz-banner-sub{font-family:var(--body);color:#5a4e40;margin:0;font-size:12px;line-height:1.5}.quiz-body{border:1px solid var(--sidebar-border);border-radius:0 0 var(--radius-lg) var(--radius-lg);background:var(--bg);border-top:none;padding:32px 32px 20px}.quiz-question{margin-bottom:36px}.quiz-q-text{color:var(--text);margin-bottom:16px;font-size:1rem;font-weight:500;line-height:1.6}.quiz-num{color:var(--accent);font-family:var(--mono);margin-right:8px;font-size:.78rem}.quiz-option{border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--bg);-webkit-user-select:none;user-select:none;align-items:flex-start;gap:12px;margin-bottom:8px;padding:13px 18px;transition:border-color .15s,background .15s,transform .1s;display:flex}.quiz-option:hover{border-color:var(--muted2);background:var(--surface)}.quiz-option.selected{border-color:var(--accent);background:var(--accent-dim)}.quiz-option.correct{animation:.35s pop-correct;border-color:var(--green)!important;background:var(--green-dim)!important}.quiz-option.correct:after{content:"✓";color:var(--green);flex-shrink:0;margin-left:auto;font-size:17px;font-weight:700;line-height:1}.quiz-option.wrong{border-color:var(--red)!important;background:var(--red-dim)!important}.quiz-option.wrong:after{content:"✕";color:var(--red);flex-shrink:0;margin-left:auto;font-size:15px;font-weight:700;line-height:1}@keyframes pop-correct{0%{transform:scale(1)}50%{transform:scale(1.012)}to{transform:scale(1)}}.quiz-option input[type=radio]{accent-color:var(--accent);flex-shrink:0;width:16px;height:16px;margin-top:3px}.quiz-option-text{color:var(--text-secondary);font-size:.95rem;line-height:1.55}.quiz-footer{margin-top:24px}.quiz-hint{font-family:var(--body);color:var(--muted);margin-bottom:16px;font-size:12px}.quiz-submit-btn{border:1.5px solid var(--border);color:var(--muted);font-family:var(--body);letter-spacing:.02em;cursor:pointer;border-radius:var(--radius-sm);background:0 0;padding:11px 28px;font-size:13px;font-weight:600;transition:all .15s}.quiz-submit-btn:not(:disabled){border-color:var(--accent);color:var(--accent)}.quiz-submit-btn:not(:disabled):hover{background:var(--accent);color:var(--on-accent)}.quiz-submit-btn:disabled{cursor:not-allowed}.quiz-result{font-family:var(--body);border-radius:var(--radius-sm);margin-top:16px;padding:14px 18px;font-size:.9rem;font-weight:500;display:none}.quiz-result.pass{color:var(--green);background:var(--green-dim);border:1.5px solid var(--green-glow);display:block}.quiz-result.fail{color:var(--red);background:var(--red-dim);border:1.5px solid #dc262633;display:block}.quiz-already-done{font-family:var(--body);color:var(--green);background:var(--green-dim);border:1.5px solid var(--green-glow);border-radius:var(--radius-sm);padding:14px 18px;font-size:.9rem;font-weight:500}.quiz-check{margin-right:8px}.quiz-block{border:1.5px solid var(--border);border-radius:var(--radius-lg);margin:32px 0;overflow:hidden}.quiz-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);border-bottom:1px solid var(--border);margin:0;padding:16px 20px 12px;font-family:Syne,sans-serif;font-size:12px;font-weight:600}.quiz-block .quiz-question{border-bottom:1px solid var(--border);padding:20px 20px 8px}.quiz-block .quiz-question:last-of-type{border-bottom:none}.quiz-block .qtext{color:var(--text);margin:0 0 12px;font-size:14px;font-weight:500;line-height:1.55}.quiz-options{flex-direction:column;gap:6px;padding-bottom:12px;display:flex}.quiz-opt{text-align:left;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;font-family:var(--body);color:var(--text-2);cursor:pointer;align-items:center;gap:10px;padding:11px 16px;font-size:13.5px;transition:border-color .15s,background .15s;display:flex}.quiz-opt-text{flex:1}.quiz-opt-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.quiz-opt-icon--correct{background:var(--green);color:#fff}.quiz-opt-icon--wrong{background:var(--red);color:#fff}.quiz-opt:hover:not(:disabled){border-color:var(--muted2);background:var(--surface)}.quiz-opt.selected{border-color:var(--accent);background:var(--accent-dim);color:var(--text)}.quiz-opt.correct{animation:.35s pop-correct;border-color:var(--green)!important;background:var(--green-dim)!important;color:var(--text)!important}.quiz-opt.wrong{border-color:var(--red)!important;background:var(--red-dim)!important;color:var(--text)!important}.quiz-opt.locked{cursor:default}.quiz-opt.locked-other{cursor:default;opacity:.4}.quiz-opt:disabled{cursor:default}.quiz-block .quiz-result{border:none;border-top:1px solid var(--border);border-radius:0;margin:0;padding:14px 20px}.quiz-block .quiz-result[hidden]{display:none}.lesson-hook{border:1.5px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);margin:0 0 40px;overflow:hidden}.hook-header{background:var(--surface);border-bottom:1.5px solid var(--border);flex-direction:column;gap:6px;padding:18px 22px 16px;display:flex}.hook-eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;color:var(--text-3);font-size:10px;font-weight:700}.hook-question{color:var(--text);font-size:16px;font-weight:600;line-height:1.45;font-family:var(--body);margin:0}.hook-items{flex-direction:column;display:flex}.hook-item{border-bottom:1px solid var(--border)}.hook-item:last-child{border-bottom:none}.hook-item--before{border-left:3px solid var(--border)}.hook-item--after{border-left:3px solid var(--accent);background:#05966908}.hook-item-btn{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:14px;width:100%;padding:18px 18px 18px 20px;transition:background .18s;display:flex}.hook-item-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.hook-item--before .hook-item-btn:hover{background:var(--surface)}.hook-item--after .hook-item-btn:hover,.hook-item--after.is-open .hook-item-btn{background:var(--accent-dim)}.hook-item--after .hook-item-btn{padding-top:20px;padding-bottom:20px}.hook-item-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.hook-item--before .hook-item-dot{border:1.5px solid var(--text-3);background:0 0}.hook-item--after .hook-item-dot{background:var(--accent);box-shadow:0 0 0 3px var(--accent-dim), 0 0 8px var(--accent-glow)}.hook-item-label{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.hook-item-main{font-family:var(--body);font-size:15px;font-weight:600;line-height:1.3}.hook-item--before .hook-item-main{color:var(--text-2)}.hook-item--after .hook-item-main{color:var(--text);font-size:15.5px}.hook-item-sub{font-family:var(--mono);letter-spacing:.01em;font-size:11px}.hook-item--before .hook-item-sub{color:var(--text-3)}.hook-item--after .hook-item-sub{color:var(--accent)}.hook-item-chevron{flex-shrink:0;align-items:center;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex}.hook-item--before .hook-item-chevron{color:var(--muted)}.hook-item--after .hook-item-chevron{color:var(--accent)}.is-open .hook-item-chevron{transform:rotate(180deg)}.hook-item-body{grid-template-rows:0fr;transition:grid-template-rows .32s cubic-bezier(.4,0,.2,1);display:grid}.is-open .hook-item-body{grid-template-rows:1fr}.hook-item-inner{overflow:hidden}.hook-out{font-family:var(--mono);color:#a8b8a0;white-space:pre-wrap;background:#060e0a;margin:0;padding:18px 22px 16px;font-size:13px;line-height:1.8;display:block}.hook-tag-bad{color:#f87171}.hook-tag-good{color:#4ade80}.hook-tag-tool{color:#52645a;font-size:11.5px}.hook-badge{font-family:var(--mono);border-top:1px solid #0000;padding:11px 22px;font-size:13px;font-weight:500;display:block}.hook-badge-bad{color:var(--red);background:var(--red-dim);border-top-color:#dc262626}.hook-badge-good{color:var(--green);background:var(--green-dim);border-top-color:#16a34a26}.terminal-sim{border-radius:var(--radius);background:#060e0a;border:1px solid #1a2e22;margin:28px 0;overflow:hidden}.terminal-sim--practice .term-output{min-height:240px;max-height:520px}.term-titlebar{background:#0a1410;border-bottom:1px solid #1a2e22;align-items:center;gap:8px;padding:10px 16px;display:flex}.term-dot{background:#1a2e22;border-radius:50%;width:10px;height:10px;transition:background .3s}.terminal-sim.completed .term-dot:first-child{background:#ef4444}.terminal-sim.completed .term-dot:nth-child(2){background:#f59e0b}.terminal-sim.completed .term-dot:nth-child(3){background:#22c55e}.term-title{font-family:var(--mono);color:#3a5848;letter-spacing:.1em;text-transform:uppercase;margin-left:6px;font-size:9.5px}.term-output{min-height:160px;max-height:360px;font-family:var(--mono);color:#6b5e50;padding:20px;font-size:.8rem;line-height:1.9;overflow-y:auto}.term-line{display:block}.term-prompt{color:var(--term-green);margin-right:4px}.term-cmd{color:#e8dcc8}.term-info{color:#3a5848}.term-tool{color:#253d30}.term-tool-label{color:#10b981;font-size:.76rem}.term-tool-arg{color:#4a6858}.term-tool-res{color:#253d30;padding-left:20px;font-size:.76rem}.term-think{color:#2e4838;font-style:italic}.term-success{color:var(--term-green)}.term-divider{color:#2a1f12}.term-error{color:#f87171}.term-run-btn{border:1px solid var(--term-green);color:var(--term-green);font-family:var(--mono);letter-spacing:.06em;cursor:pointer;text-transform:uppercase;background:0 0;border-radius:4px;padding:7px 18px;font-size:10.5px;transition:background .15s,color .15s}.term-run-btn:hover{background:var(--term-green);color:#000}.term-run-btn:disabled{opacity:.4;cursor:not-allowed}.term-footer{border-top:1px solid #1a2e22;align-items:center;gap:12px;padding:12px 20px;display:flex}.term-hint{font-family:var(--mono);color:#253d30;letter-spacing:.06em;font-size:9.5px}.term-input-line{font-family:var(--mono);background:#07050100;border-top:1px solid #1a2e22;align-items:center;gap:8px;padding:10px 20px;font-size:.8rem;display:flex}.term-input-line .term-prompt{color:var(--term-green);white-space:nowrap;-webkit-user-select:none;user-select:none;flex-shrink:0}.term-input{color:#e8dcc8;font-family:var(--mono);caret-color:var(--term-green);background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:.8rem}.term-input:disabled{opacity:.4;cursor:not-allowed}.term-input::placeholder{color:#1a2e22}.term-complete-banner{font-family:var(--mono);color:var(--term-green);background:#00ff880a;border-top:1px solid #00ff8826;align-items:center;gap:10px;padding:10px 20px;font-size:.78rem;display:flex}.practice-page{justify-content:center;min-height:100vh;padding-top:56px;display:flex}.practice-content{width:100%;max-width:860px;padding:56px 48px 80px}.practice-eyebrow{font-family:var(--body);color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px;font-size:11px;font-weight:600}h1.practice-title{font-family:var(--display);letter-spacing:-.01em;color:var(--text);margin-bottom:36px;font-size:1.9rem;font-weight:600;line-height:1.2}h1.practice-title .accent{color:var(--accent)}.practice-objective-box{background:var(--surface);border:1.5px solid var(--border);border-left:4px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;margin-bottom:28px;padding:20px 24px}.practice-obj-label{font-family:var(--body);color:var(--accent);letter-spacing:.18em;text-transform:uppercase;margin-bottom:10px;font-size:10px;font-weight:700}.practice-objective-box p:last-child{color:var(--text-secondary);margin:0;font-size:.97rem;line-height:1.7}.practice-hints-section{margin-top:14px}.practice-hint-toggle{font-family:var(--body);color:var(--muted);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:0;font-size:12px;font-weight:500;text-decoration:underline}.practice-hint-toggle:hover{color:var(--text)}.practice-hint-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);margin-top:10px;padding:14px 18px;font-size:.9rem;line-height:1.6}.practice-hint-content code{font-family:var(--mono);background:var(--surface2);color:var(--text);border-radius:3px;padding:1px 6px;font-size:.8rem}.practice-success{background:var(--green-dim);border:1.5px solid var(--green-glow);border-radius:var(--radius);margin-top:36px;padding:28px 32px}.practice-success-title{font-family:var(--sans);color:var(--green);margin-bottom:12px;font-size:1rem;font-weight:700}.practice-success p{color:var(--text-secondary);margin-bottom:20px;font-size:.95rem;line-height:1.7}.btn-back-lesson{font-family:var(--body);color:var(--green);border:1.5px solid var(--green);border-radius:var(--radius-sm);padding:10px 24px;font-size:13px;font-weight:600;transition:background .15s,color .15s;display:inline-block}.btn-back-lesson:hover{background:var(--green);color:var(--on-green);text-decoration:none}.access-page{justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex}.access-box{width:100%;max-width:400px}.access-box .logo{font-family:var(--sans);color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:44px;font-size:11px;font-weight:700}.access-box h1{font-family:var(--sans);margin-bottom:8px;font-size:1.6rem;font-weight:800}.access-box .sub{color:var(--muted);margin-bottom:36px;font-size:.95rem}.field{margin-bottom:16px}.field label{font-family:var(--body);color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:600;display:block}.field input{background:var(--surface);border:1.5px solid var(--border);width:100%;color:var(--text);font-family:var(--body);border-radius:var(--radius-sm);outline:none;padding:12px 16px;font-size:.95rem;transition:border-color .2s}.field input:focus{border-color:var(--accent)}.field input::placeholder{color:var(--muted2)}.btn-primary{background:var(--accent);width:100%;color:var(--on-accent);font-family:var(--body);cursor:pointer;border-radius:var(--radius-sm);border:none;margin-top:8px;padding:14px;font-size:14px;font-weight:700;transition:filter .2s,box-shadow .2s}.btn-primary:hover{filter:brightness(1.1);box-shadow:0 4px 16px var(--accent-glow)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.access-error{font-family:var(--body);color:var(--red);background:var(--red-dim);border-radius:var(--radius-sm);border:1.5px solid #dc262633;margin-top:16px;padding:12px 16px;font-size:13px;display:none}.course-header{margin-bottom:8px}.module-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:40px;display:grid}.module-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);color:inherit;padding:24px;transition:border-color .2s,box-shadow .2s;display:block}.module-card:hover{border-color:var(--accent);box-shadow:0 4px 16px var(--accent-glow);text-decoration:none}.module-card .card-num{font-family:var(--mono);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px;font-size:10px}.module-card h3{font-family:var(--sans);color:var(--text);margin-bottom:8px;font-size:.95rem;font-weight:700;line-height:1.4}.module-card p{color:var(--muted);font-size:.88rem;line-height:1.55}.module-card .card-lessons{font-family:var(--body);color:var(--muted2);margin-top:16px;font-size:11px}.btn-mark-done{border:1.5px solid var(--accent);color:var(--accent);font-family:var(--body);cursor:pointer;border-radius:var(--radius-sm);background:0 0;padding:9px 22px;font-size:13px;font-weight:600;transition:background .15s,color .15s}.btn-mark-done:hover{background:var(--accent);color:var(--on-accent)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--muted2)}.topbar-menu-btn{cursor:pointer;color:var(--topbar-text);opacity:.8;background:0 0;border:none;flex-shrink:0;margin-right:4px;padding:6px;display:none}.topbar-menu-btn:hover{opacity:1}.topbar-menu-btn svg{display:block}.sidebar-backdrop{z-index:99;opacity:0;pointer-events:none;background:#0000008c;transition:opacity .22s;position:fixed;inset:0}.sidebar-backdrop.visible{opacity:1;pointer-events:auto}@media (width<=960px){.topbar{padding:0 16px}.topbar-logo{white-space:nowrap;font-size:10px}.topbar-menu-btn{align-items:center;display:flex}.sidebar{z-index:100;width:68px;box-shadow:none;padding-top:56px;padding-bottom:24px;transition:transform .22s cubic-bezier(.4,0,.2,1),width .22s cubic-bezier(.4,0,.2,1);display:block;position:fixed;top:0;bottom:0;left:0;overflow:hidden;transform:translate(-100%)}.sidebar:before{display:none}.sidebar.sidebar-open{width:68px;box-shadow:none;border-right:1px solid #ffffff14;overflow:visible;transform:translate(0)}.sidebar-section+.sidebar-section{border-top:none;margin-top:0;padding-top:0}.sidebar-module{border-radius:8px;justify-content:center;gap:0;width:60px;min-width:60px;margin:2px 4px;padding:9px 4px}.mod-num{letter-spacing:.06em;border-radius:6px;justify-content:center;min-width:32px;height:24px;font-size:11px}.sidebar-module .mod-title,.sidebar-module:after{display:none}.sidebar.sidebar-open .sidebar-module.active{z-index:10;width:250px;box-shadow:inset 3px 0 0 var(--sidebar-active), 4px 4px 20px #0000008c, 0 0 0 1px var(--accent-glow);padding:9px 14px 9px 10px;position:relative}.sidebar.sidebar-open .sidebar-module.active .mod-num{flex-shrink:0;min-width:32px;height:24px;font-size:12px}.sidebar.sidebar-open .sidebar-module.active .mod-title{white-space:normal;word-break:break-word;color:#f0fff8;flex:1;font-size:11.5px;font-weight:600;line-height:1.25;display:block}.sidebar:not(.sidebar-open) .sidebar-lessons{display:none!important}.sidebar.sidebar-open .sidebar-lessons{background:var(--sidebar-bg);border:1px solid var(--sidebar-border);border-top:none;border-radius:0 0 8px 8px;width:230px;margin-left:-1px}.main{margin-left:0}.main-content,.practice-content{padding:32px 20px 60px}.topbar-practice-label{display:none}.vis-compare{grid-template-columns:1fr}.vis-vs-col{display:none}.stats-row{grid-template-columns:1fr}}.module-card.is-locked{cursor:default;opacity:.72;text-decoration:none;position:relative}.module-card.is-locked:hover{box-shadow:none;border-color:var(--border);transform:none}.module-card.is-locked .card-lock-icon{opacity:.35;font-size:1rem;position:absolute;top:1rem;right:1rem}.unlock-footer{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.unlock-price-tag{font-family:var(--sans);color:var(--text);font-size:1.1rem;font-weight:600}.unlock-btn{border-radius:var(--radius-sm);width:100%;font-family:var(--body);cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text);text-align:center;padding:.5rem 1rem;font-size:.8rem;font-weight:500;transition:background .15s,border-color .15s;display:block}.unlock-btn:hover{background:var(--surface);border-color:var(--muted2)}.unlock-btn.primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.unlock-btn.primary:hover{opacity:.9}.unlock-btn.ref-btn.can-afford{border-color:var(--green);color:var(--green)}.unlock-sep{text-align:center;color:var(--muted);font-size:.75rem}.bundle-offer{background:var(--accent-dim);border:1px solid var(--accent-glow);border-radius:var(--radius);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding:1.25rem 1.5rem;display:flex}.bundle-offer p{color:var(--text);font-size:.9rem}.bundle-discount{font-family:var(--mono);color:var(--accent);background:var(--accent-dim);border-radius:4px;margin-left:.25rem;padding:2px 6px;font-size:.75rem}.bundle-btn{background:var(--accent);color:var(--on-accent);border-radius:var(--radius-sm);font-family:var(--body);cursor:pointer;border:none;flex-shrink:0;padding:.5rem 1.25rem;font-size:.85rem;font-weight:500}.bundle-btn:hover{opacity:.9}.zona-layout{flex-direction:column;gap:2.5rem;max-width:720px;margin:0 auto;padding:48px 32px 80px;display:flex}.zona-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem 2rem}.zona-section h2{font-family:var(--sans);color:var(--text);margin-bottom:1.25rem;font-size:1rem;font-weight:600}.credits-badge{background:var(--accent-dim);border:1px solid var(--accent-glow);font-family:var(--mono);color:var(--accent);border-radius:999px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.35rem 1rem;font-size:1.25rem;font-weight:700;display:inline-flex}.credits-label{font-family:var(--body);color:var(--text-secondary);font-size:.8rem;font-weight:400}.ref-link-box{align-items:stretch;gap:.5rem;display:flex}.ref-link-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);color:var(--text);font-family:var(--mono);flex:1;padding:.6rem .9rem;font-size:.8rem}.ref-copy-btn{background:var(--accent);color:var(--on-accent);border-radius:var(--radius-sm);font-family:var(--body);cursor:pointer;white-space:nowrap;border:none;padding:.6rem 1rem;font-size:.8rem;font-weight:500}.ref-copy-btn:hover{opacity:.9}.ref-hint{color:var(--text-secondary);margin-top:.75rem;font-size:.8rem}.zona-modules{flex-direction:column;gap:.5rem;display:flex}.zona-module-row{border-radius:var(--radius-sm);background:var(--surface2);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.zona-module-name{color:var(--text);font-size:.85rem;font-weight:500}.zona-module-status{font-size:.75rem;font-family:var(--mono);border-radius:4px;padding:2px 8px}.zona-module-status.free{background:var(--surface);color:var(--muted)}.zona-module-status.locked{background:var(--surface);color:var(--muted);border:1px solid var(--border)}.zona-module-status.unlocked{background:var(--green-dim);color:var(--green);border:1px solid var(--green-glow)}.ref-history-empty{color:var(--muted);text-align:center;padding:1rem 0;font-size:.85rem}.ref-history-row{border-bottom:1px solid var(--border-light);color:var(--text-secondary);justify-content:space-between;padding:.6rem 0;font-size:.82rem;display:flex}.ref-history-row:last-child{border-bottom:none}.card-lock-badge{background:var(--surface2);border:1px solid var(--border);font-size:.78rem;font-family:var(--mono);color:var(--muted);border-radius:999px;margin-top:.75rem;padding:.25rem .75rem;display:inline-block}.locked-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#000000a6;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.locked-modal-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:440px;padding:2.5rem 2rem;display:flex;position:relative}.locked-modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:1rem;line-height:1;position:absolute;top:1rem;right:1rem}.locked-modal-close:hover{color:var(--text)}.locked-modal-tag{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.locked-modal-title{font-family:var(--sans);color:var(--text);font-size:1.3rem;font-weight:600}.locked-modal-seq{color:var(--text-secondary);font-size:.88rem;line-height:1.5}.locked-modal-price{font-family:var(--sans);color:var(--text);font-size:2rem;font-weight:700}.locked-modal-action{border-radius:var(--radius-sm);width:100%;font-family:var(--body);cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text);text-align:center;padding:.65rem 1rem;font-size:.88rem;font-weight:500;text-decoration:none;transition:background .15s;display:block}.locked-modal-action:hover{background:var(--surface)}.locked-modal-action.primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.locked-modal-action.primary:hover{opacity:.9}.locked-modal-action.ref.can-afford{border-color:var(--green);color:var(--green)}.locked-modal-sep{color:var(--muted);font-size:.75rem}.locked-modal-hint{color:var(--accent);font-size:.78rem;text-decoration:none}.locked-modal-hint:hover{text-decoration:underline}.modulo-back{color:var(--muted);margin-bottom:2.5rem;font-size:.82rem;text-decoration:none;display:inline-block}.modulo-back:hover{color:var(--text)}.modulo-page-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:1.25rem;max-width:520px;padding:2.5rem 2rem;display:flex}.modulo-page-eyebrow{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.modulo-page-title{font-family:var(--sans);color:var(--text);font-size:1.6rem;font-weight:700;line-height:1.2}.modulo-page-locked-msg{flex-direction:column;align-items:center;gap:.75rem;display:flex}.modulo-page-lock-icon{font-size:2rem}.modulo-page-locked-msg p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.modulo-page-price-row{align-items:baseline;gap:.5rem;display:flex}.modulo-page-price{font-family:var(--sans);color:var(--text);font-size:2.5rem;font-weight:700}.modulo-page-price-label{color:var(--muted);font-size:.85rem}.modulo-page-btn{border-radius:var(--radius-sm);width:100%;font-family:var(--body);cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text);text-align:center;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .15s;display:flex}.modulo-page-btn:hover{background:var(--surface)}.modulo-page-btn.primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.modulo-page-btn.primary:hover{opacity:.9}.modulo-page-btn.secondary{color:var(--text-secondary)}.modulo-page-btn.ref.can-afford{border-color:var(--green);color:var(--green)}.modulo-page-credits{opacity:.75;font-size:.75rem;font-weight:400}.modulo-page-sep{width:100%;color:var(--muted);align-items:center;gap:.75rem;font-size:.8rem;display:flex}.modulo-page-sep:before,.modulo-page-sep:after{content:"";background:var(--border);flex:1;height:1px}.modulo-page-hint{color:var(--accent);font-size:.8rem;text-decoration:none}.modulo-page-hint:hover{text-decoration:underline}.dev-test-btn{z-index:999;color:#fff;font-family:var(--body);cursor:pointer;background:#7c3aed;border:none;border-radius:999px;padding:.5rem 1rem;font-size:.78rem;font-weight:500;position:fixed;bottom:1.25rem;right:1.25rem;box-shadow:0 2px 12px #7c3aed59}.dev-test-btn:hover{opacity:.9}.dev-test-btn.active{background:#059669;box-shadow:0 2px 12px #05966959}.topbar-dev-toggle{color:var(--topbar-text);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;opacity:.5;background:#ffffff0d;border:1px solid #ffffff1f;border-radius:999px;align-items:center;gap:5px;padding:4px 10px;font-size:10px;font-weight:600;transition:opacity .15s,background .15s,border-color .15s,color .15s;display:inline-flex}.topbar-dev-toggle:hover{opacity:1;background:#ffffff1a}.topbar-dev-toggle.dev{opacity:1;color:#34d399;background:#34d39926;border-color:#34d39966}.topbar-dev-toggle.dev:hover{background:#34d39938}.topbar-zona-link{color:var(--topbar-text);opacity:.7;margin-right:.75rem;font-size:.8rem;text-decoration:none;transition:opacity .15s}.topbar-zona-link:hover{opacity:1}.modulo-page-wrap{max-width:640px;margin:0 auto;padding:52px 48px 96px}.modulo-hero{margin-bottom:40px}.modulo-eyebrow{font-family:var(--body);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);align-items:center;gap:10px;margin-bottom:14px;font-size:11px;font-weight:600;display:flex}.modulo-eyebrow-badge{font-size:10px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;border-radius:999px;padding:2px 8px}.modulo-eyebrow-badge.free{background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-glow)}.modulo-eyebrow-badge.unlocked{background:var(--green-dim);color:var(--green);border:1px solid var(--green-glow)}.modulo-eyebrow-badge.locked{background:var(--red-dim);color:var(--red);border:1px solid #dc262633}.modulo-hero-title{font-family:var(--display);letter-spacing:-.01em;color:var(--text);margin-bottom:20px;font-size:2.4rem;font-weight:600;line-height:1.15}.modulo-hero-desc{color:var(--text-secondary);max-width:560px;font-size:18px;line-height:1.8}.modulo-learnings{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;margin-bottom:40px;padding:24px 28px}.modulo-learnings-label{font-family:var(--body);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:16px;font-size:10px;font-weight:700}.modulo-learnings-list{flex-direction:column;gap:10px;list-style:none;display:flex}.modulo-learnings-list li{color:var(--text-secondary);gap:10px;font-size:15px;line-height:1.5;display:flex}.modulo-learnings-list li:before{content:"✓";color:var(--accent);font-family:var(--mono);flex-shrink:0;margin-top:2px;font-size:12px;font-weight:700}.modulo-lessons{margin-bottom:36px}.modulo-lessons-label{font-family:var(--body);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;font-size:10px;font-weight:700}.modulo-lesson-row{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--bg);align-items:center;gap:14px;margin-bottom:6px;padding:14px 16px;text-decoration:none;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}a.modulo-lesson-row:hover{border-color:var(--accent);background:var(--surface);box-shadow:0 2px 12px var(--accent-glow);text-decoration:none}.modulo-lesson-row.done{background:var(--green-dim);border-color:var(--green-glow)}.modulo-lesson-num{font-family:var(--mono);color:var(--muted);flex-shrink:0;width:20px;font-size:10px}.modulo-lesson-title{flex:1;font-size:15px;font-weight:500;line-height:1.4}.modulo-lesson-check{color:var(--green);flex-shrink:0;font-size:12px}.modulo-lesson-arrow{font-family:var(--mono);color:var(--muted2);flex-shrink:0;font-size:12px;transition:color .15s,transform .15s}a.modulo-lesson-row:hover .modulo-lesson-arrow{color:var(--accent);transform:translate(3px)}.modulo-lessons--locked{border-top:1px solid var(--border);opacity:.45;margin-top:32px;padding-top:28px}.modulo-lesson-row--locked{cursor:default;pointer-events:none}.modulo-lesson-lock{opacity:.5;flex-shrink:0;font-size:10px}.modulo-unlock-box{flex-direction:column;align-items:stretch;gap:12px;display:flex}.modulo-unlock-section{--u-bg:var(--sidebar-bg);--u-card-bg:color-mix(in srgb, var(--sidebar-bg) 60%, #000 40%);--u-card-bg2:color-mix(in srgb, var(--sidebar-bg) 40%, #000 60%);--u-border:#ffffff14;--u-border-h:color-mix(in srgb, var(--sidebar-active) 60%, transparent 40%);--u-text:#f0f0ee;--u-muted:#f0f0ee61;--u-accent:var(--sidebar-active);--u-accent-gl:var(--accent-glow);--u-green:var(--sidebar-active);--u-green-gl:var(--accent-glow);background:var(--u-bg);border-radius:var(--radius-lg);text-align:center;border:1px solid #34d3991f;margin-bottom:52px;padding:36px 28px 26px}.modulo-unlock-heading{font-family:var(--display);letter-spacing:-.02em;color:var(--u-text);margin-bottom:6px;font-size:2.1rem;font-weight:600;line-height:1.1}.modulo-unlock-subheading{font-family:var(--body);color:var(--u-muted);margin-bottom:26px;font-size:13px}.modulo-unlock-grid{text-align:left;grid-template-columns:1fr 32px 1fr;align-items:center;gap:0;margin-bottom:18px;display:grid}.unlock-divider{font-family:var(--body);color:var(--u-muted);letter-spacing:.06em;text-transform:uppercase;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.unlock-card{background:var(--u-card-bg);border:1px solid var(--u-border);border-radius:var(--radius);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;padding:24px 18px 22px;transition:border-color .2s,box-shadow .2s,background .2s;display:flex;position:relative;overflow:hidden}.unlock-card:before{content:"";background:linear-gradient(90deg, transparent, var(--u-accent), transparent);opacity:0;height:1px;transition:opacity .22s;position:absolute;top:0;left:0;right:0}.unlock-card:hover{background:var(--u-card-bg2);border-color:var(--u-border-h);box-shadow:0 0 0 1px var(--u-border-h), 0 8px 32px var(--u-accent-gl)}.unlock-card:hover:before{opacity:1}.unlock-card.can-afford{background:#0b1c14;border-color:#6ee7b74d}.unlock-card.can-afford:hover{border-color:var(--u-green);box-shadow:0 0 0 1px #6ee7b773, 0 8px 32px var(--u-green-gl)}.unlock-card-icon{width:52px;height:52px;color:var(--u-accent);opacity:.75;flex-shrink:0;margin-bottom:16px;transition:opacity .2s}.unlock-card:hover .unlock-card-icon{opacity:1}.unlock-card.can-afford .unlock-card-icon{color:var(--u-green)}.unlock-card-price{font-family:var(--display);color:var(--u-text);letter-spacing:-.02em;font-size:2rem;font-weight:600;line-height:1.05}.unlock-friends-status{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:999px;align-items:baseline;gap:8px;margin-bottom:14px;padding:10px 20px;display:inline-flex}.unlock-friends-status.enough{background:#34d39914;border-color:#34d39938}.unlock-friends-num{font-family:var(--sans);color:#e8f5ee80;font-size:1.25rem;font-weight:700;line-height:1}.unlock-friends-status.enough .unlock-friends-num{color:var(--u-green)}.unlock-friends-label{font-family:var(--body);color:#e8f5ee52;font-size:13px}.unlock-friends-label a{color:#34d3998c;text-decoration:none;transition:color .15s}.unlock-friends-label a:hover{color:var(--u-accent);text-underline-offset:3px;text-decoration:underline}.unlock-friends-status.enough .unlock-friends-label{color:#6ee7b7b3}@media (width<=960px){.modulo-page-wrap{padding:32px 20px 60px}.modulo-hero-title{font-size:1.8rem}.modulo-hero-desc{font-size:16px}.modulo-unlock-section{padding:26px 16px 20px}.modulo-unlock-heading{font-size:1.7rem}.modulo-unlock-grid{grid-template-columns:1fr 28px 1fr}.unlock-card{padding:20px 12px 18px}.unlock-card-icon{width:44px;height:44px}.unlock-card-price{font-size:1.35rem}}.prose{font-family:var(--font-body,var(--body));color:var(--text);max-width:68ch;line-height:1.8}.prose h1{font-family:var(--font-display,var(--display));color:var(--text);margin:2rem 0 1rem;font-size:1.8rem;font-weight:700;line-height:1.25}.prose h2{font-family:var(--font-display,var(--display));color:var(--text);margin:2.25rem 0 .75rem;font-size:1.35rem;font-weight:600;line-height:1.3}.prose h3{font-family:var(--font-sans,var(--sans));color:var(--text);margin:1.75rem 0 .5rem;font-size:1rem;font-weight:700}.prose p{margin-bottom:1.25rem}.prose ul,.prose ol{margin-bottom:1.25rem;padding-left:1.5rem}.prose li{margin-bottom:.4rem;line-height:1.7}.prose strong{color:var(--text);font-weight:600}.prose em{font-style:italic}.prose code{font-family:var(--font-mono,var(--mono));background:var(--surface,#f4f2ed);border:1px solid var(--border,#ddd9cf);border-radius:3px;padding:.1em .35em;font-size:.85em}.prose pre{background:var(--surface,#f4f2ed);border:1px solid var(--border,#ddd9cf);border-radius:7px;margin:1.5rem 0;padding:1.25rem;overflow-x:auto}.prose pre code{background:0 0;border:none;padding:0;font-size:.875rem}.prose table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.9rem}.prose th,.prose td{border:1px solid var(--border,#ddd9cf);text-align:left;padding:.5rem .85rem}.prose th{background:var(--surface,#f4f2ed);font-family:var(--font-sans,var(--sans));font-size:.8rem;font-weight:600}.prose a{color:var(--accent);text-underline-offset:2px;text-decoration:underline;text-decoration-thickness:1px}.prose a:hover{text-decoration-thickness:2px}.prose blockquote{border-left:3px solid var(--accent);color:var(--text-2,#3d3428);background:var(--surface,#f4f2ed);border-radius:0 6px 6px 0;margin:1.5rem 0;padding:.75rem 1.25rem;font-style:italic}.global-nav.svelte-12qhfyh{background:var(--nav-bg,#1b2a3e);height:48px;color:var(--nav-text,#e8e4dc);font-family:var(--font-sans,system-ui, sans-serif);border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex}.global-nav-logo.svelte-12qhfyh{color:var(--nav-text,#e8e4dc);opacity:.9;font-size:.9rem;font-weight:700;text-decoration:none;transition:opacity .15s}.global-nav-logo.svelte-12qhfyh:hover{opacity:1;text-decoration:none}.global-nav-acciones.svelte-12qhfyh{align-items:center;gap:.5rem;display:flex}.global-nav-avatar.svelte-12qhfyh{background:var(--accent,#e8621a);width:28px;height:28px;color:var(--accent-text,#fff);border-radius:50%;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;text-decoration:none;transition:opacity .15s;display:flex}.global-nav-avatar.svelte-12qhfyh:hover{opacity:.85;text-decoration:none}.global-nav-btn.svelte-12qhfyh{color:var(--nav-text,#e8e4dc);cursor:pointer;font-family:var(--font-sans,system-ui, sans-serif);opacity:.65;background:0 0;border:none;border-radius:5px;padding:.3rem .6rem;font-size:.8rem;font-weight:500;text-decoration:none;transition:opacity .15s,background .15s}.global-nav-btn.svelte-12qhfyh:hover{opacity:1;background:#ffffff14;text-decoration:none}.global-nav-btn--primary.svelte-12qhfyh{opacity:.85;border:1px solid #ffffff40}.global-nav-btn--primary.svelte-12qhfyh:hover{opacity:1;border-color:#ffffff80}
