@charset "UTF-8";
:root { --ink-100: #14110f; --ink-90:  #221d1a; --ink-70:  #3f3631; --ink-50:  #6e6259; --ink-30:  #9c8e82; --ink-15:  #c9bfb1; --bone-100: #f4efe6; --bone-95:  #ece5d8; --bone-90:  #e0d8c8; --accent:        #c1361f; --accent-soft:   #e89886; --accent-shadow: rgba(193, 54, 31, 0.18); --bg:        var(--bone-100); --bg-soft:   var(--bone-95); --bg-deep:   var(--bone-90); --fg:        var(--ink-100); --fg-muted:  var(--ink-50); --fg-faint:  var(--ink-30); --rule:      var(--ink-15); --link:      var(--accent); --font-display: "Fraunces", "Iowan Old Style", "Palatino Linotype", Georgia, serif; --font-body:    "Fraunces", "Iowan Old Style", "Palatino Linotype", Georgia, serif; --font-mono:    "DM Mono", "Berkeley Mono", "Courier New", Courier, monospace; --step--1: clamp(0.83rem, 0.80rem + 0.13vw, 0.89rem); --step-0:  clamp(1.00rem, 0.96rem + 0.20vw, 1.13rem); --step-1:  clamp(1.25rem, 1.16rem + 0.41vw, 1.50rem); --step-2:  clamp(1.56rem, 1.41rem + 0.74vw, 2.00rem); --step-3:  clamp(1.95rem, 1.69rem + 1.30vw, 2.75rem); --step-4:  clamp(2.44rem, 2.00rem + 2.20vw, 3.75rem); --step-5:  clamp(3.05rem, 2.31rem + 3.71vw, 5.25rem); --step-6:  clamp(3.81rem, 2.55rem + 6.31vw, 7.50rem); --s-1: 0.25rem; --s-2: 0.5rem; --s-3: 0.75rem; --s-4: 1rem; --s-5: 1.5rem; --s-6: 2rem; --s-7: 3rem; --s-8: 4rem; --s-9: 6rem; --s-10: 8rem; --s-11: 12rem; --measure-prose:  36rem; --measure-wide:   48rem; --measure-page:   72rem; --gutter:         clamp(1.25rem, 4vw, 3rem); --ease-out: cubic-bezier(0.2, 0.7, 0.2, 1); --ease-in-out: cubic-bezier(0.6, 0, 0.4, 1); --dur-fast: 180ms; --dur:      320ms; --dur-slow: 600ms; }

@media (prefers-color-scheme: dark) { :root { --bg:       #14110f; --bg-soft:  #1c1814; --bg-deep:  #100c0a; --fg:       #f4efe6; --fg-muted: #b0a89a; --fg-faint: #6e6259; --rule:     #2f2925; --link:     #e07358; --accent:        #e07358; --accent-soft:   #c1361f; --accent-shadow: rgba(224, 115, 88, 0.20); } }

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

html, body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd { margin: 0; }

body { min-height: 100vh; line-height: 1.6; text-rendering: optimizeLegibility; }

ul[role='list'], ol[role='list'] { list-style: none; padding: 0; margin: 0; }

a { color: inherit; text-decoration: none; }

img, picture, svg, video { max-width: 100%; display: block; }

input, button, textarea, select { font: inherit; color: inherit; }

@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; } }

::selection { background: var(--accent); color: var(--bone-100); }

body { font-family: var(--font-body); font-size: var(--step-0); font-weight: 400; font-optical-sizing: auto; font-variation-settings: "opsz" 14, "SOFT" 30; color: var(--fg); background: var(--bg); }

h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.01em; line-height: 1.05; color: var(--fg); }

h1 { font-size: var(--step-5); font-weight: 400; font-variation-settings: "opsz" 144, "SOFT" 100; letter-spacing: -0.025em; line-height: 0.95; }

h2 { font-size: var(--step-4); font-weight: 400; font-variation-settings: "opsz" 96, "SOFT" 80; letter-spacing: -0.02em; line-height: 1.0; }

h3 { font-size: var(--step-2); font-weight: 500; font-variation-settings: "opsz" 36, "SOFT" 50; letter-spacing: -0.01em; }

h4 { font-size: var(--step-1); font-weight: 600; font-variation-settings: "opsz" 24, "SOFT" 40; }

