.theme-loader{z-index:9999;background:radial-gradient(#141028d9 0%,#080612fa 65%,#000 100%),#000;justify-content:center;align-items:center;animation:.45s ease-out theme-loader-fade-in;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow:hidden}@keyframes theme-loader-fade-in{0%{opacity:0;-webkit-backdrop-filter:blur();backdrop-filter:blur()}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.theme-loader-canvas{width:100%;height:100%;position:absolute;top:0;bottom:0;left:0;right:0}.theme-loader-overlay{pointer-events:none;text-align:center;flex-direction:column;justify-content:flex-end;align-items:center;padding-bottom:14vh;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.theme-loader-text-wrap{flex-direction:column;align-items:center;gap:.5rem;display:flex}.theme-loader-message{color:#fff;letter-spacing:.01em;text-shadow:0 0 24px #a78bfa80,0 0 48px #a78bfa40;margin:0;font-size:max(1.05rem,min(2.4vw,1.6rem));font-weight:700;animation:1.8s ease-in-out infinite theme-loader-pulse}.theme-loader-sub{color:#ffffff8c;letter-spacing:.02em;align-items:center;gap:.4rem;margin:0;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.9rem;display:inline-flex}.theme-loader-sub-prefix{color:#a78bfa;font-weight:600}.theme-loader-cursor{vertical-align:-2px;background:#a78bfa;width:.5rem;height:1rem;margin-left:.15rem;animation:1s steps(2,end) infinite theme-loader-blink;display:inline-block}@keyframes theme-loader-pulse{0%,to{opacity:1;transform:translateY(0)}50%{opacity:.75;transform:translateY(-2px)}}@keyframes theme-loader-blink{0%,49%{opacity:1}50%,to{opacity:0}}.prefs-panel{-webkit-backdrop-filter:blur(18px);background:#141020c7;border:1px solid #a78bfa38;border-radius:18px;width:min(100%,880px);margin:1.5rem auto 0;padding:2rem 2.25rem;animation:.4s ease-out prefs-fade-in;box-shadow:0 30px 60px #0006,inset 0 0 0 1px #ffffff05}@keyframes prefs-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.prefs-header{text-align:center;margin-bottom:1.75rem}.prefs-title{color:#fff;letter-spacing:.005em;margin:0 0 .4rem;font-size:max(1.25rem,min(3vw,1.7rem));font-weight:700}.prefs-subtitle{color:#fff9;margin:0;font-size:.92rem}.prefs-section{margin-bottom:1.5rem}.prefs-section-head{justify-content:space-between;align-items:baseline;margin-bottom:.85rem;display:flex}.prefs-section h3{color:#e8e8f0;letter-spacing:.015em;margin:0;font-size:.95rem;font-weight:600}.prefs-hint{color:#ffffff73;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.75rem}.prefs-color-grid{grid-template-columns:repeat(12,1fr);gap:.5rem;display:grid}@media (max-width:720px){.prefs-color-grid{grid-template-columns:repeat(8,1fr)}}.prefs-color{aspect-ratio:1;cursor:pointer;border:2px solid #ffffff14;border-radius:10px;padding:0;transition:transform .15s,border-color .15s,box-shadow .15s;position:relative}.prefs-color:hover{border-color:#fff6;transform:translateY(-2px)}.prefs-color.is-selected{border-color:#fff;transform:translateY(-2px)scale(1.05);box-shadow:0 0 0 3px #a78bfa80,0 6px 20px #a78bfa4d}.prefs-color-badge{color:#14101f;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.prefs-style-grid{grid-template-columns:repeat(4,1fr);gap:.6rem;display:grid}@media (max-width:720px){.prefs-style-grid{grid-template-columns:repeat(2,1fr)}}.prefs-style-card{cursor:pointer;text-align:left;color:inherit;background:#ffffff08;border:1px solid #ffffff12;border-radius:10px;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.85rem .85rem .95rem;font-family:inherit;transition:all .15s;display:flex}.prefs-style-card:hover{background:#a78bfa14;border-color:#a78bfa66;transform:translateY(-1px)}.prefs-style-card.is-selected{background:#a78bfa2e;border-color:#a78bfa;box-shadow:0 0 0 1px #a78bfa80,0 8px 24px #a78bfa2e}.prefs-style-emoji{margin-bottom:.15rem;font-size:1.4rem;line-height:1}.prefs-style-label{color:#fff;font-size:.85rem;font-weight:600}.prefs-style-desc{color:#ffffff80;font-size:.72rem;line-height:1.3}.prefs-error{color:#fca5a5;text-align:center;background:#f871711f;border:1px solid #f8717166;border-radius:8px;margin:1rem 0;padding:.7rem 1rem;font-size:.85rem}.prefs-actions{border-top:1px solid #ffffff0f;justify-content:space-between;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;display:flex}.prefs-btn{cursor:pointer;border:none;border-radius:10px;padding:.85rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .15s}.prefs-btn--ghost{color:#ffffffb3;background:0 0;border:1px solid #ffffff26}.prefs-btn--ghost:hover{color:#fff;background:#ffffff0d}.prefs-btn--primary{color:#14101f;background:linear-gradient(135deg,#a78bfa 0%,#ec4899 100%);flex:1;max-width:280px;box-shadow:0 8px 24px #a78bfa59}.prefs-btn--primary:hover{transform:translateY(-1px);box-shadow:0 12px 32px #a78bfa73}:root{--bg-primary:#0a0a0f;--bg-secondary:#11111a;--bg-tertiary:#16161f;--bg-elevated:#1c1c28;--bg-code:#14141c;--text-primary:#ececf2;--text-secondary:#a8a8b3;--text-muted:#6b6b76;--text-dim:#4a4a54;--accent-purple:#a78bfa;--accent-purple-strong:#8b5cf6;--accent-purple-dim:#a78bfa1f;--accent-purple-glow:#a78bfa66;--border:#26262f;--border-strong:#34343f;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Consolas, monospace;--container-max:1120px;--section-pad-y:clamp(4rem, 10vw, 8rem);--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-soft:cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input{color:inherit;font-family:inherit}img{max-width:100%;display:block}::selection{background:var(--accent-purple-glow);color:var(--bg-primary)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-strong);border:2px solid var(--bg-primary);border-radius:100px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.landing{width:100%;position:relative;overflow-x:hidden}.container{max-width:var(--container-max);margin:0 auto;padding:0 1.5rem}.section{padding:var(--section-pad-y) 0;position:relative}.section-header{margin-bottom:max(2.5rem,min(6vw,4.5rem))}.eyebrow{font-family:var(--font-mono);letter-spacing:.18em;color:var(--accent-purple);text-transform:uppercase;margin-bottom:1.25rem;font-size:.75rem;font-weight:500;display:inline-block}.section-title{letter-spacing:-.025em;max-width:30ch;font-size:max(1.875rem,min(4.5vw,3rem));font-weight:800;line-height:1.1}.section-title .muted{color:var(--text-muted);font-weight:700}.reveal{opacity:0;transition:opacity .9s var(--ease-out), transform .9s var(--ease-out);transform:translateY(28px)}.reveal.revealed{opacity:1;transform:translateY(0)}.hero{isolation:isolate;justify-content:center;align-items:center;min-height:100svh;display:flex;position:relative;overflow:hidden}.tag-soup-canvas{z-index:0;position:absolute;top:0;bottom:0;left:0;right:0}.tag-soup-canvas canvas{display:block}.hero-overlay{z-index:1;pointer-events:none;background:radial-gradient(80% 60%,#0000 0%,#0a0a0f8c 65%,#0a0a0ff2 100%);position:absolute;top:0;bottom:0;left:0;right:0}.hero-content{z-index:2;text-align:center;width:100%;max-width:720px;animation:fadeUp 1.1s var(--ease-out) both;padding:4rem 1.5rem;position:relative}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.hero-badge{font-family:var(--font-mono);letter-spacing:.2em;color:var(--accent-purple);background:var(--accent-purple-dim);text-transform:uppercase;border:1px solid #a78bfa66;border-radius:100px;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.4rem .875rem;font-size:.7rem;font-weight:500;display:inline-flex}.hero-badge:before{content:"";background:var(--accent-purple);width:6px;height:6px;box-shadow:0 0 10px var(--accent-purple);border-radius:50%;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.hero-title{font-family:var(--font-mono);letter-spacing:-.045em;color:var(--text-primary);text-shadow:0 0 80px #a78bfa40;margin-bottom:1.5rem;font-size:max(2.5rem,min(9vw,5.75rem));font-weight:700;line-height:1;position:relative}.hero-peek-cat{transform-origin:50% 100%;filter:drop-shadow(0 8px 20px #a78bfa66);pointer-events:none;z-index:3;width:max(80px,min(10vw,140px));height:auto;animation:4s ease-in-out infinite hero-peek-bob;position:absolute;top:0;left:50%;translate:-50% -85%}@keyframes hero-peek-bob{0%,to{translate:-50% -85%;rotate:-3deg}50%{translate:-50% -78%;rotate:3deg}}@media (prefers-reduced-motion:reduce){.hero-peek-cat{animation:none}}.hero-title .bracket,.hero-title .slash{color:var(--accent-purple);font-weight:500}.hero-subtitle{color:var(--text-secondary);max-width:38ch;margin:0 auto 2.5rem;font-size:max(1.05rem,min(2vw,1.25rem));line-height:1.55}.access-form{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);background:#1c1c28b3;border-radius:100px;gap:.4rem;max-width:440px;margin:0 auto 1.75rem;padding:.4rem;transition:border-color .25s,box-shadow .25s;display:flex}.access-form:focus-within{border-color:var(--accent-purple);box-shadow:0 0 0 4px var(--accent-purple-dim)}.access-input{color:var(--text-primary);font-family:var(--font-mono);background:0 0;border:none;outline:none;flex:1;min-width:0;padding:.625rem 1rem;font-size:.95rem}.access-input::placeholder{color:var(--text-muted)}.access-btn{background:var(--accent-purple);color:var(--bg-primary);white-space:nowrap;border-radius:100px;padding:.625rem 1.4rem;font-size:.95rem;font-weight:600;transition:transform .15s,background .15s,box-shadow .15s}.access-btn:hover{box-shadow:0 6px 20px -6px var(--accent-purple-glow);background:#b9a3fb;transform:translateY(-1px)}.access-btn:active{transform:translateY(0)}.access-message{font-family:var(--font-mono);color:var(--text-muted);min-height:1.2em;margin-top:.5rem;font-size:.8rem}.access-message.error{color:#f87171}.access-message.success{color:var(--accent-purple)}.hero-meta{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.05em;flex-wrap:wrap;justify-content:center;gap:.5rem .875rem;margin-top:.5rem;font-size:.72rem;display:flex}.hero-meta .dot{color:var(--text-dim)}.scroll-hint{font-family:var(--font-mono);letter-spacing:.25em;color:var(--text-muted);z-index:2;text-transform:uppercase;pointer-events:none;flex-direction:column;align-items:center;gap:.5rem;font-size:.68rem;display:flex;position:absolute;bottom:1.75rem;left:50%;transform:translate(-50%)}.scroll-hint .arrow{background:linear-gradient(180deg, var(--text-muted), transparent);transform-origin:top;width:1px;height:24px;animation:2s ease-in-out infinite scrollLine}@keyframes scrollLine{0%{transform-origin:top;opacity:.8;transform:scaleY(0)}50%{transform-origin:top;opacity:1;transform:scaleY(1)}51%{transform-origin:bottom;transform:scaleY(1)}to{transform-origin:bottom;opacity:0;transform:scaleY(0)}}.what-you-build{background:var(--bg-primary);position:relative}.what-you-build:before{content:"";background:linear-gradient(90deg, transparent, var(--border-strong) 25%, var(--border-strong) 75%, transparent);height:1px;position:absolute;top:0;left:0;right:0}.builds-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;display:grid}.build-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;flex-direction:column;transition:border-color .3s,transform .3s,box-shadow .3s;display:flex;overflow:hidden}.build-card:hover{border-color:var(--accent-purple);transform:translateY(-4px);box-shadow:0 12px 40px -12px #a78bfa40}.build-preview{background:var(--bg-tertiary);border-bottom:1px solid var(--border);height:200px;padding:1.5rem;display:flex;position:relative;overflow:hidden}.build-preview:after{content:"";pointer-events:none;background:linear-gradient(#0000 60%,#0a0a0f66);position:absolute;top:0;bottom:0;left:0;right:0}.build-preview--hero{text-align:center;flex-direction:column;justify-content:center;align-items:center}.build-preview--hero .mock-badge{background:var(--accent-purple-dim);border:1px solid #a78bfa66;border-radius:100px;width:88px;height:14px;margin-bottom:.875rem}.build-preview--hero .mock-title{background:var(--text-secondary);border-radius:4px;width:78%;height:18px;margin-bottom:.5rem}.build-preview--hero .mock-subtitle{background:var(--text-muted);border-radius:4px;width:56%;height:9px;margin-bottom:1rem}.build-preview--hero .mock-button{background:var(--accent-purple);border-radius:8px;width:110px;height:28px}.build-preview--about{flex-direction:row;align-items:center;gap:1.25rem}.mock-avatar{background:linear-gradient(135deg, var(--accent-purple), var(--accent-purple-strong));width:64px;height:64px;box-shadow:0 0 20px -4px var(--accent-purple-glow);border-radius:50%;flex-shrink:0}.mock-lines{flex-direction:column;flex:1;gap:.5rem;display:flex}.mock-line{background:var(--text-muted);opacity:.7;border-radius:4px;width:100%;height:9px}.mock-line.short{width:55%}.build-preview--projects{flex-direction:row;align-items:stretch;gap:.625rem}.build-preview--projects .mock-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;flex-direction:column;flex:1;gap:.4rem;padding:.75rem;display:flex}.mock-card-tag{background:var(--accent-purple);border-radius:2px;width:36px;height:5px}.mock-card-line{background:var(--text-muted);opacity:.6;border-radius:2px;height:6px}.mock-card-line.w70{width:70%}.mock-card-line.w90{width:90%}.build-info{flex:1;padding:1.5rem}.build-tag{font-family:var(--font-mono);letter-spacing:.15em;color:var(--accent-purple);text-transform:uppercase;margin-bottom:.75rem;font-size:.7rem;font-weight:500}.build-title{letter-spacing:-.01em;margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.build-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.how-it-works{background:var(--bg-secondary);position:relative}.steps-list{flex-direction:column;gap:1rem;max-width:760px;display:flex}.step-item{background:var(--bg-primary);border:1px solid var(--border);border-radius:16px;align-items:flex-start;gap:2rem;padding:2rem;transition:border-color .25s,transform .25s;display:flex}.step-item:hover{border-color:var(--accent-purple);transform:translate(4px)}.step-number{font-family:var(--font-mono);color:var(--accent-purple);letter-spacing:-.04em;flex-shrink:0;width:60px;font-size:2.5rem;font-weight:700;line-height:1}.step-body{flex:1}.step-title{letter-spacing:-.01em;margin-bottom:.5rem;font-size:1.2rem;font-weight:700}.step-desc{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.footer{border-top:1px solid var(--border);background:var(--bg-primary);padding:2.5rem 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.footer-brand{font-family:var(--font-mono);letter-spacing:-.01em;font-size:1rem;font-weight:700}.footer-brand .bracket,.footer-brand .slash{color:var(--accent-purple);font-weight:500}.footer-meta{font-family:var(--font-mono);color:var(--text-muted);font-size:.78rem}@media (max-width:640px){.step-item{flex-direction:column;gap:.75rem;padding:1.5rem}.step-number{width:auto;font-size:2rem}.step-item:hover{transform:none}.access-form{border-radius:16px;flex-direction:column;gap:.5rem;padding:.5rem}.access-input{text-align:center;padding:.75rem 1rem}.access-btn{border-radius:12px;width:100%;padding:.75rem 1rem}.hero-content{padding:3rem 1.25rem 5rem}}.modality-panel{text-align:left;flex-direction:column;gap:1.5rem;width:100%;max-width:880px;margin:1.5rem auto 0;display:flex}.modality-header{text-align:center;flex-direction:column;gap:.4rem;display:flex}.modality-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--accent-purple);font-size:.78rem;font-weight:600}.modality-title{color:var(--text-primary);margin:0;font-size:max(1.5rem,min(3vw,2rem))}.modality-subtitle{color:var(--text-secondary,var(--text-primary));margin:0;font-size:.95rem}.modality-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (max-width:720px){.modality-grid{grid-template-columns:1fr}}.modality-card{border:1px solid var(--border);color:var(--text-primary);text-align:left;cursor:pointer;font:inherit;background:#ffffff06;border-radius:14px;flex-direction:column;gap:.7rem;padding:1.4rem 1.3rem 1.3rem;transition:border-color .2s,transform .2s,background .2s;display:flex}.modality-card:hover:not(:disabled){border-color:var(--accent-purple);background:#a78bfa0d;transform:translateY(-2px)}.modality-card:disabled{opacity:.55;cursor:progress}.modality-card-icon{width:38px;height:38px;color:var(--accent-purple);background:#a78bfa1f;border-radius:10px;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.modality-card-title{color:var(--text-primary);margin:0;font-size:1.15rem}.modality-card-desc{color:var(--text-secondary,var(--text-primary));margin:0;font-size:.88rem;line-height:1.55}.modality-card-list{color:var(--text-secondary,var(--text-primary));flex-direction:column;gap:.25rem;margin:.2rem 0 0;padding-left:1.1rem;font-size:.82rem;line-height:1.6;display:flex}.modality-card-list strong{color:var(--accent-purple);font-weight:600}.modality-card-cta{color:var(--accent-purple);margin-top:auto;padding-top:.7rem;font-size:.92rem;font-weight:600}.modality-error{text-align:center;color:#ff6b6b;font-size:.88rem}.modality-back{color:var(--text-secondary,var(--text-primary));font:inherit;cursor:pointer;background:0 0;border:none;border-radius:6px;align-self:center;padding:.4rem .8rem;font-size:.85rem;transition:color .15s}.modality-back:hover:not(:disabled){color:var(--accent-purple)}.modality-back:disabled{opacity:.5;cursor:not-allowed}.workshop{background:var(--bg-primary);grid-template-rows:100vh;grid-template-columns:280px minmax(0,1fr) minmax(380px,460px);height:100vh;display:grid;overflow:hidden}.workshop.workshop--local{grid-template-columns:280px minmax(0,1fr)}.step-local-hint{color:var(--text-secondary,var(--text-primary));border-left:2px solid var(--accent-purple);background:#a78bfa14;border-radius:4px;margin-top:.85rem;padding:.7rem .9rem;font-size:.82rem;line-height:1.55}@media (max-width:1023px){.workshop{display:none}}.workshop-mobile-block{display:none}@media (max-width:1023px){.workshop-mobile-block{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.mobile-block-card{text-align:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;max-width:420px;padding:2.5rem 2rem}.bracket-logo{font-family:var(--font-mono);margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.bracket-logo .bracket,.bracket-logo .slash{color:var(--accent-purple);font-weight:500}.mobile-block-card h2{letter-spacing:-.01em;margin-bottom:1rem;font-size:1.25rem;font-weight:700}.mobile-block-card p{color:var(--text-secondary);margin-bottom:.75rem;font-size:.95rem;line-height:1.6}.mobile-block-card p.muted{color:var(--text-muted);font-size:.85rem}}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;display:flex;overflow:hidden auto}.sidebar-header{border-bottom:1px solid var(--border);padding:1.5rem 1.25rem 1rem}.sidebar-brand{font-family:var(--font-mono);letter-spacing:-.01em;margin-bottom:1.25rem;font-size:1.05rem;font-weight:700}.sidebar-brand .bracket,.sidebar-brand .slash{color:var(--accent-purple);font-weight:500}.theme-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;padding:.875rem}.theme-card-label{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.4rem;font-size:.65rem}.theme-card-name{letter-spacing:-.01em;margin-bottom:.25rem;font-size:.95rem;font-weight:700}.theme-card-personality{color:var(--text-secondary);margin-bottom:.625rem;font-size:.78rem}.theme-card-swatches{gap:4px;display:flex}.theme-card-swatches span{border:1px solid #ffffff14;border-radius:5px;width:18px;height:18px}.step-nav-list{flex-direction:column;flex:1;gap:2px;padding:1rem .625rem;display:flex}.step-nav-eyebrow{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);padding:.5rem .625rem .875rem;font-size:.65rem}.step-link{text-align:left;width:100%;color:var(--text-secondary);border-left:3px solid #0000;border-radius:8px;align-items:center;gap:.75rem;margin-left:-3px;padding:.625rem .625rem .625rem .875rem;font-size:.9rem;font-weight:500;transition:background .15s,color .15s;display:flex;position:relative}.step-link:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.step-link.is-active{background:var(--accent-purple-dim);color:var(--text-primary);border-left-color:var(--accent-purple);font-weight:600}.step-link.is-completed:not(.is-active){color:var(--text-muted)}.step-link.is-completed .step-link-marker{color:var(--accent-purple)}.step-link.is-locked{opacity:.4;cursor:not-allowed}.step-link-marker{font-family:var(--font-mono);color:var(--text-muted);text-align:center;flex-shrink:0;width:22px;font-size:.78rem;font-weight:600}.step-link.is-active .step-link-marker{color:var(--accent-purple)}.step-link-name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sidebar-footer{border-top:1px solid var(--border);padding:.875rem 1.25rem 1.25rem}.sidebar-exit{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.05em;padding:.4rem 0;font-size:.78rem;transition:color .15s}.sidebar-exit:hover{color:#f87171}.step-content{background:var(--bg-primary);overflow-y:auto}.step-content-inner{max-width:720px;margin:0 auto;padding:3rem 2.5rem 4rem}.step-header{margin-bottom:2rem}.step-eyebrow-row{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.step-eyebrow{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent-purple);font-size:.7rem}.step-lang-tag{font-family:var(--font-mono);letter-spacing:.1em;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:100px;padding:.2rem .5rem;font-size:.65rem;font-weight:600}.step-title{letter-spacing:-.025em;font-size:max(1.75rem,min(3vw,2.25rem));font-weight:800;line-height:1.15}.step-theory{background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--accent-purple);border-radius:12px;margin-bottom:2rem;padding:1.25rem 1.5rem}.step-theory p{color:var(--text-secondary);font-size:.98rem;line-height:1.75}.step-block{margin-bottom:1.75rem}.step-block-header{justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.625rem;display:flex}.step-block-label{font-family:var(--font-mono);letter-spacing:.05em;color:var(--text-secondary);font-size:.78rem;font-weight:600}.step-block-hint{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.05em;font-size:.7rem}.step-reference{background:var(--bg-code);border:1px solid var(--border);font-family:var(--font-mono);color:var(--text-secondary);white-space:pre;border-radius:10px;margin:0;padding:1rem 1.25rem;font-size:.82rem;line-height:1.65;overflow-x:auto}.step-reference code{color:inherit;font-family:inherit}.step-editor{background:var(--bg-code);border:1px solid var(--border);border-radius:10px;min-height:220px;transition:border-color .2s;overflow:hidden}.step-editor:focus-within{border-color:var(--accent-purple)}.code-editor-host{height:100%;min-height:220px}.code-editor-host .cm-editor{background:0 0;height:100%}.quiz{background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;margin:2rem 0 1.5rem;padding:1.5rem;transition:border-color .25s;position:relative}.quiz--correct{border-color:var(--accent-purple);box-shadow:0 0 0 4px var(--accent-purple-dim)}.quiz--wrong{border-color:#f87171}.quiz-header{margin-bottom:1.25rem}.quiz-eyebrow{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent-purple);margin-bottom:.625rem;font-size:.7rem;display:block}.quiz-question{letter-spacing:-.01em;font-size:1.05rem;font-weight:700;line-height:1.45}.quiz-options{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;list-style:none;display:flex}.quiz-option{text-align:left;background:var(--bg-primary);border:1px solid var(--border);width:100%;color:var(--text-secondary);border-radius:10px;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;font-size:.9rem;line-height:1.5;transition:border-color .15s,background .15s,color .15s;display:flex}.quiz-option:hover:not(:disabled){border-color:var(--border-strong);color:var(--text-primary)}.quiz-option.selected,.quiz-option.correct{border-color:var(--accent-purple);background:var(--accent-purple-dim);color:var(--text-primary)}.quiz-option:disabled{cursor:default}.quiz-option-marker{font-family:var(--font-mono);color:var(--accent-purple);flex-shrink:0;width:18px;padding-top:1px;font-size:.78rem;font-weight:700}.quiz-option-text{flex:1}.quiz-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex;position:relative}.quiz-msg{font-size:.85rem;font-family:var(--font-mono)}.quiz-msg--wrong{color:#f87171}.quiz-msg--correct{color:var(--accent-purple)}.quiz-submit{background:var(--accent-purple);color:var(--bg-primary);border-radius:100px;padding:.5rem 1.125rem;font-size:.875rem;font-weight:600;transition:background .15s,transform .1s}.quiz-submit:hover:not(:disabled){background:#b9a3fb;transform:translateY(-1px)}.quiz-submit:disabled{background:var(--bg-elevated);color:var(--text-muted);cursor:not-allowed}.confetti{pointer-events:none;width:1px;height:1px;position:absolute;top:50%;right:0}.confetti span{background:var(--accent-purple);opacity:0;--i:0;--angle:calc(var(--i) * 25.7deg);border-radius:50%;width:6px;height:6px;animation:.8s cubic-bezier(.16,1,.3,1) forwards confettiBurst;position:absolute;top:0;left:0}.confetti span:nth-child(odd){background:var(--accent-purple-strong);width:5px;height:5px}.confetti span:nth-child(3n){background:#f0e6ff;border-radius:1px;width:4px;height:4px}@keyframes confettiBurst{0%{transform:translate(0, 0) rotate(var(--angle)) translateY(0);opacity:1}to{transform:translate(0, 0) rotate(var(--angle)) translateY(-72px);opacity:0}}.step-actions{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;display:flex}.step-actions-status{font-family:var(--font-mono);color:var(--text-muted);text-align:center;flex:1;min-width:0;font-size:.78rem}.step-actions-status .ready{color:var(--accent-purple)}.step-btn{font-family:var(--font-sans);border-radius:100px;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;transition:background .15s,color .15s,transform .1s}.step-btn--ghost{color:var(--text-secondary);background:0 0}.step-btn--ghost:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.step-btn--ghost:disabled{opacity:.3;cursor:not-allowed}.step-btn--primary{background:var(--accent-purple);color:var(--bg-primary)}.step-btn--primary:hover:not(:disabled){background:#b9a3fb;transform:translateY(-1px)}.step-btn--primary:disabled{background:var(--bg-elevated);color:var(--text-muted);cursor:not-allowed;transform:none}.preview{background:var(--bg-secondary);border-left:1px solid var(--border);flex-direction:column;display:flex;overflow:hidden}.preview-header{border-bottom:1px solid var(--border);background:var(--bg-tertiary);justify-content:space-between;align-items:center;gap:.5rem;padding:.875rem 1rem;display:flex}.preview-title{font-family:var(--font-mono);letter-spacing:.05em;color:var(--text-secondary);text-transform:uppercase;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;display:flex}.preview-dot{background:var(--accent-purple);width:8px;height:8px;box-shadow:0 0 8px var(--accent-purple-glow);border-radius:50%;animation:2.5s ease-in-out infinite previewPulse}@keyframes previewPulse{0%,to{opacity:1}50%{opacity:.4}}.preview-open-btn{font-family:var(--font-mono);color:var(--text-secondary);border:1px solid var(--border);background:var(--bg-primary);border-radius:100px;padding:.35rem .75rem;font-size:.72rem;font-weight:500;transition:border-color .15s,color .15s}.preview-open-btn:hover:not(:disabled){color:var(--accent-purple);border-color:var(--accent-purple)}.preview-open-btn:disabled{opacity:.4;cursor:not-allowed}.preview-frame-wrap{background:#fff;flex:1;position:relative;overflow:hidden}.preview-frame{background:#fff;border:none;width:100%;height:100%;display:block}.preview-placeholder{text-align:center;background:var(--bg-tertiary);color:var(--text-muted);font-family:var(--font-mono);z-index:1;justify-content:center;align-items:center;padding:2rem;font-size:.85rem;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.step-concepts{gap:.5rem;display:grid}.step-concept{background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--accent-purple);border-radius:10px;transition:border-color .15s,background .15s;overflow:hidden}.step-concept[open]{background:var(--bg-tertiary)}.step-concept-summary{cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;justify-content:space-between;align-items:center;gap:1rem;padding:.7rem 1rem;list-style:none;display:flex}.step-concept-summary::-webkit-details-marker{display:none}.step-concept-summary::marker{content:""}.step-concept-summary:hover .step-concept-name{background:var(--accent-purple);color:var(--bg-primary)}.step-concept-summary:focus-visible{box-shadow:inset 0 0 0 2px var(--accent-purple);border-radius:8px}.step-concept-name{font-family:var(--font-mono);color:var(--accent-purple);background:var(--accent-purple-dim);word-break:break-word;border-radius:6px;padding:.3rem .6rem;font-size:.85rem;font-weight:500;line-height:1.4;transition:background .15s,color .15s}.step-concept-chevron{border-right:2px solid var(--text-muted);border-bottom:2px solid var(--text-muted);flex-shrink:0;width:10px;height:10px;margin-right:.4rem;transition:transform .2s,border-color .15s;transform:rotate(-45deg)}.step-concept[open] .step-concept-chevron{border-color:var(--accent-purple);transform:rotate(45deg)}.step-concept-body{border-top:1px solid var(--border);flex-direction:column;gap:.35rem;margin-top:0;padding:.85rem 1rem .95rem;animation:.2s ease-out step-concept-reveal;display:flex}@keyframes step-concept-reveal{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.step-concept-what{color:var(--text-primary);margin:0;font-size:.92rem;line-height:1.55}.step-concept-why{color:var(--text-muted);margin:0;font-size:.83rem;line-height:1.55}.step-concept-why-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--accent-purple);opacity:.8;margin-right:.3rem;font-size:.7rem}.completion{background:var(--bg-primary);min-height:100vh;color:var(--text-primary);padding:3rem 1.5rem 4rem;overflow-y:auto}.completion-inner{flex-direction:column;gap:2.5rem;max-width:1080px;margin:0 auto;display:flex}.completion-hero{text-align:center;padding:2.5rem 1rem 1rem;position:relative}.completion-eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.18em;color:var(--accent-purple);background:#a78bfa1f;border:1px solid #a78bfa4d;border-radius:999px;margin-bottom:1.2rem;padding:.4rem .9rem;font-size:.75rem;display:inline-block}.completion-title{letter-spacing:-.02em;margin:0 0 1rem;font-size:max(1.8rem,min(4vw,2.8rem));font-weight:700;line-height:1.15}.completion-theme-name{background:linear-gradient(135deg, var(--accent-purple), #f0abfc);color:#0000;-webkit-background-clip:text;background-clip:text}.completion-sub{color:var(--text-muted);max-width:620px;margin:0 auto;font-size:1.05rem;line-height:1.6}.completion-sub strong{color:var(--text-primary);font-weight:600}.completion-block{background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;padding:1.5rem}.completion-block-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1.1rem;padding-bottom:.8rem;display:flex}.completion-block-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;color:var(--accent-purple);font-size:.78rem;font-weight:600}.completion-block-hint{color:var(--text-muted);font-size:.78rem;font-style:italic}.completion-preview-wrap{border:1px solid var(--border);background:#fff;border-radius:10px;width:100%;height:520px;position:relative;overflow:hidden}.completion-preview-frame{border:0;width:100%;height:100%}.completion-preview-placeholder{text-align:center;height:100%;color:var(--text-muted);background:var(--bg-primary);justify-content:center;align-items:center;padding:2rem;display:flex}.completion-preview-placeholder code{font-family:var(--font-mono);color:var(--accent-purple);background:#a78bfa1f;border-radius:4px;padding:.1rem .4rem}.completion-download{flex-direction:column;align-items:flex-start;gap:1rem;display:flex}.completion-download p{color:var(--text-muted);margin:0;line-height:1.6}.completion-btn{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:.4rem;padding:.75rem 1.4rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:transform .12s,background .18s,opacity .18s;display:inline-flex}.completion-btn:disabled{opacity:.5;cursor:not-allowed}.completion-btn--primary{background:var(--accent-purple);color:#0b0a13;border-color:var(--accent-purple)}.completion-btn--primary:not(:disabled):hover{background:#b39bff;transform:translateY(-1px)}.completion-btn--ghost{color:var(--text-primary);border-color:var(--border);background:0 0}.completion-btn--ghost:not(:disabled):hover{border-color:var(--accent-purple);background:#ffffff0a}.completion-challenge-intro{color:var(--text-muted);margin:0 0 1.2rem;line-height:1.65}.completion-challenge-intro strong{color:var(--text-primary)}.completion-challenge-grid{grid-template-columns:1fr 1fr;gap:1.2rem;display:grid}@media (max-width:860px){.completion-challenge-grid{grid-template-columns:1fr}}.completion-reference,.completion-challenge-editor{flex-direction:column;gap:.6rem;display:flex}.completion-reference-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.7rem}.completion-reference pre{background:var(--bg-primary);border:1px solid var(--border);font-family:var(--font-mono);color:var(--text-primary);border-radius:8px;margin:0;padding:1rem;font-size:.82rem;line-height:1.55;overflow-x:auto}.completion-challenge-actions{flex-wrap:wrap;align-items:center;gap:.8rem;display:flex}.completion-challenge-ok{color:#6ee7b7;font-size:.9rem;font-weight:600}.completion-local-hint{color:var(--text-muted);background:var(--bg-primary);border-left:3px solid var(--accent-purple);border-radius:0 6px 6px 0;margin:0;padding:.8rem 1rem;line-height:1.6}.completion-local-hint code{font-family:var(--font-mono);color:var(--accent-purple);background:#a78bfa1f;border-radius:4px;padding:.1rem .4rem}.completion-retos{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}@media (max-width:860px){.completion-retos{grid-template-columns:1fr}}.completion-reto{background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:.6rem;padding:1.2rem;transition:border-color .2s,transform .2s;display:flex}.completion-reto:hover{border-color:var(--accent-purple);transform:translateY(-2px)}.completion-reto h3{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.completion-reto p{color:var(--text-muted);flex:1;margin:0;font-size:.88rem;line-height:1.55}.completion-reto-link{color:var(--accent-purple);margin-top:.4rem;font-size:.85rem;font-weight:600;text-decoration:none}.completion-reto-link:hover{text-decoration:underline}.completion-goodbye{text-align:center;border-top:1px dashed var(--border);flex-direction:column;align-items:center;gap:1rem;padding:1.5rem 1rem .5rem;display:flex}.completion-goodbye p{max-width:560px;color:var(--text-muted);margin:0;line-height:1.65}
