:root{--bg: #000000;--bg-2: #0a0a0a;--panel: #111111;--line: rgba(255, 255, 255, .1);--line-soft: rgba(255, 255, 255, .06);--text: #f4f4f1;--muted: #949494;--faint: #5c5c57;--accent: #b3ffcb;--display: "Manrope", system-ui, sans-serif;--sans: "Manrope", system-ui, sans-serif;--mono: "DM Mono", ui-monospace, monospace;--max: 1240px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:#000}.page-grain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;opacity:.045;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}main,.nav{position:relative;z-index:2}.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:1.4rem clamp(1.2rem,5vw,3.5rem);background:#050505b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft)}.brand{font-family:var(--display);font-weight:700;font-size:1.15rem;letter-spacing:-.01em}.nav nav{display:flex;align-items:center;gap:clamp(1rem,2.5vw,2.6rem)}.nav nav a{font-size:.92rem;color:var(--muted);transition:color .2s}.nav nav a:hover{color:var(--text)}.nav-accent{color:var(--accent)!important}.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}.grid-lines{position:absolute;top:0;right:0;bottom:0;left:0;max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;padding:0 clamp(1.2rem,5vw,3.5rem);pointer-events:none}.grid-lines span{width:1px;background:var(--line-soft);height:100%}.hero-inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:7rem clamp(1.2rem,5vw,3.5rem) 0;width:100%}.hero-top{display:flex;justify-content:space-between;align-items:center;padding-bottom:1.4rem;margin-bottom:clamp(2rem,8vh,5rem);border-bottom:1px solid var(--line)}.hero-lead{font-family:var(--mono);color:var(--muted);font-size:.95rem;margin:0}.status{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--mono);font-size:.9rem;color:var(--muted)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 #6cf07a80;animation:pulse 2.4s infinite}@keyframes pulse{0%{box-shadow:0 0 #6cf07a73}70%{box-shadow:0 0 0 9px #6cf07a00}to{box-shadow:0 0 #6cf07a00}}.hero-title{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,9vw,7rem);line-height:.98;letter-spacing:-.035em;margin:0;max-width:16ch}.hero-title span{display:inline-block}.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:3rem}.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:999px;font-size:.92rem;font-weight:600;font-family:var(--mono);transition:transform .2s,background .2s,border-color .2s,color .2s}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover{transform:translateY(-2px)}.btn-ghost{border:1px solid var(--line);color:var(--text)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.section{position:relative;max-width:var(--max);margin:0 auto;padding:clamp(5rem,11vw,9rem) clamp(1.2rem,5vw,3.5rem)}.section-head{position:relative;display:flex;align-items:baseline;gap:1.2rem;margin-bottom:3.5rem}.eyebrow{font-family:var(--mono);font-size:.9rem;color:var(--muted);white-space:nowrap}.section-head h2{font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:-.03em;margin:0}.head-rule{flex:1;height:1px;background:var(--line);align-self:center}.proj-stack{display:flex;flex-direction:column}.proj{display:block;position:relative;margin-top:-1px;padding:clamp(1.6rem,4vw,2.6rem) clamp(1.4rem,4vw,2.4rem) clamp(1.6rem,4vw,2.4rem);border-radius:22px;border:1px solid var(--line);background:var(--panel);transition:box-shadow .35s,border-color .35s;will-change:transform}.proj:hover{box-shadow:0 30px 60px -30px #000c;z-index:5}.proj-meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.82rem;padding-bottom:1rem;margin-bottom:1.4rem;border-bottom:1px solid currentColor;opacity:.85}.proj-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.proj h3{font-family:var(--display);font-weight:700;font-size:clamp(2rem,6vw,3.6rem);letter-spacing:-.03em;margin:0;line-height:1}.proj-arrow{font-size:clamp(1.6rem,4vw,2.6rem);transition:transform .35s}.proj:hover .proj-arrow{transform:translate(6px,-6px)}.proj-blurb{margin:1.1rem 0 0;max-width:52ch;font-size:1rem;opacity:.78}.proj-image{margin-top:1.6rem;border-radius:14px;overflow:hidden;max-height:320px}.proj-image img{width:100%;height:100%;object-fit:cover;display:block}.color-blue{color:#9ec3ff;background:#0c1830;border-color:#1b3a66}.color-green{color:#b7f3c4;background:#0c1f12;border-color:#1d4329}.color-amber{color:#f7d59a;background:#241a08;border-color:#4d3914}.color-violet{color:#c9c2ff;background:#16122e;border-color:#322a63}.proj h3,.proj-arrow{color:inherit}.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,5vw,4rem);align-items:center}.prose{max-width:52ch}.prose p{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.3rem);font-weight:600;line-height:1.22;letter-spacing:-.02em;margin:0 0 1.3rem}.about-link{display:inline-block;margin-top:1rem;font-family:var(--mono);font-size:.95rem;color:var(--accent);border-bottom:1px solid transparent;transition:border-color .2s}.about-link:hover{border-color:var(--accent)}.about-photo{position:relative;aspect-ratio:4 / 5;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--bg-2)}.about-photo img{width:100%;height:100%;object-fit:cover;display:block}.photo-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-align:center;color:var(--faint);background:radial-gradient(120% 80% at 50% 0%,#1a1a1a,#0a0a0a 70%)}.photo-placeholder span{font-family:var(--mono);font-size:1rem}.photo-placeholder small{font-family:var(--mono);font-size:.72rem;max-width:22ch}.grain{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.16;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E")}.timeline{display:flex;flex-direction:column}.tl-item{display:grid;grid-template-columns:180px 1fr;gap:1.6rem;padding:2rem 0;border-top:1px solid var(--line)}.tl-item:first-child{border-top:none;padding-top:0}.tl-period{font-family:var(--mono);font-size:.88rem;color:var(--muted)}.tl-body h3{font-weight:500;margin:0 0 .7rem;font-size:1.35rem;letter-spacing:-.01em}.tl-org{color:var(--muted);font-weight:400;font-size:1rem}.tl-body ul{margin:0;padding-left:1.1rem;color:var(--muted)}.tl-body li{margin-bottom:.4rem}.posts{position:relative;display:flex;flex-direction:column}.post{position:relative;display:flex;align-items:baseline;gap:1.5rem;padding:clamp(1.6rem,4vw,2.4rem) 0;border-top:1px solid var(--line);transition:opacity .35s,padding-left .4s cubic-bezier(.22,1,.36,1)}.posts .post:last-child{border-bottom:1px solid var(--line)}.post h3{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,4.5vw,2.8rem);letter-spacing:-.025em;margin:0;flex:1;transition:color .3s}.post time{font-family:var(--mono);font-size:.85rem;color:var(--faint);white-space:nowrap}.post-arrow{font-size:1.4rem;color:var(--muted);transition:transform .35s,color .35s}.post.is-active{padding-left:1.4rem}.post.is-active h3{color:var(--accent)}.post.is-active .post-arrow{color:var(--accent);transform:translate(6px)}.post.is-dim{opacity:.32}.post-preview{position:absolute;top:0;left:0;width:230px;height:300px;border-radius:12px;overflow:hidden;pointer-events:none;z-index:10;margin:-150px 0 0 30px;border:1px solid var(--line);box-shadow:0 30px 60px -20px #000c}.post-preview img{width:100%;height:100%;object-fit:cover;display:block}.preview-swatch{width:100%;height:100%}.contact-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(1.5rem,5vw,4rem)}.contact-aside p{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:600;line-height:1.22;letter-spacing:-.02em;margin:0 0 1.6rem;max-width:20ch}.contact-mail{display:inline-block;font-family:var(--mono);color:var(--accent);margin-bottom:1.8rem;border-bottom:1px solid transparent;transition:border-color .2s}.contact-mail:hover{border-color:var(--accent)}.socials{display:flex;gap:1.4rem}.socials a{font-family:var(--mono);font-size:.9rem;color:var(--muted);transition:color .2s}.socials a:hover{color:var(--accent)}.contact-form{display:flex;flex-direction:column;gap:1.1rem}.contact-form label{display:flex;flex-direction:column;gap:.45rem;font-family:var(--mono);font-size:.8rem;color:var(--muted)}.contact-form input,.contact-form textarea{background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:.85rem .95rem;color:var(--text);font-family:var(--sans);font-size:1rem;transition:border-color .2s}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent)}.contact-form .btn{align-self:flex-start;margin-top:.3rem}.hidden-field{display:none}.form-note{font-family:var(--mono);font-size:.84rem;margin:0}.form-note.ok{color:var(--accent)}.form-note.err{color:#f7768e}.footer{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:2.4rem clamp(1.2rem,5vw,3.5rem);display:flex;justify-content:space-between;border-top:1px solid var(--line);font-family:var(--mono);font-size:.82rem;color:var(--faint)}a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:3px}@media (max-width: 820px){.about-grid{grid-template-columns:1fr}.about-photo{max-width:360px}.contact-wrap{grid-template-columns:1fr}.tl-item{grid-template-columns:1fr;gap:.5rem}.post-preview{display:none}.nav nav a:not(.nav-accent){display:none}.grid-lines{display:none}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation:none!important;transition:none!important}}.proj,.post{width:100%;text-align:left;background:var(--panel);font:inherit;color:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.post{background:transparent;border-left:none;border-right:none;border-top:1px solid var(--line)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#000000b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:clamp(1rem,5vw,4rem) clamp(1rem,5vw,2rem)}.overlay-card{position:relative;width:min(820px,100%);background:var(--bg-2);border:1px solid var(--line);border-radius:22px;padding:clamp(1.6rem,5vw,3.2rem);margin:auto 0}.overlay-card.color-blue{border-color:#1b3a66}.overlay-card.color-green{border-color:#1d4329}.overlay-card.color-amber{border-color:#4d3914}.overlay-card.color-violet{border-color:#322a63}.overlay-close{position:absolute;top:1.4rem;right:1.4rem;font-family:var(--mono);font-size:.82rem;color:var(--muted);background:none;border:1px solid var(--line);border-radius:999px;padding:.4rem .8rem;cursor:pointer;transition:color .2s,border-color .2s}.overlay-close:hover{color:var(--accent);border-color:var(--accent)}.overlay-meta{font-family:var(--mono);font-size:.85rem;color:var(--muted);margin-bottom:1rem}.overlay-title{font-weight:800;font-size:clamp(2rem,6vw,3.4rem);letter-spacing:-.03em;line-height:1;margin:0 0 1rem}.overlay-lead{font-size:clamp(1.1rem,2.4vw,1.4rem);font-weight:500;color:var(--text);opacity:.85;margin:0 0 1.8rem;max-width:60ch}.overlay-hero{border-radius:14px;overflow:hidden;margin-bottom:1.8rem;max-height:460px}.overlay-hero img{width:100%;height:100%;object-fit:cover;display:block}.overlay-body{color:var(--muted);font-size:1.05rem;line-height:1.7}.overlay-body p{margin:0 0 1.1rem}.overlay-body h2,.overlay-body h3{color:var(--text);margin:1.6rem 0 .6rem;letter-spacing:-.02em}.overlay-body a{color:var(--accent);text-decoration:underline}.overlay-body ul,.overlay-body ol{padding-left:1.2rem}.overlay-body li{margin-bottom:.4rem}.overlay-body code{font-family:var(--mono);font-size:.9em;background:#000;border:1px solid var(--line);border-radius:5px;padding:.1rem .35rem}.overlay-empty{font-style:italic;opacity:.7}.overlay-link{margin-top:1.8rem}