p { max-width: var(--measure-prose); margin-block: 0; }

p + p { margin-top: var(--s-4); }

em, i { font-style: italic; }

strong, b { font-weight: 700; }

em, i { font-variation-settings: "opsz" 24, "SOFT" 60; }

a { color: var(--link); text-decoration: none; background-image: linear-gradient(currentColor, currentColor); background-position: 0 100%; background-repeat: no-repeat; background-size: 0% 1px; transition: background-size var(--dur) var(--ease-out); padding-bottom: 0.05em; }

a:hover, a:focus-visible { background-size: 100% 1px; }

.kicker { font-family: var(--font-mono); font-size: var(--step--1); font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em; color: var(--fg-muted); display: inline-flex; align-items: center; gap: var(--s-3); }

.kicker::before { content: ""; display: inline-block; width: 1.5rem; height: 1px; background: var(--accent); }

.mono { font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: 0.02em; }

.lead { font-size: var(--step-1); line-height: 1.5; color: var(--fg-muted); font-variation-settings: "opsz" 24, "SOFT" 50; max-width: var(--measure-wide); }

.dropcap::first-letter { font-family: var(--font-display); font-size: 4.2em; font-weight: 400; font-variation-settings: "opsz" 144, "SOFT" 100; float: left; line-height: 0.85; margin: 0.05em 0.08em -0.05em 0; color: var(--accent); }

code, pre, kbd, samp { font-family: var(--font-mono); font-size: 0.92em; }

code { background: var(--bg-soft); padding: 0.1em 0.35em; border-radius: 2px; }

pre { background: var(--bg-soft); padding: var(--s-5); overflow-x: auto; border-left: 2px solid var(--accent); }

pre code { background: transparent; padding: 0; }

blockquote { margin: var(--s-6) 0; padding-left: var(--s-5); border-left: 1px solid var(--rule); font-style: italic; color: var(--fg-muted); font-variation-settings: "opsz" 36, "SOFT" 70; }

hr { border: 0; border-top: 1px solid var(--rule); margin: var(--s-8) 0; }

.rule { border: 0; height: 1px; background: var(--rule); margin: var(--s-7) 0; }

.rule--accent { background: var(--accent); width: 3rem; margin: var(--s-5) 0; }

.page { display: grid; grid-template-rows: auto 1fr auto; min-height: 100vh; background: var(--bg); }

.wrap { width: 100%; max-width: var(--measure-page); margin-inline: auto; padding-inline: var(--gutter); }

.wrap--prose { max-width: var(--measure-prose); }

.wrap--wide { max-width: var(--measure-wide); }

.wrap--media { max-width: 56rem; }

main { display: block; }

section { position: relative; }

.section-pad { padding-block: clamp(var(--s-7), 10vw, var(--s-10)); }

.section-pad-tight { padding-block: clamp(var(--s-5), 6vw, var(--s-7)); }

body::before { content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 1000; opacity: 0.035; mix-blend-mode: multiply; background-image: radial-gradient(rgba(20, 17, 15, 0.5) 1px, transparent 1px), radial-gradient(rgba(20, 17, 15, 0.4) 1px, transparent 1px); background-size: 3px 3px, 7px 7px; background-position: 0 0, 1px 1px; }

@media (prefers-color-scheme: dark) { body::before { opacity: 0.06; mix-blend-mode: screen; background-image: radial-gradient(rgba(244, 239, 230, 0.4) 1px, transparent 1px), radial-gradient(rgba(244, 239, 230, 0.3) 1px, transparent 1px); } }

.site-header { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(12px) saturate(140%); -webkit-backdrop-filter: blur(12px) saturate(140%); background: color-mix(in oklab, var(--bg) 78%, transparent); border-bottom: 1px solid var(--rule); transition: background var(--dur) var(--ease-out); }

.site-header__inner { display: flex; align-items: baseline; justify-content: space-between; gap: var(--s-5); padding-block: var(--s-4); }

.brand { font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg); font-weight: 500; display: inline-flex; align-items: center; gap: var(--s-2); }

.brand::before { content: ""; width: 8px; height: 8px; background: var(--accent); border-radius: 1px; transform: rotate(45deg); transition: transform var(--dur) var(--ease-out); }

.brand:hover::before { transform: rotate(225deg); }

.nav { display: flex; gap: clamp(var(--s-4), 2vw, var(--s-6)); align-items: baseline; }

