:root {
  --bg: oklch(97% 0.006 240);
  --surface: oklch(100% 0 0);
  --fg: oklch(15% 0.02 100);
  --muted: oklch(44% 0.018 100);
  --border: oklch(84% 0.01 100);
  --accent: oklch(60% 0.22 25);
  --success: oklch(48% 0.12 160);
  --danger: oklch(55% 0.18 25);
  --accent-soft: color-mix(in oklch, var(--accent) 12%, transparent);
  --glass: color-mix(in oklch, var(--surface) 72%, transparent);
  --glass-soft: color-mix(in oklch, var(--surface) 48%, transparent);
  --glass-edge: color-mix(in oklch, var(--surface) 68%, var(--border));
  --shadow-soft: 0 24px 80px color-mix(in oklch, var(--fg) 9%, transparent);
  --font-display: 'Times New Roman', 'Iowan Old Style', Georgia, serif;
  --font-body: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-mono: ui-monospace, 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  --container: 1180px;
  --gutter: clamp(20px, 4vw, 44px);
  --radius: 10px;
  --radius-lg: 22px;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  overflow-x: clip;
  background:
    linear-gradient(120deg, color-mix(in oklch, var(--surface) 62%, transparent), transparent 36%),
    linear-gradient(180deg, var(--bg) 0%, color-mix(in oklch, var(--bg) 86%, var(--surface)) 100%);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
button:disabled { cursor: not-allowed; opacity: .62; }
p { text-wrap: pretty; }
h1, h2, h3 { text-wrap: balance; }

.skip-link { position: fixed; left: 16px; top: 12px; z-index: 20; transform: translateY(-140%); background: var(--fg); color: var(--surface); border: 1px solid var(--fg); padding: 10px 14px; border-radius: var(--radius); font-size: 14px; transition: transform .15s ease; }
.skip-link:focus { transform: translateY(0); outline: 2px solid var(--accent); outline-offset: 3px; }
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(56px, 8vw, 96px); }
.section + .section { border-top: 1px solid color-mix(in oklch, var(--border) 74%, transparent); }
.stack { display: flex; flex-direction: column; gap: 20px; }
.row { display: flex; align-items: center; gap: 20px; }
.row-between { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: clamp(22px, 4vw, 48px); }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.grid-1-2 { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(28px, 5vw, 64px); align-items: start; }

.h1, h1 { font-family: var(--font-display); font-size: clamp(48px, 7vw, 104px); line-height: .94; letter-spacing: 0; margin: 0; font-weight: 400; }
.h2, h2 { font-family: var(--font-display); font-size: clamp(34px, 4.4vw, 62px); line-height: 1; letter-spacing: 0; margin: 0; font-weight: 400; }
.h3, h3 { font-family: var(--font-display); font-size: 26px; font-weight: 400; line-height: 1.08; letter-spacing: 0; margin: 0; }
.lead { font-size: 19px; line-height: 1.62; color: var(--muted); max-width: 60ch; margin: 0; }
.eyebrow { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0; text-transform: uppercase; color: var(--accent); margin: 0 0 20px; }
.meta { font-family: var(--font-mono); font-size: 13px; color: var(--muted); }

