:root{--bg: #fbfbf9;--surface: #ffffff;--ink: #1a1a18;--ink-soft: #4a4a45;--ink-faint: #8c8c84;--line: #e6e5df;--hover: #f3f2ed;--shadow: rgba(20,20,18,.07);--serif-display: "Fraunces", Georgia, serif;--serif-body: "Newsreader", Georgia, serif;--sans: "Hanken Grotesk", system-ui, sans-serif;--pad: clamp(20px, 5vw, 64px);--wide: 1280px}html[data-theme=dark]{--bg: #121211;--surface: #1a1a18;--ink: #ecebe5;--ink-soft: #b4b3ac;--ink-faint: #76756e;--line: #2c2c29;--hover: #232320;--shadow: rgba(0,0,0,.45)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background .4s ease,color .4s ease;overflow-x:hidden}::selection{background:var(--ink);color:var(--bg)}.shell{max-width:var(--wide);margin:0 auto;padding-inline:var(--pad)}header.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line)}.nav-inner{max-width:var(--wide);margin:0 auto;padding:15px var(--pad);display:flex;align-items:center;justify-content:space-between}.wordmark{font-family:var(--serif-display);font-weight:500;font-size:1.4rem;letter-spacing:-.01em;color:var(--ink);text-decoration:none}.wordmark span{font-style:italic}.nav-links{display:flex;align-items:center;gap:clamp(16px,3vw,34px)}.nav-links a{font-size:.92rem;color:var(--ink-soft);text-decoration:none;position:relative;transition:color .25s}.nav-links a:after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--ink);transition:width .3s ease}.nav-links a:hover,.nav-links a.active{color:var(--ink)}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.toggle{background:none;border:1px solid var(--line);width:36px;height:36px;border-radius:50%;cursor:pointer;color:var(--ink-soft);display:grid;place-items:center;transition:all .25s;flex-shrink:0}.toggle:hover{border-color:var(--ink-faint);color:var(--ink)}.toggle svg{width:16px;height:16px}.hero{min-height:calc(100svh - 67px);display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center;padding-block:clamp(48px,7vw,80px);border-bottom:1px solid var(--line)}.hero-text{min-width:0}.hero-portrait{position:relative;width:100%;max-width:380px;aspect-ratio:4 / 5;justify-self:center}.hero-portrait .frame{position:absolute;inset:0;z-index:2;overflow:hidden;border-radius:48px;border:1px solid var(--line);background:var(--hover);transform:rotate(-3deg);transition:transform .4s ease}.hero-portrait:hover .frame{transform:rotate(0)}.hero-portrait .frame img{width:100%;height:100%;object-fit:cover;display:block;transform:rotate(3deg) scale(1.08);transition:transform .4s ease}.hero-portrait:hover .frame img{transform:rotate(0) scale(1)}.hero-portrait .accent{position:absolute;inset:20px -20px -20px 20px;z-index:1;border:1px solid var(--ink-faint);border-radius:48px;transform:rotate(-3deg);transition:transform .4s ease}.hero-portrait:hover .accent{transform:rotate(0)}.hero .kicker{font-size:.78rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:28px}.hero h1{font-family:var(--serif-display);font-weight:400;font-size:clamp(2.6rem,8vw,6rem);line-height:1.02;letter-spacing:-.025em;color:var(--ink);margin-bottom:32px;max-width:16ch}.hero h1 em{font-style:italic;color:var(--ink-soft)}.hero .lead{font-family:var(--serif-body);font-size:clamp(1.12rem,2vw,1.4rem);line-height:1.6;color:var(--ink-soft);max-width:56ch;margin-bottom:38px}.socials{display:flex;gap:clamp(16px,2.5vw,26px);flex-wrap:wrap}.socials a{font-size:.95rem;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink-faint);padding-bottom:2px;transition:opacity .2s}.socials a:hover{opacity:.55}section.block{padding-block:clamp(48px,6vw,80px);border-bottom:1px solid var(--line)}section.block:last-of-type{border-bottom:none}.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:clamp(36px,5vw,56px);flex-wrap:wrap}.sec-head h2{font-family:var(--serif-display);font-weight:400;font-size:clamp(1.8rem,4vw,2.8rem);letter-spacing:-.02em;color:var(--ink)}.sec-head .count{font-size:.85rem;color:var(--ink-faint);letter-spacing:.04em}.see-all{font-size:.85rem;color:var(--ink-soft);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:2px;transition:color .2s,border-color .2s;white-space:nowrap}.see-all:hover{color:var(--ink);border-color:var(--ink-faint)}.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:clamp(16px,2vw,24px)}.article{display:flex;gap:22px;align-items:flex-start;padding:26px;border:1px solid transparent;border-radius:14px;text-decoration:none;color:inherit;transition:background .25s,border-color .25s,transform .25s}.article:hover{background:var(--hover);transform:translateY(-2px)}.article .art-body{flex:1;min-width:0}.art-meta{font-size:.8rem;color:var(--ink-faint);letter-spacing:.02em;margin-bottom:9px}.art-body h3{font-family:var(--serif-display);font-weight:500;font-size:1.4rem;line-height:1.22;letter-spacing:-.01em;color:var(--ink);margin-bottom:9px;transition:color .2s}.art-body p{font-family:var(--serif-body);color:var(--ink-soft);font-size:1.02rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.art-tag{display:inline-block;margin-top:14px;font-size:.74rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.12em}.art-thumb{flex-shrink:0;width:96px;height:96px;border-radius:10px;background:linear-gradient(145deg,var(--hover),var(--surface));border:1px solid var(--line);display:grid;place-items:center;overflow:hidden}.art-thumb .ph{font-family:var(--serif-display);font-size:1.5rem;color:var(--ink-faint);font-style:italic}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:clamp(16px,2vw,24px)}.project{border:1px solid var(--line);border-radius:16px;background:var(--surface);overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease,border-color .3s}.project:hover{transform:translateY(-4px);box-shadow:0 20px 50px var(--shadow);border-color:var(--ink-faint)}.p-cover{width:100%;aspect-ratio:16 / 9;background:var(--hover);overflow:hidden}.p-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}.project:hover .p-cover img{transform:scale(1.04)}.p-content{padding:clamp(24px,3vw,32px);display:flex;flex-direction:column;flex:1}.project .p-top{display:flex;justify-content:space-between;align-items:baseline;gap:14px;margin-bottom:12px}.project h3{font-family:var(--serif-display);font-weight:500;font-size:clamp(1.3rem,2vw,1.55rem);letter-spacing:-.01em;color:var(--ink)}.project .year{font-size:.82rem;color:var(--ink-faint);flex-shrink:0}.project p{font-family:var(--serif-body);color:var(--ink-soft);font-size:1.05rem;line-height:1.55;margin-bottom:22px;flex:1}.stack{display:flex;flex-wrap:wrap;gap:8px}.stack span{font-size:.76rem;color:var(--ink-soft);border:1px solid var(--line);border-radius:999px;padding:5px 12px;letter-spacing:.02em}.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,52px);align-items:start}.contact-intro p{font-family:var(--serif-body);font-size:1.15rem;line-height:1.6;color:var(--ink-soft);margin-bottom:22px;max-width:36ch}.contact-intro .mail{font-family:var(--serif-display);font-size:1.25rem;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink-faint);padding-bottom:2px;transition:opacity .2s}.contact-intro .mail:hover{opacity:.6}form.contact{display:grid;gap:18px}.field{display:flex;flex-direction:column;gap:7px}.field label{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}.field input,.field textarea{font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:13px 15px;width:100%;transition:border-color .2s,box-shadow .2s}.field input::placeholder,.field textarea::placeholder{color:var(--ink-faint)}.field textarea{resize:vertical;min-height:140px;line-height:1.55}.field input:focus,.field textarea:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px color-mix(in srgb,var(--ink) 8%,transparent)}.btn-send{justify-self:start;font-family:var(--sans);font-size:.95rem;font-weight:500;background:var(--ink);color:var(--bg);border:none;border-radius:999px;padding:13px 32px;cursor:pointer;margin-top:4px;transition:opacity .2s,transform .2s}.btn-send:hover{opacity:.85;transform:translateY(-1px)}.btn-send:disabled{opacity:.5;cursor:default;transform:none}.form-status{font-size:.92rem;color:var(--ink-soft);min-height:1.2em}.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}footer{max-width:var(--wide);margin:0 auto;padding:clamp(32px,5vw,52px) var(--pad);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;color:var(--ink-faint);font-size:.85rem}footer .f-links{display:flex;gap:22px}footer a{color:var(--ink-soft);text-decoration:none}footer a:hover{color:var(--ink)}.reveal{opacity:0;transform:translateY(18px)}.reveal.in{opacity:1;transform:none;transition:opacity .7s ease,transform .7s ease}.page-hero{padding-block:clamp(48px,7vw,80px);border-bottom:1px solid var(--line);max-width:72ch}.page-hero h1{font-family:var(--serif-display);font-weight:400;font-size:clamp(2.4rem,6vw,4rem);letter-spacing:-.025em;margin-bottom:12px}.page-hero p{font-family:var(--serif-body);font-size:1.15rem;color:var(--ink-soft);max-width:52ch}#reading-progress{position:fixed;top:0;left:0;z-index:100;height:2px;width:0%;background:var(--ink);transition:width .1s linear;pointer-events:none}.article-header{padding-block:clamp(48px,7vw,80px);border-bottom:1px solid var(--line);max-width:72ch;margin-inline:auto}.article-header .art-meta{font-size:.85rem;color:var(--ink-faint);margin-bottom:20px}.article-header h1{font-family:var(--serif-display);font-weight:400;font-size:clamp(2rem,5vw,3.2rem);line-height:1.1;letter-spacing:-.025em;margin-bottom:20px}.article-header .lead{font-family:var(--serif-body);font-size:1.2rem;line-height:1.6;color:var(--ink-soft);margin-bottom:20px}.prose{max-width:72ch;padding-block:clamp(40px,6vw,72px);margin-inline:auto}.prose h2,.prose h3{font-family:var(--serif-display);font-weight:400;letter-spacing:-.02em;margin-block:2em .6em;color:var(--ink)}.prose h2{font-size:clamp(1.5rem,3vw,2rem)}.prose h3{font-size:clamp(1.2rem,2.5vw,1.5rem)}.prose p{font-family:var(--serif-body);font-size:1.15rem;line-height:1.75;margin-bottom:1.5em;color:var(--ink-soft)}.prose a{color:var(--ink)}.prose strong{color:var(--ink);font-weight:600}.prose ul,.prose ol{padding-left:1.5em;margin-bottom:1.5em}.prose li{font-family:var(--serif-body);font-size:1.15rem;line-height:1.75;color:var(--ink-soft);margin-bottom:.4em}.prose pre{border-radius:10px;padding:1.25em;overflow-x:auto;margin-bottom:1.5em;font-size:.9rem}.prose code:not(pre code){font-size:.88em;background:var(--hover);border-radius:4px;padding:2px 6px}.prose img{width:100%;border-radius:12px;margin-block:2em;border:1px solid var(--line);display:block}.prose blockquote{border-left:2px solid var(--line);padding-left:1.25em;margin-block:1.5em;color:var(--ink-faint);font-family:var(--serif-body);font-style:italic;font-size:1.15rem}.project-detail-header{padding-block:clamp(48px,7vw,80px);border-bottom:1px solid var(--line);max-width:72ch;margin-inline:auto}.project-detail-header h1{font-family:var(--serif-display);font-weight:400;font-size:clamp(2rem,5vw,3.2rem);letter-spacing:-.025em;margin-bottom:16px}.project-detail-header p{font-family:var(--serif-body);font-size:1.2rem;line-height:1.6;color:var(--ink-soft);max-width:60ch;margin-bottom:20px}.project-cover{width:100%;max-width:72ch;aspect-ratio:16 / 9;border-radius:16px;overflow:hidden;border:1px solid var(--line);margin-block:clamp(32px,5vw,56px);margin-inline:auto}.project-cover img{width:100%;height:100%;object-fit:cover;display:block}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:.88rem;color:var(--ink-soft);text-decoration:none;padding-block:clamp(24px,4vw,40px) 0;transition:color .2s}.back-link:hover{color:var(--ink)}@media (max-width: 860px){.hero{grid-template-columns:1fr;min-height:auto;gap:48px;padding-block:clamp(48px,9vw,80px)}.hero-text{order:2}.hero-portrait{order:1;max-width:300px;justify-self:start}.hero h1{font-size:clamp(2.4rem,9vw,4rem)}.contact-grid{grid-template-columns:1fr;gap:36px}}@media (max-width: 540px){.nav-inner{padding:12px var(--pad);gap:16px}.nav-links{gap:clamp(10px,2.5vw,16px);margin-left:8px}.nav-links a{font-size:.8rem}.article{padding:18px 4px;gap:16px}.art-thumb{width:72px;height:72px}.art-body h3{font-size:1.25rem}.project-grid{grid-template-columns:1fr}}