.nav a { font-family: var(--font-mono); font-size: var(--step--1); text-transform: uppercase; letter-spacing: 0.14em; color: var(--fg-muted); position: relative; padding-block: var(--s-2); transition: color var(--dur) var(--ease-out); background: none; background-image: none; }

.nav a::after { content: ""; position: absolute; inset-inline: 0; bottom: 0; height: 1px; background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform var(--dur) var(--ease-out); }

.nav a:hover, .nav a:focus-visible { color: var(--fg); }

.nav a:hover::after, .nav a:focus-visible::after, .nav a.is-active::after { transform: scaleX(1); }

.nav a.is-active { color: var(--fg); }

.nav-toggle { display: none; align-items: center; gap: var(--s-3); padding: var(--s-2) 0; background: none; border: 0; color: var(--fg-muted); font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: 0.14em; text-transform: uppercase; cursor: pointer; transition: color var(--dur) var(--ease-out); }

.nav-toggle:hover, .nav-toggle:focus-visible { color: var(--fg); }

.nav-toggle__mark { width: 8px; height: 8px; background: var(--accent); border-radius: 1px; transform: rotate(45deg); transition: transform var(--dur) var(--ease-out); }

.nav-toggle[aria-expanded="true"] { color: var(--fg); }

.nav-toggle[aria-expanded="true"] .nav-toggle__mark { transform: rotate(225deg); }

@media (max-width: 720px) { .site-header__inner { flex-wrap: wrap; } .nav-toggle { display: inline-flex; } .nav { flex-basis: 100%; flex-direction: column; align-items: flex-start; gap: 0; overflow: hidden; max-height: 0; opacity: 0; visibility: hidden; transition: max-height var(--dur) var(--ease-out), opacity var(--dur) var(--ease-out), visibility 0s linear var(--dur), margin-top 0s linear var(--dur); } .nav.is-open { max-height: 70vh; opacity: 1; visibility: visible; margin-top: var(--s-3); transition: max-height var(--dur) var(--ease-out), opacity var(--dur) var(--ease-out), visibility 0s linear 0s, margin-top 0s linear 0s; } .nav a { width: 100%; padding-block: var(--s-3); border-bottom: 1px dashed var(--rule); font-size: var(--step-0); letter-spacing: 0.18em; opacity: 0; transform: translateY(-4px); } .nav a:last-child { border-bottom: 0; } .nav a::after { inset-inline: 0 auto; width: var(--s-5); } .nav.is-open a { animation: nav-item-in var(--dur) var(--ease-out) forwards; } .nav.is-open a:nth-child(1) { animation-delay: 60ms; } .nav.is-open a:nth-child(2) { animation-delay: 120ms; } .nav.is-open a:nth-child(3) { animation-delay: 180ms; } .nav.is-open a:nth-child(4) { animation-delay: 240ms; } .nav.is-open a:nth-child(5) { animation-delay: 300ms; } .nav.is-open a:nth-child(6) { animation-delay: 360ms; } .nav.is-open a:nth-child(7) { animation-delay: 420ms; } .nav.is-open a:nth-child(8) { animation-delay: 480ms; } .brand { letter-spacing: 0.12em; } }

@keyframes nav-item-in { to { opacity: 1;
    transform: translateY(0); } }

@media (prefers-reduced-motion: reduce) { .nav, .nav.is-open, .nav a, .nav.is-open a { transition: none; animation: none; } .nav.is-open a { opacity: 1; transform: none; } }

.page-head { padding-block: clamp(var(--s-7), 10vw, var(--s-9)) clamp(var(--s-5), 4vw, var(--s-6)); position: relative; }

.page-head__kicker { display: block; margin-bottom: var(--s-4); }

.page-head__title { font-size: var(--step-5); line-height: 0.9; font-variation-settings: "opsz" 144, "SOFT" 100; letter-spacing: -0.025em; font-weight: 400; }

.page-head__title em { font-style: italic; color: var(--accent); }

.page-head__lead { margin-top: var(--s-5); }

.site-footer { border-top: 1px solid var(--rule); padding-block: var(--s-7) var(--s-5); margin-top: var(--s-9); }

.footer-grid { display: grid; grid-template-columns: 1fr auto; gap: var(--s-5); align-items: end; }

@media (max-width: 600px) { .footer-grid { grid-template-columns: 1fr; } }