.topnav { position: sticky; top: 0; z-index: 10; background: transparent; padding: 12px var(--gutter) 0; }
.topnav-inner { display: grid; grid-template-columns: auto minmax(0, 1fr) auto; align-items: center; gap: 32px; padding: 12px clamp(16px, 2.6vw, 28px); background: color-mix(in oklch, var(--surface) 66%, transparent); border: 1px solid var(--glass-edge); border-radius: var(--radius); box-shadow: 0 18px 60px color-mix(in oklch, var(--fg) 6%, transparent); -webkit-backdrop-filter: blur(24px) saturate(1.12); backdrop-filter: blur(24px) saturate(1.12); }
.logo { font-family: var(--font-display); font-size: 23px; font-weight: 400; letter-spacing: 0; }
.menu-toggle { display: none; min-height: 34px; padding: 0; border: 0; background: transparent; color: var(--fg); font-size: 14px; line-height: 1; letter-spacing: 0; }
.menu-toggle::after { content: ''; display: inline-block; width: 18px; height: 13px; margin-left: 9px; background: linear-gradient(currentColor 0 0) top / 100% 1.4px no-repeat, linear-gradient(currentColor 0 0) center / 100% 1.4px no-repeat, linear-gradient(currentColor 0 0) bottom / 100% 1.4px no-repeat; transform: none; transition: background .18s ease, transform .18s ease; }
.topnav.is-open .menu-toggle::after { height: 18px; background: linear-gradient(45deg, transparent 46%, currentColor 47% 53%, transparent 54%) center / 100% 100% no-repeat, linear-gradient(-45deg, transparent 46%, currentColor 47% 53%, transparent 54%) center / 100% 100% no-repeat; transform: rotate(0deg); }
.site-menu { display: flex; justify-content: center; gap: clamp(18px, 2.4vw, 30px); }
.site-menu a { position: relative; font-size: 14px; color: var(--muted); }
.site-menu a::after { content: ''; position: absolute; left: 0; right: 0; bottom: -7px; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .18s ease; }
.site-menu a:hover, .site-menu a[aria-current="page"] { color: var(--fg); }
.site-menu a:hover::after, .site-menu a[aria-current="page"]::after { transform: scaleX(1); }
.nav-action { justify-self: end; color: var(--fg); font-size: 14px; border-bottom: 1px solid color-mix(in oklch, var(--fg) 34%, transparent); padding-bottom: 3px; }
.nav-action:hover { color: var(--accent); border-color: currentColor; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 44px; padding: 11px 20px; border-radius: 999px; border: 1px solid transparent; font-size: 15px; font-weight: 500; letter-spacing: 0; transition: transform .16s ease, background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; box-shadow: 0 0 0 5px var(--accent-soft); }
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(1px); }
.btn-primary { background: linear-gradient(180deg, color-mix(in oklch, var(--accent) 88%, var(--surface)), var(--accent)); color: var(--surface); border-color: color-mix(in oklch, var(--accent) 82%, var(--fg)); box-shadow: 0 14px 34px color-mix(in oklch, var(--accent) 24%, transparent); }
.btn-secondary { background: var(--glass-soft); color: var(--fg); border-color: var(--glass-edge); -webkit-backdrop-filter: blur(18px) saturate(1.08); backdrop-filter: blur(18px) saturate(1.08); }
.btn-ghost { background: transparent; color: var(--fg); border-color: transparent; padding-inline: 8px; }
.btn-ghost:hover { text-decoration: underline; text-underline-offset: 5px; }
.btn-arrow::after { content: '→'; transition: transform .15s ease; }
.btn-arrow:hover::after { transform: translateX(2px); }

