: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;--html-bg: rgba(255, 107, 53, .13);--css-color: #4da6ff;--css-bg: rgba(77, 166, 255, .13);--js-color: #ffd166;--js-bg: rgba(255, 209, 102, .13);--react-color: #00d4aa;--react-bg: rgba(0, 212, 170, .13);--node-color: #5bc17a;--node-bg: rgba(91, 193, 122, .13);--express-color: #b57aff;--express-bg: rgba(181, 122, 255, .13);--mongo-color: #47a855;--mongo-bg: rgba(71, 168, 85, .13);--projects-color: #ff6eb4;--projects-bg: rgba(255, 110, 180, .13);--sql-color: #f7941d;--sql-bg: rgba(247, 148, 29, .13);--api-color: #00b4d8;--api-bg: rgba(0, 180, 216, .13);--bootstrap-color: #7952b3;--bootstrap-bg: rgba(121, 82, 179, .13);--tailwind-color: #38bdf8;--tailwind-bg: rgba(56, 189, 248, .13);--redis-color: #ff4444;--redis-bg: rgba(255, 68, 68, .13)}[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;--html-color: #cc4810;--html-bg: rgba(204, 72, 16, .08);--css-color: #1a6db5;--css-bg: rgba(26, 109, 181, .08);--js-color: #966c03;--js-bg: rgba(150, 108, 3, .08);--react-color: #007a66;--react-bg: rgba(0, 122, 102, .08);--node-color: #2b733d;--node-bg: rgba(43, 115, 61, .08);--express-color: #6d28d9;--express-bg: rgba(109, 40, 217, .08);--mongo-color: #245e2d;--mongo-bg: rgba(36, 94, 45, .08);--projects-color: #b51a66;--projects-bg: rgba(181, 26, 102, .08);--sql-color: #a35200;--sql-bg: rgba(163, 82, 0, .08);--api-color: #0a748c;--api-bg: rgba(10, 116, 140, .08);--bootstrap-color: #5c3b8c;--bootstrap-bg: rgba(92, 59, 140, .08);--tailwind-color: #0a75a1;--tailwind-bg: rgba(10, 117, 161, .08);--redis-color: #cc2222;--redis-bg: rgba(204, 34, 34, .08)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{scrollbar-width:none}html::-webkit-scrollbar,body::-webkit-scrollbar{display:none}html{scroll-behavior:smooth;overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:Cabinet Grotesk,sans-serif;font-size:15px;line-height:1.8;min-height:100vh;overflow-x:hidden;transition:background .25s,color .25s}.app-layout{display:flex;min-height:100vh}.main-content{margin-left:var(--sidebar-w);min-height:100vh;flex:1;min-width:0}.top-bar{position:fixed;top:0;left:var(--sidebar-w);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 .logo-title{font-family:Fraunces,serif;font-size:18px;font-weight:800;line-height:1.15;color:var(--text);margin:0}.sidebar-logo .logo-title 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(--card-accent, 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}.top-bar{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}.page-toc{display:none!important}}.page-toc{position:fixed;right:0;transform:translateY(-50%);z-index:200;display:flex;flex-direction:row-reverse;align-items:center;gap:0;pointer-events:none}.page-toc__handle{display:flex;flex-direction:column;align-items:center;gap:5px;padding:14px 8px;background:var(--surface);border:1px solid var(--border2);border-right:none;border-radius:var(--radius) 0 0 var(--radius);cursor:grab;-webkit-user-select:none;user-select:none;transition:background .2s,box-shadow .2s;pointer-events:auto}.page-toc__handle:active{cursor:grabbing}.page-toc:hover .page-toc__handle{background:var(--surface2);box-shadow:-4px 0 16px #0000004d}.page-toc__pip{width:6px;height:6px;border-radius:3px;background:var(--text3);transition:background .2s,height .2s;flex-shrink:0}.page-toc__pip--active{background:var(--green);height:14px}.page-toc__list{display:flex;flex-direction:column;min-width:200px;max-width:260px;max-height:60vh;overflow-y:auto;background:var(--surface);border:1px solid var(--border2);border-right:none;border-radius:var(--radius) 0 0 var(--radius);box-shadow:-8px 0 32px #00000059;padding:8px 0;scrollbar-width:thin;scrollbar-color:var(--border2) transparent;opacity:0;transform:translate(12px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}.page-toc--open .page-toc__list{opacity:1;transform:translate(0);pointer-events:auto}.page-toc--open .page-toc__handle{display:flex}.page-toc__header{font-family:Space Mono,monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);padding:4px 16px 8px;border-bottom:1px solid var(--border);margin-bottom:4px}.page-toc__item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:6px 16px;color:var(--text2);font-family:Inter,sans-serif;font-size:12px;line-height:1.4;transition:color .15s,background .15s;border-left:2px solid transparent}.page-toc__item:hover{color:var(--text);background:var(--surface2)}.page-toc__item--active{color:var(--green);border-left-color:var(--green);background:#00e59b0f}.page-toc__num{font-family:Space Mono,monospace;font-size:10px;color:var(--text3);flex-shrink:0;min-width:22px}.page-toc__item--active .page-toc__num{color:var(--green)}.page-toc__label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-toc__list::-webkit-scrollbar{width:3px}.page-toc__list::-webkit-scrollbar-track{background:transparent}.page-toc__list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.chapter-complete-btn{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border2);border-radius:6px;padding:6px 12px;cursor:pointer;color:var(--text3);font-size:11px;font-family:Space Mono,monospace;font-weight:700;transition:all .12s ease;-webkit-user-select:none;user-select:none;box-shadow:0 1px 2px #0000001a}.chapter-complete-btn:hover{color:var(--text);border-color:var(--border);background:var(--surface2)}.chapter-complete-btn.completed{background:#00e59b14;border-color:var(--green);color:var(--green)}.chapter-complete-btn.completed:hover{background:#00e59b1f}.page-toc__item-wrapper{display:flex;align-items:center;width:100%;gap:0;padding-left:12px;border-left:2px solid transparent;transition:all .12s}.page-toc__item-wrapper:hover{background:var(--surface2)}.page-toc__item-wrapper--active{border-left-color:var(--green);background:#00e59b0a}.page-toc__item-wrapper .page-toc__item{border-left:none!important;padding-left:8px!important}.page-toc__item-wrapper .page-toc__item:hover{background:none!important}.page-toc__checkbox{cursor:pointer;accent-color:var(--green);width:13px;height:13px;flex-shrink:0;border-radius:3px;border:1px solid var(--border2);background:var(--surface)}.search-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;justify-content:center;align-items:flex-start;padding-top:100px;animation:fadeIn .15s ease-out}.search-modal{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);width:100%;max-width:600px;box-shadow:0 24px 64px #0009;overflow:hidden;animation:slideUp .18s ease-out}.search-input-wrapper{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border2);gap:12px}.search-input-icon{font-size:18px;color:var(--text3)}.search-field{background:none;border:none;outline:none;color:var(--text);font-family:Inter,sans-serif;font-size:16px;width:100%}.search-field::placeholder{color:var(--text3)}.search-close-hint{font-family:Space Mono,monospace;font-size:10px;background:var(--surface2);border:1px solid var(--border2);padding:2px 6px;border-radius:4px;color:var(--text3);-webkit-user-select:none;user-select:none}.search-results{max-height:360px;overflow-y:auto;padding:8px 0}.search-result-item{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;text-decoration:none;transition:all .12s ease;border-left:3px solid transparent}.search-result-item.selected{background:var(--surface2);border-left-color:var(--green)}.search-result-icon{font-size:16px;color:var(--text3)}.search-result-item.selected .search-result-icon{color:var(--green)}.search-result-details{flex:1;display:flex;flex-direction:column}.search-result-title{font-size:14px;font-weight:600;color:var(--text)}.search-result-category{font-family:Space Mono,monospace;font-size:10px;color:var(--text3);margin-top:2px}.search-no-results{padding:32px 20px;text-align:center;color:var(--text3);font-size:12.5px;font-family:Space Mono,monospace}@keyframes slideUp{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.notes-toggle-btn{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--green);color:#000;border:none;cursor:pointer;z-index:240;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 16px #00e59b59;transition:all .15s ease}.notes-toggle-btn:hover{transform:scale(1.08)}.notes-toggle-btn.active{background:var(--surface2);color:var(--text);border:1px solid var(--border2);box-shadow:0 4px 16px #0000004d}.notes-drawer{position:fixed;top:0;right:0;bottom:0;width:360px;background:var(--surface);border-left:1px solid var(--border2);z-index:260;box-shadow:-8px 0 32px #00000073;display:flex;flex-direction:column;transform:translate(100%);transition:transform .22s cubic-bezier(.16,1,.3,1)}.notes-drawer.open{transform:translate(0)}.notes-drawer-header{padding:20px;border-bottom:1px solid var(--border2);display:flex;justify-content:space-between;align-items:center}.notes-drawer-title{font-family:Space Mono,monospace;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text)}.notes-drawer-body{flex:1;padding:20px;display:flex;flex-direction:column;gap:12px}.notes-textarea{flex:1;background:var(--bg);border:1px solid var(--border2);border-radius:var(--radius);padding:16px;color:var(--text);font-family:Inter,sans-serif;font-size:13.5px;line-height:1.6;resize:none;outline:none}.notes-textarea:focus{border-color:var(--green)}.notes-save-status{font-family:Space Mono,monospace;font-size:9px;color:var(--text3);text-align:right}@media (max-width: 600px){.notes-drawer{width:100vw}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.socrates-drawer *::-webkit-scrollbar{display:none!important}.socrates-drawer *{-ms-overflow-style:none!important;scrollbar-width:none!important}.gamification-container{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:20px 0 40px}.gamification-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;position:relative;overflow:hidden}.gamification-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--teal));opacity:.8}.gamification-card.badges-card:before{background:linear-gradient(90deg,var(--purple),var(--orange))}.gamification-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.gamification-card-title{font-family:Fraunces,serif;font-size:20px;font-weight:700;color:var(--text)}.gamification-level-badge{font-family:Space Mono,monospace;font-size:11px;font-weight:700;background:#00e59b1a;color:var(--green);border:1px solid rgba(0,229,155,.2);padding:4px 10px;border-radius:4px;letter-spacing:.05em;text-transform:uppercase}.xp-container{margin-bottom:24px}.xp-meta{display:flex;justify-content:space-between;font-family:Space Mono,monospace;font-size:11px;color:var(--text3);margin-bottom:8px}.xp-progress-bar{width:100%;height:10px;background:var(--bg3);border-radius:5px;overflow:hidden;border:1px solid var(--border2)}.xp-progress-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--teal));border-radius:5px;transition:width .6s cubic-bezier(.16,1,.3,1)}.stats-subgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stat-pill{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:14px;display:flex;align-items:center;gap:12px;transition:border-color .15s}.stat-pill:hover{border-color:var(--border)}.stat-pill-icon{font-size:24px}.stat-pill-value{font-family:Space Mono,monospace;font-size:18px;font-weight:700;color:var(--text);line-height:1.1}.stat-pill-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.badges-container{display:grid;grid-template-columns:1fr;gap:12px;height:100%}.badge-row{display:flex;align-items:center;gap:16px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:12px 16px;transition:all .2s ease;position:relative;overflow:hidden}.badge-row.unlocked{border-color:#ffd16640;background:#ffd16605}.badge-row.unlocked:hover{border-color:var(--yellow);transform:translateY(-1px);box-shadow:0 4px 12px #ffd16614}.badge-row.locked{opacity:.65}.badge-avatar{font-size:28px;flex-shrink:0;filter:grayscale(100%);transition:filter .2s}.badge-row.unlocked .badge-avatar{filter:grayscale(0%)}.badge-details{flex:1}.badge-name-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.badge-name{font-family:Cabinet Grotesk,sans-serif;font-size:13.5px;font-weight:700;color:var(--text2);transition:color .2s}.badge-row.unlocked .badge-name{color:var(--text)}.badge-status{font-family:Space Mono,monospace;font-size:9px;font-weight:700;text-transform:uppercase;padding:1px 6px;border-radius:3px;background:var(--surface);color:var(--text3);border:1px solid var(--border2)}.badge-row.unlocked .badge-status{background:#ffd1661a;color:var(--yellow);border-color:#ffd16633}.badge-desc{font-size:11.5px;color:var(--text3);margin-bottom:6px}.badge-row.unlocked .badge-desc{color:var(--text2)}.badge-progress-bar{width:100%;height:4px;background:var(--surface);border-radius:2px;overflow:hidden}.badge-progress-fill{height:100%;background:var(--text3);border-radius:2px;transition:width .4s}.badge-row.unlocked .badge-progress-fill{background:var(--yellow)}@keyframes pulse-fire{0%{transform:scale(1);filter:drop-shadow(0 0 2px rgba(255,123,53,.4))}50%{transform:scale(1.08);filter:drop-shadow(0 0 8px rgba(255,123,53,.8))}to{transform:scale(1);filter:drop-shadow(0 0 2px rgba(255,123,53,.4))}}.pulse-fire-animation{animation:pulse-fire 2s infinite ease-in-out}@media (max-width: 800px){.gamification-container{grid-template-columns:1fr}}