.footer-mark { font-family: var(--font-display); font-size: var(--step-3); font-weight: 400; font-variation-settings: "opsz" 96, "SOFT" 100; letter-spacing: -0.02em; line-height: 0.9; }

.footer-meta { font-family: var(--font-mono); font-size: var(--step--1); color: var(--fg-muted); letter-spacing: 0.04em; margin-top: var(--s-3); }

.socials { display: flex; gap: var(--s-4); align-items: center; }

.socials a { display: inline-flex; width: 2rem; height: 2rem; align-items: center; justify-content: center; color: var(--fg-muted); transition: color var(--dur) var(--ease-out), transform var(--dur) var(--ease-out); background: none; background-image: none; }

.socials a svg { width: 1.05rem; height: 1.05rem; fill: currentColor; }

.socials a:hover { color: var(--accent); transform: translateY(-2px); }

.index { display: flex; flex-direction: column; border-top: 1px solid var(--rule); }

.index__row { display: grid; grid-template-columns: 4rem 1fr auto; gap: var(--s-5); align-items: baseline; padding-block: clamp(var(--s-5), 3vw, var(--s-6)); border-bottom: 1px solid var(--rule); position: relative; text-decoration: none; background: none; background-image: none; transition: padding-inline var(--dur) var(--ease-out), color var(--dur) var(--ease-out); }

.index__row::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%) scaleX(0); transform-origin: left; width: 0.5rem; height: 1px; background: var(--accent); transition: transform var(--dur) var(--ease-out); }

.index__row:hover, .index__row:focus-visible { padding-inline-start: var(--s-3); }

.index__row:hover::before, .index__row:focus-visible::before { transform: translateY(-50%) scaleX(1); }

.index__row:hover .index__title, .index__row:focus-visible .index__title { color: var(--accent); }

.index__row:hover .index__arrow, .index__row:focus-visible .index__arrow { transform: translateX(4px); color: var(--accent); }

.index__num { font-family: var(--font-mono); font-size: var(--step--1); color: var(--fg-faint); letter-spacing: 0.05em; font-feature-settings: "tnum"; }

.index__body { display: flex; flex-direction: column; gap: var(--s-2); min-width: 0; }

.index__title { font-family: var(--font-display); font-size: var(--step-3); font-weight: 400; font-variation-settings: "opsz" 72, "SOFT" 80; letter-spacing: -0.02em; line-height: 1; transition: color var(--dur) var(--ease-out); }

.index__desc { color: var(--fg-muted); max-width: 42rem; font-size: var(--step-0); margin: 0; }

.index__arrow { font-family: var(--font-mono); font-size: var(--step-1); color: var(--fg-faint); transition: transform var(--dur) var(--ease-out), color var(--dur) var(--ease-out); }

@media (max-width: 600px) { .index__row { grid-template-columns: 3rem 1fr auto; gap: var(--s-3); } .index__title { font-size: var(--step-2); } }

.video-embed { position: relative; aspect-ratio: 16 / 9; margin-block: clamp(var(--s-6), 5vw, var(--s-7)); background: var(--bg-deep); overflow: hidden; isolation: isolate; box-shadow: 0 1px 0 var(--rule), 0 30px 60px -25px color-mix(in oklab, var(--ink) 35%, transparent); }

.video-embed::after { content: ""; position: absolute; top: -1px; right: -1px; width: 2.25rem; height: 2.25rem; border-top: 1px solid var(--accent); border-right: 1px solid var(--accent); pointer-events: none; z-index: 2; }

.video-embed iframe, .video-embed video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