.page-hero { padding-block: clamp(32px, 4.6vw, 64px) clamp(28px, 4vw, 46px); }
.hero-immersive { position: relative; display: grid; grid-template-columns: minmax(0, 1fr); gap: clamp(18px, 3vw, 34px); align-items: center; min-width: 0; isolation: isolate; }
.hero-immersive > * { min-width: 0; }
.hero-immersive .hero-copy { max-width: min(560px, 100%); gap: 14px; }
.hero-immersive .hero-copy .lead { max-width: 38ch; font-size: 17px; line-height: 1.58; }
.hero-immersive .hero-media { width: 100%; min-height: clamp(300px, 34vw, 500px); }
.hero-gallery { grid-template-columns: minmax(0, 1.46fr) minmax(300px, .54fr); align-items: end; }
.hero-gallery .hero-media { grid-column: 1; grid-row: 1; min-height: clamp(340px, 38vw, 520px); }
.hero-gallery .hero-copy { grid-column: 2; grid-row: 1; }
.hero-case { min-height: clamp(340px, 38vw, 520px); align-items: end; }
.hero-case .hero-media { grid-column: 1; grid-row: 1; min-height: inherit; z-index: 1; }
.hero-case .hero-copy { grid-column: 1; grid-row: 1; align-self: end; margin: clamp(20px, 4vw, 46px); max-width: min(620px, calc(100% - 40px)); padding: 0; color: var(--surface); z-index: 2; text-shadow: 0 1px 24px color-mix(in oklch, var(--fg) 38%, transparent); }
.hero-case .hero-copy .eyebrow, .hero-case .hero-copy .lead { color: color-mix(in oklch, var(--surface) 78%, transparent); }
.hero-studio { grid-template-columns: minmax(320px, .7fr) minmax(0, 1.3fr); align-items: end; }
.hero-studio .hero-media { min-height: clamp(330px, 38vw, 520px); }
.hero-services { grid-template-columns: minmax(0, 1.3fr) minmax(300px, .7fr); align-items: end; }
.hero-services .hero-media { grid-column: 1; grid-row: 1; min-height: clamp(320px, 36vw, 500px); }
.hero-services .hero-copy { grid-column: 2; grid-row: 1; }
.hero-journal { grid-template-columns: minmax(320px, .72fr) minmax(0, 1.28fr); align-items: end; }
.hero-contact { grid-template-columns: minmax(320px, .68fr) minmax(0, 1.32fr); align-items: end; }
.hero-contact .hero-media { min-height: clamp(320px, 36vw, 500px); }
.hero-launcher { grid-template-columns: minmax(0, 1.28fr) minmax(320px, .72fr); align-items: end; }
.page-hero h1 { font-size: clamp(42px, 4.9vw, 78px); max-width: min(780px, 100%); }
.hero-immersive .tag-row { margin-top: 22px; }
.glass { background: var(--glass); border: 1px solid var(--glass-edge); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft), inset 0 1px 0 color-mix(in oklch, var(--surface) 84%, transparent); -webkit-backdrop-filter: blur(22px) saturate(1.08); backdrop-filter: blur(22px) saturate(1.08); }
.panel { padding: clamp(22px, 3vw, 34px); }
.image-card { position: relative; overflow: hidden; min-height: 320px; border-radius: var(--radius-lg); border: 1px solid var(--glass-edge); box-shadow: var(--shadow-soft); background: var(--glass-soft); }
.image-card img { width: 100%; height: 100%; min-height: inherit; object-fit: cover; filter: saturate(.94) contrast(.98); transition: transform .7s ease, filter .7s ease; }
.image-card::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 54%, color-mix(in oklch, var(--fg) 28%, transparent)); pointer-events: none; }
.image-caption { position: absolute; left: 18px; right: 18px; bottom: 16px; z-index: 1; color: color-mix(in oklch, var(--surface) 82%, transparent); font-family: var(--font-mono); font-size: 11px; }
.tag { display: inline-flex; align-items: center; padding: 4px 10px; background: var(--glass-soft); color: var(--muted); border: 1px solid var(--glass-edge); border-radius: 999px; font-size: 12px; }
.tag-row { display: flex; flex-wrap: wrap; gap: 8px; }

.project-card { position: relative; display: grid; min-height: clamp(360px, 42vw, 500px); overflow: hidden; color: inherit; }
.project-card.panel { padding: 0; }
.project-card .image-card { position: absolute; inset: 0; min-height: 100%; border: 0; border-radius: inherit; box-shadow: none; }
.project-card .image-card::after { background: linear-gradient(180deg, transparent 34%, color-mix(in oklch, var(--fg) 18%, transparent) 62%, color-mix(in oklch, var(--fg) 58%, transparent) 100%); }
.project-card > .stack { position: relative; z-index: 1; align-self: end; gap: 8px; padding: clamp(20px, 3vw, 28px); color: var(--surface); }
.project-card > .stack h3 { max-width: 14ch; color: var(--surface); text-shadow: 0 1px 18px color-mix(in oklch, var(--fg) 34%, transparent); }
.project-card > .stack .meta { max-width: 28ch; color: color-mix(in oklch, var(--surface) 72%, transparent); }
.project-card > .stack .tag { width: max-content; padding: 0; background: transparent; color: color-mix(in oklch, var(--surface) 76%, transparent); border: 0; border-radius: 0; }
.project-card:hover .image-card img { transform: scale(1.025); filter: saturate(1) contrast(1.02); }
.project-card:hover h3 { text-decoration: none; }
.project-meta { display: flex; justify-content: space-between; gap: 16px; padding-top: 14px; border-top: 1px solid var(--glass-edge); }
.filterbar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 26px; }
.filter-btn { min-height: 40px; padding: 8px 13px; border: 1px solid var(--glass-edge); background: var(--glass-soft); color: var(--muted); border-radius: 999px; font-size: 13px; -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px); transition: transform .16s ease, background .18s ease, border-color .18s ease, color .18s ease; }
.filter-btn:hover, .filter-btn[aria-pressed="true"] { color: var(--fg); border-color: color-mix(in oklch, var(--fg) 36%, var(--border)); background: var(--glass); }
.filter-status, .form-note { color: var(--muted); font-size: 13px; }
.empty-state { border: 1px solid var(--glass-edge); border-radius: var(--radius-lg); padding: 22px 24px; background: var(--glass-soft); color: var(--muted); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); }
.empty-state[hidden], [hidden] { display: none !important; }

