:root,[data-theme=dark]{--ink:#0e0e10;--surface:#16161a;--surface-2:#1c1c21;--surface-3:#222228;--line:#2a2a30;--line-soft:#202026;--line-strong:#3a3a42;--fg:#f4f2ee;--fg-dim:#a6a3a0;--fg-mute:#6e6b68;--mint:#9be7c4;--mint-deep:#06241b;--mint-soft:#1e3a30;--peach:#ffb088;--peach-soft:#3a2620;--rose:#ff8a8a;--rose-soft:#3a1f1f;--amber:#f2c94c;--sans:"Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;--serif:"Source Serif 4", Georgia, serif;--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}[data-theme=light]{--ink:#f4f2ee;--surface:#fbfaf7;--surface-2:#f1efea;--surface-3:#e8e5df;--line:#dcd8d0;--line-soft:#e6e2da;--line-strong:#c4bfb5;--fg:#0e0e10;--fg-dim:#5a5854;--fg-mute:#8c8a85;--mint:#0a7a62;--mint-deep:#e4f7ee;--mint-soft:#d4ede0;--peach:#c4623a;--peach-soft:#f5ddcb;--rose:#b83a3a;--rose-soft:#f2d5d5;--amber:#9c7a1f}*{box-sizing:border-box}html,body{background:var(--ink);color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;padding:0;font-size:15px;font-weight:300;line-height:1.5;transition:background .25s,color .25s}::selection{background:var(--mint);color:var(--mint-deep)}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:0;padding:0}input,textarea,select{font:inherit;color:inherit}img{max-width:100%;display:block}.shell{flex-direction:column;min-height:100vh;display:flex}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 32px}.container.wide{max-width:1240px}@media (width<=640px){.container{padding:0 20px}}.topbar{z-index:50;background:color-mix(in srgb, var(--ink) 88%, transparent);-webkit-backdrop-filter:blur(10px)saturate(140%);border-bottom:1px solid var(--line-soft);position:sticky;top:0}.topbar-inner{align-items:center;gap:24px;max-width:1240px;height:60px;margin:0 auto;padding:0 32px;display:flex}@media (width<=640px){.topbar-inner{gap:14px;height:56px;padding:0 20px}}.brand{letter-spacing:-.01em;color:var(--fg);cursor:pointer;align-items:baseline;font-size:16px;font-weight:500;display:flex}.brand .dot{color:var(--mint);margin-left:1px}.topnav{flex:1;gap:2px;margin-left:8px;display:flex}.topnav a{color:var(--fg-dim);cursor:pointer;border-radius:5px;padding:6px 10px;font-size:13px;transition:all .15s}.topnav a:hover{color:var(--fg);background:var(--surface)}.topnav a.active{color:var(--fg)}.topnav a.active:before{content:"·";color:var(--mint);margin-right:4px}@media (width<=760px){.topnav{display:none}}.topnav-utils{align-items:center;gap:8px;display:flex}.resume-link{color:var(--fg-dim);border:1px solid var(--line);border-radius:5px;align-items:center;gap:6px;padding:6px 10px;font-size:12.5px;transition:all .15s;display:inline-flex}.resume-link:hover{color:var(--fg);border-color:var(--line-strong);background:var(--surface)}.lang-toggle{font-family:var(--mono);letter-spacing:.08em;color:var(--fg-mute);cursor:pointer;border-radius:5px;align-items:center;gap:6px;padding:6px 8px;font-size:11px;display:inline-flex}.lang-toggle:hover{color:var(--fg-dim)}.lang-toggle .on{color:var(--fg)}.lang-toggle .sep{color:var(--line-strong)}.icon-btn{width:32px;height:32px;color:var(--fg-dim);border:1px solid var(--line);background:var(--surface);border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.icon-btn:hover{color:var(--fg);border-color:var(--line-strong)}.mobile-toggle{color:var(--fg-dim);display:none}@media (width<=760px){.mobile-toggle{display:inline-flex}}.mobile-sheet{display:none}.mobile-sheet.open{background:var(--ink);border-bottom:1px solid var(--line);z-index:49;padding:14px 20px 20px;display:block;position:fixed;top:56px;left:0;right:0}.mobile-sheet a{color:var(--fg-dim);border-bottom:1px solid var(--line-soft);padding:10px 4px;font-size:14px;display:block}.mobile-sheet a:last-child{border-bottom:0}.mobile-sheet a.active{color:var(--fg)}.eyebrow{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--fg-mute);font-size:10px}.eyebrow .num{color:var(--mint);margin-right:8px}.section{border-top:1px solid var(--line-soft);padding:96px 0}.section:first-of-type{border-top:0}@media (width<=760px){.section{padding:64px 0}}.section-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:48px;padding-bottom:18px;display:flex}.section-head h2{letter-spacing:-.015em;margin:6px 0 0;font-size:28px;font-weight:400}.section-head h2 em{font-family:var(--serif);color:var(--fg-dim);font-style:italic;font-weight:400}.section-head .meta{font-family:var(--mono);color:var(--fg-mute);letter-spacing:.14em;text-transform:uppercase;text-align:right;font-size:10px;line-height:1.6}.hero{border-bottom:1px solid var(--line-soft);padding:120px 0 100px}@media (width<=760px){.hero{padding:72px 0 56px}}.hero-eyebrow{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--fg-mute);align-items:center;gap:10px;margin-bottom:28px;font-size:11px;display:flex}.hero-eyebrow .pulse{background:var(--mint);width:8px;height:8px;box-shadow:0 0 0 0 var(--mint);border-radius:50%;animation:2.4s ease-out infinite pulse}@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--mint) 60%, transparent)}70%{box-shadow:0 0 0 10px color-mix(in srgb, var(--mint) 0%, transparent)}to{box-shadow:0 0 0 0 color-mix(in srgb, var(--mint) 0%, transparent)}}.hero-name{letter-spacing:-.035em;margin:0 0 24px;font-size:clamp(48px,8vw,96px);font-weight:300;line-height:.98}.hero-name em{font-family:var(--serif);color:var(--fg-dim);letter-spacing:-.02em;font-style:italic;font-weight:400}.hero-position{font-family:var(--mono);color:var(--fg-dim);letter-spacing:.02em;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:36px;font-size:14px;display:flex}.hero-position .pip{color:var(--mint)}.hero-proof{color:var(--fg);letter-spacing:-.01em;max-width:32ch;margin:0 0 44px;font-size:clamp(20px,2.6vw,26px);font-weight:300;line-height:1.45}.hero-proof em{font-family:var(--serif);color:var(--mint);font-style:italic;font-weight:400}.hero-ctas{flex-wrap:wrap;gap:12px;margin-bottom:40px;display:flex}.hero-meta{font-family:var(--mono);letter-spacing:.05em;color:var(--fg-mute);flex-wrap:wrap;gap:0 14px;font-size:11.5px;line-height:1.7;display:flex}.hero-meta span:not(:last-child):after{content:"·";color:var(--line-strong);margin-left:14px}.btn{font-family:var(--sans);letter-spacing:-.005em;cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;gap:8px;height:40px;padding:0 16px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s,color .15s,transform 80ms;display:inline-flex}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--mint);color:var(--mint-deep);border-color:var(--mint)}.btn-primary:hover{background:#b5efd2;border-color:#b5efd2}[data-theme=light] .btn-primary:hover{background:#0c8c70;border-color:#0c8c70}.btn-secondary{color:var(--fg);border-color:var(--line-strong);background:0 0}.btn-secondary:hover{border-color:var(--fg-dim);background:var(--surface)}.btn-ghost{color:var(--fg-dim);background:0 0;border-color:#0000}.btn-ghost:hover{color:var(--fg);background:var(--surface)}.btn.lg{border-radius:7px;height:46px;padding:0 22px;font-size:14px}.projects-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=760px){.projects-grid{grid-template-columns:1fr;gap:16px}}.project-card{background:var(--surface);border:1px solid var(--line);cursor:pointer;text-align:left;border-radius:10px;flex-direction:column;gap:18px;padding:24px;transition:border-color .2s,transform .2s,background .2s;display:flex}.project-card:hover{border-color:var(--line-strong);background:var(--surface-2)}.project-card:hover .pc-arrow{color:var(--mint);transform:translate(3px)}.project-card:hover .pc-thumb{border-color:var(--line-strong)}.pc-thumb{aspect-ratio:16/10;border:1px solid var(--line);background:var(--ink);border-radius:8px;transition:border-color .2s;position:relative;overflow:hidden}.pc-thumb-label{font-family:var(--mono);color:var(--fg-mute);letter-spacing:.14em;text-transform:uppercase;z-index:3;font-size:10px;position:absolute;bottom:12px;left:14px}.pc-thumb-tag{font-family:var(--mono);color:var(--peach);letter-spacing:.14em;text-transform:uppercase;background:var(--peach-soft);border:1px solid color-mix(in srgb, var(--peach) 30%, var(--line));z-index:3;border-radius:4px;padding:3px 8px;font-size:9.5px;position:absolute;top:12px;right:12px}.pc-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.pc-num{font-family:var(--mono);letter-spacing:.18em;color:var(--fg-mute);text-transform:uppercase;font-size:10px}.pc-title{letter-spacing:-.015em;color:var(--fg);margin:4px 0 8px;font-size:20px;font-weight:500}.pc-desc{color:var(--fg-dim);font-size:13.5px;font-weight:300;line-height:1.55}.pc-tags{flex-wrap:wrap;gap:6px;margin-top:auto;display:flex}.pc-tag{font-family:var(--mono);background:var(--surface-2);border:1px solid var(--line);color:var(--fg-dim);border-radius:4px;padding:3px 8px;font-size:10.5px}[data-theme=light] .pc-tag{background:var(--surface-3)}.pc-foot{border-top:1px solid var(--line-soft);justify-content:space-between;align-items:center;padding-top:14px;display:flex}.pc-link{color:var(--fg);align-items:center;gap:6px;font-size:12.5px;font-weight:500;display:inline-flex}.pc-arrow{color:var(--fg-dim);transition:color .2s,transform .2s}.thumb-stripes{background-image:repeating-linear-gradient(45deg, var(--surface-2) 0 12px, transparent 12px 24px);opacity:.5;position:absolute;inset:0}.thumb-grid{background-image:linear-gradient(to right, var(--line-soft) 1px, transparent 1px), linear-gradient(to bottom, var(--line-soft) 1px, transparent 1px);opacity:.6;background-size:24px 24px;position:absolute;inset:0}.thumb-content{justify-content:center;align-items:center;padding:18px;display:flex;position:absolute;inset:0}.thumb-almanac{background:linear-gradient(155deg, var(--surface) 0%, var(--surface-2) 100%)}.thumb-carwash{background:linear-gradient(135deg, var(--surface) 0%, var(--surface-3) 100%)}.thumb-nova{background:radial-gradient(circle at 30% 30%, var(--surface-3), var(--surface) 60%, var(--ink) 100%)}.thumb-eventflow{background:linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%)}.thumb-more{background:linear-gradient(155deg, var(--surface) 0%, var(--surface-2) 100%)}.thumb-more .thumb-content{color:var(--fg-mute)}.more-projects-card{color:inherit;border-style:dashed;text-decoration:none}.more-projects-card:hover .thumb-content{color:var(--mint)}.about-grid{grid-template-columns:280px 1fr;align-items:start;gap:48px;display:grid}@media (width<=760px){.about-grid{grid-template-columns:1fr;gap:24px}}.about-photo{aspect-ratio:4/5;border:1px solid var(--line);background:var(--surface);border-radius:10px;justify-content:flex-start;align-items:flex-end;display:flex;position:relative;overflow:hidden}.about-photo .photo-label{font-family:var(--mono);color:var(--fg-mute);letter-spacing:.16em;text-transform:uppercase;z-index:2;background:linear-gradient(0deg, var(--surface), transparent);width:100%;padding:12px 14px;font-size:10px}.about-prose p{color:var(--fg-dim);max-width:62ch;margin:0 0 20px;font-size:16px;font-weight:300;line-height:1.7}.about-prose p em{font-family:var(--serif);color:var(--fg);font-style:italic}.about-prose p strong{color:var(--fg);font-weight:500}.about-prose p:first-child{color:var(--fg);font-size:17px}.loom-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;align-items:center;gap:16px;max-width:520px;margin-top:36px;padding:18px;display:flex}.loom-thumb{aspect-ratio:16/10;border:1px solid var(--line);background:radial-gradient(circle at center, var(--surface-3) 0%, var(--ink) 70%);width:96px;color:var(--mint);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.loom-thumb .play{background:var(--mint);width:36px;height:36px;color:var(--mint-deep);border-radius:50%;justify-content:center;align-items:center;display:flex}.loom-meta{flex-direction:column;gap:4px;display:flex}.loom-eyebrow{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--mint);font-size:10px}.loom-title{color:var(--fg);font-size:14.5px;font-weight:500}.loom-sub{color:var(--fg-dim);font-size:12.5px;font-weight:300}.meta-grid{background:var(--line);border:1px solid var(--line);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;margin-top:48px;display:grid;overflow:hidden}@media (width<=760px){.meta-grid{grid-template-columns:1fr}}.meta-cell{background:var(--surface);flex-direction:column;gap:6px;min-height:88px;padding:18px 20px;display:flex}.meta-key{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute);font-size:9.5px}.meta-val{color:var(--fg);font-size:13.5px;font-weight:400;line-height:1.45}.meta-val em{font-family:var(--serif);color:var(--fg-dim);font-style:italic;font-weight:400}.meta-val .badge-inline{font-family:var(--mono);background:var(--mint-soft);color:var(--mint);border:1px solid color-mix(in srgb, var(--mint) 25%, var(--line));letter-spacing:.1em;text-transform:uppercase;border-radius:4px;align-items:center;gap:6px;margin-left:6px;padding:3px 7px;font-size:10px;display:inline-flex}.stack-grid{background:var(--line);border:1px solid var(--line);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;display:grid;overflow:hidden}@media (width<=760px){.stack-grid{grid-template-columns:1fr}}.stack-cell{background:var(--surface);flex-direction:column;gap:14px;min-height:140px;padding:24px;display:flex}.stack-key{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute);font-size:10px}.stack-key .num{color:var(--mint);margin-right:8px}.stack-list{flex-wrap:wrap;gap:6px;display:flex}.stack-item{font-family:var(--mono);background:var(--surface-2);border:1px solid var(--line-soft);color:var(--fg);border-radius:5px;padding:5px 10px;font-size:12px;font-weight:400}[data-theme=light] .stack-item{background:var(--surface-3)}.stack-item.explore{color:var(--fg-dim);background:0 0;border-style:dashed}.contact-grid{grid-template-columns:1fr 1fr;gap:32px;display:grid}@media (width<=760px){.contact-grid{grid-template-columns:1fr;gap:24px}}.contact-links{background:var(--line);border:1px solid var(--line);border-radius:8px;flex-direction:column;gap:1px;display:flex;overflow:hidden}.contact-link{background:var(--surface);cursor:pointer;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;transition:background .15s;display:flex}.contact-link:hover{background:var(--surface-2)}.contact-link:hover .cl-arrow{color:var(--mint);transform:translate(3px)}.cl-left{align-items:center;gap:14px;display:flex}.cl-icon{background:var(--surface-2);border:1px solid var(--line);width:34px;height:34px;color:var(--fg-dim);border-radius:6px;justify-content:center;align-items:center;display:flex}.cl-meta{flex-direction:column;gap:2px;display:flex}.cl-key{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute);font-size:9.5px}.cl-val{color:var(--fg);font-size:13.5px;font-weight:400}.cl-arrow{color:var(--fg-mute);transition:color .15s,transform .15s}.contact-form{background:var(--surface);border:1px solid var(--line);border-radius:8px;flex-direction:column;gap:14px;padding:24px;display:flex}.field{flex-direction:column;gap:6px;width:100%;display:flex}.field-label{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--fg-dim);font-size:10px}.field-hint{color:var(--fg-mute);font-size:11px;font-family:var(--mono);letter-spacing:.04em}.input{background:var(--ink);border:1px solid var(--line);width:100%;height:40px;color:var(--fg);border-radius:6px;padding:0 12px;font-size:13.5px;font-weight:400;transition:border-color .15s,background .15s}.input::placeholder{color:var(--fg-mute);font-weight:300}.input:focus{border-color:var(--mint);outline:none}.textarea{min-height:120px;line-height:1.55;font-family:var(--sans);resize:vertical;padding:10px 12px}.form-success{background:var(--mint-soft);border:1px solid color-mix(in srgb, var(--mint) 25%, var(--line));color:var(--mint);font-size:13px;font-family:var(--mono);letter-spacing:.04em;border-radius:6px;align-items:center;gap:10px;padding:14px;display:flex}.footer{border-top:1px solid var(--line-soft);margin-top:auto;padding:28px 0 36px}.footer-inner{font-family:var(--mono);letter-spacing:.06em;color:var(--fg-mute);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;font-size:10.5px;display:flex}.footer-inner a{color:var(--fg-dim)}.footer-inner a:hover{color:var(--fg)}.footer-socials{align-items:center;gap:14px;display:flex}.footer-coffee{color:var(--fg-mute)}.footer-coffee strong{color:var(--fg-dim);font-weight:500}.cs-back{font-family:var(--mono);color:var(--fg-dim);letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:36px;padding:6px 0;font-size:11px;display:inline-flex}.cs-back:hover{color:var(--fg)}.cs-back .arrow{transition:transform .15s}.cs-back:hover .arrow{transform:translate(-3px)}.cs-hero{border-bottom:1px solid var(--line-soft);padding:48px 0 64px}.cs-eyebrow{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--fg-mute);align-items:center;gap:10px;margin-bottom:16px;font-size:11px;display:flex}.cs-eyebrow .num{color:var(--mint)}.cs-title{letter-spacing:-.03em;margin:0 0 18px;font-size:clamp(36px,5vw,56px);font-weight:300;line-height:1.05}.cs-oneline{color:var(--fg-dim);max-width:62ch;margin:0 0 32px;font-size:18px;font-weight:300;line-height:1.55}.cs-oneline em{font-family:var(--serif);color:var(--fg);font-style:italic}.cs-meta-row{flex-wrap:wrap;gap:8px;margin-bottom:36px;display:flex}.cs-tag{font-family:var(--mono);background:var(--surface-2);border:1px solid var(--line);color:var(--fg-dim);border-radius:5px;padding:5px 10px;font-size:11px}.cs-tag.status{background:var(--peach-soft);color:var(--peach);border-color:color-mix(in srgb, var(--peach) 30%, var(--line))}.cs-hero-shot{aspect-ratio:16/9;border:1px solid var(--line);background:var(--surface);border-radius:10px;position:relative;overflow:hidden}.cs-hero-shot .pc-thumb-label{font-size:11px}.cs-block{border-bottom:1px solid var(--line-soft);padding:64px 0}.cs-block:last-of-type{border-bottom:0}.cs-block-head{align-items:baseline;gap:18px;margin-bottom:24px;display:flex}.cs-block-num{font-family:var(--mono);color:var(--mint);letter-spacing:.14em;text-transform:uppercase;flex-shrink:0;width:48px;font-size:11px}.cs-block-title{letter-spacing:-.015em;margin:0;font-size:24px;font-weight:400}.cs-block-body{max-width:68ch;margin-left:0}@media (width>=760px){.cs-block-body{margin-left:66px}}.cs-block-body p{color:var(--fg-dim);margin:0 0 18px;font-size:15.5px;font-weight:300;line-height:1.7}.cs-block-body p strong{color:var(--fg);font-weight:500}.cs-block-body p em{font-family:var(--serif);color:var(--fg);font-style:italic}.cs-deck{margin-top:24px;margin-left:0}@media (width>=760px){.cs-deck{margin-left:66px}}.cs-stack-line{font-family:var(--mono);color:var(--fg);border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:18px 22px;font-size:13px;line-height:1.7}.cs-stack-line .dim{color:var(--fg-mute)}.cs-stack-line .pip{color:var(--mint);margin:0 6px}.cs-decisions{flex-direction:column;gap:14px;display:flex}.cs-decision{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:22px}.cs-decision-eyebrow{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--mint);margin-bottom:10px;font-size:10px}.cs-decision h4{letter-spacing:-.005em;margin:0 0 8px;font-size:15.5px;font-weight:500}.cs-decision p{color:var(--fg-dim);margin:0;font-size:14px;font-weight:300;line-height:1.65}.cs-decision .tradeoff{border-top:1px dashed var(--line);font-family:var(--mono);color:var(--fg-mute);letter-spacing:.02em;margin-top:10px;padding-top:10px;font-size:11.5px;line-height:1.6}.cs-decision .tradeoff strong{color:var(--peach);font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;margin-right:8px;font-size:10px;font-weight:500}.cs-status-list{flex-direction:column;gap:10px;display:flex}.cs-status-item{background:var(--surface);border:1px solid var(--line);color:var(--fg-dim);border-radius:6px;align-items:flex-start;gap:12px;padding:14px 18px;font-size:14px;line-height:1.5;display:flex}.cs-status-item .ic{width:20px;height:20px;font-size:11px;font-family:var(--mono);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.cs-status-item.done .ic{background:var(--mint-soft);color:var(--mint)}.cs-status-item.wip .ic{background:var(--peach-soft);color:var(--peach)}.cs-status-item.planned .ic{background:var(--surface-3);color:var(--fg-mute)}.cs-status-item strong{color:var(--fg);margin-right:6px;font-weight:500}.cs-links{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.diagram{background:var(--surface);border:1px solid var(--line);border-radius:10px;flex-direction:column;gap:18px;padding:28px;display:flex;position:relative;overflow:hidden}.diagram:before{content:"";opacity:.4;pointer-events:none;background-image:linear-gradient(to right, var(--line-soft) 1px, transparent 1px), linear-gradient(to bottom, var(--line-soft) 1px, transparent 1px);background-size:16px 16px;position:absolute;inset:0}.diagram-caption{font-family:var(--mono);letter-spacing:.16em;color:var(--fg-mute);text-transform:uppercase;z-index:1;align-items:center;gap:10px;font-size:10px;display:flex;position:relative}.diagram-caption .line{background:var(--line);flex:1;height:1px}.dnode{z-index:1;background:var(--ink);border:1px solid var(--line);font-family:var(--mono);color:var(--fg);letter-spacing:.02em;border-radius:6px;align-items:center;gap:10px;padding:10px 14px;font-size:11.5px;display:flex;position:relative}.dnode .pip{color:var(--mint);font-size:9px}.dnode.muted{color:var(--fg-dim);background:var(--surface-2)}.dnode.accent{border-color:color-mix(in srgb, var(--mint) 35%, var(--line));background:var(--mint-soft);color:var(--mint)}.dnode.warm{border-color:color-mix(in srgb, var(--peach) 30%, var(--line));background:var(--peach-soft);color:var(--peach)}.dlayer{z-index:1;flex-direction:column;gap:8px;display:flex;position:relative}.dlayer-title{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute);padding-left:2px;font-size:9.5px}.drow{flex-wrap:wrap;gap:8px;display:flex}.dflow{z-index:1;flex-wrap:wrap;align-items:center;gap:6px;display:flex;position:relative}.dflow .arrow{color:var(--mint);font-family:var(--mono);font-size:14px}.dgrid-3{z-index:1;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid;position:relative}@media (width<=640px){.dgrid-3{grid-template-columns:1fr}}.erd{z-index:1;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid;position:relative}@media (width<=640px){.erd{grid-template-columns:1fr}}.erd-table{background:var(--ink);border:1px solid var(--line);font-family:var(--mono);border-radius:6px;font-size:11px;overflow:hidden}.erd-head{background:var(--surface-2);color:var(--mint);letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--line);padding:8px 12px;font-size:10px}.erd-row{color:var(--fg-dim);border-bottom:1px solid var(--line-soft);justify-content:space-between;gap:8px;padding:6px 12px;display:flex}.erd-row:last-child{border-bottom:0}.erd-row .type{color:var(--fg-mute)}.erd-row.pk{color:var(--mint)}.kernel{z-index:1;flex-direction:column;gap:6px;display:flex;position:relative}.kernel-band{border:1px solid var(--line);border-radius:6px;align-items:center;gap:14px;padding:14px 18px;display:flex}.kernel-band .layer-tag{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--fg-mute);flex-shrink:0;width:104px;font-size:9.5px}.kernel-band .layer-name{font-family:var(--mono);color:var(--fg);letter-spacing:.02em;font-size:12px;font-weight:500}.kernel-band .layer-desc{color:var(--fg-dim);font-size:12px;font-family:var(--mono);letter-spacing:.01em}.kernel-band.app{background:var(--mint-soft);border-color:color-mix(in srgb, var(--mint) 25%, var(--line))}.kernel-band.app .layer-name{color:var(--mint)}.kernel-band.shell{background:var(--surface-2)}.kernel-band.comm{background:var(--peach-soft);border-color:color-mix(in srgb, var(--peach) 25%, var(--line))}.kernel-band.comm .layer-name{color:var(--peach)}.kernel-band.kernel-k{background:var(--surface-3)}.spacer{height:24px}.spacer-lg{height:48px}.row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}