.video-embed--local video { background: #000; object-fit: contain; }

.entries { display: flex; flex-direction: column; border-top: 1px solid var(--rule); }

.entry { display: grid; grid-template-columns: max-content 1fr; gap: var(--s-5); padding-block: var(--s-5); border-bottom: 1px solid var(--rule); background: none; background-image: none; transition: background var(--dur) var(--ease-out); }

.entry:hover { background: var(--bg-soft); }

.entry:hover .entry__title { color: var(--accent); }

.entry__date { font-family: var(--font-mono); font-size: var(--step--1); color: var(--fg-faint); letter-spacing: 0.04em; padding-top: 0.45rem; font-feature-settings: "tnum"; white-space: nowrap; }

.entry__title { font-family: var(--font-display); font-size: var(--step-2); font-weight: 400; font-variation-settings: "opsz" 36, "SOFT" 60; letter-spacing: -0.015em; line-height: 1.1; margin: 0; transition: color var(--dur) var(--ease-out); }

.entry__meta { margin-top: var(--s-2); font-size: var(--step--1); color: var(--fg-muted); }

@media (max-width: 600px) { .entry { grid-template-columns: 1fr; gap: var(--s-2); } .entry__date { padding-top: 0; } .entry__title { font-size: var(--step-1); } }

.work-list { display: grid; gap: var(--s-7); }

.work-card { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); gap: clamp(var(--s-5), 4vw, var(--s-7)); align-items: start; padding-block: var(--s-6); border-top: 1px solid var(--rule); }

.work-card:nth-child(even) { grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr); }

.work-card:nth-child(even) .work-card__media { order: 2; }

.work-card:nth-child(even) .work-card__body { order: 1; }

.work-card__body { display: flex; flex-direction: column; gap: var(--s-3); }

.work-card__title { font-family: var(--font-display); font-size: var(--step-3); font-weight: 400; font-variation-settings: "opsz" 72, "SOFT" 80; letter-spacing: -0.02em; line-height: 1; }

.work-card__meta { font-family: var(--font-mono); font-size: var(--step--1); color: var(--fg-faint); letter-spacing: 0.05em; display: flex; flex-wrap: wrap; gap: var(--s-3); }

.work-card__meta a { color: var(--fg-muted); text-transform: uppercase; background: none; background-image: none; border-bottom: 1px solid var(--rule); padding-bottom: 1px; transition: color var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out); }

.work-card__meta a:hover { color: var(--accent); border-color: var(--accent); }

.work-card__meta span + span::before { content: "·"; margin-right: var(--s-3); color: var(--fg-faint); }

.work-card__desc { color: var(--fg-muted); font-size: var(--step-0); max-width: 38rem; }

.work-card__media { position: relative; overflow: hidden; background: var(--bg-soft); aspect-ratio: 4 / 3; }

.work-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }

.work-card__media:hover img { transform: scale(1.03); }

@media (max-width: 700px) { .work-card, .work-card:nth-child(even) { grid-template-columns: 1fr; } .work-card .work-card__media, .work-card:nth-child(even) .work-card__media { order: 0; } .work-card .work-card__body, .work-card:nth-child(even) .work-card__body { order: 1; } }

.photo-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(var(--s-4), 3vw, var(--s-6)) clamp(var(--s-4), 2vw, var(--s-5)); }

.photo { display: flex; flex-direction: column; gap: var(--s-3); position: relative; }

.photo:nth-child(6n + 1) { grid-column: span 7; }

.photo:nth-child(6n + 2) { grid-column: span 5; padding-top: var(--s-7); }

.photo:nth-child(6n + 3) { grid-column: span 5; }

.photo:nth-child(6n + 4) { grid-column: span 7; padding-top: var(--s-6); }

.photo:nth-child(6n + 5) { grid-column: span 6; }

.photo:nth-child(6n) { grid-column: span 6; padding-top: var(--s-5); }

.photo__frame { appearance: none; border: 0; padding: 0; margin: 0; width: 100%; display: block; cursor: zoom-in; overflow: hidden; background: var(--bg-soft); position: relative; aspect-ratio: 3 / 2; }

.photo__frame:focus-visible { outline: 2px solid var(--accent); outline-offset: 4px; }

.photo--portrait .photo__frame { aspect-ratio: 4 / 5; }

.photo__frame img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out), filter var(--dur) var(--ease-out); user-select: none; -webkit-user-select: none; -webkit-user-drag: none; -webkit-touch-callout: none; pointer-events: none; }

.photo__frame::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 0 0 1px rgba(20, 17, 15, 0.06); pointer-events: none; }

.photo__frame:hover img { transform: scale(1.02); }

.photo__caption { display: flex; flex-direction: column; gap: var(--s-2); padding-top: var(--s-3); }

.photo__title { font-family: var(--font-display); font-size: var(--step-1); font-weight: 400; font-variation-settings: "opsz" 36, "SOFT" 60; line-height: 1.1; letter-spacing: -0.01em; margin: 0; position: relative; }

