@layer tokens{:root{--void:#0a0a0f;--void-card:#111115;--void-elevated:#161620;--quas:#6cf;--wex:#9b6dff;--exort:#ff6b00;--text-primary:#fff;--text-body:#9ca3af;--text-muted:#4b5060;--border:#ffffff0f;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--space-24:96px;--ease-out:cubic-bezier(.16, 1, .3, 1);--transition-fast:.3s var(--ease-out);--transition-med:.4s var(--ease-out);--transition-slow:.8s var(--ease-out);--orb-quas:#6cf;--orb-wex:#9b6dff;--orb-exort:#ff6b00}[data-theme=quas]{--bg-primary:#ede8dc;--bg-surface:#f7f3ea;--bg-surface-hover:#fdfaf7;--bg-elevated:#fff;--border-default:#d8cdbc;--border-subtle:#6450321a;--text-primary:#1e1608;--text-secondary:#3b3225;--text-body:#4a3f33;--text-muted:#8b7d6b;--text-faint:#a89e8e;--accent:#b8860b;--accent-red:#be3c3299;--accent-highlight:#ffd24659;--shadow-card:0 2px 8px #503c1e14, 0 0 0 1px #503c1e0a;--shadow-tape:0 1px 3px #0000000f;--tape-bg:linear-gradient(135deg, #d2c8aaa6, #c8bea073);--tag-bg:#3b3225;--tag-text:#ede8dc;--tag-border:transparent;--code-border:2px dashed #64503226;--dot-color:#64503209;--font-heading:"DM Serif Display", Georgia, serif;--font-heading-weight:400;--font-heading-spacing:-.3px;--font-body:"Crimson Pro", Georgia, serif;--font-body-size:17px;--font-mono:"JetBrains Mono", monospace;--font-nav:"JetBrains Mono", monospace;--heading-color:var(--text-primary)}[data-theme=exort]{--bg-primary:#1c1917;--bg-surface:#292524;--bg-surface-hover:#353130;--bg-elevated:#44403c;--border-default:#57534e;--border-subtle:#b496501a;--text-primary:#fafaf9;--text-secondary:#e7e5e4;--text-body:#a8a29e;--text-muted:#78716c;--text-faint:#57534e;--accent:#d4a574;--accent-red:#dc645080;--accent-highlight:#d4a57433;--shadow-card:0 4px 16px #0000004d, 0 0 0 1px #b496500f;--shadow-tape:0 1px 4px #00000040;--tape-bg:linear-gradient(135deg, #b4965040, #a0824626);--tag-bg:#d4a5741f;--tag-text:#d4a574;--tag-border:1px solid #d4a57426;--code-border:1px dashed #b4965026;--dot-color:#b4965005;--font-heading:"Cinzel", serif;--font-heading-weight:500;--font-heading-spacing:1px;--font-body:"EB Garamond", Garamond, serif;--font-body-size:18px;--font-mono:"JetBrains Mono", monospace;--font-nav:"JetBrains Mono", monospace;--heading-color:var(--accent)}[data-theme=wex]{--bg-primary:#08060e;--bg-surface:#12101a;--bg-surface-hover:#1d1a28;--bg-elevated:#282438;--border-default:#342f4a;--border-subtle:#7850c814;--text-primary:#f0ecf8;--text-secondary:#d8d2e8;--text-body:#a8a0c0;--text-muted:#7a7098;--text-faint:#4a4262;--accent:#b490ff;--accent-red:#9b6dff66;--accent-highlight:#9b6dff24;--shadow-card:0 4px 20px #0006, 0 0 0 1px #7850c80f;--shadow-tape:0 1px 4px #00000059;--tape-bg:linear-gradient(135deg, #9b6dff2e, #7850c814);--tag-bg:#9b6dff1a;--tag-text:#b490ff;--tag-border:1px solid #9b6dff26;--code-border:1px dashed #9b6dff1f;--dot-color:#7850c814;--font-heading:"Playfair Display", Georgia, serif;--font-heading-weight:700;--font-heading-spacing:-.3px;--font-body:"Cormorant Garamond", Garamond, serif;--font-body-size:18px;--font-mono:"JetBrains Mono", monospace;--font-nav:"JetBrains Mono", monospace;--heading-color:var(--text-primary)}}@layer base{*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--wex) var(--void)}body{background:var(--void);color:var(--text-primary);font-family:Space Grotesk,sans-serif;overflow-x:hidden}::selection{background:var(--wex);color:var(--void)}a{color:inherit;text-decoration:none}}@layer layout{#particles-canvas{z-index:0;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0}#comet-trail-canvas{z-index:49;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0}.hero{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:120px 32px 80px;display:flex;position:relative}.hero-orbs{pointer-events:none;z-index:2;width:300px;height:300px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}#hero-portrait-canvas{pointer-events:none;z-index:1;opacity:0;will-change:transform, opacity;width:600px;height:700px;animation:2.5s cubic-bezier(.16,1,.3,1) .3s forwards portraitFadeIn;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.section{max-width:1200px;margin:0 auto;padding:100px 48px;position:relative}.section-label{letter-spacing:5px;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:16px;margin-bottom:56px;font-family:JetBrains Mono,monospace;font-size:13px;display:flex}.section-label:after{content:"";background:var(--border);flex:1;height:1px}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;display:grid;container-type:inline-size}.scrolls-grid{gap:16px;max-width:800px;display:grid}.resources-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid;container-type:inline-size}}@layer components{.nav-pill{z-index:100;-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);background:#0a0a0f99;border-radius:100px;align-items:center;gap:32px;padding:12px 32px;display:flex;position:fixed;top:24px;left:50%;transform:translate(-50%)}.nav-pill a{letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);cursor:pointer;font-family:JetBrains Mono,monospace;font-size:12px;text-decoration:none;transition:color .3s}.nav-pill a:hover{color:var(--text-primary)}.nav-dots{gap:6px;margin-left:8px;display:flex}.nav-dot{border-radius:50%;width:6px;height:6px}.nav-dot.q{background:var(--quas);box-shadow:0 0 8px var(--quas)}.nav-dot.w{background:var(--wex);box-shadow:0 0 8px var(--wex)}.nav-dot.e{background:var(--exort);box-shadow:0 0 8px var(--exort)}.spell-wheel-trigger{z-index:101;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;background:#0a0a0fb3;border:1px solid #9b6dff40;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;bottom:32px;left:32px}.spell-wheel-trigger:hover{border-color:var(--wex);transform:scale(1.1);box-shadow:0 0 24px #9b6dff33}.spell-wheel-trigger .invoke-icon{color:var(--wex);font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700}.scroll-hud{z-index:100;align-items:center;gap:16px;display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%)}.hud-slot{background:0 0;border:1px solid #ffffff14;border-radius:50%;width:32px;height:32px;position:relative;overflow:hidden}.hud-slot-fill{border-radius:0 0 50% 50%;height:0%;transition:height .6s cubic-bezier(.16,1,.3,1);position:absolute;bottom:0;left:0;right:0}.hud-slot.q .hud-slot-fill{background:var(--quas);box-shadow:0 0 12px var(--quas)}.hud-slot.w .hud-slot-fill{background:var(--wex);box-shadow:0 0 12px var(--wex)}.hud-slot.e .hud-slot-fill{background:var(--exort);box-shadow:0 0 12px var(--exort)}.spell-wheel-overlay{z-index:150;-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);opacity:0;pointer-events:none;background:#050508f0;justify-content:center;align-items:center;transition:opacity .5s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;inset:0}.spell-wheel-overlay.active{opacity:1;pointer-events:all}.spell-wheel{width:580px;height:580px;position:relative}.spell-wheel-center{text-align:center;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spell-wheel-center .center-label{letter-spacing:4px;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;font-family:JetBrains Mono,monospace;font-size:14px}.spell-wheel-center .center-name{letter-spacing:4px;text-transform:uppercase;color:var(--text-primary);min-height:28px;font-family:Cinzel,serif;font-size:26px;transition:color .3s}.spell-wheel-center .center-orbs{justify-content:center;gap:8px;min-height:16px;margin-top:14px;display:flex}.spell-wheel-center .center-orb{opacity:0;border-radius:50%;width:14px;height:14px;transition:all .3s cubic-bezier(.16,1,.3,1);transform:scale(0)}.spell-wheel-center .center-orb.visible{opacity:1;transform:scale(1)}.spell-node{cursor:pointer;opacity:0;flex-direction:column;align-items:center;gap:10px;width:120px;transition:all .5s cubic-bezier(.16,1,.3,1);display:flex;position:absolute;transform:scale(.3)}.spell-wheel-overlay.active .spell-node{opacity:1;transform:scale(1)}.spell-node:hover{transform:scale(1.15)!important}.spell-node .node-orbs{gap:6px;display:flex}.spell-node .node-orb{border-radius:50%;width:12px;height:12px;transition:all .3s}.spell-node:hover .node-orb{transform:scale(1.3)}.spell-node .node-name{letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);text-align:center;white-space:nowrap;font-family:JetBrains Mono,monospace;font-size:13px;transition:color .3s}.spell-node:hover .node-name{color:var(--text-primary)}.spell-node .node-ring{pointer-events:none;border:1px solid #0000;border-radius:50%;width:38px;height:38px;transition:all .4s;position:absolute;top:-8px;left:calc(50% - 19px)}.spell-node:hover .node-ring{border-color:var(--wex);box-shadow:0 0 20px #9b6dff33}.spell-node.active-spell .node-name{color:#fff}.spell-node.active-spell .node-orb{transform:scale(1.4)}.spell-wheel-close{letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-family:JetBrains Mono,monospace;font-size:14px;transition:color .3s;position:absolute;top:32px;right:48px}.spell-wheel-close:hover{color:var(--exort)}.spell-wheel-hint{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:11px;position:absolute;bottom:48px;left:50%;transform:translate(-50%)}.spell-circle-wrap{pointer-events:none;z-index:0;opacity:.12;will-change:transform, opacity;width:680px;height:680px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spell-circle-wrap svg{width:100%;height:100%;animation:60s linear infinite rotateSlow}.hero-orb{filter:blur(1px);will-change:transform, opacity;border-radius:50%;width:12px;height:12px;position:absolute}.hero-orb.oq{background:var(--quas);box-shadow:0 0 20px var(--quas)}.hero-orb.ow{background:var(--wex);box-shadow:0 0 20px var(--wex)}.hero-orb.oe{background:var(--exort);box-shadow:0 0 20px var(--exort)}.dispersed-orb{pointer-events:none;z-index:50;opacity:0;filter:blur(1px);border-radius:50%;width:12px;height:12px;transition:none;position:fixed}.dispersed-orb.dq{background:var(--quas);box-shadow:0 0 30px var(--quas), 0 0 60px #66ccff4d}.dispersed-orb.dw{background:var(--wex);box-shadow:0 0 30px var(--wex), 0 0 60px #9b6dff4d}.dispersed-orb.de{background:var(--exort);box-shadow:0 0 30px var(--exort), 0 0 60px #ff6b004d}.dispersed-orb .orb-trail{border-radius:50%;width:60px;height:60px;animation:2s ease-in-out infinite orbTrailPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.dispersed-orb.dq .orb-trail{background:radial-gradient(circle,#66ccff14,#0000)}.dispersed-orb.dw .orb-trail{background:radial-gradient(circle,#9b6dff14,#0000)}.dispersed-orb.de .orb-trail{background:radial-gradient(circle,#ff6b0014,#0000)}.hero-tag{letter-spacing:5px;text-transform:uppercase;color:var(--wex);z-index:3;margin-bottom:28px;font-family:JetBrains Mono,monospace;font-size:13px;position:relative}.hero-title{z-index:3;max-width:800px;margin-bottom:28px;font-family:Cinzel,serif;font-size:clamp(48px,6vw,80px);font-weight:600;line-height:1.15;position:relative}.hero-title .hq{color:var(--quas)}.hero-title .hw{color:var(--wex)}.hero-title .he{color:var(--exort)}.hero-subtitle{color:var(--text-body);z-index:3;max-width:540px;margin-bottom:48px;font-family:Space Grotesk,sans-serif;font-size:18px;line-height:1.8;position:relative}.descend-hint{z-index:3;cursor:pointer;flex-direction:column;align-items:center;gap:12px;display:flex;position:relative}.descend-hint span{letter-spacing:4px;text-transform:uppercase;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:9px;transition:color .3s}.descend-hint:hover span{color:var(--wex)}.descend-line{background:linear-gradient(to bottom, var(--wex), transparent);width:1px;height:48px;animation:2s ease-in-out infinite pulseLine}.project-card{background:var(--void-card);border:1px solid var(--border);cursor:pointer;padding:32px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.project-card:before,.project-card:after{content:"";border-style:solid;border-color:#ffffff1a;width:16px;height:16px;transition:border-color .4s;position:absolute}.project-card:before{border-width:1px 0 0 1px;top:8px;left:8px}.project-card:after{border-width:1px 1px 0 0;top:8px;right:8px}.project-card .corner-bl,.project-card .corner-br{border-style:solid;border-color:#ffffff1a;width:16px;height:16px;transition:border-color .4s;position:absolute}.project-card .corner-bl{border-width:0 0 1px 1px;bottom:8px;left:8px}.project-card .corner-br{border-width:0 1px 1px 0;bottom:8px;right:8px}.project-card:hover{border-color:#9b6dff59;box-shadow:0 0 40px #9b6dff14,0 0 80px #9b6dff0a}.project-card:hover:before,.project-card:hover:after,.project-card:hover .corner-bl,.project-card:hover .corner-br{border-color:#9b6dff66}.project-card-head{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.project-tag{letter-spacing:2px;text-transform:uppercase;border:1px solid;border-radius:2px;padding:4px 8px;font-family:JetBrains Mono,monospace;font-size:9px}.project-tag.t-systems{color:var(--quas);border-color:#66ccff40}.project-tag.t-ai{color:var(--wex);border-color:#9b6dff40}.project-tag.t-product{color:var(--exort);border-color:#ff6b0040}.project-number{color:#ff6b001f;font-family:Cinzel,serif;font-size:48px;font-weight:700;line-height:1;transition:color .4s}.project-card:hover .project-number{color:#ff6b004d}.project-name{color:var(--text-primary);margin-bottom:10px;font-family:Cinzel,serif;font-size:22px;font-weight:500;line-height:1.4;transition:color .3s}.project-card:hover .project-name{color:#fff}.project-desc{color:var(--text-body);margin-bottom:20px;font-size:15px;line-height:1.7}.project-meta{flex-wrap:wrap;gap:6px;display:flex}.project-meta-pill{letter-spacing:1px;text-transform:uppercase;border:1px solid var(--border);color:var(--text-muted);background:#ffffff08;border-radius:2px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:11px}.project-stats{border-top:1px solid var(--border);gap:16px;margin-top:14px;padding-top:14px;display:flex}.project-stat{color:var(--text-muted);letter-spacing:.5px;font-family:JetBrains Mono,monospace;font-size:10px}.project-stat strong{color:var(--text-primary)}.project-links{gap:12px;margin-top:14px;display:flex}.project-link{letter-spacing:1px;text-transform:uppercase;color:var(--wex);font-family:JetBrains Mono,monospace;font-size:9px;transition:opacity .3s}.project-link:hover{opacity:.7}.project-card.spell-highlight{box-shadow:0 0 40px #9b6dff1a;border-color:#9b6dff80!important}.project-card.spell-dimmed{opacity:.12;transition:opacity .5s}.project-filters{flex-wrap:wrap;gap:8px;margin-bottom:32px;display:flex}.filter-btn{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:2px;padding:8px 20px;font-family:JetBrains Mono,monospace;font-size:11px;transition:all .3s}.filter-btn:hover,.filter-btn.active{color:var(--wex);border-color:#9b6dff59}.scroll-card{background:var(--void-card);border:1px solid var(--border);border-left:3px solid var(--quas);cursor:pointer;padding:28px 32px;transition:all .4s cubic-bezier(.16,1,.3,1)}.scroll-card:hover{border-color:#66ccff59;transform:translate(6px);box-shadow:0 0 40px #66ccff0f}.blog-date{letter-spacing:2px;color:var(--text-muted);margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:9px}.blog-title{color:var(--text-primary);margin-bottom:8px;font-family:Cinzel,serif;font-size:20px;transition:color .3s}.scroll-card:hover .blog-title{color:var(--quas)}.blog-excerpt{color:var(--text-body);font-size:15px;line-height:1.7}.blog-link{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:8px;margin-top:10px;font-family:JetBrains Mono,monospace;font-size:9px;transition:color .3s;display:inline-flex}.blog-link-line{background:var(--text-muted);width:16px;height:1px;transition:all .4s cubic-bezier(.16,1,.3,1)}.scroll-card:hover .blog-link{color:var(--quas)}.scroll-card:hover .blog-link-line{background:var(--quas);width:32px}.resource-card{background:var(--void-card);border:1px solid var(--border);padding:24px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative}.resource-card:hover{border-color:#ff6b0059;transform:translateY(-2px);box-shadow:0 0 40px #ff6b000f}.resource-card .resource-type{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:9px;position:absolute;top:12px;right:16px}.resource-card .resource-name{color:var(--text-primary);padding-right:80px;font-size:16px;transition:color .3s}.resource-card:hover .resource-name{color:var(--exort)}a.resource-card-link{color:inherit;text-decoration:none;display:block}.resource-status{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);opacity:.6;margin-top:8px;font-family:JetBrains Mono,monospace;font-size:9px}.archive-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:flex-end;max-width:1200px;margin:0 auto;padding:80px 48px 48px;display:flex}.archive-label{letter-spacing:4px;text-transform:uppercase;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10px}.archive-links{gap:32px;display:flex}.archive-links a{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10px;text-decoration:none;transition:color .3s}.archive-links a:hover{color:var(--wex)}.footer-left{flex-direction:column;gap:8px;display:flex}.footer-right{flex-direction:column;align-items:flex-end;gap:16px;display:flex}.footer-tagline{color:var(--text-muted);font-family:Space Grotesk,sans-serif;font-size:14px;line-height:1.6}.footer-cta{letter-spacing:2px;text-transform:uppercase;color:var(--exort);border:1px solid #ff6b004d;border-radius:2px;padding:10px 24px;font-family:JetBrains Mono,monospace;font-size:12px;text-decoration:none;transition:all .4s cubic-bezier(.16,1,.3,1)}.footer-cta:hover{border-color:var(--exort);background:#ff6b0014;box-shadow:0 0 24px #ff6b001f}.info-overlay{z-index:200;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);opacity:0;pointer-events:none;background:#050508f5;justify-content:center;align-items:center;transition:opacity .5s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;inset:0}.info-overlay.active{opacity:1;pointer-events:all}.info-content{max-width:600px;padding:48px}.info-content h2{letter-spacing:3px;text-transform:uppercase;color:var(--wex);margin-bottom:32px;font-family:Cinzel,serif;font-size:20px}.info-content p{color:var(--text-body);margin-bottom:24px;font-size:17px;line-height:2}.info-content .stat-grid{grid-template-columns:1fr 1fr 1fr;gap:32px;margin-top:48px;display:grid}.stat-item .stat-value{color:var(--text-primary);font-family:Cinzel,serif;font-size:32px;font-weight:700}.stat-item .stat-label{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-top:4px;font-family:JetBrains Mono,monospace;font-size:9px}.close-info{letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-family:JetBrains Mono,monospace;font-size:11px;transition:color .3s;position:absolute;top:32px;right:48px}.close-info:hover{color:var(--exort)}@container (width<=400px){.project-card{padding:20px}.project-name{font-size:18px}.project-desc{font-size:13px}.project-number{font-size:36px}.project-meta-pill{padding:3px 7px;font-size:9px}.project-tag{padding:3px 6px;font-size:8px}}@container (width<=350px){.resource-card .resource-type{margin-top:8px;display:block;position:static}.resource-card .resource-name{padding-right:0}}}@layer animations{.spell-enter{opacity:0;filter:blur(4px);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1),filter .6s cubic-bezier(.16,1,.3,1);transform:translateY(20px)}.spell-enter.entered{opacity:1;filter:blur();transform:translateY(0)}.spell-enter-left{opacity:0;filter:blur(2px);transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1),filter .5s cubic-bezier(.16,1,.3,1);transform:translate(-30px)}.spell-enter-left.entered{opacity:1;filter:blur();transform:translate(0)}.spell-stagger>*{transition-delay:calc(var(--i,0) * 60ms)}.section-label-text{clip-path:inset(0 100% 0 0);transition:clip-path .8s cubic-bezier(.16,1,.3,1)}.section-label.entered .section-label-text{clip-path:inset(0)}.section-label:after{opacity:0;transition:opacity .6s cubic-bezier(.16,1,.3,1) .4s}.section-label.entered:after{opacity:1}.fade-up{opacity:0;transition:all .8s cubic-bezier(.16,1,.3,1);transform:translateY(24px)}.fade-up.visible{opacity:1;transform:translateY(0)}@keyframes rotateSlow{to{transform:rotate(360deg)}}@keyframes portraitFadeIn{to{opacity:1}}@keyframes pulseLine{0%,to{opacity:.4}50%{opacity:1}}@keyframes orbTrailPulse{0%,to{opacity:.5;transform:translate(-50%,-50%)scale(1)}50%{opacity:1;transform:translate(-50%,-50%)scale(1.6)}}@supports (animation-timeline:view()){.spell-enter{animation:linear both spellReveal;animation-timeline:view();animation-range:entry entry 30%}.spell-enter-left{animation:linear both spellRevealLeft;animation-timeline:view();animation-range:entry entry 30%}.section-label-text{animation:linear both labelWipe;animation-timeline:view();animation-range:entry entry 25%}@keyframes spellReveal{0%{opacity:0;filter:blur(4px);transform:translateY(20px)}to{opacity:1;filter:blur();transform:translateY(0)}}@keyframes spellRevealLeft{0%{opacity:0;filter:blur(2px);transform:translate(-30px)}to{opacity:1;filter:blur();transform:translate(0)}}@keyframes labelWipe{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0)}}}}@layer utilities;@media (prefers-reduced-motion:reduce){.spell-enter,.spell-enter-left,.section-label-text{opacity:1!important;filter:none!important;clip-path:none!important;transition-duration:.01ms!important;transform:none!important}.section-label:after{opacity:1!important;transition-duration:.01ms!important}}::view-transition-old(root){animation-duration:.3s;animation-timing-function:cubic-bezier(.16,1,.3,1)}::view-transition-new(root){animation-duration:.3s;animation-timing-function:cubic-bezier(.16,1,.3,1)}@media (width<=900px){.nav-pill{gap:12px;max-width:calc(100vw - 32px);padding:10px 16px}.nav-pill a{letter-spacing:1.5px;font-size:9px}.blog-entry:active{opacity:.7}.project-card:active{opacity:.8}.filter-btn{padding:6px 12px;font-size:10px}.hero{padding:100px 24px 60px}#hero-portrait-canvas{width:360px;height:480px}.section{padding:60px 24px}.projects-grid,.resources-grid{grid-template-columns:1fr}.archive-footer{flex-direction:column;align-items:flex-start;gap:24px;padding:40px 24px 120px}.footer-right{align-items:flex-start}.archive-links{flex-wrap:wrap;gap:16px;padding-left:48px}.spell-wheel-trigger{bottom:72px;left:16px}.scroll-hud{bottom:20px}.spell-wheel{width:400px;height:400px}.spell-circle-wrap{width:440px;height:440px}.hero-orbs{width:200px;height:200px}}[data-blog-theme=quas]{--bg-primary:#ede8dc;--bg-surface:#f7f3ea;--bg-surface-hover:#fdfaf7;--border-default:#d8cdbc;--border-subtle:#6450321a;--text-primary:#1e1608;--text-secondary:#3b3225;--text-body:#4a3f33;--text-muted:#8b7d6b;--text-faint:#a89e8e;--accent:#b8860b;--accent-red:#be3c3299;--accent-highlight:#ffd24659;--shadow-card:0 2px 8px #503c1e14, 0 0 0 1px #503c1e0a;--shadow-tape:0 1px 3px #0000000f;--tape-bg:linear-gradient(135deg, #d2c8aaa6, #c8bea073);--tag-bg:#3b3225;--tag-text:#ede8dc;--tag-border:none;--code-border:2px dashed #64503226;--dot-color:#64503209;--font-heading:"DM Serif Display", Georgia, serif;--font-heading-weight:400;--font-heading-spacing:-.3px;--font-body:"Crimson Pro", Georgia, serif;--font-body-size:17px;--heading-color:var(--text-primary)}[data-blog-theme=exort]{--bg-primary:#1c1917;--bg-surface:#292524;--bg-surface-hover:#353130;--border-default:#57534e;--border-subtle:#b496501a;--text-primary:#fafaf9;--text-secondary:#e7e5e4;--text-body:#a8a29e;--text-muted:#78716c;--text-faint:#57534e;--accent:#d4a574;--accent-red:#dc645080;--accent-highlight:#d4a57433;--shadow-card:0 4px 16px #0000004d, 0 0 0 1px #b496500f;--shadow-tape:0 1px 4px #00000040;--tape-bg:linear-gradient(135deg, #b4965040, #a0824626);--tag-bg:#d4a5741f;--tag-text:#d4a574;--tag-border:1px solid #d4a57426;--code-border:1px dashed #b4965026;--dot-color:#b4965005;--font-heading:"Cinzel", serif;--font-heading-weight:500;--font-heading-spacing:1px;--font-body:"EB Garamond", Garamond, serif;--font-body-size:18px;--heading-color:var(--accent)}[data-blog-theme=wex]{--bg-primary:#08060e;--bg-surface:#12101a;--bg-surface-hover:#1d1a28;--border-default:#342f4a;--border-subtle:#7850c814;--text-primary:#f0ecf8;--text-secondary:#d8d2e8;--text-body:#a8a0c0;--text-muted:#7a7098;--text-faint:#4a4262;--accent:#b490ff;--accent-red:#9b6dff66;--accent-highlight:#9b6dff24;--shadow-card:0 4px 20px #0006, 0 0 0 1px #7850c80f;--shadow-tape:0 1px 4px #00000059;--tape-bg:linear-gradient(135deg, #9b6dff2e, #7850c814);--tag-bg:#9b6dff1a;--tag-text:#b490ff;--tag-border:1px solid #9b6dff26;--code-border:1px dashed #9b6dff1f;--dot-color:#7850c814;--font-heading:"Playfair Display", Georgia, serif;--font-heading-weight:700;--font-heading-spacing:-.3px;--font-body:"Cormorant Garamond", Garamond, serif;--font-body-size:18px;--heading-color:var(--text-primary)}.blog-theme-bar{justify-content:space-between;align-items:center;max-width:740px;margin:0 auto;padding:24px 40px 0 88px;display:flex}.blog-back{letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10px;text-decoration:none;transition:color .3s}.blog-back:hover{color:var(--accent)}.blog-theme-toggle{border:1px solid var(--border-subtle);background:var(--bg-surface);border-radius:100px;gap:4px;padding:4px 8px;display:flex}.blog-theme-btn{cursor:pointer;background:0 0;border:none;border-radius:100px;align-items:center;gap:6px;padding:6px 12px;transition:all .3s;display:flex}.blog-theme-btn .orb{opacity:.4;border-radius:50%;width:8px;height:8px;transition:all .3s}.blog-theme-btn .label{letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);font-family:JetBrains Mono,monospace;font-size:9px;transition:color .3s}.blog-theme-btn.active .orb{opacity:1;box-shadow:0 0 8px}.blog-theme-btn.active .label{color:var(--text-secondary)}.blog-theme-btn:hover .orb{opacity:.8}.blog-post-wrapper{background:var(--bg-primary);min-height:100vh;transition:background-color .4s}.blog-post-wrapper:after{content:"";background-image:radial-gradient(circle, var(--dot-color) .7px, transparent .7px);pointer-events:none;z-index:0;background-size:4px 4px;position:fixed;inset:0}.blog-post{color:var(--text-body);font-family:var(--font-body);font-size:var(--font-body-size);z-index:1;max-width:740px;min-height:400px;margin:0 auto;padding:24px 40px 60px 88px;line-height:1.7;position:relative}.blog-post .margin-line{background:var(--accent-red);z-index:2;width:1px;position:absolute;top:0;bottom:0;left:64px}.blog-post .ring-holes{pointer-events:none;z-index:3;width:24px;position:absolute;top:0;bottom:0;left:18px}.blog-post .ring-hole{border:2px solid var(--border-subtle);border-radius:50%;width:16px;height:16px;position:absolute;left:0}.blog-post .post-content{z-index:4;position:relative}.blog-post .post-date{color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:11px}.blog-post h1{font-family:var(--font-heading);font-weight:var(--font-heading-weight);letter-spacing:var(--font-heading-spacing);color:var(--heading-color);margin-bottom:24px;font-size:28px;line-height:1.2}.blog-post h2{font-family:var(--font-heading);font-weight:var(--font-heading-weight);color:var(--heading-color);margin-top:36px;margin-bottom:14px;font-size:22px}.blog-post h3{font-family:var(--font-heading);font-weight:var(--font-heading-weight);color:var(--text-secondary);margin-top:28px;margin-bottom:12px;font-size:18px}.blog-post p{color:var(--text-body);margin-bottom:20px}.blog-post .hl{background:0 0;background-image:linear-gradient(to right, #0000, var(--accent-highlight) 4%, var(--accent-highlight));-webkit-box-decoration-break:clone;box-decoration-break:clone;color:inherit;border-radius:.8em .3em;margin:0 -.4em;padding:.1em .4em}.blog-post blockquote{border-left:3px solid var(--accent-red);color:var(--text-muted);margin:24px 0;padding:10px 0 10px 20px;font-style:italic}.blog-post pre{background:var(--bg-surface);border:var(--code-border);color:var(--text-muted);box-shadow:var(--shadow-card);border-radius:4px;margin:28px 0;padding:18px 20px;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.65;position:relative;overflow-x:auto;transform:rotate(-.3deg)}.blog-post pre:before{content:"";background:var(--tape-bg);width:80px;height:17px;box-shadow:var(--shadow-tape);border-radius:1px;position:absolute;top:-8px;left:50%;transform:translate(-50%)rotate(.6deg)}.blog-post pre:after{content:"";background:var(--tape-bg);border-radius:1px;width:54px;height:14px;position:absolute;bottom:-6px;right:24px;transform:rotate(-1.8deg)}.blog-post code{font-family:JetBrains Mono,monospace;font-size:13px}.blog-post p code{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:3px;padding:2px 6px;font-size:.85em}.blog-post .sep{text-align:center;color:var(--text-faint);letter-spacing:8px;opacity:.6;margin:28px 0;font-size:14px}.blog-post .info-card{background:var(--bg-surface);border:1px solid var(--border-default);box-shadow:var(--shadow-card);border-radius:6px;margin:24px 0;padding:20px 22px;transition:border-color .3s}.blog-post .info-card:hover{border-color:var(--accent)}.blog-post .info-card .card-label{letter-spacing:2px;text-transform:uppercase;color:var(--text-faint);margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:9px}.blog-post .info-card .card-title{font-family:var(--font-heading);font-weight:var(--font-heading-weight);color:var(--heading-color);margin-bottom:6px;font-size:18px}.blog-post .info-card .card-body{font-family:var(--font-body);font-size:calc(var(--font-body-size) - 2px);color:var(--text-muted);line-height:1.6}.blog-post .info-card .card-meta{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.blog-post .info-card .card-meta span{letter-spacing:.5px;background:var(--bg-surface-hover);color:var(--text-muted);border:1px solid var(--border-subtle);border-radius:3px;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:9px}.blog-post .post-tag{background:var(--tag-bg);color:var(--tag-text);letter-spacing:1px;text-transform:uppercase;border:var(--tag-border);border-radius:2px;margin-right:6px;padding:4px 14px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-block}body.blog-view .nav-pill,body.blog-view .scroll-hud,body.blog-view .spell-wheel-trigger,body.blog-view #particles-canvas,body.blog-view #comet-trail-canvas{display:none!important}[data-blog-theme=wex] .blog-post:before{content:"";z-index:5;background:linear-gradient(90deg,#0000 10%,#9b6dff33 50%,#0000 90%);height:1px;position:absolute;top:0;left:0;right:0}
