@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700&family=Instrument+Serif:ital@0;1&family=IBM+Plex+Sans:wght@300;400;500;600&display=swap";
:root{--bg:#0a0c15;--bg-2:#121420;--bg-3:#1a1d2c;--surface-1:color-mix(in oklab, var(--bg) 96%, var(--bg-2));--line:#2e3242;--line-soft:#202330;--fg:#eff2f5;--fg-2:#b4b8bc;--fg-3:#767b80;--fg-4:#484e54;--accent:#a8afff;--accent-2:#a8afff2e;--accent-3:#a8afff14;--warn:#ff9c3e;--mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--sans:"IBM Plex Sans", ui-sans-serif, system-ui, sans-serif;--serif:"Instrument Serif", ui-serif, Georgia, serif;--radius:4px;--maxw:1280px}@supports (color:lab(0% 0 0)){:root{--bg:lab(3.26676% .790931 -5.01566);--bg-2:lab(6.50625% 1.55926 -8.89768);--bg-3:lab(10.999% 2.10403 -10.8938);--line:lab(20.8785% 1.80185 -10.9866);--line-soft:lab(13.9576% 1.51926 -9.14954);--fg:lab(95.3562% -.55331 -1.78927);--fg-2:lab(74.4733% -.873745 -2.85633);--fg-3:lab(51.2706% -1.07196 -3.55947);--fg-4:lab(32.7066% -1.24663 -4.25125);--accent:lab(72.6833% 18.9877 -56.6484);--accent-2:lab(72.6833% 18.9877 -56.6484/.18);--accent-3:lab(72.6833% 18.9877 -56.6484/.08);--warn:lab(73.6945% 38.4558 76.7614)}}[data-theme=light]{--bg:#fbfaf8;--bg-2:#f3f2ef;--bg-3:#e9e8e3;--surface-1:color-mix(in oklab, var(--bg) 94%, var(--bg-2));--line:#c6c4be;--line-soft:#d9d7d3;--fg:#0f1215;--fg-2:#2f3338;--fg-3:#5e646a;--fg-4:#8b9095;--accent:#6054ec;--accent-2:#6054ec24;--accent-3:#6054ec0f}@supports (color:lab(0% 0 0)){[data-theme=light]{--bg:lab(98.2757% -.0089407 1.14335);--bg-2:lab(95.3809% -.0106692 1.52529);--bg-3:lab(91.9111% -.0120103 2.29049);--line:lab(79.161% -.00849366 3.05902);--line-soft:lab(86.1111% -.0114143 2.2909);--fg:lab(5.25979% -.594564 -2.30088);--fg-2:lab(21.1084% -1.03098 -3.53888);--fg-3:lab(41.9875% -1.26274 -4.25921);--fg-4:lab(59.3909% -1.07732 -3.56233);--accent:lab(44.3191% 38.7476 -76.8339);--accent-2:lab(44.3191% 38.7476 -76.8339/.14);--accent-3:lab(44.3191% 38.7476 -76.8339/.06)}}*{box-sizing:border-box}button{color:inherit;font:inherit;cursor:pointer;background:0 0;border:0;padding:0}html,body{background:var(--bg);color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;padding:0;font-size:15px;line-height:1.55}body{min-height:100vh;transition:background-color .3s,color .3s}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}::selection{background:var(--accent);color:var(--bg)}.mono{font-family:var(--mono)}.serif{font-family:var(--serif)}.label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;color:var(--fg-3);font-size:11px;font-weight:500}.eyebrow{font-family:var(--mono);letter-spacing:.18em;color:var(--fg-3);text-transform:uppercase;font-size:11px;font-weight:500}h1,h2,h3,h4{margin:0;font-weight:500}.display{font-family:var(--serif);letter-spacing:-.02em;font-size:clamp(48px,8vw,120px);font-weight:400;line-height:.95}.shell{max-width:var(--maxw);margin:0 auto;padding:0 32px}.shell-narrow{max-width:760px;margin:0 auto;padding:0 32px}.nav{z-index:50;-webkit-backdrop-filter:blur(16px)saturate(140%);background:color-mix(in oklab, var(--bg) 78%, transparent);border-bottom:1px solid var(--line-soft);position:sticky;top:0}.nav-inner{max-width:var(--maxw);justify-content:space-between;align-items:center;gap:24px;margin:0 auto;padding:14px 32px;display:flex}.brand{font-family:var(--mono);letter-spacing:.04em;color:inherit;cursor:pointer;background:0 0;border:0;align-items:center;gap:10px;padding:0;font-size:12.5px;font-weight:500;display:flex}.brand-text{line-height:1}.nav-links{font-family:var(--mono);letter-spacing:.04em;gap:28px;font-size:12px;display:flex}.nav-links button{color:var(--fg-3);font-family:inherit;font-size:inherit;letter-spacing:inherit;background:0 0;border:0;padding:6px 0;transition:color .15s;position:relative}.nav-links button:before{content:"";background:var(--accent);width:4px;height:4px;transition:transform .18s;position:absolute;top:50%;left:-10px;transform:translateY(-50%)scale(0)}.nav-links button:hover,.nav-links button.active{color:var(--fg)}.nav-links button.active:before{transform:translateY(-50%)scale(1)}.nav-meta{font-family:var(--mono);color:var(--fg-3);align-items:center;gap:16px;font-size:11px;display:flex}.theme-toggle{border:1px solid var(--line);color:var(--fg-2);width:28px;height:28px;font-family:var(--mono);background:0 0;border-radius:2px;justify-content:center;align-items:center;font-size:11px;transition:all .15s;display:inline-flex}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.hero{border-bottom:1px solid var(--line-soft);min-height:72vh;position:relative;overflow:hidden}.hero-canvas{z-index:0;opacity:.95;width:100%;height:100%;position:absolute;inset:0}.hero-grain{pointer-events:none;z-index:1;opacity:.5;mix-blend-mode:overlay;background-image:radial-gradient(circle at 1px 1px, color-mix(in oklab, var(--fg) 12%, transparent) 1px, transparent 0);background-size:3px 3px;position:absolute;inset:0}.hero-vignette{pointer-events:none;z-index:2;background:linear-gradient(to bottom, color-mix(in oklab, var(--bg) 30%, transparent) 0%, transparent 30%, transparent 60%, var(--bg) 100%), radial-gradient(ellipse at center, transparent 30%, color-mix(in oklab, var(--bg) 60%, transparent) 100%);position:absolute;inset:0}.hero-content{z-index:3;max-width:var(--maxw);flex-direction:column;justify-content:center;gap:32px;min-height:72vh;margin:0 auto;padding:48px 32px 40px;display:flex;position:relative}.hero-top{font-family:var(--mono);color:var(--fg-3);letter-spacing:.08em;justify-content:space-between;align-items:flex-start;gap:24px;font-size:11px;display:flex}.hero-coords{flex-wrap:wrap;gap:32px;display:flex}.hero-coords>div{flex-direction:column;gap:2px;display:flex}.hero-coords b{color:var(--fg);letter-spacing:.04em;font-weight:500}.hero-title{margin-top:0}.hero-name{font-family:var(--serif);letter-spacing:-.025em;color:var(--fg);text-shadow:0 2px 32px color-mix(in oklab, var(--bg) 60%, transparent);font-size:clamp(64px,11vw,168px);font-style:italic;font-weight:400;line-height:.92}.hero-name .em-accent{color:var(--accent);font-style:italic}.hero-tagline{max-width:580px;font-family:var(--mono);color:var(--fg-2);margin-top:32px;font-size:13px;line-height:1.65}.hero-tagline .accent{color:var(--accent)}.hero-bottom{gap:16px;margin-top:8px;display:flex}.hero-cta{border:1px solid var(--line);background:color-mix(in oklab, var(--bg) 60%, transparent);color:var(--fg);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:10px;padding:12px 18px;font-size:12px;transition:all .18s;display:inline-flex}.hero-cta:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-3)}.hero-cta .arrow{transition:transform .18s}.hero-cta:hover .arrow{transform:translate(3px)}.hero-status{font-family:var(--mono);color:var(--fg-3);letter-spacing:.06em;align-items:center;gap:10px;font-size:11px;display:flex}.dot{background:var(--accent);width:8px;height:8px;box-shadow:0 0 0 0 var(--accent);border-radius:50%;animation:2.4s ease-in-out infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 0 0 var(--accent-2)}50%{box-shadow:0 0 0 6px #0000}}.section{border-bottom:1px solid var(--line-soft);padding:96px 0}.section-head{border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:baseline;gap:24px;margin-bottom:48px;padding-bottom:16px;display:flex}.section-head h2{font-family:var(--serif);letter-spacing:-.01em;font-size:clamp(28px,3.4vw,44px);font-weight:400;line-height:1.05}.section-head .meta{font-family:var(--mono);color:var(--fg-3);letter-spacing:.08em;white-space:nowrap;font-size:11px}.work-grid{grid-template-columns:repeat(12,1fr);gap:24px;display:grid}.archive-grid{align-items:stretch;padding-top:24px}.archive-grid .work-card:not(.is-writing),.archive-grid .work-card.is-writing.has-writing-thumb{padding-top:12px}.work-card{background:var(--bg-2);border:1px solid var(--line-soft);cursor:pointer;flex-direction:column;transition:border-color .2s,transform .4s;display:flex;position:relative;overflow:hidden}.work-card:hover{border-color:var(--accent)}.work-card:hover .work-thumb-inner{transform:scale(1.03)}.work-card.span-3{grid-column:span 3}.work-card.span-7{grid-column:span 7}.work-card.span-5{grid-column:span 5}.work-card.span-6{grid-column:span 6}.work-card.span-4{grid-column:span 4}.work-card.span-8{grid-column:span 8}.work-card.span-9{grid-column:span 9}.work-card.span-12{grid-column:span 12}.work-card.is-writing{background:var(--surface-1);border:1px solid var(--line-soft);border-radius:4px;flex-direction:column;justify-content:space-between;gap:24px;min-height:260px;padding:24px;transition:border-color .2s,transform .2s;display:flex;position:relative}.work-card.is-writing.has-writing-thumb{padding-top:0}.work-card.is-writing:hover{border-color:var(--accent);transform:translateY(-2px)}.work-card.is-writing:before{content:"";background-image:repeating-linear-gradient(0deg, transparent 0, transparent 23px, var(--line-soft) 23px, var(--line-soft) 24px);opacity:.35;pointer-events:none;border-radius:4px;position:absolute;inset:0}.writing-thumb{aspect-ratio:16/9;background:var(--bg-3);border-bottom:1px solid var(--line-soft);margin:0 -24px;position:relative;overflow:hidden}.work-card.is-writing .writing-head{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);justify-content:space-between;align-items:baseline;font-size:10px;display:flex;position:relative}.work-card.is-writing .writing-head .accent{color:var(--accent)}.work-card.is-writing .writing-title{font-family:var(--serif);letter-spacing:-.005em;color:var(--fg);text-wrap:pretty;margin:0;font-size:26px;font-style:italic;line-height:1.2;position:relative}.work-card.is-writing .writing-foot{font-family:var(--mono);letter-spacing:.06em;color:var(--fg-3);justify-content:space-between;font-size:11px;display:flex;position:relative}.work-thumb{aspect-ratio:16/10;background:var(--bg-3);position:relative;overflow:hidden}.work-thumb-inner{transition:transform .6s cubic-bezier(.2,.8,.2,1);position:absolute;inset:0}.work-thumb-tag{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg);background:color-mix(in oklab, var(--bg) 75%, transparent);border:1px solid var(--line);z-index:2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4px 8px;font-size:10px;position:absolute;top:12px;left:12px}.work-thumb-index{font-family:var(--mono);color:var(--fg-3);letter-spacing:.12em;z-index:2;font-size:10px;position:absolute;top:12px;right:12px}.work-meta{flex-direction:column;flex:1;gap:8px;padding:20px 22px 22px;display:flex}.work-meta .row{font-family:var(--mono);color:var(--fg-3);letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;align-items:baseline;gap:16px;font-size:11px;display:flex}.work-title{font-family:var(--serif);letter-spacing:-.005em;color:var(--fg);margin:4px 0 6px;font-size:28px;font-weight:400;line-height:1.1}.work-desc{color:var(--fg-2);max-width:52ch;font-size:13.5px;line-height:1.55}.work-tags{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.tag{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);border:1px solid var(--line-soft);border-radius:2px;padding:3px 7px;font-size:10px}.media-placeholder{background:repeating-linear-gradient(135deg, color-mix(in oklab, var(--fg) 3%, transparent) 0 1px, transparent 1px 8px), var(--bg-3);color:var(--fg-3);font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;justify-content:center;align-items:center;font-size:11px;display:flex;position:absolute;inset:0}.media-placeholder span{border:1px dashed var(--line);background:color-mix(in oklab, var(--bg) 80%, transparent);padding:6px 12px}.posts{border-top:1px solid var(--line-soft);flex-direction:column;display:flex}.post-row{border-bottom:1px solid var(--line-soft);cursor:pointer;grid-template-columns:100px 80px 1fr auto;align-items:center;gap:24px;padding:18px 0;transition:padding .18s,background .18s;display:grid;position:relative}.post-row:before{content:"";background:var(--accent);transform-origin:top;width:2px;transition:transform .2s;position:absolute;top:0;bottom:0;left:-24px;transform:scaleY(0)}.post-row:hover:before{transform:scaleY(1)}.post-row:hover{background:var(--bg-2);padding-left:12px;padding-right:12px}.post-row.has-thumb{grid-template-columns:88px 80px 90px 1fr auto;align-items:center;padding-top:18px;padding-bottom:18px}.post-thumb{aspect-ratio:4/3;background:var(--bg-3);border:1px solid var(--line-soft);align-items:flex-end;width:88px;padding:6px 8px;display:flex;position:relative;overflow:hidden}.post-thumb.has-image{justify-content:flex-start;align-items:flex-end}.post-thumb.has-image .asset-image{position:absolute;inset:0}.post-thumb.has-image:before{content:"";z-index:1;background:linear-gradient(#0000 35%,#000000b8);position:absolute;inset:0}.post-thumb.has-image .post-thumb-tag{z-index:2}.post-thumb:after{content:"";pointer-events:none;background-image:repeating-linear-gradient(135deg,#ffffff0a 0 1px,#0000 1px 8px);position:absolute;inset:0}.post-thumb-tag{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg);z-index:1;background:#0006;border-radius:2px;padding:2px 5px;font-size:9px;position:relative}.post-thumb-writing{background:var(--surface-1);background-image:repeating-linear-gradient(0deg, transparent 0, transparent 11px, var(--line-soft) 11px, var(--line-soft) 12px);justify-content:center;align-items:center;padding:0}.post-thumb-writing .post-thumb-tag{font-family:var(--serif);color:var(--accent);letter-spacing:0;background:0 0;padding:0;font-size:26px;font-style:italic}.post-date{font-family:var(--mono);color:var(--fg-3);letter-spacing:.06em;white-space:nowrap;font-size:11px}.post-title{font-family:var(--serif);color:var(--fg);letter-spacing:-.005em;font-size:22px;font-weight:400;line-height:1.2}.post-tag{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);white-space:nowrap;font-size:10px}.link-arrow{font-family:var(--mono);color:var(--fg-2);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--line);background:0 0;border-top:0;border-left:0;border-right:0;align-items:center;gap:6px;padding-bottom:2px;font-size:12px;transition:color .15s,border-color .15s;display:inline-flex}.link-arrow:hover{color:var(--accent);border-bottom-color:var(--accent)}.footer{z-index:4;border-top:1px solid var(--line-soft);background:var(--surface-1);padding:96px 0 32px;position:relative}.footer-top{grid-template-columns:1.2fr 2fr;align-items:start;gap:64px;display:grid}.footer-mark-block{flex-direction:column;gap:20px;display:flex}.footer-mark{font-family:var(--serif);letter-spacing:-.01em;color:var(--fg);font-size:56px;font-style:italic;line-height:.95}.footer-tag{max-width:32ch;color:var(--fg-2);font-size:16px;line-height:1.5;font-family:var(--serif);font-style:italic}.footer-tag em{color:var(--accent);font-style:italic}.footer-links{grid-template-columns:repeat(3,1fr);gap:32px;margin:0;padding-top:8px;display:grid}.footer-links>div{flex-direction:column;gap:8px;display:flex}.footer-links dt{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;color:var(--fg-3);border-bottom:1px solid var(--line-soft);margin-bottom:8px;padding-bottom:8px;font-size:10px;font-weight:500}.footer-links dd{font-family:var(--mono);color:var(--fg-2);letter-spacing:.02em;margin:0;font-size:12px;line-height:1.6}.footer-links dd a{color:inherit;cursor:pointer;transition:color .15s}.footer-links dd a:hover{color:var(--accent)}.footer-bottom{border-top:1px solid var(--line-soft);font-family:var(--mono);color:var(--fg-3);letter-spacing:.06em;justify-content:space-between;align-items:center;margin-top:64px;padding-top:24px;font-size:11px;display:flex}.case-hero{border-bottom:1px solid var(--line-soft);padding:64px 0 48px}.resume-fluid-page{isolation:isolate;position:relative;overflow:clip}.resume-fluid-page>.hero-canvas{z-index:0;opacity:.58;pointer-events:none;width:100%;height:100%;position:fixed;inset:0}.resume-fluid-page>.hero-vignette{z-index:1;background:linear-gradient(to bottom, color-mix(in oklab, var(--bg) 30%, transparent) 0%, color-mix(in oklab, var(--bg) 14%, transparent) 34%, color-mix(in oklab, var(--bg) 42%, transparent) 70%, var(--bg) 100%), radial-gradient(ellipse at 25% 12%, transparent 0%, color-mix(in oklab, var(--bg) 46%, transparent) 70%), radial-gradient(ellipse at center, transparent 20%, color-mix(in oklab, var(--bg) 72%, transparent) 100%);position:fixed}.resume-fluid-page>.case-hero,.resume-fluid-page>.shell{z-index:3;position:relative}.resume-hero{background:0 0;padding:72px 0 56px;position:relative;overflow:hidden}.resume-hero .shell{z-index:3;position:relative}.crumbs{font-family:var(--mono);color:var(--fg-3);letter-spacing:.08em;text-transform:uppercase;gap:8px;margin-bottom:32px;font-size:11px;display:flex}.compact-crumbs{margin-bottom:20px}.crumbs button{color:var(--fg-3);font:inherit;letter-spacing:inherit;background:0 0;border:0;padding:0}.crumbs button:hover{color:var(--accent)}.case-title{font-family:var(--serif);letter-spacing:-.02em;max-width:min(100%,1120px);font-size:clamp(40px,6vw,72px);font-weight:400;line-height:1}.case-deck{color:var(--fg-2);max-width:60ch;margin-top:24px;font-size:17px;line-height:1.55}.case-meta{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px;padding:20px 0;display:grid}.case-meta dt{font-family:var(--mono);color:var(--fg-3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;font-size:10px}.case-meta dd{font-family:var(--mono);color:var(--fg);margin:0;font-size:13px}.case-cover{aspect-ratio:16/9;background:var(--bg-3);border:1px solid var(--line-soft);margin:32px 0 64px;position:relative;overflow:hidden}.case-section{border-bottom:1px solid var(--line-soft);grid-template-columns:220px 1fr;gap:64px;padding:64px 0;display:grid}.case-section h3{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3);align-self:start;font-size:11px;font-weight:500;position:sticky;top:96px}.case-section h3 .num{color:var(--accent);margin-bottom:6px;display:block}.case-section .body{flex-direction:column;gap:20px;max-width:64ch;display:flex}.case-section .body p{color:var(--fg-2);margin:0;font-size:16px;line-height:1.7}.case-section .body p strong{color:var(--fg);font-weight:500}.case-section .body a,.case-section .body .post-link{color:var(--accent);border-bottom:1px solid var(--accent-2);cursor:pointer;transition:border-color .15s}.case-section .body a:hover,.case-section .body .post-link:hover{border-bottom-color:var(--accent)}.pull{font-family:var(--serif);color:var(--fg);border-left:2px solid var(--accent);margin:8px 0;padding:8px 0 8px 24px;font-size:26px;font-style:italic;line-height:1.3}.code{background:var(--bg-2);border:1px solid var(--line-soft);font-family:var(--mono);font-size:12.5px;line-height:1.7;overflow:hidden}.code-head{border-bottom:1px solid var(--line-soft);background:color-mix(in oklab, var(--bg) 60%, var(--bg-2));color:var(--fg-3);letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;align-items:center;padding:8px 14px;font-size:11px;display:flex}.code-body{color:var(--fg);white-space:pre;padding:16px 18px;overflow-x:auto}.code-body pre{color:inherit;font:inherit;white-space:pre;margin:0}.code-body .k{color:#b7a7ff;color:lab(72.4358% 26.3132 -54.1271)}.code-body .s{color:#f3b94c;color:lab(79.1818% 14.062 61.488)}.code-body .c{color:var(--fg-3);font-style:italic}.code-body .n{color:#34dde5;color:lab(80.3785% -40.7121 -16.7271)}.code-body .f{color:var(--accent)}[data-theme=light] .code-body .k{color:#4e1ca8;color:lab(26.487% 46.8638 -66.7942)}[data-theme=light] .code-body .s{color:#814300;color:lab(35.3908% 34.3728 76.6553)}[data-theme=light] .code-body .n{color:#006077;color:lab(36.7448% -27.8156 -32.2865)}.code-preview{border:1px solid var(--line-soft);background:var(--bg-2);grid-template-columns:1fr 1fr;display:grid}.code-preview .code{border:0;border-right:1px solid var(--line-soft)}.code-preview .preview{justify-content:center;align-items:center;min-height:280px;display:flex;position:relative}.code-preview .preview-canvas{width:100%;height:100%;display:block}.case-figure{aspect-ratio:16/9;background:var(--bg-3);border:1px solid var(--line-soft);position:relative;overflow:hidden}.case-figure-cap{font-family:var(--mono);color:var(--fg-3);letter-spacing:.04em;margin-top:10px;font-size:11px}.case-figure-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.post-hero{border-bottom:1px solid var(--line-soft);padding:60px 0 36px}.post-topline{font-family:var(--mono);color:var(--fg-3);letter-spacing:.12em;text-transform:uppercase;flex-wrap:wrap;align-items:center;gap:8px 18px;margin-bottom:28px;font-size:11px;display:flex}.post-topline a{color:var(--fg-2)}.post-topline a:hover{color:var(--accent)}.post-meta-bar{color:var(--fg-3);flex-wrap:wrap;gap:8px 18px;display:flex}.post-meta-bar .accent{color:var(--accent)}.post-h1{font-family:var(--serif);letter-spacing:-.015em;max-width:min(100%,1120px);font-size:clamp(40px,5.5vw,64px);font-weight:400;line-height:1.05}@media (max-width:720px){.post-topline{gap:8px 14px}}.post-body{flex-direction:column;gap:24px;max-width:64ch;padding:48px 0;display:flex}.post-body p{color:var(--fg-2);margin:0;font-size:17px;line-height:1.75}.post-body p strong{color:var(--fg)}.post-body h2{font-family:var(--serif);letter-spacing:-.01em;margin-top:24px;font-size:30px;font-weight:400}.post-body a{color:var(--accent);border-bottom:1px solid var(--accent-2)}.post-body a:hover{border-bottom-color:var(--accent)}.about-strip{grid-template-columns:1fr 1fr;align-items:start;gap:64px;display:grid}.about-strip .lead{font-family:var(--serif);letter-spacing:-.005em;color:var(--fg);font-size:32px;line-height:1.25}.about-strip .lead em{color:var(--accent);font-style:italic}.discipline-list{font-family:var(--mono);grid-template-columns:1fr 1fr;gap:28px;font-size:12px;display:grid}.discipline-list dt{color:var(--fg-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;font-size:10px}.discipline-list dd{color:var(--fg);letter-spacing:.02em;margin:0 0 4px}.marquee{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3);white-space:nowrap;padding:14px 0;font-size:12px;overflow:hidden}.marquee-track{gap:48px;animation:60s linear infinite scroll;display:inline-flex}.marquee-track>span{gap:48px;display:inline-flex}.marquee-track .accent{color:var(--accent)}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.divider{background:var(--line-soft);height:1px;margin:0}.kbd{border:1px solid var(--line);font-family:var(--mono);color:var(--fg-2);background:var(--bg-2);border-radius:3px;padding:1px 6px;font-size:10.5px;display:inline-block}.resume-row{border-bottom:1px solid var(--line-soft);padding:24px 0}.resume-row:last-child{border-bottom:0}.resume-row-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:24px;margin-bottom:12px;display:flex}.resume-row-head h4{font-family:var(--serif);letter-spacing:-.005em;color:var(--fg);margin:0;font-size:22px;font-weight:400}.resume-org{font-family:var(--mono);color:var(--fg-3);letter-spacing:.04em;margin-top:4px;font-size:12px;display:block}.resume-when{font-family:var(--mono);color:var(--fg-3);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;font-size:11px}.resume-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.resume-list li{color:var(--fg-2);padding-left:18px;font-size:15px;line-height:1.65;position:relative}.resume-list li:before{content:"◆";color:var(--accent);font-size:9px;position:absolute;top:1px;left:0}.resume-list li strong{color:var(--fg);font-weight:500}.skill-grid{grid-template-columns:1fr 2fr;gap:14px 24px;margin:0;display:grid}.skill-grid dt{font-family:var(--mono);color:var(--fg-3);letter-spacing:.12em;text-transform:uppercase;font-size:11px}.skill-grid dd{font-family:var(--mono);color:var(--fg);letter-spacing:.02em;margin:0;font-size:13px}@media (max-width:900px){.work-grid>*{grid-column:span 12!important}.case-section{grid-template-columns:1fr;gap:24px}.case-section h3{position:static}.footer-top{grid-template-columns:1fr;gap:32px}.footer-links{grid-template-columns:1fr 1fr}.post-row{grid-template-columns:80px 1fr}.post-row.has-thumb{grid-template-columns:64px 1fr;padding:14px 0}.post-row.has-thumb .post-thumb{width:64px}.post-row .post-date,.post-row .post-tag{display:none}.about-strip{grid-template-columns:1fr}.case-meta{grid-template-columns:1fr 1fr}.code-preview{grid-template-columns:1fr}}
.nav-links a{color:var(--fg-3);font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;font-size:11px;transition:color .2s;position:relative}.nav-links a:before{content:"";background:var(--accent);width:5px;height:5px;transition:transform .2s;position:absolute;top:50%;left:-12px;transform:translateY(-50%)scale(0)}.nav-links a:hover,.nav-links a.active{color:var(--fg)}.nav-links a.active:before{transform:translateY(-50%)scale(1)}.crumbs a{color:inherit;cursor:pointer}.crumbs a:hover{color:var(--accent)}.dashboard-shell{min-height:80vh;padding:56px 24px 96px}.dashboard-grid{max-width:var(--maxw);grid-template-columns:240px minmax(0,1fr);gap:28px;margin:0 auto;display:grid}.dashboard-side{border:1px solid var(--line-soft);background:var(--bg-2);align-self:start;padding:16px;position:sticky;top:96px}.dashboard-side a,.dashboard-side button{border-bottom:1px solid var(--line-soft);width:100%;color:var(--fg-2);font-family:var(--mono);text-align:left;text-transform:uppercase;letter-spacing:.12em;padding:10px 0;font-size:11px;display:block}.dashboard-side a:hover,.dashboard-side button:hover{color:var(--accent)}.dashboard-main{gap:24px;display:grid}.dashboard-panel{border:1px solid var(--line-soft);background:var(--bg-2);padding:22px}.dashboard-panel h1,.dashboard-panel h2,.dashboard-panel h3{font-family:var(--serif)}.dashboard-panel h1{font-size:clamp(36px,5vw,72px)}.dashboard-panel h2{font-size:30px}.dashboard-panel h3{font-size:24px}.dashboard-muted{color:var(--fg-2)}.dashboard-error{color:#ff8a8a;margin:0;font-size:12px}.dashboard-error.full{grid-column:1/-1}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.form-field{gap:6px;display:grid}.form-field.full{grid-column:1/-1}.form-field label{color:var(--fg-3);font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;font-size:10px}.form-field input,.form-field select,.form-field textarea{border:1px solid var(--line);background:var(--bg);width:100%;color:var(--fg);font:inherit;padding:10px 12px}.form-field textarea{min-height:260px;font-family:var(--mono);resize:vertical;font-size:12px}.dashboard-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.dashboard-actions.compact{margin-top:10px}.dashboard-button{border:1px solid var(--line);min-height:38px;color:var(--fg);font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-size:11px;display:inline-flex}.dashboard-button:hover{border-color:var(--accent);color:var(--accent)}.dashboard-button.primary{background:var(--accent);border-color:var(--accent);color:var(--bg)}.dashboard-button.danger:hover{color:#ff7163;color:lab(65.812% 55.7362 36.8491);border-color:#ff7163;border-color:lab(65.812% 55.7362 36.8491)}.dashboard-button.compact{min-height:30px;padding:0 10px;font-size:10px}.dashboard-list{gap:14px;display:grid}.dashboard-row{border:1px solid var(--line-soft);background:var(--bg);padding:16px}.dashboard-row-head{justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:12px;display:flex}.status-pill{border:1px solid var(--line);color:var(--fg-3);font-family:var(--mono);text-transform:uppercase;padding:3px 8px;font-size:10px}.status-pill.published{border-color:var(--accent);color:var(--accent)}.content-index{gap:18px;display:grid}.content-index-hero,.content-index-controls{justify-content:space-between;align-items:center;gap:18px;display:flex}.content-index-hero h1{margin-top:4px}.content-index-hero .dashboard-muted{max-width:720px}.content-search{flex:360px;gap:8px;display:grid}.content-search input{border:1px solid var(--line);background:var(--bg);width:100%;color:var(--fg);font:inherit;padding:12px 14px}.status-tabs{flex-wrap:wrap}.status-tabs button{min-width:108px}.status-tabs span{color:inherit;opacity:.68;margin-left:6px}.content-table{gap:10px;display:grid}.content-table-head,.content-row{grid-template-columns:minmax(260px,1fr) 120px 140px minmax(260px,360px);align-items:center;gap:14px;display:grid}.content-table-head{color:var(--fg-3);font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;padding:0 16px;font-size:10px}.content-row{border:1px solid var(--line-soft);background:var(--bg);padding:16px}.content-row-title{color:var(--fg);font-family:var(--serif);font-size:24px;line-height:1.08}.content-row-title:hover{color:var(--accent)}.content-row-main p{color:var(--fg-2);margin-top:6px}.content-row-meta{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.content-row-meta span,.content-row-updated{color:var(--fg-3);font-family:var(--mono);text-transform:uppercase;font-size:10px}.content-row-meta span{border:1px solid var(--line-soft);padding:4px 7px}.content-row-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.content-row-actions .dashboard-button{min-height:34px}.media-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.media-card{border:1px solid var(--line-soft);background:var(--bg);overflow:hidden}.media-thumb{aspect-ratio:4/3;background:var(--bg-3);width:100%;display:block}.media-thumb img,.media-thumb video{object-fit:cover;width:100%;height:100%;display:block}.media-thumb.pdf{background:var(--bg-3);color:var(--fg-3);font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;place-items:center;font-size:12px;display:grid}.media-card .media-placeholder{min-height:135px;position:relative}.media-card-body{gap:10px;padding:12px;display:grid}.media-card-body h3{font-family:var(--serif);overflow-wrap:anywhere;font-size:22px;line-height:1.1}.media-meta{flex-wrap:wrap;gap:8px;display:flex}.media-meta span,.media-path{color:var(--fg-3);font-family:var(--mono);text-transform:uppercase;font-size:10px}.media-meta span{border:1px solid var(--line-soft);padding:4px 7px}.media-path{overflow-wrap:anywhere}.media-library-head{justify-content:space-between;align-items:center;gap:18px;display:flex}.media-search{margin-top:18px}.media-empty{border:1px solid var(--line-soft);background:var(--bg);margin-top:18px;padding:18px}.builder-shell{gap:16px;display:grid}.builder-toolbar,.builder-section-head,.builder-block-head,.sticky-savebar{justify-content:space-between;align-items:center;gap:16px;display:flex}.builder-toolbar{border:1px solid var(--line-soft);background:var(--bg);flex-wrap:wrap;padding:16px}.builder-toolbar h3{margin-top:4px}.segmented-control{border:1px solid var(--line);display:inline-flex}.segmented-control button{border-right:1px solid var(--line);min-width:88px;color:var(--fg-3);font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;padding:9px 12px;font-size:10px}.segmented-control button:last-child{border-right:0}.segmented-control button.active{background:var(--accent);color:var(--bg)}.builder-basics{margin-top:16px}.builder-sections{gap:18px;margin-top:18px;display:grid}.builder-section{border:1px solid var(--line-soft);background:var(--bg)}.builder-section-head{border-bottom:1px solid var(--line-soft);background:var(--bg-2);padding:14px}.builder-section-title{grid-template-columns:76px minmax(0,1fr);gap:10px;width:100%;display:grid}.builder-section-title input,.builder-block input,.builder-block select,.builder-block textarea{border:1px solid var(--line);background:var(--bg);width:100%;color:var(--fg);font:inherit;padding:10px 12px}.builder-section-title input{font-family:var(--mono);font-size:12px}.builder-section-title input:last-child{font-family:var(--serif);font-size:24px}.builder-blocks{gap:12px;padding:14px;display:grid}.builder-block{border:1px solid var(--line-soft);background:var(--bg-2);padding:14px}.builder-block-head{margin-bottom:12px}.writer-textarea{min-height:150px;line-height:1.6}.writer-textarea.quote{min-height:110px;font-family:var(--serif);font-size:26px;font-style:italic}.code-textarea{min-height:260px;font-family:var(--mono)!important;font-size:12px!important}.image-block-editor{display:block}.image-preview{border:1px dashed var(--line);background:var(--bg);min-height:150px;color:var(--fg-3);font-family:var(--mono);text-transform:uppercase;place-items:center;font-size:10px;display:grid}.image-preview img{object-fit:cover;width:100%;height:100%}.color-field{grid-template-columns:48px minmax(0,1fr);gap:10px;display:grid}.color-field input[type=color]{width:48px;min-height:42px;padding:4px}.color-value{border:1px solid var(--line);min-height:42px;color:var(--fg-2);font-family:var(--mono);letter-spacing:0;align-items:center;padding:0 12px;font-size:11px;display:flex}.cover-picker{grid-template-columns:220px minmax(0,1fr);gap:16px;display:grid}.cover-picker-preview{border:1px dashed var(--line);background:var(--bg);min-height:124px;color:var(--fg-3);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;place-items:center;font-size:10px;display:grid;overflow:hidden}.cover-picker-preview img{object-fit:cover;width:100%;height:100%}.cover-picker-controls{align-content:center;gap:10px;display:grid}.cover-picker-controls select{width:100%}.asset-picker{grid-template-columns:220px minmax(0,1fr);gap:16px;display:grid}.asset-picker-selected{border:1px dashed var(--line);background:var(--bg);min-height:150px;color:var(--fg-3);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;place-items:center;font-size:10px;display:grid;overflow:hidden}.asset-picker-selected img,.asset-picker-selected video{object-fit:cover;width:100%;height:100%}.asset-picker-browser{align-content:start;gap:10px;min-width:0;display:grid}.asset-picker-search{grid-template-columns:minmax(0,1fr) auto;gap:8px;display:grid}.asset-picker-search input{border:1px solid var(--line);background:var(--bg);width:100%;color:var(--fg);font:inherit;padding:10px 12px}.asset-picker-grid{grid-template-columns:repeat(auto-fill,minmax(136px,1fr));gap:8px;max-height:340px;padding-right:4px;display:grid;overflow:auto}.asset-option{border:1px solid var(--line-soft);background:var(--bg);color:var(--fg);text-align:left;grid-template-rows:auto auto 1fr;gap:6px;padding:8px;display:grid}.asset-option:hover,.asset-option.selected{border-color:var(--accent)}.asset-option img,.asset-option video{aspect-ratio:4/3;object-fit:cover;background:var(--bg-3);width:100%;display:block}.asset-option span{overflow-wrap:anywhere;font-size:12px;line-height:1.25}.asset-option small{color:var(--fg-3);font-family:var(--mono);text-transform:uppercase;overflow-wrap:anywhere;font-size:9px;line-height:1.3}.resume-builder{gap:18px;display:grid}.resume-bullets{gap:10px;margin:14px 0;display:grid}.link-list-editor{gap:10px;display:grid}.resume-field-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.resume-nested-block{border:1px solid var(--line-soft);background:var(--bg);gap:10px;padding:12px;display:grid}.block-add-bar{flex-wrap:wrap;gap:8px;padding:0 14px 14px;display:flex}.block-add-bar button{border:1px solid var(--line);color:var(--fg-2);font-family:var(--mono);text-transform:uppercase;padding:8px 10px;font-size:10px}.block-add-bar button:hover{border-color:var(--accent);color:var(--accent)}.sticky-savebar{z-index:20;border:1px solid var(--line);background:color-mix(in oklch, var(--bg-2), transparent 8%);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);margin-top:18px;padding:12px;position:sticky;bottom:14px}.builder-preview{border:1px solid var(--line-soft);background:var(--bg);padding:18px}.builder-preview-hero{border-bottom:1px solid var(--line-soft);margin-bottom:12px;padding-bottom:24px}.builder-preview-hero h2{font-family:var(--serif);font-size:clamp(40px,6vw,84px)}.code-body pre{white-space:pre-wrap;color:inherit;font:inherit;margin:0}.asset-image,.figure-image,.asset-video{object-fit:cover;width:100%;height:100%;display:block}.metric-grid,.link-list{gap:12px;display:grid}.metric-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.metric-card,.link-list a{border:1px solid var(--line-soft);background:var(--bg-2);padding:14px}.metric-card b{color:var(--accent);font-family:var(--serif);font-size:30px;font-weight:400;display:block}.link-list a:hover{border-color:var(--accent)}@media (max-width:760px){.dashboard-grid,.form-grid,.cover-picker,.image-block-editor,.asset-picker,.content-table-head,.content-row{grid-template-columns:1fr}.dashboard-side{position:static}.builder-toolbar,.builder-section-head,.builder-block-head,.resume-field-head,.sticky-savebar,.content-index-hero,.content-index-controls,.media-library-head{flex-direction:column;align-items:stretch}.asset-picker-search{grid-template-columns:1fr}.content-table-head{display:none}.content-row-actions{justify-content:flex-start}}
.pe-shell,.pe-form{flex-direction:column;gap:18px;display:flex}.pe-editor-shell{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;min-height:480px;padding:28px 36px;transition:border-color .15s;position:relative}.pe-editor-shell.drag-over{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklch, var(--accent) 20%, transparent)}.pe-editor-content{font-family:var(--serif);color:var(--fg);font-size:18px;line-height:1.7}.pe-editor-content .ProseMirror{outline:none;min-height:400px}.pe-editor-content .ProseMirror>*+*{margin-top:22px}.pe-editor-content p.is-editor-empty:first-child:before,.pe-editor-content .pe-section-body p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--fg-3);pointer-events:none;height:0}.pe-editor-content p{margin:0}.pe-editor-content a.post-link{color:var(--accent);text-underline-offset:3px;text-decoration:underline;text-decoration-thickness:1px}.pe-editor-content code{font-family:var(--mono);background:var(--bg-3);border-radius:4px;padding:2px 6px;font-size:.9em}.pe-drop-overlay{background:color-mix(in oklch, var(--bg) 70%, transparent);border:2px dashed var(--accent);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg);pointer-events:none;border-radius:14px;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;inset:0}.pe-uploading{background:var(--bg);border:1px solid var(--line);font-family:var(--mono);letter-spacing:.05em;color:var(--fg-2);pointer-events:none;border-radius:999px;padding:6px 12px;font-size:11px;position:absolute;bottom:12px;right:14px}.pe-drag-handle{width:22px;height:22px;color:var(--fg-3);cursor:grab;-webkit-user-select:none;user-select:none;opacity:0;border-radius:4px;justify-content:center;align-items:center;font-size:14px;transition:opacity .12s,background .12s,color .12s;display:inline-flex;position:absolute;top:6px;left:-28px}.pe-drag-handle:hover{background:var(--bg-3);color:var(--fg)}.pe-drag-handle:active{cursor:grabbing}.pe-section:hover>.pe-section-head .pe-drag-handle,.pe-figure:hover .pe-drag-handle,.pe-figure-grid:hover>.pe-drag-handle,.pe-code:hover>.pe-drag-handle,.pe-shader:hover>.pe-drag-handle,.pe-code-preview:hover>.pe-drag-handle,.pe-metric-grid:hover>.pe-drag-handle,.pe-link-list:hover>.pe-drag-handle{opacity:1}.pe-section,.pe-figure,.pe-figure-grid,.pe-code,.pe-shader,.pe-code-preview,.pe-metric-grid,.pe-link-list,.pe-pull{position:relative}.pe-section{border-top:1px solid var(--line-soft);margin:36px 0;padding-top:18px}.pe-section-head{align-items:center;gap:14px;margin-bottom:18px;display:flex}.pe-section-head .pe-drag-handle{opacity:.5;position:static}.pe-section-h3{font-family:var(--serif);align-items:baseline;gap:14px;margin:0;font-size:24px;font-weight:500;display:flex}.pe-section-number{width:56px;font-family:var(--mono);letter-spacing:.12em;color:var(--fg-3);text-transform:uppercase;background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 6px;font-size:12px}.pe-section-number:hover,.pe-section-number:focus{border-color:var(--line);outline:none}.pe-section-title{font-family:var(--serif);color:var(--fg);background:0 0;border:1px solid #0000;border-radius:4px;flex:1;padding:4px 6px;font-size:24px;font-weight:500}.pe-section-title:hover,.pe-section-title:focus{border-color:var(--line);outline:none}.pe-section-body{flex-direction:column;gap:22px;display:flex}.pe-pull{font-family:var(--serif);color:var(--fg);border-left:3px solid var(--accent);margin:0;padding-left:18px;font-size:22px;font-style:italic;line-height:1.55}.pe-figure{margin:0}.pe-figure-frame{cursor:pointer;background:var(--bg-3);border:1px solid #0000;border-radius:8px;transition:border-color .15s;overflow:hidden}.pe-figure-frame:hover{border-color:var(--line)}.pe-figure.selected .pe-figure-frame{border-color:var(--accent)}.pe-figure-empty{height:100%;color:var(--fg-3);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex}.pe-figure-empty span{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;font-size:12px}.pe-figure-empty small{color:var(--fg-3);font-size:11px}.pe-figure .case-figure-cap,.pe-figure-cap-display{font-family:var(--mono);color:var(--fg-2);letter-spacing:.04em;margin-top:8px;font-size:11px}.pe-figure-toolbar{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.pe-figure-fields{background:var(--bg);border:1px solid var(--line-soft);border-radius:8px;grid-template-columns:2fr 1fr 1fr;gap:10px;margin-top:12px;padding:12px;display:grid}.pe-figure-grid-row{grid-auto-columns:1fr;grid-auto-flow:column;gap:14px;display:grid}.pe-figure-grid-toolbar{gap:6px;margin-top:10px;display:flex}.pe-code-frame{margin:0}.pe-code-head{align-items:center;gap:10px;display:flex}.pe-code-filename,.pe-code-language{color:var(--fg-2);font-family:var(--mono);background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 6px;font-size:11px}.pe-code-filename{flex:1}.pe-code-language{width:80px}.pe-code-filename:hover,.pe-code-filename:focus,.pe-code-language:hover,.pe-code-language:focus{border-color:var(--line);outline:none}.pe-code-textarea{width:100%;min-height:220px;color:var(--fg);font-family:var(--mono);resize:vertical;white-space:pre;background:0 0;border:none;outline:none;padding:0;font-size:13px;line-height:1.55;overflow:auto}.pe-code-placeholder{color:var(--fg-3)}.pe-code-toolbar,.pe-shader-toolbar,.pe-metric-toolbar,.pe-link-toolbar{justify-content:flex-end;gap:6px;margin-top:10px;display:flex}.pe-shader-frame{min-height:260px;position:relative}.pe-shader-controls{background:color-mix(in oklch, var(--bg) 70%, transparent);border:1px solid var(--line-soft);border-radius:6px;gap:8px;padding:6px 8px;display:flex;position:absolute;bottom:8px;left:8px}.pe-shader-controls .pe-form-field{flex-direction:column;gap:2px;min-width:120px;display:flex}.pe-shader-controls .pe-form-field span{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);font-size:9px}.pe-shader-controls input,.pe-shader-controls select{background:var(--bg-2);border:1px solid var(--line);color:var(--fg);font-family:var(--mono);border-radius:4px;padding:3px 5px;font-size:11px}.pe-shader-label{font-family:var(--mono);color:var(--fg-3);letter-spacing:.08em;text-transform:uppercase;font-size:10px;position:absolute;bottom:8px;right:10px}.pe-shader-placeholder{height:100%;color:var(--fg-3);font-family:var(--mono);justify-content:center;align-items:center;font-size:12px;display:flex}.pe-code-preview-frame{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px;display:grid}@media (max-width:900px){.pe-code-preview-frame{grid-template-columns:1fr}}.pe-metric-grid-frame{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.pe-metric-card{background:var(--bg);border:1px solid var(--line-soft);border-radius:10px;flex-direction:column;gap:6px;padding:14px;display:flex;position:relative}.pe-metric-value{font-family:var(--serif);color:var(--fg);background:0 0;border:1px solid #0000;border-radius:4px;padding:2px 4px;font-size:28px;font-weight:500}.pe-metric-label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-2);background:0 0;border:1px solid #0000;border-radius:4px;padding:2px 4px;font-size:11px}.pe-metric-detail{color:var(--fg-2);background:0 0;border:1px solid #0000;border-radius:4px;padding:2px 4px;font-size:13px}.pe-metric-card input:hover,.pe-metric-card input:focus,.pe-link-row input:hover,.pe-link-row input:focus{border-color:var(--line);outline:none}.pe-metric-card .pe-mini-button.danger{position:absolute;top:6px;right:6px}.pe-link-list-frame{flex-direction:column;gap:8px;display:flex}.pe-link-row{background:var(--bg);border:1px solid var(--line-soft);border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(0,2fr) minmax(0,1fr) auto;align-items:center;gap:8px;padding:6px 8px;display:grid}.pe-link-row input{color:var(--fg);background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 6px;font-size:13px}.pe-link-label{font-weight:500}.pe-link-href{font-family:var(--mono);color:var(--fg-2);font-size:12px}.pe-link-detail{color:var(--fg-2)}.pe-mini-button{background:var(--bg);border:1px solid var(--line);color:var(--fg-2);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border-radius:6px;padding:5px 9px;font-size:10px;transition:all .12s}.pe-mini-button:hover{background:var(--bg-3);border-color:var(--line);color:var(--fg)}.pe-mini-button.danger{color:color-mix(in oklch, #d97070 80%, var(--fg-2))}.pe-mini-button.danger:hover{color:#ff8a8a;background:color-mix(in oklch, #d97070 12%, var(--bg))}.pe-slash-menu{background:var(--bg-2);border:1px solid var(--line);min-width:240px;max-height:320px;font-family:var(--mono);border-radius:10px;padding:6px;font-size:12px;overflow-y:auto;box-shadow:0 12px 32px #0006}.pe-slash-menu.empty{color:var(--fg-3);text-align:center;text-transform:uppercase;letter-spacing:.08em;padding:12px}.pe-slash-item{text-align:left;width:100%;color:var(--fg);cursor:pointer;background:0 0;border:none;border-radius:6px;grid-template-columns:1fr;gap:2px;padding:8px 10px;display:grid}.pe-slash-item.active,.pe-slash-item:hover{background:var(--bg-3)}.pe-slash-item strong{font-family:var(--serif);color:var(--fg);font-size:14px;font-weight:500}.pe-slash-item span{color:var(--fg-3);letter-spacing:.05em;font-size:10px}.pe-upload-error{color:#ff8a8a;text-transform:none;border-color:#ff8a8a;max-width:min(420px,100% - 28px)}.pe-bubble{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;gap:2px;padding:4px;display:flex;box-shadow:0 8px 24px #0006}.pe-bubble button{color:var(--fg-2);cursor:pointer;font-family:var(--serif);background:0 0;border:none;border-radius:4px;min-width:28px;padding:4px 8px;font-size:13px}.pe-bubble button:hover{background:var(--bg-3);color:var(--fg)}.pe-bubble button.active{background:color-mix(in oklch, var(--accent) 20%, transparent);color:var(--fg)}.pe-bubble code{font-family:var(--mono);background:0 0;padding:0;font-size:11px}.pe-modal-backdrop{z-index:1100;background:#000000a6;background:lab(0% 0 0/.65);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.pe-modal{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;flex-direction:column;width:min(820px,100%);max-height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 80px #00000080}.pe-modal-head{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:16px 20px;display:flex}.pe-modal-head h2{font-family:var(--serif);flex:1;margin:0;font-size:18px;font-weight:500}.pe-modal-tabs{background:var(--bg);border:1px solid var(--line);border-radius:999px;gap:4px;padding:3px;display:flex}.pe-modal-tabs button{color:var(--fg-3);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;border-radius:999px;padding:5px 12px;font-size:11px}.pe-modal-tabs button.active{background:var(--bg-3);color:var(--fg)}.pe-modal-close{color:var(--fg-3);cursor:pointer;background:0 0;border:none;border-radius:6px;width:32px;height:32px;font-size:24px}.pe-modal-close:hover{background:var(--bg-3);color:var(--fg)}.pe-modal-search{border-bottom:1px solid var(--line-soft);padding:12px 20px}.pe-modal-search input{background:var(--bg);border:1px solid var(--line);width:100%;color:var(--fg);font-family:var(--mono);border-radius:8px;padding:8px 12px;font-size:12px}.pe-modal-search input:focus{border-color:var(--accent);outline:none}.pe-modal-body{flex:1;padding:16px 20px;overflow-y:auto}.pe-modal-empty{text-align:center;color:var(--fg-3);padding:40px}.pe-modal-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.pe-asset-tile{background:var(--bg);cursor:pointer;border:2px solid #0000;border-radius:10px;flex-direction:column;gap:6px;padding:6px;transition:border-color .12s;display:flex;overflow:hidden}.pe-asset-tile:hover{border-color:var(--line)}.pe-asset-tile.selected{border-color:var(--accent)}.pe-asset-tile img,.pe-asset-tile video{aspect-ratio:4/3;object-fit:cover;background:var(--bg-3);border-radius:6px;width:100%}.pe-asset-tile-label{color:var(--fg-2);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.pe-asset-tile-fallback{aspect-ratio:4/3;font-family:var(--mono);color:var(--fg-3);background:var(--bg-3);border-radius:6px;justify-content:center;align-items:center;font-size:10px;display:flex}.pe-modal-foot{border-top:1px solid var(--line);background:var(--bg);align-items:center;gap:14px;padding:14px 20px;display:flex}.pe-modal-foot-meta{color:var(--fg-3);flex-direction:column;flex:1;gap:2px;font-size:11px;display:flex}.pe-modal-foot-meta strong{color:var(--fg-2);font-weight:500}.pe-modal-foot-actions{gap:8px;display:flex}.pe-modal-upload{flex-direction:column;gap:14px;padding:20px;display:flex;overflow-y:auto}.pe-dropzone{border:2px dashed var(--line);cursor:pointer;background:var(--bg);border-radius:10px;justify-content:center;align-items:center;min-height:220px;padding:12px;transition:border-color .12s,background .12s;display:flex}.pe-dropzone:hover,.pe-dropzone.drag-over{border-color:var(--accent);background:color-mix(in oklch, var(--accent) 6%, var(--bg))}.pe-dropzone input[type=file]{display:none}.pe-dropzone-empty{color:var(--fg-3);flex-direction:column;align-items:center;gap:4px;display:flex}.pe-dropzone-empty strong{font-family:var(--serif);color:var(--fg);font-size:18px;font-weight:500}.pe-dropzone-empty span{font-size:12px}.pe-dropzone-preview{flex-direction:column;align-items:center;gap:10px;width:100%;display:flex}.pe-dropzone-preview img,.pe-dropzone-preview video{border-radius:8px;max-width:100%;max-height:240px}.pe-dropzone-meta{font-family:var(--mono);color:var(--fg-2);gap:10px;font-size:11px;display:flex}.pe-form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.pe-form-field{flex-direction:column;gap:4px;display:flex}.pe-form-field span{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);font-size:10px}.pe-form-field input,.pe-form-field select,.pe-form-field textarea{background:var(--bg);border:1px solid var(--line);color:var(--fg);font-family:var(--serif);border-radius:6px;padding:7px 10px;font-size:14px}.pe-form-field input:focus,.pe-form-field select:focus,.pe-form-field textarea:focus{border-color:var(--accent);outline:none}.pe-form-error{color:#ff8a8a;margin:0;font-size:12px}.pe-cover-picker{align-items:flex-start;gap:12px;display:flex}.pe-cover-tile{aspect-ratio:4/3;border:1px solid var(--line);background:var(--bg);cursor:pointer;width:220px;color:var(--fg-3);font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;border-radius:10px;justify-content:center;align-items:center;padding:0;font-size:11px;display:flex;overflow:hidden}.pe-cover-tile:hover{border-color:var(--accent)}.pe-cover-tile img,.pe-cover-tile video{object-fit:cover;width:100%;height:100%}.pe-cover-actions{flex-direction:column;gap:6px;display:flex}.pe-savebar{justify-content:flex-end;align-items:center;gap:14px;display:flex}.pe-savebar-hint{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);font-size:10px}.pe-basics .form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.pe-basics .form-field.full{grid-column:1/-1}