.photo__title::before { content: ""; display: block; width: 1.25rem; height: 1px; background: var(--accent); margin-bottom: var(--s-3); transition: width var(--dur) var(--ease-out); }

.photo:hover .photo__title::before, .photo:focus-within .photo__title::before { width: 2.75rem; }

.photo__meta { font-family: var(--font-mono); font-size: var(--step--1); color: var(--fg-muted); letter-spacing: 0.08em; text-transform: uppercase; margin: 0; }

.photo__desc { color: var(--fg-muted); font-size: var(--step-0); line-height: 1.55; margin: var(--s-2) 0 0; max-width: 34rem; }

@media (max-width: 720px) { .photo-grid { grid-template-columns: 1fr; } .photo, .photo:nth-child(6n + 1), .photo:nth-child(6n + 2), .photo:nth-child(6n + 3), .photo:nth-child(6n + 4), .photo:nth-child(6n + 5), .photo:nth-child(6n) { grid-column: 1 / -1; padding-top: 0; } }

.now-list { display: flex; flex-direction: column; gap: var(--s-3); padding: 0; margin: var(--s-6) 0; list-style: none; border-top: 1px solid var(--rule); }

.now-list li { display: grid; grid-template-columns: 12rem 1fr; gap: var(--s-4); padding-block: var(--s-4); border-bottom: 1px solid var(--rule); align-items: baseline; }

.now-list .action { font-family: var(--font-mono); font-size: var(--step--1); text-transform: uppercase; letter-spacing: 0.12em; color: var(--fg-faint); }

@media (max-width: 600px) { .now-list li { grid-template-columns: 1fr; gap: var(--s-1); } }

.signature { margin-top: var(--s-7); font-family: var(--font-display); font-style: italic; font-size: var(--step-1); color: var(--fg-muted); font-variation-settings: "opsz" 36, "SOFT" 80; }

.masthead { position: relative; min-height: clamp(640px, 88vh, 920px); display: flex; flex-direction: column; justify-content: center; padding-top: clamp(var(--s-7), 10vw, var(--s-9)); padding-bottom: clamp(var(--s-7), 8vw, var(--s-9)); overflow: hidden; isolation: isolate; }

.masthead::before { content: ""; position: absolute; inset: 0; z-index: -1; background: radial-gradient(ellipse 80% 50% at 12% 0%, var(--accent-shadow) 0%, transparent 60%), radial-gradient(ellipse 60% 40% at 100% 100%, color-mix(in oklab, var(--accent) 18%, transparent) 0%, transparent 70%), linear-gradient(180deg, var(--bg) 0%, var(--bg-deep) 100%); }

.masthead::after { content: ""; position: absolute; top: var(--s-7); right: var(--gutter); width: 6rem; height: 6rem; border-top: 1px solid var(--accent); border-right: 1px solid var(--accent); opacity: 0.7; z-index: -1; }

.masthead__inner { display: flex; flex-direction: column; justify-content: center; gap: var(--s-6); width: 100%; max-width: var(--measure-page); margin-inline: auto; padding-inline: var(--gutter); }

.masthead__kicker { display: inline-flex; align-self: flex-start; opacity: 0; animation: fade-up var(--dur-slow) var(--ease-out) forwards; animation-delay: 80ms; }

.masthead__name { font-family: var(--font-display); font-size: var(--step-6); font-weight: 400; font-variation-settings: "opsz" 144, "SOFT" 100; letter-spacing: -0.04em; line-height: 0.86; margin: 0; max-width: 14ch; opacity: 0; animation: fade-up var(--dur-slow) var(--ease-out) forwards; animation-delay: 200ms; }

.masthead__name em { font-style: italic; color: var(--accent); font-variation-settings: "opsz" 144, "SOFT" 100; }

.masthead__tag { font-size: var(--step-1); line-height: 1.4; color: var(--fg-muted); max-width: 36rem; font-variation-settings: "opsz" 24, "SOFT" 50; opacity: 0; animation: fade-up var(--dur-slow) var(--ease-out) forwards; animation-delay: 360ms; }

.masthead__strip { margin-top: var(--s-6); border-top: 1px solid var(--rule); padding-top: var(--s-5); display: grid; grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr)); gap: var(--s-5); opacity: 0; animation: fade-up var(--dur-slow) var(--ease-out) forwards; animation-delay: 540ms; }

.strip__item { display: flex; flex-direction: column; gap: var(--s-2); }