.timeline { display: grid; gap: 0; }
.timeline-row { display: grid; grid-template-columns: 148px 1fr; gap: 28px; padding: 24px 0; border-top: 1px solid var(--border); }
.quote { font-family: var(--font-display); font-size: clamp(28px, 3.4vw, 48px); line-height: 1.12; letter-spacing: 0; }
.pagefoot { padding-block: clamp(54px, 8vw, 96px) 0; color: var(--muted); font-size: 13px; border-top: 1px solid var(--border); overflow: hidden; }
.footer-grid { display: grid; grid-template-columns: minmax(0, 1.25fr) .6fr .75fr; gap: clamp(28px, 5vw, 72px); align-items: start; padding-bottom: clamp(42px, 7vw, 76px); }
.footer-logo { display: inline-block; font-family: var(--font-display); font-size: clamp(34px, 4vw, 58px); line-height: .9; color: var(--fg); letter-spacing: 0; margin-bottom: 18px; }
.footer-intro p { max-width: 34ch; margin: 0; color: var(--muted); font-size: 15px; line-height: 1.68; }
.footer-kicker { display: block; margin-bottom: 14px; color: var(--fg); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0; }
.footer-links, .footer-contact { display: grid; gap: 10px; }
.footer-links a, .footer-contact a { width: max-content; color: var(--muted); }
.footer-links a:hover, .footer-contact a:hover { color: var(--fg); text-decoration: underline; text-underline-offset: 5px; }
.footer-meta { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 14px; padding: 18px 0; border-top: 1px solid color-mix(in oklch, var(--border) 72%, transparent); color: var(--muted); }
.brand-field { position: relative; margin-inline: calc(var(--gutter) * -1); border-top: 1px solid color-mix(in oklch, var(--border) 72%, transparent); overflow: hidden; min-height: clamp(128px, 22vw, 260px); display: flex; align-items: center; }
.brand-field::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 20% 40%, color-mix(in oklch, var(--accent) 12%, transparent), transparent 34%), linear-gradient(90deg, var(--bg), transparent 18%, transparent 82%, var(--bg)); pointer-events: none; z-index: 1; }
.brand-track { display: flex; gap: clamp(26px, 5vw, 70px); white-space: nowrap; animation: brandDrift 24s linear infinite; }
.brand-word { font-family: var(--font-display); font-size: clamp(96px, 18vw, 260px); line-height: .78; letter-spacing: 0; color: transparent; -webkit-text-stroke: 1px color-mix(in oklch, var(--fg) 24%, transparent); text-shadow: 0 26px 80px color-mix(in oklch, var(--accent) 12%, transparent); }
.brand-word.is-solid { color: color-mix(in oklch, var(--fg) 8%, transparent); -webkit-text-stroke-color: color-mix(in oklch, var(--fg) 34%, transparent); }
@keyframes brandDrift { from { transform: translateX(0); } to { transform: translateX(calc(-50% - 35px)); } }

