:root{--mono:"JetBrains Mono", ui-monospace, monospace;--serif:"Fraunces", "Times New Roman", serif;--t-bg-0:#06090f;--t-bg-1:#0b1220;--t-bg-2:#111a2c;--t-line:#39ff1424;--t-line-2:#39ff1452;--t-ink:#d6f5cc;--t-ink-2:#a8d99e;--t-ink-3:#82b478;--t-accent:#39ff14;--t-accent-2:#00c853;--t-warn:#ffb454;--t-ok:#6ef0a4;--c-bg-0:#0e0c0a;--c-bg-1:#15110d;--c-bg-2:#1d1813;--c-line:#d4b88424;--c-line-2:#d4b8844d;--c-ink:#f3ead8;--c-ink-2:#ccbb95;--c-ink-3:#a3906a;--c-accent:#d4b884;--c-accent-2:#b89758;--bg-0:var(--t-bg-0);--bg-1:var(--t-bg-1);--bg-2:var(--t-bg-2);--line:var(--t-line);--line-2:var(--t-line-2);--ink:var(--t-ink);--ink-2:var(--t-ink-2);--ink-3:var(--t-ink-3);--accent:var(--t-accent);--accent-2:var(--t-accent-2)}html,body{height:100%;margin:0;padding:0;overflow:hidden}body.vault{background:var(--bg-0);color:var(--ink);font-family:var(--mono);overscroll-behavior:none;font-size:13px;transition:background .7s,color .7s}body.vault *,body.vault :before,body.vault :after{box-sizing:border-box}body.vault button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:0}#app{grid-template:"header header header"64px"left stage right"1fr"ledge ledge ledge"92px/280px 1fr 320px;gap:0;display:grid;position:fixed;inset:0}.hdr{border-bottom:1px solid var(--line);background:linear-gradient(180deg, color-mix(in oklab, var(--bg-1), transparent 30%), transparent);z-index:5;grid-area:header;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:relative}.hdr-left{align-items:baseline;gap:14px;display:flex}.wordmark{font-family:var(--serif);letter-spacing:.02em;color:var(--ink);font-size:22px;font-weight:600;line-height:1}.wordmark .slash{color:var(--accent);margin:0 4px}.crumb{color:var(--ink-3);letter-spacing:.18em;text-transform:uppercase;font-size:11px}.crumb b{color:var(--accent);font-weight:500}.mode-toggle{border:1px solid var(--line-2);background:color-mix(in oklab, var(--bg-1), transparent 40%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:999px;align-items:center;gap:10px;padding:4px;display:flex}.mode-toggle .seg{letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);border-radius:999px;padding:6px 14px;font-size:11px;transition:color .24s,background .24s,box-shadow .24s}.mode-toggle .seg.on{background:var(--accent);color:#06090f;box-shadow:0 0 24px color-mix(in oklab, var(--accent), transparent 60%);font-weight:600}.side{border-top:1px solid #0000;flex-direction:column;gap:14px;padding:22px 20px;display:flex;position:relative;overflow:hidden}.side.left{border-right:1px solid var(--line);grid-area:left}.side.right{border-left:1px solid var(--line);grid-area:right}.side-eyebrow{letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);align-items:center;gap:8px;font-size:10px;display:flex}.side-eyebrow:before{content:"";background:var(--accent);width:6px;height:6px;box-shadow:0 0 8px var(--accent);border-radius:50%}.cat-list{flex-direction:column;gap:2px;display:flex}.cat{border:1px solid #0000;border-radius:4px;overflow:hidden}.cat-head{cursor:pointer;justify-content:space-between;align-items:center;padding:10px 12px;transition:background .2s,border-color .2s;display:flex}.cat-head:hover{background:color-mix(in oklab, var(--accent), transparent 92%)}.cat-head .name{font-family:var(--serif);letter-spacing:.01em;color:var(--ink);font-size:16px;font-weight:500}.cat-head .chev{font-family:var(--mono);color:var(--ink-3);font-size:11px;transition:transform .24s,color .24s}.cat.open .cat-head .chev{color:var(--accent);transform:rotate(90deg)}.cat-body{max-height:0;transition:max-height .32s cubic-bezier(.4,0,.2,1);overflow:hidden}.cat.open .cat-body{max-height:240px}.cat-body ul{flex-direction:column;gap:6px;margin:0;padding:4px 12px 12px 20px;list-style:none;display:flex}.cat-body li{font-family:var(--mono);color:var(--ink-2);letter-spacing:.04em;cursor:pointer;font-size:11px;transition:color .16s}.cat-body li:hover{color:var(--accent)}.cat-body li:before{content:"› ";color:var(--ink-3)}.ctx-title{font-family:var(--serif);color:var(--ink);font-size:26px;font-weight:600;line-height:1.05}.ctx-sub{color:var(--ink-2);letter-spacing:.12em;text-transform:uppercase;margin-top:4px;font-size:11px}.ctx-rows{flex-direction:column;gap:8px;margin-top:6px;display:flex}.ctx-row{border-bottom:1px dashed var(--line);justify-content:space-between;align-items:baseline;padding-bottom:6px;font-size:12px;display:flex}.ctx-row .k{color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase;font-size:10px}.ctx-row .v{color:var(--ink);font-variant-numeric:tabular-nums}.ctx-row .v.ok{color:var(--t-ok)}.ctx-row .v.warn{color:var(--t-warn)}.meter{background:color-mix(in oklab, var(--ink), transparent 88%);border-radius:2px;height:4px;margin-top:4px;overflow:hidden}.meter>i{background:linear-gradient(90deg, var(--accent), var(--accent-2));height:100%;box-shadow:0 0 12px color-mix(in oklab, var(--accent), transparent 50%);transition:width .48s;display:block}.ctx-cta{flex-direction:column;gap:8px;margin-top:auto;display:flex}.ctx-cta a,.ctx-cta button{border:1px solid var(--line-2);color:var(--ink);font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;border-radius:4px;justify-content:space-between;align-items:center;padding:12px 14px;font-size:11px;text-decoration:none;transition:background .2s,border-color .2s,color .2s;display:flex}.ctx-cta a:hover,.ctx-cta button:hover{background:var(--accent);color:var(--bg-0);border-color:var(--accent)}.stage{grid-area:stage;position:relative;overflow:hidden}#core-canvas{cursor:grab;width:100%;height:100%;position:absolute;inset:0}#core-canvas:active{cursor:grabbing}.stage .corners>i{border:1px solid var(--line-2);width:22px;height:22px;position:absolute}.stage .corners>i:first-child{border-bottom:0;border-right:0;top:16px;left:16px}.stage .corners>i:nth-child(2){border-bottom:0;border-left:0;top:16px;right:16px}.stage .corners>i:nth-child(3){border-top:0;border-right:0;bottom:16px;left:16px}.stage .corners>i:nth-child(4){border-top:0;border-left:0;bottom:16px;right:16px}.stage-hud{color:var(--ink-3);letter-spacing:.18em;text-transform:uppercase;pointer-events:none;background:color-mix(in oklab, var(--bg-1), transparent 30%);border:1px solid var(--line);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3;border-radius:999px;gap:18px;padding:6px 14px;font-size:10px;display:flex;position:absolute;bottom:18px;left:50%;transform:translate(-50%)}.stage-hud b{color:var(--ink);font-weight:500}.core-label{text-align:center;pointer-events:none;position:absolute;bottom:14%;left:50%;transform:translate(-50%)}.core-label .name{font-family:var(--serif);letter-spacing:.1em;color:var(--ink);font-size:28px;font-weight:500}.core-label .meta{letter-spacing:.32em;color:var(--ink-3);text-transform:uppercase;margin-top:4px;font-size:10px}.node{pointer-events:auto;position:absolute;transform:translate(-50%,-50%)}.node-dot{border:1px solid var(--accent);background:var(--bg-0);width:12px;height:12px;box-shadow:0 0 0 4px color-mix(in oklab, var(--accent), transparent 86%), 0 0 16px color-mix(in oklab, var(--accent), transparent 60%);cursor:pointer;border-radius:50%;transition:transform .2s,box-shadow .2s}.node:hover .node-dot{box-shadow:0 0 0 6px color-mix(in oklab, var(--accent), transparent 70%), 0 0 28px var(--accent);transform:scale(1.4)}.node-tag{white-space:nowrap;font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line);background:color-mix(in oklab, var(--bg-1), transparent 20%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:3px;padding:4px 8px;font-size:10px;transition:color .16s,border-color .16s;position:absolute;top:-2px;left:18px}.node:hover .node-tag,.node.active .node-tag{color:var(--accent);border-color:var(--line-2)}.node.flip .node-tag{left:auto;right:18px}.sysview{z-index:2;flex-direction:column;gap:14px;display:none;position:absolute;inset:32px;overflow:auto}body.tech[data-view=systems] .sysview{display:flex}body.tech[data-view=systems] #core-canvas,body.tech[data-view=systems] #core-label,body.tech[data-view=systems] #nodes,body.tech[data-view=systems] .stage-hud{display:none}.sysview-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:baseline;gap:16px;padding-bottom:10px;display:flex}.sysview-title{font-family:var(--serif);color:var(--ink);letter-spacing:.02em;font-size:18px;font-weight:500}.sysview-meta{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.sysview-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;display:grid}.sys-card{text-align:left;border:1px solid var(--line);background:color-mix(in oklab, var(--bg-1), black 6%);cursor:pointer;border-radius:4px;flex-direction:column;gap:8px;padding:14px 16px;transition:border-color .2s,background .2s,transform .2s;display:flex}.sys-card:hover{border-color:var(--accent);background:color-mix(in oklab, var(--bg-1), black 0%);transform:translateY(-1px)}.sys-card .row{justify-content:space-between;align-items:center;display:flex}.sys-card .name{font-family:var(--serif);color:var(--ink);letter-spacing:.01em;font-size:20px;font-weight:600}.sys-card .dot{background:var(--t-ok);width:8px;height:8px;box-shadow:0 0 8px var(--t-ok);border-radius:50%}.sys-card .sub{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.sys-card .stats{font-family:var(--mono);grid-template-columns:repeat(2,1fr);gap:4px 12px;margin-top:2px;font-size:11px;display:grid}.sys-card .stats .k{color:var(--ink-3);letter-spacing:.12em;text-transform:uppercase;font-size:9px}.sys-card .stats .v{color:var(--ink);font-variant-numeric:tabular-nums}.sys-card .svc{border-top:1px dashed var(--line);font-family:var(--mono);color:var(--ink-2);letter-spacing:.06em;margin-top:6px;padding-top:8px;font-size:10px}.sys-card .svc b{color:var(--accent);font-weight:500}.abview{z-index:2;flex-direction:column;gap:22px;max-width:820px;margin:0 auto;display:none;position:absolute;inset:32px 0;overflow:auto}body.creative[data-view=about] .abview{display:flex}body.creative[data-view=about] #core-canvas,body.creative[data-view=about] #core-label,body.creative[data-view=about] #nodes,body.creative[data-view=about] .stage-hud,body.creative[data-view=about] .cgrid{display:none}.abview-head{border-bottom:1px solid var(--line);flex-direction:column;gap:6px;padding-bottom:16px;display:flex}.abview-eye{font-family:var(--mono);letter-spacing:.32em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.abview-title{font-family:var(--serif);letter-spacing:.02em;color:var(--ink);font-size:38px;font-style:italic;font-weight:400;line-height:1.1}.abview-highlights{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.abview-highlights .hl{border:1px solid var(--line);background:color-mix(in oklab, var(--bg-1), black 6%);border-radius:4px;flex-direction:column;gap:4px;padding:12px 14px;display:flex}.abview-highlights .hl .k{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-size:9px}.abview-highlights .hl .v{font-family:var(--serif);color:var(--ink);font-size:18px}.abview-body{flex-direction:column;gap:16px;display:flex}.abview-body p{font-family:var(--serif);color:var(--ink);margin:0;font-size:16px;line-height:1.65}.abview-body p:first-child:first-letter{font-family:var(--serif);float:left;color:var(--accent);margin:4px 10px 0 0;font-size:56px;font-weight:600;line-height:.9}.abview-closing{border-top:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding-top:18px;display:flex}.abview-closing .lbl{font-family:var(--serif);color:var(--ink);font-size:22px;font-style:italic}.abview-closing .cta{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--bg-0);background:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:12px 18px;font-size:11px;text-decoration:none;transition:filter .16s}.abview-closing .cta:hover{filter:brightness(1.1)}@media (max-width:700px){.abview-title{font-size:28px}.abview-body p:first-child:first-letter{font-size:42px}}.ctview{z-index:2;flex-direction:column;gap:16px;display:none;position:absolute;inset:32px;overflow:auto}body.tech[data-view=contact] .ctview{display:flex}body.tech[data-view=contact] #core-canvas,body.tech[data-view=contact] #core-label,body.tech[data-view=contact] #nodes,body.tech[data-view=contact] .stage-hud,body.tech[data-view=contact] .sysview,body.tech[data-view=contact] .rsview{display:none}.ctview-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:12px;display:flex}.ctview-title{font-family:var(--serif);color:var(--ink);font-size:22px;font-weight:600}.ctview-sub{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-top:4px;font-size:10px}.ctview-status{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink);align-items:center;gap:8px;font-size:10px;display:flex}.ctview-status .dot{background:var(--t-ok);width:8px;height:8px;box-shadow:0 0 8px var(--t-ok);border-radius:50%}.ctview-body{display:block}.ctform{border:1px solid var(--line);background:color-mix(in oklab, var(--bg-1), black 6%);border-radius:4px;flex-direction:column;gap:12px;padding:16px 18px;display:flex;position:relative}.ctform-eye{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-size:9px}.ctform-title{font-family:var(--serif);color:var(--ink);font-size:22px;font-weight:600}.ctform-fields{grid-template-columns:1fr 1fr;gap:12px;display:grid}.ctform .field{flex-direction:column;gap:4px;display:flex}.ctform .lbl{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-size:9px}.ctform input[type=text],.ctform input[type=email],.ctform textarea{font-family:var(--mono);color:var(--ink);background:color-mix(in oklab, var(--bg-2), black 25%);border:1px solid var(--line);resize:vertical;border-radius:3px;outline:none;padding:8px 10px;font-size:12px;transition:border-color .16s}.ctform input:focus,.ctform textarea:focus{border-color:var(--accent)}.ctform input::placeholder,.ctform textarea::placeholder{color:var(--ink-3)}.inquiry-pills{flex-wrap:wrap;gap:6px;display:flex}.inquiry-pills .pill{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:10px;transition:background .16s,color .16s,border-color .16s}.inquiry-pills .pill:hover{color:var(--ink);border-color:var(--line-2)}.inquiry-pills .pill.on{background:var(--accent);color:var(--bg-0);border-color:var(--accent)}.ctform-actions{gap:10px;margin-top:6px;display:flex}.ctform .btn-primary{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;background:var(--accent);color:var(--bg-0);border:1px solid var(--accent);cursor:pointer;border-radius:4px;padding:10px 16px;font-size:10px;transition:filter .16s}.ctform .btn-primary:hover{filter:brightness(1.1)}.ctform .btn-secondary{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink);border:1px solid var(--line-2);cursor:pointer;background:0 0;border-radius:4px;padding:10px 16px;font-size:10px;transition:background .16s,color .16s,border-color .16s}.ctform .btn-secondary:hover{background:var(--accent);color:var(--bg-0);border-color:var(--accent)}.ct-toast{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent);background:color-mix(in oklab, var(--bg-1), black 30%);border:1px solid var(--line-2);opacity:0;pointer-events:none;border-radius:3px;padding:6px 10px;font-size:10px;transition:opacity .2s,transform .2s;position:absolute;bottom:14px;right:18px;transform:translateY(6px)}.ct-toast.on{opacity:1;transform:none}@media (max-width:800px){.ctform-fields{grid-template-columns:1fr}}@media (max-width:600px){.ctview{inset:12px}.ctview-head{flex-direction:column;align-items:flex-start;gap:6px}.ctform{padding:14px}.ctform-actions{flex-direction:column}.ctform-actions .btn-primary,.ctform-actions .btn-secondary{width:100%}}.rsview{z-index:2;flex-direction:column;gap:14px;display:none;position:absolute;inset:32px;overflow:auto}body.tech[data-view=resume] .rsview{display:flex}body.tech[data-view=resume] #core-canvas,body.tech[data-view=resume] #core-label,body.tech[data-view=resume] #nodes,body.tech[data-view=resume] .stage-hud,body.tech[data-view=resume] .sysview{display:none}.rsview-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:12px;display:flex}.rsview-title{font-family:var(--serif);color:var(--ink);font-size:22px;font-weight:600}.rsview-sub{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-top:4px;font-size:10px}.rsview-actions{flex-shrink:0;gap:8px;display:flex}.rsview-actions a{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink);border:1px solid var(--line-2);border-radius:4px;padding:8px 14px;font-size:10px;text-decoration:none;transition:background .16s,color .16s,border-color .16s}.rsview-actions a.rsview-cv,.rsview-actions a:hover{background:var(--accent);color:var(--bg-0);border-color:var(--accent)}.rsview-tabs{flex-wrap:wrap;gap:4px;display:flex}.rsview-tabs button{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:10px;transition:background .16s,color .16s,border-color .16s}.rsview-tabs button:hover{color:var(--ink);border-color:var(--line-2)}.rsview-tabs button.on{background:var(--accent);color:var(--bg-0);border-color:var(--accent)}.rsview-list{flex-direction:column;gap:10px;display:flex}.rs-card{text-align:left;border:1px solid var(--line);background:color-mix(in oklab, var(--bg-1), black 6%);cursor:pointer;border-radius:4px;grid-template-columns:110px 1fr;align-items:start;gap:16px;width:100%;padding:14px 16px;transition:border-color .2s,background .2s;display:grid}.rs-card:hover{border-color:var(--accent);background:color-mix(in oklab, var(--bg-1), black 0%)}.rs-card.open{border-color:var(--accent)}.rs-card .when{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);padding-top:4px;font-size:10px}.rs-card .body{flex-direction:column;gap:4px;display:flex}.rs-card .role{font-family:var(--serif);color:var(--ink);letter-spacing:.01em;font-size:18px;font-weight:600}.rs-card .org{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-size:10px}.rs-card .tags{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.rs-card .tag{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--line);border-radius:999px;padding:2px 7px;font-size:9px}.rs-card .detail{border-top:1px dashed var(--line);flex-direction:column;gap:12px;margin-top:10px;padding-top:10px;display:none}.rs-card.open .detail{display:flex}.rs-card .detail .grid{font-family:var(--mono);grid-template-columns:1fr 1fr;gap:4px 18px;font-size:11px;display:grid}.rs-card .detail .grid .k{color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase;font-size:9px}.rs-card .detail .grid .v{color:var(--ink);font-variant-numeric:tabular-nums}.rs-card .detail .grid .row{border-bottom:1px dashed var(--line);justify-content:space-between;align-items:baseline;padding-bottom:3px;display:flex}.rs-card .detail ul.bullets{font-family:var(--mono);color:var(--ink);flex-direction:column;gap:6px;margin:0;padding:0;font-size:11px;line-height:1.6;list-style:none;display:flex}.rs-card .detail ul.bullets li:before{content:"▸ ";color:var(--accent);margin-right:4px}.rsview-skills{border-top:1px solid var(--line);grid-template-columns:repeat(2,1fr);gap:14px;margin-top:16px;padding-top:14px;display:grid}.rsview-skills .grp .head{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px;font-size:9px}.rsview-skills .grp .items{flex-wrap:wrap;gap:6px;display:flex}.rsview-skills .grp .items span{font-family:var(--mono);letter-spacing:.06em;color:var(--ink);border:1px solid var(--line);background:color-mix(in oklab, var(--bg-1), black 4%);border-radius:3px;padding:4px 8px;font-size:10px}@media (max-width:700px){.rs-card{grid-template-columns:1fr;gap:6px}.rs-card .detail .grid,.rsview-skills{grid-template-columns:1fr}.rsview-head{flex-direction:column;align-items:stretch}.rsview-actions{justify-content:flex-start}}.cgrid{z-index:2;flex-direction:column;gap:14px;display:none;position:absolute;inset:32px}body.creative .cgrid{display:flex}body.creative #core-canvas,body.creative #core-label,body.creative #nodes,body.creative .stage-hud{display:none}.cgrid-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:baseline;gap:16px;padding-bottom:10px;display:flex}.cgrid-title{font-family:var(--serif);color:var(--ink);letter-spacing:.02em;font-size:18px;font-weight:500}.cgrid-link{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;font-size:10px;text-decoration:none;transition:color .16s}.cgrid-link:hover{color:var(--accent)}.cgrid-photos{counter-reset:ph;flex:1;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:10px;display:grid;overflow:hidden}.cgrid-photos .ph{background-color:color-mix(in oklab, var(--bg-2), black 20%);border:1px solid var(--line);cursor:pointer;background-position:50%;background-size:cover;border-radius:3px;text-decoration:none;transition:border-color .16s,transform .2s;display:block;position:relative}.cgrid-photos .ph:hover{border-color:var(--accent);transform:translateY(-1px)}.cgrid-photos .ph-video{background-position:50%;background-size:cover;padding:0;overflow:hidden}.cgrid-photos .ph-video .ph-play{color:#ffffffd9;text-shadow:0 1px 6px #000000b3;pointer-events:none;justify-content:center;align-items:center;font-size:28px;display:flex;position:absolute;inset:0}.cgrid-photos .ph .date{font-family:var(--mono);letter-spacing:.16em;color:#ffffffeb;text-transform:uppercase;pointer-events:none;background:#0000008c;border-radius:2px;padding:2px 6px;font-size:9px;position:absolute;bottom:6px;left:8px}.lightbox{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000d9;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:32px;display:none;position:fixed;inset:0}.lightbox.on{display:flex}.lightbox-stage{flex:1;justify-content:center;align-items:center;width:100%;min-height:0;display:flex}.lightbox img,.lightbox video{object-fit:contain;border:1px solid var(--line-2);background:#000;border-radius:4px;max-width:100%;max-height:100%;box-shadow:0 30px 80px #0009}.lightbox-close{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);cursor:pointer;background:0 0;border:0;font-size:11px;position:absolute;top:18px;right:22px}.lightbox-close:hover{color:var(--accent)}.lightbox-meta{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);align-items:center;gap:18px;font-size:11px;display:flex}.lightbox-meta a{color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:8px 14px;text-decoration:none;transition:background .16s,color .16s}.lightbox-meta a:hover{background:var(--accent);color:var(--bg-0)}.flyout{background:color-mix(in oklab, var(--bg-1), black 10%);border:1px solid var(--line-2);opacity:0;pointer-events:none;z-index:4;border-radius:6px;width:min(560px,70%);padding:22px 24px;transition:opacity .24s,transform .24s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.96);box-shadow:0 30px 80px #0000008c}.flyout.on{opacity:1;pointer-events:auto;transform:translate(-50%,-50%)scale(1)}.flyout-close{color:var(--ink-3);font-size:12px;position:absolute;top:10px;right:12px}.flyout-close:hover{color:var(--accent)}.flyout h3{font-family:var(--serif);color:var(--ink);margin:0;font-size:30px;font-weight:600}.flyout .sub{color:var(--ink-2);letter-spacing:.18em;text-transform:uppercase;margin-top:4px;font-size:11px}.flyout .grid{grid-template-columns:1fr 1fr;gap:14px;margin-top:16px;display:grid}.flyout .stat{border:1px solid var(--line);border-radius:4px;padding:10px 12px}.flyout .stat .k{letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-size:9px}.flyout .stat .v{font-family:var(--serif);color:var(--ink);margin-top:2px;font-size:24px}.flyout .photos{grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px;display:grid}.flyout .photos .ph{aspect-ratio:1;background:repeating-linear-gradient(45deg, color-mix(in oklab, var(--ink), transparent 88%) 0 1px, transparent 1px 8px), color-mix(in oklab, var(--bg-2), black 20%);border:1px solid var(--line);border-radius:3px;position:relative}.flyout .photos .ph:after{content:"PHOTO " counter(ph);counter-increment:ph;font-family:var(--mono);letter-spacing:.2em;color:var(--ink-3);font-size:8px;position:absolute;bottom:4px;left:6px}.flyout .photos{counter-reset:ph}.flyout .services{border:1px solid var(--line);background:color-mix(in oklab, var(--bg-2), black 25%);border-radius:4px;margin-top:16px;padding:10px 12px}.flyout .services .svc-head{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px dashed var(--line);margin-bottom:8px;padding-bottom:6px;font-size:9px}.flyout .services .svc-list{font-family:var(--mono);color:var(--ink);letter-spacing:.04em;grid-template-columns:1fr 1fr;gap:4px 18px;margin:0;padding:0;font-size:11px;list-style:none;display:grid}.flyout .services .svc-list li:before{content:"▸ ";color:var(--accent);margin-right:4px}.flyout .services .svc-role{font-family:var(--mono);color:var(--ink-2);margin:0 0 10px;font-size:11px;line-height:1.55}.flyout .services .svc-spec{font-family:var(--mono);grid-template-columns:1fr 1fr;gap:4px 18px;margin:0 0 12px;padding:0;font-size:11px;list-style:none;display:grid}.flyout .services .svc-spec li{border-bottom:1px dashed var(--line);justify-content:space-between;align-items:baseline;padding-bottom:3px;display:flex}.flyout .services .svc-spec .k{color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase;font-size:9px}.flyout .services .svc-spec .v{color:var(--ink)}@media (max-width:600px){.flyout .services .svc-spec,.flyout .services .svc-list{grid-template-columns:1fr}}.flyout-actions{gap:10px;margin-top:16px;display:flex}.flyout-actions a{text-align:center;border:1px solid var(--line-2);color:var(--ink);letter-spacing:.2em;text-transform:uppercase;border-radius:4px;flex:1;padding:12px;font-size:10px;text-decoration:none;transition:background .16s,color .16s}.flyout-actions a.primary,.flyout-actions a:hover{background:var(--accent);color:var(--bg-0);border-color:var(--accent)}.ledge{border-top:1px solid var(--line-2);background:linear-gradient(180deg, color-mix(in oklab, var(--bg-1), transparent 0%), color-mix(in oklab, var(--bg-0), black 30%));z-index:5;grid-area:ledge;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:24px;padding:0 24px;display:grid;position:relative}.ledge:before,.ledge:after{content:"";background:radial-gradient(circle at 18px center, color-mix(in oklab, var(--ink-3), transparent 30%) 0 1.5px, transparent 2px) 0 0/36px 6px;height:6px;position:absolute;left:0;right:0}.ledge:before{top:4px}.ledge:after{bottom:4px}body.creative .ledge:before,body.creative .ledge:after{opacity:0}.ledge{transition:background .6s}.ticker{font-family:var(--mono);letter-spacing:.08em;color:var(--ink-2);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.ticker .dot{color:var(--accent)}.ticker.right{text-align:right}.nav{border:1px solid var(--line-2);background:color-mix(in oklab, var(--bg-2), black 30%);border-radius:999px;gap:4px;padding:6px;display:flex}.nav button{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-2);border-radius:999px;padding:8px 16px;font-size:10px;transition:background .2s,color .2s}.nav button:hover{color:var(--ink)}.nav button.active{background:var(--accent);color:var(--bg-0);box-shadow:0 0 18px color-mix(in oklab, var(--accent), transparent 60%)}body.creative{--bg-0:var(--c-bg-0);--bg-1:var(--c-bg-1);--bg-2:var(--c-bg-2);--line:var(--c-line);--line-2:var(--c-line-2);--ink:var(--c-ink);--ink-2:var(--c-ink-2);--ink-3:var(--c-ink-3);--accent:var(--c-accent);--accent-2:var(--c-accent-2)}.letterbox{z-index:6;pointer-events:none;background:#000;height:0;transition:height .7s cubic-bezier(.7,0,.3,1);position:fixed;left:0;right:0}.letterbox.top{top:0}.letterbox.bot{bottom:0}body.creative .letterbox{height:0}#landing{background:var(--t-bg-0);color:var(--t-ink);z-index:100;grid-template-rows:1fr auto auto 1fr;place-items:center;padding:48px 32px;transition:opacity .5s,visibility 0s .5s;display:grid;position:fixed;inset:0}#landing.hidden{opacity:0;visibility:hidden;pointer-events:none}.landing-mark{text-align:center;font-family:var(--serif)}.landing-mark .a{letter-spacing:.04em;color:var(--t-ink);font-size:56px;font-weight:600;line-height:1}.landing-mark .slash{color:var(--t-ink-3);letter-spacing:.6em;margin:12px 0;font-size:22px}.landing-mark .b{letter-spacing:.18em;color:var(--c-accent);font-size:56px;font-style:italic;font-weight:300;line-height:1}.landing-tag{font-family:var(--mono);letter-spacing:.32em;text-transform:uppercase;color:var(--t-ink-3);margin-top:14px;font-size:11px}.terminal{background:color-mix(in oklab, var(--t-bg-1), black 10%);border:1px solid var(--t-line-2);width:min(640px,90%);font-family:var(--mono);color:var(--t-ink-2);box-shadow:0 0 0 1px color-mix(in oklab, var(--t-accent), transparent 90%) inset;border-radius:4px;margin-top:32px;padding:16px 18px 14px;font-size:12px}.terminal .head{color:var(--t-ink-3);letter-spacing:.22em;text-transform:uppercase;border-bottom:1px dashed var(--t-line);justify-content:space-between;margin-bottom:10px;padding-bottom:8px;font-size:10px;display:flex}.terminal .line{opacity:0;line-height:1.7;transform:translateY(4px)}.terminal .line.in{opacity:1;transition:opacity .2s,transform .2s;transform:none}.terminal .line .ok{color:var(--t-accent)}.terminal .line .path{color:var(--t-ink)}.terminal .bar{background:color-mix(in oklab, var(--t-ink), transparent 88%);border-radius:2px;height:4px;margin-top:12px;overflow:hidden}.terminal .bar>i{background:linear-gradient(90deg, var(--t-accent), var(--t-accent-2));width:0;height:100%;box-shadow:0 0 10px var(--t-accent);transition:width .22s linear;display:block}.terminal .cursor:after{content:"_";color:var(--t-accent);margin-left:4px;animation:.9s steps(2,end) infinite vault-blink}@keyframes vault-blink{50%{opacity:0}}.doors{opacity:0;grid-template-columns:repeat(2,minmax(300px,360px));gap:18px;width:min(760px,92%);margin-top:32px;transition:opacity .5s .4s,transform .5s .4s;display:grid;transform:translateY(8px)}.doors.in{opacity:1;transform:none}.door{text-align:left;border:1px solid var(--t-line-2);color:var(--t-ink);background:color-mix(in oklab, var(--t-bg-1), black 4%);cursor:pointer;border-radius:4px;padding:22px 22px 20px;transition:background .24s,border-color .24s,transform .24s}.door:hover{background:color-mix(in oklab, var(--t-accent), black 80%);border-color:var(--t-accent);transform:translateY(-2px)}.door .eyebrow{font-family:var(--mono);letter-spacing:.28em;text-transform:uppercase;color:var(--t-ink-3);font-size:10px;display:block}.door .name{font-family:var(--serif);white-space:nowrap;margin-top:6px;font-size:28px;font-weight:600;display:block}.door .name.creative{color:var(--c-accent);letter-spacing:.06em;font-style:italic;font-weight:400}.door .meta{color:var(--t-ink-2);letter-spacing:.04em;margin-top:8px;font-size:11px;line-height:1.5;display:block}.door .arrow{color:var(--t-accent);font-family:var(--mono);letter-spacing:.3em;margin-top:14px;font-size:11px;display:block}.skip{font-family:var(--mono);letter-spacing:.24em;text-transform:uppercase;color:var(--t-ink-3);font-size:10px;position:absolute;bottom:22px;right:24px}.skip:hover{color:var(--t-accent)}.hide{display:none!important}.fade-swap{transition:opacity .36s}.fade-swap.swapping{opacity:0}@media (max-width:900px){#app{grid-template:"header"56px"left""stage"1fr"right""ledge"/1fr}.hdr{padding:0 14px}.wordmark{font-size:18px}.crumb{display:none}.mode-toggle .seg{letter-spacing:.12em;padding:5px 10px;font-size:10px}.side{padding:14px 16px}.side.left{border-right:0;border-bottom:1px solid var(--line);max-height:200px;overflow-y:auto}body.tech[data-view=resume] .side,body.tech[data-view=contact] .side{max-height:none}body.tech[data-view=resume] .sysview,body.tech[data-view=contact] .sysview{display:none}.rsview,.sysview,.ctview{inset:16px}.side.right{border-left:0;border-top:1px solid var(--line)}.ctx-title{font-size:22px}.stage{min-height:320px}.stage-hud{display:none}.core-label .name{font-size:22px}.core-label .meta{letter-spacing:.2em;font-size:9px}.ledge{grid-template-rows:auto auto auto;grid-template-columns:1fr;gap:10px;padding:12px}.ticker,.ticker.right{text-align:center;white-space:normal;font-size:10px}.nav{justify-self:center}.nav button{letter-spacing:.16em;padding:6px 12px;font-size:9px}body.vault{font-size:12px}.landing-mark .a,.landing-mark .b{letter-spacing:.04em;font-size:32px}.landing-mark .slash{margin:8px 0;font-size:16px}.landing-tag{letter-spacing:.2em;font-size:9px}.terminal{margin-top:20px;padding:12px 14px;font-size:11px}.doors{grid-template-columns:1fr;width:min(420px,92%);margin-top:20px}.door{padding:16px}.door .name{font-size:22px}.flyout{width:92%;padding:16px}.flyout h3{font-size:22px}.flyout .grid{grid-template-columns:1fr 1fr;gap:8px}.flyout .stat .v{font-size:18px}.flyout .photos{grid-template-columns:repeat(3,1fr)}.node-tag{letter-spacing:.1em;padding:3px 6px;font-size:9px}body.creative .letterbox{height:0}.cgrid{inset:16px}.cgrid-photos{grid-template-columns:repeat(3,1fr);gap:6px}.cgrid-title{font-size:15px}}@media (max-width:480px){.landing-mark .a,.landing-mark .b{font-size:26px}.doors{grid-template-columns:1fr}.nav button{letter-spacing:.14em;padding:6px 10px;font-size:8px}}