.strip__label { font-family: var(--font-mono); font-size: var(--step--1); text-transform: uppercase; letter-spacing: 0.16em; color: var(--fg-faint); }

.strip__value { font-family: var(--font-display); font-size: var(--step-1); font-variation-settings: "opsz" 24, "SOFT" 60; line-height: 1.15; color: var(--fg); }

.strip__value a { color: inherit; background-image: linear-gradient(var(--accent), var(--accent)); background-position: 0 100%; background-repeat: no-repeat; background-size: 0% 1px; transition: background-size var(--dur) var(--ease-out); }

.strip__value a:hover { background-size: 100% 1px; }

.masthead__scroll { position: absolute; bottom: var(--s-5); left: 50%; transform: translateX(-50%); font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-faint); opacity: 0; animation: fade-up var(--dur-slow) var(--ease-out) forwards, blink 2.4s var(--ease-in-out) infinite; animation-delay: 800ms; }

@keyframes fade-up { from { opacity: 0;
    transform: translateY(14px); }
  to { opacity: 1;
    transform: translateY(0); } }

@keyframes blink { 0%, 100% { opacity: 0.6; }
  50% { opacity: 0.95; } }

.about { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr); gap: clamp(var(--s-6), 6vw, var(--s-8)); align-items: start; }

.about__portrait { position: relative; aspect-ratio: 4 / 5; overflow: hidden; }

.about__portrait img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.15) contrast(1.02); }

.about__portrait::before { content: ""; position: absolute; bottom: -0.5rem; left: -0.5rem; width: 3rem; height: 3rem; border-bottom: 2px solid var(--accent); border-left: 2px solid var(--accent); }

.about__body { display: flex; flex-direction: column; gap: var(--s-4); }

.about__title { font-size: var(--step-4); font-weight: 400; font-variation-settings: "opsz" 96, "SOFT" 80; letter-spacing: -0.02em; line-height: 0.95; margin: 0 0 var(--s-2); }

.about__title em { font-style: italic; color: var(--accent); }

@media (max-width: 760px) { .about { grid-template-columns: 1fr; } .about__portrait { max-width: 22rem; aspect-ratio: 1 / 1; } }

.section-head { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: var(--s-5); align-items: end; margin-bottom: var(--s-6); }

@media (max-width: 700px) { .section-head { grid-template-columns: 1fr; } }

.section-head__title { font-size: var(--step-4); font-variation-settings: "opsz" 96, "SOFT" 80; letter-spacing: -0.02em; line-height: 0.95; }

.section-head__title em { font-style: italic; color: var(--accent); }

.section-head__lead { color: var(--fg-muted); max-width: 32rem; justify-self: end; text-align: right; }

@media (max-width: 700px) { .section-head__lead { justify-self: start; text-align: left; } }

.post-head { padding-block: clamp(var(--s-7), 9vw, var(--s-9)) var(--s-5); border-bottom: 1px solid var(--rule); margin-bottom: var(--s-7); }

.post-head__date { font-family: var(--font-mono); font-size: var(--step--1); text-transform: uppercase; letter-spacing: 0.14em; color: var(--fg-faint); margin-bottom: var(--s-3); }

.post-head__title { font-size: var(--step-5); font-variation-settings: "opsz" 144, "SOFT" 100; letter-spacing: -0.025em; line-height: 0.95; font-weight: 400; max-width: 22ch; }

.post-head__meta { margin-top: var(--s-4); font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: 0.04em; color: var(--fg-muted); }

.post-head__meta a { color: inherit; background-image: linear-gradient(var(--accent), var(--accent)); background-position: 0 100%; background-repeat: no-repeat; background-size: 0% 1px; transition: background-size var(--dur) var(--ease-out), color var(--dur) var(--ease-out); }

.post-head__meta a:hover { background-size: 100% 1px; color: var(--fg); }

.post-head__sep { color: var(--fg-faint); margin-inline: 0.25em; }

.prose { font-size: var(--step-0); line-height: 1.7; color: var(--fg); }

.prose > * + * { margin-top: var(--s-4); }

.prose > h2 { margin-top: var(--s-7); font-size: var(--step-3); }

.prose > h3 { margin-top: var(--s-6); font-size: var(--step-2); }

.prose > p { max-width: var(--measure-prose); }