.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 13px; color: var(--muted); }
.input, .textarea, .select { width: 100%; padding: 11px 14px; border: 1px solid var(--glass-edge); border-radius: var(--radius); background: color-mix(in oklch, var(--surface) 76%, transparent); color: var(--fg); font: inherit; font-size: 15px; box-shadow: inset 0 1px 0 color-mix(in oklch, var(--surface) 82%, transparent); }
.input[aria-invalid="true"], .textarea[aria-invalid="true"], .select[aria-invalid="true"] { border-color: var(--danger); background: color-mix(in oklch, var(--danger) 5%, var(--surface)); }
.textarea { min-height: 132px; resize: vertical; line-height: 1.55; }
.field-error { margin: 0; color: var(--danger); font-size: 12px; }
.form-note.is-ok { color: var(--success); }
.form-note.is-error { color: var(--danger); }
.form-note.is-loading { color: var(--accent); }

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .topnav-inner, .glass, .btn-secondary, .filter-btn, .empty-state { background: color-mix(in oklch, var(--surface) 92%, var(--bg)); }
}

@media (max-width: 920px) {
  .topnav { padding: 8px clamp(14px, 4.2vw, 20px) 0; }
  .topnav-inner { grid-template-columns: 1fr auto; grid-template-areas: "logo toggle" "menu menu" "action action"; gap: 0 16px; padding: 6px 12px; min-height: 46px; border-radius: 13px; box-shadow: 0 12px 34px color-mix(in oklch, var(--fg) 5%, transparent); }
  .topnav .logo { grid-area: logo; }
  .menu-toggle { display: inline-flex; grid-area: toggle; align-items: center; justify-content: center; justify-self: end; align-self: center; min-height: 34px; padding-inline: 2px; }
  .site-menu { grid-area: menu; display: none; grid-template-columns: 1fr; gap: 0; justify-content: stretch; margin-top: 6px; padding-top: 4px; border-top: 1px solid color-mix(in oklch, var(--border) 58%, transparent); }
  .topnav.is-open .site-menu { display: grid; }
  .site-menu a { min-height: 36px; display: flex; align-items: center; border-bottom: 1px solid color-mix(in oklch, var(--border) 44%, transparent); line-height: 1; }
  .site-menu a::after { display: none; }
  .nav-action { grid-area: action; display: none; width: 100%; min-height: 36px; align-items: center; justify-content: space-between; justify-self: stretch; margin-top: 4px; padding: 2px 0 0; border: 0; color: var(--fg); line-height: 1; }
  .nav-action::after { content: '→'; color: var(--accent); transition: transform .15s ease; }
  .nav-action:hover::after { transform: translateX(2px); }
  .topnav.is-open .nav-action { display: flex; }
  .grid-2, .grid-3, .grid-1-2, .hero-immersive, .hero-gallery, .hero-case, .hero-studio, .hero-services, .hero-journal, .hero-contact, .hero-launcher, .footer-grid { grid-template-columns: 1fr; }
  .timeline-row { grid-template-columns: 1fr; gap: 8px; }
  h1 { font-size: clamp(48px, 16vw, 76px); }
  .page-hero { padding-block: 50px 36px; }
  .hero-gallery .hero-media, .hero-gallery .hero-copy, .hero-services .hero-media, .hero-services .hero-copy, .hero-case .hero-media, .hero-case .hero-copy { grid-column: auto; grid-row: auto; }
  .hero-case { min-height: 0; }
  .hero-case .hero-copy { margin: 0; color: var(--fg); text-shadow: none; }
  .hero-case .hero-copy .eyebrow { color: var(--accent); }
  .hero-case .hero-copy .lead { color: var(--muted); }
  .hero-studio .hero-media, .hero-gallery .hero-media, .hero-immersive .hero-media { min-height: 340px; }
  .footer-meta { padding-inline: 0; }
}

@media (max-width: 560px) {
  .topnav-inner { gap: 8px; }
  .nav-action { font-size: 13px; }
  .row-between { align-items: flex-start; flex-direction: column; }
  .filter-btn { flex: 1 1 calc(50% - 8px); }
  .btn { width: 100%; }
  .site-menu a { font-size: 14px; }
  .project-meta { flex-direction: column; gap: 6px; }
  .project-card { min-height: 330px; }
  .hero-immersive .hero-media, .hero-studio .hero-media, .hero-gallery .hero-media { min-height: 280px; }
  .page-hero h1 { font-size: clamp(40px, 12vw, 58px); }
  .brand-field { min-height: 112px; }
}

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