@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600&family=IBM+Plex+Mono:wght@300;400;500;600&family=Courier+Prime:wght@400;700&family=Fira+Code:wght@300;400;500&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap');

:root {
  --bg: #f3ead6;
  --paper: #f6efe1;
  --ink: #1a2734;
  --deep: #163a5f;
  --mid: #3577a8;
  --shallow: #79b3d6;
  --foam: #ffffff;
  --mono: 'JetBrains Mono', 'IBM Plex Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--bg, #f3ead6); color: var(--ink, #1a2734); font-family: 'Cormorant Garamond', Georgia, serif; font-size: 18px; line-height: 1.55; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; overflow-x: hidden; }
::selection { background: var(--mid); color: var(--bg); }
.page { position: relative; min-height: 100vh; }
.waves { position: fixed; inset: 0; width: 100vw; height: 100vh; z-index: 0; pointer-events: none; }
.paper-grain { position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: 0.35; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0.1  0 0 0 0 0.1  0 0 0 0 0.1  0 0 0 0.18 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.5'/></svg>"); mix-blend-mode: multiply; }
.page > header, .page > section, .page > footer { position: relative; z-index: 2; }
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 10; padding: 18px 0; pointer-events: none; }
.nav-inner { max-width: 1320px; margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 24px; pointer-events: none; }
.nav-inner > * { pointer-events: auto; }
.nav-mark { display: inline-flex; align-items: baseline; gap: 8px; text-decoration: none; color: var(--ink); font-family: var(--mono); font-size: 13px; padding: 6px 10px; margin-left: -10px; }
.mark-glyph { font-size: 18px; color: var(--deep); }
.mark-text { font-weight: 500; }
.nav-links { justify-self: center; display: flex; gap: 28px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.nav-links a { color: var(--ink); text-decoration: none; padding: 6px 0; position: relative; opacity: 0.65; transition: opacity .2s; }
.nav-links a:hover { opacity: 1; }
.nav-links a::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 1px; background: var(--ink); transform: scaleX(0); transform-origin: left; transition: transform .25s ease; }
.nav-links a:hover::after { transform: scaleX(1); }
.nav-meta { justify-self: end; display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 11px; color: var(--ink); opacity: 0.5; font-variant-numeric: tabular-nums; }
.nav-meta .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--deep); animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 0.4; } 50% { opacity: 1; } }
.hero { min-height: 100vh; display: grid; place-items: center; padding: 120px 32px 80px; }
.hero-inner { width: 100%; max-width: 1200px; display: grid; grid-template-rows: auto auto auto 1fr auto; gap: 32px; min-height: calc(100vh - 200px); }
.hero-meta { display: inline-flex; align-items: center; gap: 14px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink); opacity: 0.6; }
.hero-meta .rule { display: inline-block; width: 56px; height: 1px; background: var(--ink); opacity: 0.5; }
.hero-name { margin: 0; font-family: 'Cormorant Garamond', serif; font-weight: 500; font-size: clamp(72px, 14vw, 220px); line-height: 0.92; letter-spacing: -0.02em; color: var(--ink); display: grid; }
.hn-l1 { font-style: italic; font-weight: 400; }
.hn-l2 { padding-left: 0.18em; font-weight: 600; }
.hero-tagline { font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 400; font-size: clamp(24px, 2.6vw, 36px); color: var(--ink); opacity: 0.78; padding-left: 0.18em; margin-top: -8px; }
.hero-intro { max-width: 560px; font-size: clamp(18px, 1.4vw, 22px); line-height: 1.5; color: var(--ink); align-self: end; }
.hero-intro p { margin: 0 0 12px; }
.hero-intro p:first-child::first-letter { font-size: 1.6em; font-weight: 600; color: var(--deep); float: left; line-height: 0.9; padding: 4px 8px 0 0; }
.hero-bottom { display: flex; justify-content: space-between; align-items: end; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink); opacity: 0.55; padding-top: 24px; border-top: 1px solid currentColor; border-image: linear-gradient(to right, currentColor 0%, currentColor 30%, transparent 30%) 1; }
.hb-tag { animation: float 3.5s ease-in-out infinite; }
@keyframes float { 0%,100% { transform: translateY(0); opacity: 0.55; } 50% { transform: translateY(3px); opacity: 0.9; } }
.section { padding: 140px 32px; position: relative; }
.section-inner { max-width: 1200px; margin: 0 auto; padding: 40px 0; position: relative; }
.sec-head { display: grid; grid-template-columns: 80px 1fr; gap: 32px; align-items: baseline; margin-bottom: 64px; padding-bottom: 28px; border-bottom: 1px solid color-mix(in oklab, var(--ink) 15%, transparent); }
.sec-index { font-family: var(--mono); font-size: 13px; letter-spacing: 0.1em; color: var(--deep); font-weight: 500; }
.sec-kicker { font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink); opacity: 0.55; margin-bottom: 10px; }
.sec-title { margin: 0; font-family: 'Cormorant Garamond', serif; font-weight: 500; font-style: italic; font-size: clamp(48px, 6vw, 88px); line-height: 1; letter-spacing: -0.01em; color: var(--ink); }
.about-body { max-width: 680px; display: grid; gap: 22px; font-size: clamp(19px, 1.5vw, 24px); line-height: 1.55; color: var(--ink); }
.about-body p { margin: 0; }
.about-body p:first-child::first-letter { font-family: 'Cormorant Garamond', serif; font-size: 3.4em; font-weight: 600; color: var(--deep); float: left; line-height: 0.85; padding: 6px 12px 0 0; }
.now-list { margin: 0; padding: 0; max-width: 800px; display: grid; gap: 0; }
.now-row { display: grid; grid-template-columns: 140px 1fr; align-items: baseline; gap: 32px; padding: 22px 0; border-bottom: 1px dashed color-mix(in oklab, var(--ink) 18%, transparent); }
.now-row dt { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink); opacity: 0.55; margin: 0; }
.now-row dd { margin: 0; font-size: clamp(20px, 2vw, 26px); font-style: italic; color: var(--ink); line-height: 1.35; }
.now-foot { margin-top: 40px; max-width: 600px; font-family: var(--mono); font-size: 12px; color: var(--ink); opacity: 0.55; }
.proj-list { list-style: none; margin: 0; padding: 0; }
.proj { border-top: 1px solid color-mix(in oklab, var(--ink) 18%, transparent); }
.proj:last-child { border-bottom: 1px solid color-mix(in oklab, var(--ink) 18%, transparent); }
.proj-link { display: grid; grid-template-columns: 80px 1fr 180px 24px; gap: 32px; align-items: baseline; padding: 28px 8px; text-decoration: none; color: var(--ink); transition: padding .3s ease, background .3s ease; }
.proj-link:hover { padding-left: 24px; background: color-mix(in oklab, var(--shallow) 12%, transparent); }
.proj-year { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--deep); font-weight: 500; font-variant-numeric: tabular-nums; }
.proj-body { display: grid; gap: 8px; }
.proj-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 3vw, 42px); line-height: 1.05; font-weight: 500; }
.proj-blurb { font-size: 17px; line-height: 1.5; color: var(--ink); opacity: 0.75; max-width: 520px; }
.proj-kind { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink); opacity: 0.55; text-align: right; }
.proj-arrow { font-family: var(--mono); font-size: 18px; color: var(--deep); transform: translate(-6px, 0); opacity: 0; text-align: right; transition: transform .3s ease; }
.proj-link:hover .proj-arrow { transform: translate(0, -3px); opacity: 1; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.contact-blurb { font-family: 'Cormorant Garamond', serif; font-size: clamp(22px, 2.2vw, 32px); line-height: 1.4; font-style: italic; font-weight: 400; color: var(--ink); max-width: 460px; }
.contact-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0; }
.contact-list li { border-top: 1px solid color-mix(in oklab, var(--ink) 18%, transparent); }
.contact-list li:last-child { border-bottom: 1px solid color-mix(in oklab, var(--ink) 18%, transparent); }
.contact-list a { display: grid; grid-template-columns: 100px 1fr 24px; gap: 24px; align-items: baseline; padding: 22px 8px; text-decoration: none; color: var(--ink); transition: padding .3s ease, background .3s ease; }
.contact-list a:hover { padding-left: 24px; background: color-mix(in oklab, var(--shallow) 12%, transparent); }
.cl-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink); opacity: 0.55; }
.cl-value { font-family: var(--mono); font-size: 15px; color: var(--ink); }
.cl-arrow { font-family: var(--mono); font-size: 16px; color: var(--deep); text-align: right; transition: transform .3s ease; }
.contact-list a:hover .cl-arrow { transform: translateX(6px); }
.foot { position: relative; z-index: 2; padding: 60px 32px 80px; }
.foot-inner { max-width: 1200px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--ink); opacity: 0.55; }
.foot-glyph { font-size: 16px; color: var(--deep); opacity: 0.6; letter-spacing: 0.4em; }
.scroll-hint { position: fixed; right: 18px; top: 50%; transform: translateY(-50%); z-index: 9; pointer-events: none; }
.sh-track { width: 1px; height: 200px; background: color-mix(in oklab, var(--ink) 15%, transparent); position: relative; }
.sh-fill { position: absolute; top: 0; left: -1px; width: 3px; background: var(--deep); transition: height .15s ease; }
.surface-text { display: inline; position: relative; }
.st-space { display: inline-block; white-space: pre; }
.st-ch { --p: 0; display: inline-block; position: relative; vertical-align: baseline; }
.st-ch > .st-real { display: inline-block; color: var(--ink); opacity: var(--p); transform: translateY(calc((1 - var(--p)) * -3px)); filter: blur(calc((1 - var(--p)) * 1.2px)); will-change: opacity, filter, transform; transition: opacity .25s linear, filter .25s linear, transform .25s linear; }
.st-ch > .st-glyph { position: absolute; left: 50%; top: 50%; font-family: var(--mono); font-weight: 400; font-size: 0.78em; line-height: 1; color: var(--shallow); opacity: calc(1 - var(--p)); transform: translate(-50%, -50%) translateY(calc((1 - var(--p)) * 4px)) scale(calc(0.92 + 0.08 * (1 - var(--p)))); filter: blur(calc((1 - var(--p)) * 0.6px)); text-shadow: 0 0 12px color-mix(in oklab, var(--foam) 80%, transparent); pointer-events: none; will-change: opacity, filter, transform; transition: opacity .25s linear, filter .25s linear, transform .25s linear; }
.notready { position: relative; z-index: 2; min-height: 100vh; display: grid; place-items: center; padding: 80px 32px; }
.notready-inner { position: relative; max-width: 640px; display: grid; gap: 28px; padding: 8px; }
.nr-meta { display: inline-flex; align-items: center; gap: 14px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink); opacity: 0.6; }
.nr-meta .rule { display: inline-block; width: 56px; height: 1px; background: var(--ink); opacity: 0.5; }
.nr-title { margin: 0; font-family: 'Cormorant Garamond', serif; font-weight: 500; font-size: clamp(56px, 9vw, 120px); line-height: 0.95; letter-spacing: -0.015em; color: var(--ink); }
.nr-title em { font-weight: 400; }
.nr-body { margin: 0; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: clamp(20px, 2vw, 28px); line-height: 1.45; color: var(--ink); opacity: 0.85; max-width: 480px; }
.nr-foot { margin: 12px 0 0; font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; color: var(--ink); opacity: 0.65; }
.nr-foot a { color: var(--deep); text-decoration: none; border-bottom: 1px solid color-mix(in oklab, var(--deep) 40%, transparent); padding-bottom: 1px; }
.nr-foot a:hover { color: var(--ink); border-bottom-color: var(--ink); }
[data-reveal] { opacity: 1; }
@media (max-width: 720px) {
  body { font-size: 16px; }
  .nav-inner { grid-template-columns: 1fr auto; }
  .nav-meta { display: none; }
  .nav-links { gap: 18px; font-size: 11px; }
  .hero { padding: 100px 20px 60px; }
  .section { padding: 80px 18px; }
  .section::before { inset: 30px 8px; }
  .sec-head { grid-template-columns: 1fr; gap: 8px; }
  .now-row { grid-template-columns: 1fr; gap: 4px; }
  .proj-link { grid-template-columns: 60px 1fr 24px; }
  .proj-kind { display: none; }
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .scroll-hint { display: none; }
  .foot-inner { flex-direction: column; gap: 12px; text-align: center; }
}
