:root,[data-theme=dark]{--bg: #0a0a0a;--bg2: #0f0f0f;--bg3: #141414;--surface: #1a1a1a;--surface2: #222;--border: #1f1f1f;--border2: #2a2a2a;--text: #f0ede8;--text2: #a09b93;--text3: #5a5650;--green: #00e59b;--green2: #00b87c;--orange: #ff7b35;--orange2: #e05a1a;--blue: #4da6ff;--purple: #b57aff;--yellow: #ffd166;--red: #ff5757;--teal: #00d4aa;--pink: #ff6eb4;--code-bg: #111;--topbar-h: 2px;--sidebar-w: 270px;--radius: 6px;--radius-lg: 12px;--html-color: #ff6b35;--css-color: #4da6ff;--js-color: #ffd166;--react-color: #00d4aa;--node-color: #5bc17a;--express-color: #b57aff;--mongo-color: #47a855;--projects-color: #ff6eb4;--sql-color: #f7941d;--api-color: #00b4d8;--bootstrap-color: #7952b3}[data-theme=light]{--bg: #f5f3ef;--bg2: #edeae4;--bg3: #e5e1d8;--surface: #fff;--surface2: #f0ede6;--border: #e0ddd5;--border2: #d4d0c8;--text: #1a1714;--text2: #5a5550;--text3: #9a9590;--green: #009966;--green2: #007a52;--orange: #e05a00;--orange2: #c04800;--blue: #1a6db5;--purple: #7c3aed;--yellow: #b5860a;--red: #cc3333;--teal: #007a66;--pink: #cc4488;--code-bg: #1e1e1e}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Cabinet Grotesk,sans-serif;font-size:15px;line-height:1.8;min-height:100vh;transition:background .25s,color .25s}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:2px}*{scrollbar-width:thin;scrollbar-color:var(--surface2) transparent}.app-layout{display:flex;min-height:100vh}.main-content{margin-left:var(--sidebar-w);min-height:100vh;flex:1;min-width:10;overflow-x:hidden}.top-bar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);z-index:400;background:var(--bg)}.top-bar-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--teal),var(--blue));transform-origin:left;transform:scaleX(0);transition:transform .1s linear}.mobile-menu-btn{display:none}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;z-index:300;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:var(--surface2) transparent;transition:background .25s,border-color .25s,transform .25s}.sidebar-logo{padding:20px 20px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.logo-mark{display:flex;align-items:center;gap:10px;margin-bottom:8px}.logo-mark svg{flex-shrink:0;filter:drop-shadow(0 0 8px rgba(0,229,155,.45))}.logo-text-group{display:flex;flex-direction:column;gap:1px}.sidebar-logo h1{font-family:Fraunces,serif;font-size:18px;font-weight:800;line-height:1.15;color:var(--text);margin:0}.sidebar-logo h1 span{color:var(--green)}.sidebar-logo .logo-domain{font-size:10px;color:var(--text3);font-family:Space Mono,monospace;letter-spacing:.03em;opacity:.7;margin:0}.sidebar-logo p{font-size:10.5px;color:var(--text3);margin-top:2px;font-family:Space Mono,monospace}.sidebar-progress{padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.progress-label{display:flex;justify-content:space-between;font-size:10px;color:var(--text3);font-family:Space Mono,monospace;margin-bottom:6px}.progress-track{height:3px;background:var(--surface2);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--teal));border-radius:2px;transition:width .3s ease}.nav-section{padding:16px 20px 5px;font-size:10px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--text3);font-family:Space Mono,monospace;margin-top:4px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;font-size:13.5px;color:var(--text2);text-decoration:none;cursor:pointer;transition:all .12s;border-left:2px solid transparent;font-weight:500;letter-spacing:-.01em}.nav-item:hover{color:var(--text);background:var(--surface);border-left-color:var(--border2)}.nav-item.active{color:var(--text);background:#00e59b12;border-left-color:var(--green);font-weight:600}.nav-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;box-shadow:0 0 5px currentColor}.hero{background:var(--bg);border-bottom:1px solid var(--border);padding:80px 72px 72px;position:relative}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 50%,rgba(0,229,155,.05) 0%,transparent 65%);pointer-events:none;z-index:0}.hero>*{position:relative;z-index:1}.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border2);padding:5px 14px;border-radius:20px;font-size:11px;color:var(--text3);font-family:Space Mono,monospace;margin-bottom:28px}.hero-eyebrow span{color:var(--green)}.hero h1{font-family:Fraunces,serif;font-size:58px;font-weight:900;line-height:1.05;margin-bottom:20px;max-width:700px}.hero h1 em{font-style:italic;font-weight:300;color:var(--text2)}.hero h1 .accent{color:var(--green)}.hero-desc{font-size:16px;color:var(--text2);max-width:560px;margin-bottom:40px;line-height:1.75}.hero-stack{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:48px}.stack-chip{padding:6px 14px;background:var(--surface);border:1px solid var(--border2);border-radius:4px;font-size:12px;font-family:Space Mono,monospace;font-weight:700;letter-spacing:.03em}.hero-stats{display:grid;grid-template-columns:repeat(4,auto);gap:40px;width:fit-content}.hero-stat-num{font-family:Fraunces,serif;font-size:36px;font-weight:900;line-height:1;color:var(--green)}.hero-stat-lbl{font-size:11px;color:var(--text3);margin-top:4px;font-family:Space Mono,monospace}.chapter{padding:64px 72px;border-bottom:1px solid var(--border)}.chapter:nth-child(2n){background:#80808004}.chapter-header{display:flex;align-items:flex-start;gap:24px;margin-bottom:48px;padding-bottom:36px;border-bottom:1px solid var(--border)}.chapter-num{flex-shrink:0;width:56px;height:56px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-family:Space Mono,monospace;font-size:13px;font-weight:700;border:1px solid}.chapter-meta{flex:1}.chapter-track{font-size:10px;font-family:Space Mono,monospace;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}.chapter-meta h2{font-family:Fraunces,serif;font-size:32px;font-weight:700;line-height:1.15;color:var(--text);margin-bottom:8px}.chapter-intro{font-size:14.5px;color:var(--text2);max-width:680px;line-height:1.75}.topic{margin-bottom:48px}.topic h3{font-family:Cabinet Grotesk,sans-serif;font-size:19px;font-weight:700;margin-bottom:12px;color:var(--text);display:flex;align-items:center;gap:10px}.topic h3:before{content:"";display:inline-block;width:3px;height:18px;background:currentColor;border-radius:2px;opacity:.4}.topic p{color:var(--text2);margin-bottom:16px;font-size:14.5px}.code-block{background:var(--code-bg);border:1px solid var(--border2);border-radius:var(--radius-lg);overflow:hidden;margin:16px 0}.code-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border2);background:#ffffff06}.code-lang,.code-label{font-family:Space Mono,monospace;font-size:10px;color:var(--text3);letter-spacing:.08em;text-transform:uppercase}.code-dots{display:flex;align-items:center;gap:5px}.code-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.code-copy{background:none;border:1px solid var(--border2);color:var(--text3);font-family:Space Mono,monospace;font-size:10px;padding:3px 10px;border-radius:3px;cursor:pointer;transition:all .15s}.code-copy:hover{color:var(--text);background:var(--surface)}.code-copy.copied{color:var(--green);border-color:var(--green)}pre{padding:20px;overflow-x:auto;font-family:Space Mono,monospace;font-size:12.5px;line-height:1.7;color:#e0ddd8;-moz-tab-size:2;tab-size:2}code{font-family:Space Mono,monospace;font-size:12px;background:var(--surface);padding:2px 6px;border-radius:4px;color:var(--green)}pre code{background:none;padding:0;color:inherit;font-size:inherit}.callout{border-left:3px solid;border-radius:0 var(--radius) var(--radius) 0;padding:14px 18px;margin:20px 0}.callout-title{font-size:12px;font-weight:700;font-family:Space Mono,monospace;letter-spacing:.06em;margin-bottom:8px;text-transform:uppercase}.callout.tip{background:#00e59b0f;border-color:var(--green)}.callout.tip .callout-title{color:var(--green)}.callout.warn{background:#ff7b3512;border-color:var(--orange)}.callout.warn .callout-title{color:var(--orange)}.callout.info{background:#4da6ff0f;border-color:var(--blue)}.callout.info .callout-title{color:var(--blue)}.callout.key{background:#ffd1660f;border-color:var(--yellow)}.callout.key .callout-title{color:var(--yellow)}.callout p{color:var(--text2)}.callout code{background:#ffffff12;color:var(--text)}.concept-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin:16px 0}.concept-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:18px;transition:border-color .15s,transform .15s}.concept-card:hover{transform:translateY(-2px)}.concept-icon{font-size:22px;margin-bottom:8px}.concept-card h5{font-size:13px;font-weight:700;margin-bottom:6px;color:var(--text);font-family:Cabinet Grotesk,sans-serif}.concept-card p{font-size:12.5px;color:var(--text2);line-height:1.6}.concept-card code{font-size:11px}.table-wrap{overflow-x:auto;margin:16px 0}table{width:100%;border-collapse:collapse;font-size:13px}thead tr{background:var(--surface)}th{padding:10px 14px;text-align:left;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);font-family:Space Mono,monospace;border-bottom:1px solid var(--border2)}td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:top}td code{font-size:11px;background:var(--surface)}tbody tr:hover{background:#80808008}td:first-child{color:var(--text);font-weight:600}.section-divider{display:flex;align-items:center;gap:16px;margin:40px 0 32px}.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background:var(--border)}.section-divider-text{font-size:10px;font-family:Space Mono,monospace;color:var(--text3);letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin:16px 0}.resource-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:18px 20px;text-decoration:none;display:block;transition:border-color .15s,transform .15s}.resource-card:hover{transform:translateY(-2px);border-color:var(--green)}.resource-card-type{font-size:9.5px;font-family:Space Mono,monospace;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}.resource-card h4{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px;font-family:Cabinet Grotesk,sans-serif}.resource-card p{font-size:12.5px;color:var(--text2);line-height:1.55}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin:16px 0}.game-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:16px;text-decoration:none;display:block;transition:border-color .15s,transform .15s}.game-card:hover{transform:translateY(-2px);border-color:var(--purple)}.game-card-emoji{font-size:24px;margin-bottom:8px}.game-card h5{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px}.game-card p{font-size:12px;color:var(--text2);line-height:1.5}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin:20px 0}.project-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:24px;transition:transform .15s,border-color .15s;cursor:pointer;text-decoration:none;display:block}.project-card:hover{transform:translateY(-3px);border-color:var(--teal)}.project-card-badge{display:inline-block;font-size:10px;font-family:Space Mono,monospace;font-weight:700;padding:2px 8px;border-radius:3px;margin-bottom:12px;letter-spacing:.06em;text-transform:uppercase}.project-card h4{font-size:18px;font-weight:700;margin-bottom:8px;font-family:Fraunces,serif;color:var(--text)}.project-card>p{font-size:13px;color:var(--text2);margin-bottom:14px;line-height:1.6}.project-tags{display:flex;gap:6px;flex-wrap:wrap}.project-tag{font-size:10px;font-family:Space Mono,monospace;background:var(--bg3);border:1px solid var(--border2);color:var(--text3);padding:2px 7px;border-radius:3px}.flow{display:flex;align-items:center;flex-wrap:wrap;gap:0;margin:20px 0;padding:20px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg)}.flow-step{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:10px 16px;font-size:12px;font-family:Space Mono,monospace;color:var(--text);text-align:center;flex-shrink:0}.flow-arrow{color:var(--text3);font-size:14px;padding:0 8px;flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:4px;font-family:Space Mono,monospace;font-size:10px;font-weight:700;padding:3px 9px;border-radius:3px;letter-spacing:.05em;text-transform:uppercase}.footer{padding:48px 72px;border-top:1px solid var(--border);text-align:center;color:var(--text3);font-family:Space Mono,monospace;font-size:11px}@media (max-width: 960px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #0006}.main-content{margin-left:0}.chapter,.hero{padding:48px 28px}.hero h1{font-size:38px}.hero-stats{grid-template-columns:repeat(2,auto);gap:24px}.chapter-header{flex-direction:column}.mobile-menu-btn{display:block}}@media (max-width: 600px){.chapter,.hero{padding:32px 20px}.hero h1{font-size:32px}.hero-stats{grid-template-columns:1fr;gap:16px}.chapter-header{margin-bottom:24px}.chapter-header h2{font-size:24px}.project-grid{grid-template-columns:1fr}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -20px 20px;padding:0 20px;width:calc(100% + 40px)}.compare-grid{grid-template-columns:1fr!important}.mobile-menu-btn{padding:8px}.mobile-menu-btn span{display:none}}
