:root{--bg:#f7f6f1;--bg2:#efeee8;--bg3:#e8e7df;--surface:#fff;--text:#1a1a18;--text2:#4a4a45;--text3:#8a8a82;--accent:#00b894;--accent-dark:#00966e;--accent-light:#e0fbf3;--border:#1a1a181a;--border2:#1a1a180f;--nav-bg:#f7f6f1e0}[data-theme=dark]{--bg:#0f1117;--bg2:#161b26;--bg3:#1e2535;--surface:#1a2030;--text:#e8e6df;--text2:#a8a49c;--text3:#666260;--accent:#00c8a0;--accent-dark:#00e6b8;--accent-light:#00281e;--border:#e8e6df1a;--border2:#e8e6df0d;--nav-bg:#0f1117e0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;max-width:100%;overflow-x:hidden}:focus-visible{outline:3px solid var(--accent);outline-offset:4px}.skip-link{background:var(--accent);color:#fff;z-index:1000;border-radius:4px;padding:10px 20px;font-family:Outfit,sans-serif;font-size:.875rem;font-weight:500;text-decoration:none;transition:top .2s;position:absolute;top:-100px;left:20px}.skip-link:focus-visible{top:10px}body{background:var(--bg);color:var(--text);max-width:100%;font-family:Outfit,sans-serif;font-size:16px;line-height:1.7;transition:background .3s,color .3s;overflow-x:hidden}.navbar{z-index:1000;background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:70px;padding:0 4rem;transition:background .3s,border-color .3s;display:flex;position:fixed;top:0;left:0;right:0}@media (max-width:992px){.navbar{height:60px;padding:0 1.5rem}}.nav-logo{color:var(--text);letter-spacing:-.02em;white-space:nowrap;z-index:1001;flex-shrink:0;align-items:center;font-family:DM Serif Display,serif;font-size:1.35rem;font-weight:700;text-decoration:none;display:flex;position:relative}.nav-logo span{color:var(--accent)}.nav-links{align-items:center;gap:2rem;margin:0;padding:0;list-style:none;display:flex}@media (min-width:993px){.nav-links{position:absolute;left:50%;transform:translate(-50%)}}.nav-links a{color:var(--text2);letter-spacing:.01em;white-space:nowrap;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .25s}.nav-links a:hover,.nav-links a.nav-link-active{color:var(--accent)}.nav-links a.nav-link-active{position:relative}.nav-links a.nav-link-active:after{content:"";background:var(--accent);height:2px;position:absolute;bottom:-4px;left:0;right:0}.nav-links a.nav-link-cta{border:1.5px solid var(--accent);letter-spacing:.02em;background:0 0;border-radius:50px;justify-content:center;align-items:center;margin-left:.5rem;padding:6px 16px;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:600;transition:all .25s cubic-bezier(.16,1,.3,1);display:inline-flex;color:var(--accent)!important}.nav-links a.nav-link-cta:hover{background:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px #00b89440;color:#fff!important}.nav-links a.nav-link-cta.nav-link-active{background:var(--accent);color:#fff!important}.nav-links a.nav-link-cta.nav-link-active:after{display:none}.nav-right{z-index:1001;flex-shrink:0;align-items:center;gap:1rem;display:flex;position:relative}.theme-toggle{border:1px solid var(--border);color:var(--text2);cursor:pointer;white-space:nowrap;background:0 0;border-radius:50px;align-items:center;gap:6px;padding:6px 12px;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:500;transition:all .25s;display:flex}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.nav-cta{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 18px;font-family:Outfit,sans-serif;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .2s,transform .1s}.nav-cta:hover{background:var(--accent-dark);transform:translateY(-1px)}section{padding:5rem 0}.container{max-width:1450px;margin:0 auto;padding:0 2rem}.section-label{color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.75rem;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:500}.section-title{color:var(--text);letter-spacing:-.02em;margin-bottom:1rem;font-family:DM Serif Display,serif;font-size:clamp(2rem,4vw,3rem);line-height:1.15}#hero{align-items:center;min-height:100vh;padding-top:60px;display:flex;position:relative;overflow:hidden}.hero-container{z-index:1;position:relative}.hero-grid{grid-template-columns:55fr 45fr;align-items:center;gap:4rem;width:100%;display:grid}@media (min-width:769px){#hero{height:220vh;min-height:220vh;padding-top:0;display:block;overflow:visible}.hero-container{box-sizing:border-box;z-index:1;align-items:center;height:100vh;padding-top:70px;display:flex;position:sticky;top:0;overflow:hidden}.hero-grid{grid-template-columns:calc(55% * (1 - var(--hero-scroll-ratio,0))) 1fr;gap:calc(4rem * (1 - var(--hero-scroll-ratio,0)))}.hero-left-col{opacity:calc(1 - var(--hero-scroll-ratio,0) * 1.5);transform:translateX(calc(-30px * var(--hero-scroll-ratio,0)));min-width:0;max-height:calc(800px * (1 - var(--hero-scroll-ratio,0)));overflow:hidden}}.hero-eyebrow{color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem;font-family:JetBrains Mono,monospace;font-size:.75rem}.hero-title{letter-spacing:-.03em;color:var(--text);margin-bottom:1rem;font-family:DM Serif Display,serif;font-size:clamp(2rem,3.8vw,3rem);line-height:1.08}.hero-title em{color:var(--accent);font-style:italic}.hero-sub{color:var(--text2);max-width:440px;margin-bottom:1.75rem;font-size:.95rem;line-height:1.6}.hero-actions{flex-wrap:wrap;gap:.875rem;display:flex}.btn-primary{color:var(--accent);border:1px solid var(--accent);text-transform:uppercase;letter-spacing:.05em;background:0 0;border-radius:0;align-items:center;gap:8px;padding:11px 22px;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex;position:relative}.btn-primary:hover{background:var(--accent-light);box-shadow:3px 3px 0px var(--accent);transform:translate(-3px,-3px)}.btn-secondary{color:var(--text2);border:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;background:0 0;border-radius:0;align-items:center;gap:8px;padding:11px 22px;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex;position:relative}.btn-secondary:hover{color:var(--text);border-color:var(--text);box-shadow:3px 3px 0px var(--text);transform:translate(-3px,-3px)}.hero-stats{border-top:1px solid var(--border);gap:2.25rem;margin-top:2rem;padding-top:1.5rem;display:flex}.stat-num{color:var(--text);font-family:DM Serif Display,serif;font-size:1.75rem;line-height:1}.stat-num span{color:var(--accent)}.stat-label{color:var(--text3);margin-top:4px;font-size:.8rem;line-height:1.3}.hero-terminal{background:var(--bg2);border:1px solid var(--border);border-radius:14px;position:relative;overflow:hidden}.terminal-bar{background:var(--bg3);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:12px 16px;display:flex}.t-dot{border-radius:50%;width:12px;height:12px}.t-dot.r{background:#ff5f57}.t-dot.y{background:#ffbd2e}.t-dot.g{background:#28ca42}.terminal-title{color:var(--text3);margin-left:6px;font-family:JetBrains Mono,monospace;font-size:.7rem}.terminal-body{text-align:left;min-height:320px;padding:1.5rem;font-family:JetBrains Mono,monospace;font-size:.8rem;line-height:1.8}.t-prompt{color:var(--accent)}.t-cmd{color:var(--text)}.t-out{color:var(--text2)}.t-accent{color:var(--accent)}.t-dim{color:var(--text3)}.t-line{display:block}.cursor{background:var(--accent);vertical-align:middle;width:8px;height:1.1em;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.photo-placeholder{background:var(--bg3);border:2px dashed var(--border);width:200px;height:200px;color:var(--text3);text-align:center;cursor:pointer;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;margin:0 auto 1.5rem;font-size:.75rem;transition:border-color .2s;display:flex}.photo-placeholder:hover{border-color:var(--accent);color:var(--accent)}.photo-placeholder svg{opacity:.5;margin-bottom:8px}#photoInput,#photoInput2{display:none}#about{background:var(--bg2)}.about-grid{grid-template-columns:1fr 2fr;align-items:start;gap:4rem;display:grid}.about-photo-wrap{position:sticky;top:80px}.avatar-frame{aspect-ratio:1;background:var(--bg3);cursor:pointer;border-radius:0;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:visible}.avatar-image-wrapper{border:1px solid var(--border);width:100%;height:100%;transition:border-color .2s;position:relative;overflow:hidden}.avatar-frame:before{content:"";border-top:3px solid var(--accent);border-left:3px solid var(--accent);pointer-events:none;width:32px;height:32px;transition:all .3s cubic-bezier(.25,1,.5,1);position:absolute;top:-8px;left:-8px}.avatar-frame:after{content:"";border-bottom:3px solid var(--accent);border-right:3px solid var(--accent);pointer-events:none;width:32px;height:32px;transition:all .3s cubic-bezier(.25,1,.5,1);position:absolute;bottom:-8px;right:-8px}.avatar-frame:hover .avatar-image{transform:scale(1.04)}.avatar-frame:hover .avatar-image-wrapper{border-color:var(--accent)}.avatar-frame:hover:before{top:-4px;left:-4px}.avatar-frame:hover:after{bottom:-4px;right:-4px}.avatar-image{object-fit:cover;width:100%;height:100%;transition:transform .4s cubic-bezier(.25,1,.5,1)}.about-text p{color:var(--text2);text-align:left;margin-bottom:1.25rem;font-size:1.0125rem}.about-text p:last-child{margin-bottom:0}.about-art-statement{border-left:2px solid var(--accent);padding-left:1.1rem;font-family:DM Serif Display,serif;font-size:1.15rem;font-style:italic;line-height:1.65;color:var(--text1)!important;margin-bottom:2rem!important}.highlight{color:var(--accent);font-weight:500}.interactive-tags-wrapper{width:100%;margin-top:2rem;margin-bottom:2rem;position:relative}.about-tags{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.tag{color:var(--text2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:0;outline:none;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:.8125rem;font-weight:500;transition:all .2s}.tag:hover,.tag.active{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}[data-theme=dark] .tag{color:var(--text2);border-color:var(--border)}[data-theme=dark] .tag:hover,[data-theme=dark] .tag.active{color:var(--accent);border-color:var(--accent);background:var(--accent-light)}.tag-connector-svg{pointer-events:none;z-index:5;width:100%;height:100%;position:absolute;top:0;left:0}.tag-connector-svg line{stroke:var(--accent);stroke-width:1.5px}.tag-connector-svg circle{fill:var(--accent)}.tag-details-box{-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);text-align:left;opacity:0;pointer-events:none;z-index:20;background:#f7f6f1eb;padding:12px 16px;transition:all .3s cubic-bezier(.25,1,.5,1);position:absolute;bottom:16px;left:16px;right:16px;transform:translateY(10px);box-shadow:0 8px 25px #0000001f}[data-theme=dark] .tag-details-box{background:#161b26eb;border-color:#e8e6df1a}.tag-details-box.active{opacity:1;pointer-events:auto;border-color:var(--accent);transform:translateY(0);box-shadow:0 8px 30px #00b89426}.tag-details-content{font-family:JetBrains Mono,monospace;color:var(--text2)!important;margin:0!important;font-size:.8rem!important;line-height:1.45!important}.tag-details-box.active .tag-details-content{color:var(--text)!important}#services{background:var(--bg)}.services-header{justify-content:space-between;align-items:flex-end;margin-bottom:2rem;display:flex}.services-controls{align-self:flex-end;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.services-control-btn{border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.services-control-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.services-control-btn:disabled{opacity:.35;cursor:not-allowed}.services-grid{scroll-behavior:smooth;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab;gap:1.5rem;min-height:370px;margin-top:3rem;display:flex;overflow-x:auto}.services-grid.grabbing{cursor:grabbing;scroll-behavior:auto;scroll-snap-type:none;-webkit-user-select:none;user-select:none}.services-grid::-webkit-scrollbar{display:none}.service-card{background:var(--surface);border:1px solid var(--border);text-align:left;scroll-snap-align:start;border-radius:0;flex:0 0 calc(33.333% - 1rem);padding:2rem;transition:all .2s;position:relative;overflow:hidden}.service-card:hover{border-color:var(--accent);box-shadow:4px 4px 0px var(--accent);transform:translate(-4px,-4px)}.service-icon{background:var(--bg2);border:1px solid var(--border);border-radius:0;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:1.25rem;font-size:1.5rem;transition:all .2s;display:flex}.service-card:hover .service-icon{border-color:var(--accent);background:var(--accent-light);color:var(--accent-dark)}.service-title{color:var(--text);margin-bottom:.625rem;font-family:DM Serif Display,serif;font-size:1.25rem}.service-desc{color:var(--text2);font-size:.9rem;line-height:1.65}.service-techs{flex-wrap:wrap;gap:6px;margin-top:1rem;display:flex}.stech{color:var(--text3);background:var(--bg2);border:1px solid var(--border2);border-radius:0;padding:3px 9px;font-family:JetBrains Mono,monospace;font-size:.7rem}.services-dots-container{justify-content:center;align-items:center;gap:1.5rem;margin-top:2.5rem;display:flex;position:relative}.services-dots-track{background:var(--border);z-index:1;width:190px;height:2px;position:absolute;left:50%;transform:translate(-50%)}.services-dots-progress{background:var(--accent);height:100%;transition:width .3s cubic-bezier(.25,.46,.45,.94)}.service-dot{background:var(--bg);border:1.5px solid var(--text3);z-index:2;cursor:pointer;border-radius:0;width:8px;height:8px;padding:0;transition:all .2s;position:relative}.service-dot:hover,.service-dot.active{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}@media (max-width:992px){.service-card{flex:0 0 calc(50% - .75rem)}}@media (max-width:768px){.services-header{flex-direction:column;align-items:flex-start;gap:1rem}.services-controls{display:none}.services-grid{margin-left:-2rem;margin-right:-2rem;padding-left:2rem;padding-right:2rem}.service-card{flex:0 0 78vw;max-width:320px;box-shadow:0 8px 24px #0000000a}}#experience{background:var(--bg2)}.ide-container{border:1px solid var(--border);background:var(--bg2);border-radius:0;height:520px;margin-top:3rem;display:flex;overflow:hidden}.ide-sidebar{border-right:1px solid var(--border);background:var(--bg3);-webkit-user-select:none;user-select:none;flex-direction:column;width:250px;padding:12px 0;display:flex}.ide-sidebar-title{color:var(--text3);letter-spacing:.08em;padding:0 16px 12px;font-family:JetBrains Mono,monospace;font-size:.65rem;font-weight:700}.ide-tree{flex-direction:column;display:flex}.ide-tree-node{color:var(--text2);cursor:default;align-items:center;padding:6px 16px;font-family:JetBrains Mono,monospace;font-size:.75rem;display:flex}.ide-chevron{color:var(--text3);opacity:.7;flex-shrink:0;margin-right:4px}.ide-folder-icon{color:var(--accent);fill:#00c8a01a;flex-shrink:0;margin-right:6px}.ide-file-icon{color:var(--text3);flex-shrink:0;margin-right:6px}.indent-1{padding-left:26px}.indent-2{padding-left:38px}.indent-3{padding-left:50px}.ide-tree-files{flex-direction:column;gap:2px;display:flex}.ide-tree-file{color:var(--text2);cursor:pointer;text-align:left;background:0 0;border:none;outline:none;align-items:center;width:100%;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:.75rem;transition:all .15s;display:flex}.ide-tree-file:hover{background:var(--border2);color:var(--text)}.ide-tree-file.active{background:var(--border);color:var(--accent);font-weight:600}.ide-editor{background:var(--surface);flex-direction:column;flex:1;display:flex;overflow:hidden}.ide-tabs-bar{background:var(--bg3);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.ide-tabs-scrollable{scrollbar-width:none;flex:1;display:flex;overflow-x:auto}.ide-tabs-scrollable::-webkit-scrollbar{display:none}.ide-actions{border-left:1px solid var(--border);align-items:center;height:100%;padding:0 12px;display:flex}.ide-action-btn{background:var(--bg2);border:1px solid var(--border);color:var(--text2);cursor:pointer;outline:none;align-items:center;gap:5px;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:600;transition:all .2s;display:flex}.ide-action-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.ide-action-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.ide-tab-preview-badge{color:var(--accent);text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:.6rem}.ide-preview-window{text-align:left;color:var(--text);flex:1;padding:2rem;font-family:Outfit,sans-serif;overflow-y:auto}.preview-h1{color:var(--text);border-bottom:1px solid var(--border);margin-bottom:.75rem;padding-bottom:.5rem;font-family:DM Serif Display,serif;font-size:1.5rem;font-weight:700}.preview-h2{color:var(--accent);margin-bottom:1.25rem;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:600}.preview-period{color:var(--text3);font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:400}.preview-desc{color:var(--text2);margin-bottom:1.5rem;font-size:.92rem;line-height:1.65}.preview-h3{color:var(--text);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px dashed var(--border);margin-bottom:.75rem;padding-bottom:6px;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:700}.preview-list{margin-bottom:1rem;padding-left:1rem}.preview-list-item{color:var(--text2);margin-bottom:.6rem;font-size:.88rem;line-height:1.6;list-style-type:square}.ide-tab{border:none;border-right:1px solid var(--border);color:var(--text3);cursor:pointer;white-space:nowrap;background:0 0;outline:none;align-items:center;gap:8px;padding:10px 16px;font-family:JetBrains Mono,monospace;font-size:.72rem;transition:background .15s,color .15s;display:flex}.ide-tab:hover{background:var(--border2);color:var(--text2)}.ide-tab.active{background:var(--surface);color:var(--accent);border-bottom:1px solid var(--surface);font-weight:600}.ide-tab-close{opacity:.5;font-size:.85rem;transition:opacity .15s}.ide-tab:hover .ide-tab-close{opacity:1}.ide-editor-body{flex:1;padding:1.25rem 0;display:flex;overflow:auto}.ide-gutter{border-right:1px solid var(--border2);-webkit-user-select:none;user-select:none;flex-direction:column;align-items:flex-end;width:48px;padding-right:14px;display:flex}.gutter-num{color:var(--text3);opacity:.5;height:1.8rem;font-family:JetBrains Mono,monospace;font-size:.75rem;line-height:1.8}.ide-code-window{text-align:left;flex:1;margin:0;padding:0 20px;font-family:JetBrains Mono,monospace;font-size:.78rem;overflow-x:auto}.p-bracket{color:var(--text);font-weight:500}.p-indent-line{white-space:pre-wrap;min-height:1.8rem;padding-left:20px;line-height:1.8}.p-indent-2-line{padding-left:40px;line-height:1.8}.bullet-string-line{white-space:pre-wrap;min-height:1.8rem}:root{--json-key:#0984e3;--json-string:#2b8a3e;--md-accent:#00b894}[data-theme=dark]{--json-key:#4fc1ff;--json-string:#ce9178;--md-accent:#00c8a0}.p-key{color:var(--json-key);font-weight:500}.p-string{color:var(--json-string)}.md-header{color:var(--json-key);margin-bottom:4px;font-size:.95rem;font-weight:700}.md-subheader{color:var(--text3);margin-bottom:6px;font-size:.8rem;font-weight:500}.md-text{color:var(--text2);white-space:pre-wrap;font-size:.8rem;line-height:1.6}.md-section{color:var(--md-accent);margin-top:10px;margin-bottom:4px;font-size:.88rem;font-weight:600}.md-list-item{gap:8px;margin-bottom:4px;padding-left:6px;line-height:1.5;display:flex}.md-list-bullet{color:var(--md-accent);font-weight:700}.md-list-text{color:var(--text2);white-space:pre-wrap;font-size:.8rem}@media (max-width:768px){.ide-container{flex-direction:column;height:auto;min-height:400px}.ide-sidebar{display:none}.ide-editor{height:520px}.ide-action-btn span{display:none}.ide-action-btn{padding:6px 8px}.ide-actions{padding:0 8px}.ide-tab{gap:4px;padding:8px 12px;font-size:.68rem}.ide-tab-preview-badge{display:none}.ide-preview-window{padding:1.25rem}.preview-h1{font-size:1.25rem;line-height:1.2}.preview-h2{margin-bottom:.75rem;font-size:.95rem;line-height:1.3}.preview-period{margin-top:4px;font-size:.75rem;display:block}.preview-desc{margin-bottom:1rem;font-size:.85rem;line-height:1.5}.preview-list-item{font-size:.8rem;line-height:1.5}.ide-code-window{padding:1.25rem;font-size:.75rem}}#stack{background:var(--bg)}.stack-grid{display:flex;overflow-x:auto}.stack-interactive-layout{grid-template-columns:minmax(420px,500px) 1fr;align-items:start;gap:3rem;margin-top:3rem;display:grid}.stack-diagram-pane{background:var(--surface);border:1px solid var(--border);flex-direction:column;justify-content:flex-start;padding:1.5rem;display:flex}.stack-diagram-header{color:var(--text3);letter-spacing:.08em;border-bottom:1px dashed var(--border);padding-bottom:8px;font-family:JetBrains Mono,monospace;font-size:.65rem;font-weight:700}.arch-stack-svg{width:100%;height:auto;display:block}.arch-layer-group{cursor:pointer}.arch-layer-group rect{fill:var(--bg3);stroke:var(--border);stroke-width:1.5px;transition:all .25s}.arch-layer-group text{fill:var(--text);pointer-events:none;font-family:JetBrains Mono,monospace;font-size:10.5px;font-weight:700;transition:all .25s}.arch-layer-group:hover rect{fill:var(--accent-light);stroke:var(--accent)}.arch-layer-group:hover text{fill:var(--accent-dark)}.arch-layer-group.active rect{fill:var(--accent-light);stroke:var(--accent);stroke-width:2.5px}.arch-layer-group.active text{fill:var(--accent-dark);font-weight:700}.stack-diagram-footer{color:var(--text3);margin-top:4px;font-family:JetBrains Mono,monospace;font-size:.62rem}.stack-details-pane{background:var(--surface);border:1px solid var(--border);flex-direction:column;justify-content:flex-start;min-height:330px;padding:2.25rem;transition:all .25s;display:flex}.stack-details-title-row{border-bottom:1.5px solid var(--border);text-align:left;margin-bottom:1.5rem;padding-bottom:1.5rem}.stack-details-category-code{color:var(--accent);margin-bottom:6px;font-family:JetBrains Mono,monospace;font-size:.7rem;display:block}.stack-details-title{color:var(--text);margin-bottom:6px;font-family:DM Serif Display,serif;font-size:1.75rem}.stack-details-subtitle{color:var(--text2);font-size:.92rem;line-height:1.5}.stack-skills-matrix{text-align:left;grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.matrix-skill-row{border-bottom:1px dashed var(--border2);flex-direction:column;gap:8px;padding-bottom:12px;display:flex}.skill-meta{justify-content:space-between;align-items:center;display:flex}.skill-name{color:var(--text);font-size:.85rem;font-weight:600}.skill-tag{color:var(--text3);border:1.5px solid var(--border);padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:.65rem}.skill-gauge{gap:4px;display:flex}.gauge-segment{background:var(--border2);flex:1;height:4px}.gauge-segment.filled{background:var(--accent)}.mobile-only{display:none}@media (max-width:768px){.desktop-only{display:none!important}.mobile-only{display:block!important}.stack-mobile-select-container{flex-direction:column;gap:8px;width:100%;margin:1.5rem 0;display:flex}.stack-select-label{color:var(--accent);letter-spacing:.05em;font-family:JetBrains Mono,monospace;font-size:.72rem}.stack-select-wrapper{width:100%;position:relative}.stack-select-input{color:var(--text);background:var(--bg2);border:1.5px solid var(--border);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2300a896' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-position:right 16px center;background-repeat:no-repeat;border-radius:6px;outline:none;width:100%;padding:12px 16px;font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:500;transition:border-color .2s}.stack-select-input:focus{border-color:var(--accent)}.stack-mobile-layout{flex-direction:column;gap:1.5rem;margin-top:1.25rem;display:flex}.mobile-stack-card{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:1.5rem}}@media (max-width:992px){.stack-interactive-layout{grid-template-columns:1fr;gap:2rem}}@media (max-width:576px){.stack-skills-matrix{grid-template-columns:1fr;gap:1.25rem}}#projects{background:var(--bg2)}.projects-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);color:inherit;text-align:left;border-radius:0;padding:2rem;text-decoration:none;transition:border-color .2s,transform .2s,box-shadow .2s;display:block}.project-card:hover{border-color:var(--accent);box-shadow:4px 4px 0px var(--accent);transform:translate(-4px,-4px)}.project-eyebrow{color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem;font-family:JetBrains Mono,monospace;font-size:.7rem}.project-name{color:var(--text);margin-bottom:.5rem;font-family:DM Serif Display,serif;font-size:1.4rem}.project-desc{color:var(--text2);font-size:.875rem;line-height:1.6}.project-techs{flex-wrap:wrap;gap:6px;margin-top:1rem;display:flex}#contact{background:var(--text);color:var(--bg)}#contact .section-label{color:var(--accent)}#contact .section-title{color:var(--bg)}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:4rem;margin-top:3rem;display:grid}.contact-desc{color:#e8e6dfa6;text-align:left;margin-bottom:2rem;font-size:1.05rem;line-height:1.7}[data-theme=dark] #contact{background:var(--bg3)}[data-theme=dark] #contact .section-title{color:var(--text)}[data-theme=dark] .contact-desc{color:var(--text2)}.contact-links{text-align:left;flex-direction:column;gap:1rem;display:flex}.contact-link{color:#e8e6dfa6;align-items:center;gap:12px;font-size:.95rem;text-decoration:none;transition:color .2s;display:flex}[data-theme=dark] .contact-link{color:var(--text2)}.contact-link:hover{color:var(--accent)}.contact-link-icon{background:#e8e6df14;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.contact-form{text-align:left;flex-direction:column;gap:1rem;display:flex}.cf-label{color:#e8e6df80;margin-bottom:4px;font-size:.8rem;display:block}[data-theme=dark] .cf-label{color:var(--text3)}.cf-input,.cf-textarea{width:100%;color:var(--bg);background:#e8e6df0f;border:1px solid #e8e6df26;border-radius:0;outline:none;padding:12px 16px;font-family:Outfit,sans-serif;font-size:.9rem;transition:border-color .2s}[data-theme=dark] .cf-input,[data-theme=dark] .cf-textarea{color:var(--text);background:var(--bg2);border-color:var(--border)}.cf-input:focus,.cf-textarea:focus{border-color:var(--accent)}.cf-input::placeholder,.cf-textarea::placeholder{color:#e8e6df4d}[data-theme=dark] .cf-input::placeholder,[data-theme=dark] .cf-textarea::placeholder{color:var(--text3)}.cf-textarea{resize:vertical;min-height:120px}.cf-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:0;align-self:flex-start;padding:14px 28px;font-family:Outfit,sans-serif;font-size:.9375rem;font-weight:500;transition:background .2s,transform .1s}.cf-submit:hover{background:var(--accent-dark);transform:translateY(-1px)}footer{background:var(--bg2);border-top:1px solid var(--border);padding:0}.footer-inner{max-width:1450px;margin:0 auto;padding:0 2rem}.footer-top{border-bottom:1px solid var(--border2);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;padding:2rem 0;display:flex}.footer-logo{color:var(--text);letter-spacing:-.02em;font-family:DM Serif Display,serif;font-size:1.1rem;text-decoration:none}.footer-logo span{color:var(--accent)}.footer-nav{flex-wrap:wrap;gap:1.5rem;display:flex}.footer-nav a{color:var(--text3);font-size:.8125rem;text-decoration:none;transition:color .2s}.footer-nav a:hover{color:var(--accent)}.footer-socials{gap:.625rem;display:flex}.footer-social-link{border:1px solid var(--border);width:36px;height:36px;color:var(--text3);justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:flex}.footer-social-link:hover{border-color:var(--accent);color:var(--accent)}.footer-bottom{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:1.25rem 0;display:flex}.footer-copy{color:var(--text3);font-size:.8125rem}.footer-badge{color:var(--text3);letter-spacing:.05em;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:.7rem;display:flex}.footer-badge-dot{background:var(--accent);border-radius:0%;width:6px;height:6px;animation:2s ease-in-out infinite badge-pulse}@keyframes badge-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}@media (max-width:768px){.footer-top{flex-direction:column;align-items:flex-start;gap:1.25rem}.footer-nav{gap:1rem}}.fade-in{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.fade-in.visible{opacity:1;transform:translateY(0)}@media (max-width:768px){#hero{min-height:auto;padding:100px 0 40px;overflow:visible}.hero-container{overflow:visible}.hero-title{margin-bottom:.75rem;font-size:clamp(1.8rem,8vw,2.2rem)}.hero-sub{margin-bottom:1.25rem;font-size:.9rem}.hero-actions{gap:.5rem;margin-bottom:1.5rem}.hero-grid,.about-grid,.exp-layout,.contact-grid,.projects-grid{grid-template-columns:1fr;gap:2rem}.about-photo-wrap{order:2;position:static;top:auto}.about-text{order:1}.hero-stats{flex-wrap:wrap;gap:1.25rem;margin-top:1.5rem;padding-top:1.25rem}.stat-num{font-size:1.5rem}.stat-label{font-size:.72rem}.exp-nav{gap:0;display:flex;position:static;overflow-x:auto}.exp-nav-item{border-left:none;border-bottom:2px solid var(--border);white-space:nowrap;border-radius:0;padding:8px 16px}.exp-nav-item.active{border-bottom-color:var(--accent)}}.intro-overlay{z-index:2000;background:#0f1117;justify-content:center;align-items:center;width:100vw;height:100vh;transition:opacity .6s ease-in-out;display:flex;position:fixed;top:0;left:0}.fade-out-intro{opacity:0;pointer-events:none}.intro-content{text-align:center}.intro-logo{color:#e8e6df;letter-spacing:-.02em;opacity:0;font-family:DM Serif Display,serif;font-size:clamp(2.5rem,6vw,4.5rem);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);transform:translateY(20px)}.intro-logo span{color:var(--accent)}.intro-logo.visible-name{opacity:1;transform:translateY(0)}.intro-subtext{color:var(--accent);letter-spacing:.25em;text-transform:uppercase;opacity:0;margin-top:1rem;font-family:JetBrains Mono,monospace;font-size:clamp(.9rem,2vw,1.25rem);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);transform:translateY(10px)}.intro-subtext.visible-sub{opacity:1;transform:translateY(0)}.arch-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;flex-direction:column;min-height:480px;display:flex;position:relative;overflow:hidden}.arch-bar{background:var(--bg3);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.arch-dots{gap:8px;display:flex}.arch-tabs{gap:6px;display:flex}.arch-tab-btn{color:var(--text3);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:500;transition:all .2s}.arch-tab-btn:hover{color:var(--text);border-color:var(--border)}.arch-tab-btn.active{color:var(--accent);background:var(--surface);border-color:var(--border)}.arch-body{flex-grow:1;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative}.ddd-bounded-context{stroke:var(--accent);stroke-dasharray:6 4;animation:4s linear infinite ddd-marching-ants}@keyframes ddd-marching-ants{0%{stroke-dashoffset:0}to{stroke-dashoffset:-20px}}.ddd-pulse{animation:3s ease-in-out infinite ddd-pulse-glow}@keyframes ddd-pulse-glow{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;fill:var(--accent-light);transform:scale(1.15)}}.eda-event{fill:var(--accent);filter:drop-shadow(0 0 4px var(--accent));animation:4s linear infinite eda-flow-horizontal}.eda-event.delayed{animation-delay:2s}@keyframes eda-flow-horizontal{0%{cx:100px;cy:150px;opacity:0}10%{opacity:1}48%{cx:160px;cy:150px;opacity:1}50%{cx:160px;cy:150px;opacity:0}to{cx:160px;cy:150px;opacity:0}}.eda-event-vertical-up{fill:var(--accent-dark);filter:drop-shadow(0 0 4px var(--accent-dark));animation:4s linear infinite eda-flow-vertical-up}.eda-event-vertical-up.delayed{animation-delay:2s}@keyframes eda-flow-vertical-up{0%,48%{cx:240px;cy:150px;opacity:0}50%{opacity:1}95%{opacity:1}to{cx:300px;cy:72px;opacity:0}}.eda-event-vertical-down{fill:var(--accent-dark);filter:drop-shadow(0 0 4px var(--accent-dark));animation:4s linear infinite eda-flow-vertical-down}.eda-event-vertical-down.delayed{animation-delay:2s}@keyframes eda-flow-vertical-down{0%,48%{cx:240px;cy:150px;opacity:0}50%{opacity:1}95%{opacity:1}to{cx:300px;cy:222px;opacity:0}}.cqrs-path-write{stroke:var(--accent);stroke-dasharray:8 6;animation:30s linear infinite cqrs-dash-write}@keyframes cqrs-dash-write{to{stroke-dashoffset:-500px}}.cqrs-path-read{stroke:var(--accent-dark);stroke-dasharray:8 6;animation:30s linear infinite cqrs-dash-read}@keyframes cqrs-dash-read{to{stroke-dashoffset:500px}}.cqrs-pulse-node{animation:2s ease-in-out infinite cqrs-node-glow}@keyframes cqrs-node-glow{0%,to{r:6px;opacity:.6}50%{r:9px;opacity:1}}.cqrs-arrow-path{stroke-dasharray:10;animation:1.5s linear infinite cqrs-arrow-dash}@keyframes cqrs-arrow-dash{to{stroke-dashoffset:-20px}}.sandbox-body{height:320px;position:relative;overflow:hidden}.sandbox-svg{width:100%;height:100%;display:block}.sandbox-node-group{transition:transform .15s}.sandbox-node-group:hover{transform:scale(1.03)}.sandbox-hint{text-align:center;color:var(--text3);pointer-events:none;background:linear-gradient(to top, var(--bg2) 70%, transparent);padding:8px 0;font-family:JetBrains Mono,monospace;font-size:.65rem;position:absolute;bottom:12px;left:0;right:0}.sandbox-header-actions{align-items:center;display:flex}@keyframes sandbox-pulse{0%{r:3px;opacity:.8}50%{r:5px;opacity:1;fill:var(--accent)}to{r:3px;opacity:.8}}.hero-container{width:100%;max-width:1450px;margin:0 auto;padding:0 clamp(1.5rem,5vw,6rem)}.hero-canvas-overlay{z-index:50;background:var(--bg);pointer-events:auto;position:fixed;overflow:hidden}.hero-canvas-wrap{opacity:var(--canvas-fade,1);position:absolute;inset:0}.hero-manifesto{pointer-events:none;position:absolute;inset:0}@keyframes manifesto-float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.manifesto-word{opacity:min(clamp(0, (var(--words-show,0) - var(--word-delay,0)) * 10, 1), clamp(0, 1 - var(--art-show,0) * 5, 1));animation:manifesto-float var(--float-duration,4s) ease-in-out infinite var(--float-phase,0s);white-space:nowrap;position:absolute}.manifesto-word--mono{letter-spacing:.12em;text-transform:uppercase;color:var(--text3);font-family:JetBrains Mono,monospace;font-size:clamp(.65rem,1.1vw,.95rem);font-weight:600}.manifesto-word--serif{color:var(--text2);font-family:DM Serif Display,serif;font-size:clamp(1.4rem,2.4vw,2.2rem);font-style:italic}.manifesto-art{opacity:var(--art-show,0);transform:scale(calc(.94 + .06 * var(--art-show,0)));transform-origin:50%;pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:0;display:flex;position:absolute;inset:0}.manifesto-art-line1{letter-spacing:.35em;text-transform:uppercase;color:var(--text3);margin-bottom:.5rem;font-family:JetBrains Mono,monospace;font-size:clamp(1rem,2vw,1.4rem);font-weight:400;display:block}.manifesto-art-line2{color:var(--text);letter-spacing:-.03em;font-family:DM Serif Display,serif;font-size:clamp(3.5rem,9vw,8rem);font-style:italic;font-weight:400;line-height:.9;display:block}.manifesto-almost{opacity:clamp(0, calc((var(--art-show,0) - .42) * 12), 1);display:inline-block;position:relative}.manifesto-almost:after{content:"";background:var(--accent);height:.12em;width:calc(clamp(0, (var(--art-show,0) - .66) * 15, 1) * 105%);border-radius:2px;position:absolute;top:48%;left:0;transform:translateY(-50%)}.wizard-card{background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;flex-direction:column;height:520px;transition:all .3s;display:flex;overflow:hidden;box-shadow:0 10px 30px #00000026}.wizard-header{border-bottom:1px solid var(--border);background:var(--bg2);align-items:center;gap:12px;padding:1rem 1.5rem;display:flex}.wizard-title-label{color:var(--text2);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:600;overflow:hidden}.wizard-body{flex-direction:column;flex:1;justify-content:center;padding:1.5rem;display:flex}.wizard-step{flex-direction:column;height:100%;display:flex}.wizard-step.result{justify-content:flex-start;overflow-y:auto}.wizard-h3{color:var(--text);margin-bottom:.75rem;font-size:1.1rem;font-weight:600;line-height:1.4}.wizard-p{color:var(--text2);margin-bottom:1.25rem;font-size:.8rem;line-height:1.5}.wizard-field{flex-direction:column;gap:8px;margin-bottom:1.5rem;display:flex}.wizard-label{color:var(--text3);text-transform:uppercase;letter-spacing:.05em;font-family:JetBrains Mono,monospace;font-size:.7rem}.wizard-input{box-sizing:border-box;background:var(--bg3);border:1.5px solid var(--border);width:100%;color:var(--text);border-radius:8px;padding:12px 16px;font-size:.95rem;transition:all .2s}.wizard-input:focus{border-color:var(--accent);outline:none}.wizard-progress-row{align-items:center;gap:12px;margin-bottom:1rem;display:flex}.wizard-progress{color:var(--accent);text-transform:uppercase;white-space:nowrap;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:.68rem}.wizard-progress-track{background:var(--border);border-radius:2px;flex:1;height:3px;overflow:hidden}.wizard-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .4s}.wizard-options{flex-direction:column;flex:1;justify-content:center;gap:8px;margin-bottom:1.25rem;display:flex}.wizard-options--4{grid-template-columns:1fr 1fr;gap:8px;display:grid}.wizard-opt-btn{text-align:left;background:var(--bg2);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;align-items:flex-start;padding:10px 14px;transition:all .2s;display:flex}.wizard-opt-btn strong{color:var(--text);margin-bottom:4px;font-size:.85rem}.wizard-opt-btn span{color:var(--text3);font-size:.7rem;line-height:1.3}.wizard-opt-btn:hover{border-color:var(--accent-dark);background:var(--bg3)}.wizard-opt-btn.active{border-color:var(--accent);background:var(--accent-light)}.wizard-nav-btns{justify-content:space-between;gap:12px;margin-top:auto;display:flex}.btn-wizard-action{background:var(--accent);color:#fff;cursor:pointer;text-align:center;border:none;border-radius:8px;justify-content:center;align-items:center;padding:12px 24px;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-wizard-action:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px)}.btn-wizard-action:disabled{opacity:.5;cursor:not-allowed}.btn-wizard-sec{color:var(--text2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:12px 20px;font-size:.875rem;transition:all .2s}.btn-wizard-sec:hover{color:var(--text);border-color:var(--text3)}.wizard-result-diagram{background:var(--bg2);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;height:190px;margin-bottom:1rem;display:flex;overflow:hidden}.wizard-result-headline{color:var(--accent);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem;font-size:.95rem;font-weight:700}.wizard-result-desc{color:var(--text2);margin-bottom:1.25rem;font-size:.775rem;line-height:1.5}.wizard-result-actions{gap:10px;margin-top:auto;display:flex}.eda-event{animation:3s linear infinite wizard-eda-flow-horizontal}.eda-event-vertical-up{animation:3s linear infinite wizard-eda-flow-up}.eda-event-vertical-down{animation:3s linear infinite wizard-eda-flow-down}@keyframes wizard-eda-flow-horizontal{0%{cx:95px;cy:150px;opacity:0}10%{opacity:1}45%{cx:160px;cy:150px;opacity:1}50%{cx:160px;cy:150px;opacity:0}to{cx:160px;cy:150px;opacity:0}}@keyframes wizard-eda-flow-up{0%,50%{cx:240px;cy:150px;opacity:0}55%{opacity:1}95%{opacity:1}to{cx:300px;cy:90px;opacity:0}}@keyframes wizard-eda-flow-down{0%,50%{cx:240px;cy:150px;opacity:0}55%{opacity:1}95%{opacity:1}to{cx:300px;cy:210px;opacity:0}}.hero-interactive-zone{background:0 0;justify-content:center;align-items:center;width:100%;min-height:520px;display:flex;position:relative}.btn-wizard-replay{cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:6px;padding:4px 8px;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:600;transition:all .2s;display:flex;border:1px solid var(--border)!important;color:var(--accent)!important}.btn-wizard-replay:hover{background:var(--accent-light)!important;color:var(--accent-dark)!important;border-color:var(--accent)!important}.btn-wizard-replay svg{transition:transform .5s}.btn-wizard-replay:hover svg{transform:rotate(360deg)}.fade-in-fast{animation:.35s cubic-bezier(.16,1,.3,1) forwards fadeInFast}@keyframes fadeInFast{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.projects-interactive-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr));align-items:start;gap:2rem;width:100%;max-width:1400px;margin:2rem auto 4rem;display:grid}.projects-interactive-grid .arch-card,.projects-interactive-grid .wizard-card{box-sizing:border-box;width:100%;max-width:100%;height:600px;box-shadow:0 10px 30px #00000014}@media (max-width:768px){.projects-interactive-grid{box-sizing:border-box!important;flex-direction:column!important;gap:1.5rem!important;width:100%!important;max-width:100%!important;display:flex!important;overflow:visible!important}.projects-interactive-grid .arch-card,.projects-interactive-grid .wizard-card{box-sizing:border-box!important;width:100%!important;min-width:0!important;max-width:100%!important;height:auto!important;min-height:450px!important;overflow:hidden!important}.arch-layout{flex-direction:column!important;width:100%!important;min-width:0!important;max-width:100%!important;overflow:hidden!important}.arch-layout .arch-body{box-sizing:border-box!important;width:100%!important;min-width:0!important;max-width:100%!important;padding:1rem!important;display:block!important}.arch-card svg,.wizard-card svg,.wizard-result-diagram svg{width:100%!important;min-width:0!important;max-width:100%!important;height:auto!important;display:block!important}.wizard-title-label{font-size:.65rem!important}}.monolith-memory-flow{animation:1.5s linear infinite monolith-dash}@keyframes monolith-dash{to{stroke-dashoffset:-20px}}.microservices-broker-flow{animation:2s linear infinite microservices-dash}@keyframes microservices-dash{to{stroke-dashoffset:-20px}}.arch-layout{flex-direction:row;flex:1;min-height:0;display:flex;overflow:hidden}.arch-sidebar{background:var(--bg3);border-right:1px solid var(--border);scrollbar-width:none;flex-direction:column;flex-shrink:0;width:158px;min-width:158px;display:flex;overflow-y:auto}.arch-sidebar::-webkit-scrollbar{display:none}.arch-sidebar-section{color:var(--text3);letter-spacing:.08em;border-bottom:1px dashed var(--border);text-transform:uppercase;-webkit-user-select:none;user-select:none;padding:8px 10px 6px;font-family:JetBrains Mono,monospace;font-size:.57rem}.arch-folder-item{cursor:pointer;text-align:left;background:0 0;border:none;border-left:2px solid #0000;align-items:flex-start;gap:7px;width:100%;padding:10px;transition:background .15s,border-color .15s;display:flex}.arch-folder-item:hover{background:var(--bg2)}.arch-folder-item.active{background:var(--accent-light);border-left-color:var(--accent)}.arch-folder-text{flex-direction:column;gap:1px;min-width:0;display:flex}.arch-folder-code{color:var(--text3);letter-spacing:.04em;font-family:JetBrains Mono,monospace;font-size:.57rem}.arch-folder-item.active .arch-folder-code{color:var(--accent-dark)}.arch-folder-label{color:var(--text2);word-break:break-word;font-family:JetBrains Mono,monospace;font-size:.62rem;font-weight:600;line-height:1.2;transition:color .15s}.arch-folder-item.active .arch-folder-label{color:var(--accent)}.arch-folder-item:hover .arch-folder-label{color:var(--text)}.arch-folder-sublabel{color:var(--text3);opacity:.75;font-family:JetBrains Mono,monospace;font-size:.54rem}.arch-folder-item.active .arch-folder-sublabel{color:var(--accent-dark);opacity:1}.arch-layout .arch-body{flex:1;min-width:0;padding:1.25rem}@media (max-width:768px){.arch-layout{flex-direction:column;width:100%;overflow:hidden}.arch-sidebar{border-right:none;border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch;flex-flow:row;width:100%;min-width:0;overflow:auto hidden}.arch-sidebar-section{display:none}.arch-folder-item{border-bottom:2px solid #0000;border-left:none;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:80px!important;min-width:80px!important;max-width:80px!important;padding:8px 6px!important}.arch-folder-item svg{flex-shrink:0!important;width:18px!important;height:18px!important;display:inline-block!important}.arch-folder-item.active{border-bottom-color:var(--accent);border-left-color:#0000}.arch-folder-sublabel{display:none}.arch-folder-label{text-align:center;white-space:nowrap;font-size:.58rem}.arch-folder-code{font-size:.5rem}.blueprint-style{overflow:hidden!important}.blueprint-style:before,.blueprint-style:after{display:none!important}.wizard-options--4{grid-template-columns:1fr!important}.wizard-header{min-width:0!important}.wizard-h3,.wizard-p,.wizard-result-desc,.wizard-opt-btn strong,.wizard-opt-btn span{word-break:break-word!important;overflow-wrap:break-word!important}}.blueprint-style{position:relative;background:var(--surface)!important;border:1.5px solid var(--border)!important;border-radius:12px!important;overflow:hidden!important;box-shadow:0 10px 30px #00000014!important}.blueprint-style .arch-bar{flex-direction:row;align-items:center;gap:0;display:flex;background:var(--bg2)!important;border-bottom:1.5px solid var(--border)!important;border-radius:0!important;padding:14px 20px!important}.blueprint-style .wizard-header{background:var(--bg2)!important;border-bottom:1.5px solid var(--border)!important;border-radius:0!important;padding:14px 20px!important}.arch-blueprint-tag{color:var(--accent-dark);letter-spacing:.05em;width:100%;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:600}.blueprint-style .arch-tabs{z-index:2;scrollbar-width:none;gap:6px;width:100%;margin-bottom:-1.5px;display:flex;overflow-x:auto}.blueprint-style .arch-tabs::-webkit-scrollbar{display:none}.blueprint-style .arch-tab-btn{cursor:pointer;z-index:1;align-items:center;font-family:JetBrains Mono,monospace;display:inline-flex;position:relative;background:var(--bg2)!important;border:1.5px solid var(--border)!important;border-bottom:1.5px solid var(--border)!important;color:var(--text2)!important;border-radius:6px 6px 0 0!important;padding:8px 14px!important;font-size:.7rem!important;transition:all .2s!important}.blueprint-style .arch-tab-btn:hover{border-color:var(--text3)!important;color:var(--text)!important;background:var(--border2)!important}.blueprint-style .arch-tab-btn.active{z-index:5;font-weight:600;background:var(--surface)!important;border:1.5px solid var(--border)!important;border-bottom-color:var(--surface)!important;color:var(--accent)!important}.folder-tab-icon{flex-shrink:0;margin-right:6px;transition:transform .2s}.blueprint-style .arch-tab-btn.active .folder-tab-icon{stroke:var(--accent);transform:scale(1.1)}.nav-hamburger{border:1px solid var(--border);cursor:pointer;background:0 0;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;padding:0;transition:border-color .2s;display:none}.nav-hamburger:hover{border-color:var(--accent)}.nav-hamburger span{background:var(--text2);transform-origin:50%;width:18px;height:1.5px;transition:all .25s cubic-bezier(.16,1,.3,1);display:block}.nav-hamburger.open span:first-child{transform:translateY(6.5px)rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}.mobile-menu-overlay{z-index:98;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;animation:.2s forwards fadeInFast;position:fixed;inset:0}.mobile-menu{background:var(--bg);border-left:1px solid var(--border);z-index:99;flex-direction:column;width:min(300px,85vw);padding:1.5rem;transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;top:60px;bottom:0;right:0;transform:translate(100%)}.mobile-menu.open{transform:translate(0)}.mobile-menu ul{flex-direction:column;flex:1;margin:0;padding:0;list-style:none;display:flex}.mobile-menu ul li a{color:var(--text2);border-bottom:1px solid var(--border2);letter-spacing:-.01em;padding:.875rem 0;font-family:DM Serif Display,serif;font-size:1.1rem;font-weight:400;text-decoration:none;transition:color .2s;display:block}.mobile-menu ul li:first-child a{border-top:1px solid var(--border2)}.mobile-menu ul li a:hover,.mobile-menu ul li a.nav-link-active{color:var(--accent)}.mobile-menu-footer{flex-direction:column;gap:.75rem;padding-top:1.5rem;display:flex}.mobile-menu-toggles{gap:.5rem;display:flex}.mobile-menu-toggles .theme-toggle{flex:1;justify-content:center;display:flex}.mobile-menu-footer .nav-cta{text-align:center;box-sizing:border-box;width:100%;display:block}@media (max-width:992px){.nav-links{display:none}.nav-hamburger{display:flex}.navbar .nav-cta,.navbar .theme-toggle{display:none}}
.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (max-width:1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (max-width:1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (max-width:1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (max-width:1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (max-width:1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (max-width:1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