.prose > ul, .prose > ol { padding-left: var(--s-5); max-width: var(--measure-prose); }

.prose > ul li, .prose > ol li { margin-top: var(--s-2); }

.prose > img, .prose > figure { margin-top: var(--s-6); }

.prose > hr { margin: var(--s-7) 0; }

.lightbox { position: fixed; inset: 0; width: 100vw; height: 100dvh; max-width: none; max-height: none; margin: 0; padding: 0; border: 0; background: transparent; color: #f4efe6; overflow: hidden; }

.lightbox[open] { display: grid; grid-template-rows: auto 1fr auto; }

.lightbox::backdrop { background: rgba(20, 17, 15, 0.94); backdrop-filter: blur(10px); }

.lightbox__topbar { display: flex; justify-content: flex-end; align-items: center; padding: var(--s-5) var(--s-6); z-index: 2; }

.lightbox__close { appearance: none; background: transparent; border: 1px solid rgba(255, 255, 255, 0.18); color: rgba(255, 255, 255, 0.85); font-family: var(--font-mono); font-size: var(--step-0); line-height: 1; width: 2.4rem; height: 2.4rem; border-radius: 50%; cursor: pointer; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }

.lightbox__close:hover, .lightbox__close:focus-visible { background: rgba(255, 255, 255, 0.08); border-color: rgba(255, 255, 255, 0.4); color: #fff; outline: none; }

.lightbox__stage { display: flex; align-items: center; justify-content: center; min-height: 0; padding: 0 var(--s-6); position: relative; }

.lightbox__image { max-width: 100%; max-height: 100%; object-fit: contain; box-shadow: 0 30px 80px -20px rgba(0, 0, 0, 0.6); animation: lightbox-rise var(--dur) var(--ease-out); user-select: none; -webkit-user-select: none; -webkit-user-drag: none; -webkit-touch-callout: none; }

@keyframes lightbox-rise { from { opacity: 0;
    transform: translateY(8px) scale(0.985); }
  to { opacity: 1;
    transform: translateY(0) scale(1); } }

.lightbox__nav { appearance: none; background: transparent; border: 0; color: rgba(255, 255, 255, 0.35); font-family: var(--font-mono); font-size: var(--step-3); cursor: pointer; position: absolute; top: 0; bottom: 0; width: 22%; max-width: 9rem; display: flex; align-items: center; transition: color var(--dur-fast) var(--ease-out); }

.lightbox__nav--prev { left: 0; padding-left: var(--s-6); justify-content: flex-start; }

.lightbox__nav--next { right: 0; padding-right: var(--s-6); justify-content: flex-end; }

.lightbox__nav:hover, .lightbox__nav:focus-visible { color: #fff; outline: none; }

.lightbox__caption { padding: var(--s-5) var(--s-7) var(--s-6); display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr); gap: var(--s-4) var(--s-6); align-items: baseline; border-top: 1px solid rgba(255, 255, 255, 0.06); animation: fade-up var(--dur) var(--ease-out) both; animation-delay: 80ms; }

.lightbox__title { font-family: var(--font-display); font-size: var(--step-2); font-weight: 400; font-variation-settings: "opsz" 36, "SOFT" 60; line-height: 1.05; letter-spacing: -0.01em; margin: 0; color: #fff; }

.lightbox__title::before { content: ""; display: block; width: 2rem; height: 1px; background: var(--accent); margin-bottom: var(--s-3); }

.lightbox__meta { font-family: var(--font-mono); font-size: var(--step--1); letter-spacing: 0.06em; text-transform: uppercase; color: rgba(255, 255, 255, 0.55); margin: var(--s-2) 0 0; grid-column: 1; }

.lightbox__desc { grid-column: 2; grid-row: 1 / span 2; color: rgba(255, 255, 255, 0.78); font-size: var(--step-0); margin: 0; max-width: 36rem; }

@media (max-width: 720px) { .lightbox__topbar { padding: var(--s-3) var(--s-4); } .lightbox__stage { padding: 0 var(--s-3); } .lightbox__nav { width: 18%; font-size: var(--step-2); } .lightbox__caption { grid-template-columns: 1fr; gap: var(--s-2); padding: var(--s-4); } .lightbox__desc { grid-column: 1; grid-row: auto; } }

@media (prefers-reduced-motion: reduce) { .lightbox__image, .lightbox__caption { animation: none; } }
