/* =============================================================
   Club of Curiouser — site styles  (built on Oom tokens)
   ============================================================= */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  overflow-x: hidden;
  transition: background var(--dur-medium) var(--ease), color var(--dur-medium) var(--ease);
}

/* ---------- Looking-glass (dark) theme ---------- */
[data-theme="dark"] {
  --paper:        #16140F;
  --paper-deep:   #100E0A;
  --ink:          #F2ECDE;
  --ink-soft:     #DAD2C0;
  --stone-05:     #1E1B15;
  --stone-10:     #26231B;
  --stone-20:     #34302666;
  --stone-30:     #4A4537;
  --stone-50:     #8C8470;
  --stone-70:     #B8AF99;
  --stone-90:     #E8E1D1;
  --tide:         #3FC1D8;
  --tide-deep:    #6FD6E8;
  --tide-wash:    #0E2F37;
  --sage:         #9CB09A;
  --clay:         #D08A6E;

  --bg:           #16140F;
  --bg-sunk:      #100E0A;
  --bg-raised:    #1E1B15;
  --fg:           #F2ECDE;
  --fg-muted:     #B8AF99;
  --fg-subtle:    #8C8470;
  --fg-on-accent: #16140F;
  --border:       #3A3528;
  --border-soft:  #2A2619;
  --border-strong:#5A5340;
  --accent:       #3FC1D8;
  --accent-hover: #6FD6E8;
  --accent-wash:  #0E2F37;
  --shadow-1: 0 1px 2px rgba(0,0,0,0.3), 0 2px 10px rgba(0,0,0,0.35);
  --shadow-2: 0 6px 18px rgba(0,0,0,0.45), 0 16px 44px rgba(0,0,0,0.5);
}

/* accent override hook (tweak) */
[data-accent="clay"] { --accent: var(--clay); --accent-hover: var(--clay-deep); --accent-wash: var(--clay-wash); --focus-ring: var(--clay); }
[data-accent="sage"] { --accent: var(--sage); --accent-hover: var(--sage-deep); --accent-wash: var(--sage-wash); --focus-ring: var(--sage); }
[data-theme="dark"][data-accent="clay"] { --accent:#D89A7E; --accent-hover:#E7B89C; }
[data-theme="dark"][data-accent="sage"] { --accent:#A9BCA6; --accent-hover:#C2D1BF; }

::selection { background: var(--accent-wash); color: var(--fg); }
a { color: inherit; }

.shell { max-width: var(--content-wide); margin: 0 auto; padding: 0 var(--margin-outer); }
@media (max-width: 800px){ .shell { padding: 0 24px; } }

.serif { font-family: var(--font-serif); }
.mono  { font-family: var(--font-mono); }
.eyebrow {
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--fg-subtle);
}

/* =============================================================
   Top bar
   ============================================================= */
.topbar {
  position: sticky; top: 0; z-index: 60;
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-base) var(--ease), background var(--dur-medium) var(--ease);
}
.topbar.scrolled { border-bottom-color: var(--border-soft); }
.topbar-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; height: 68px;
}
.brand { display: flex; align-items: center; gap: 12px; cursor: pointer; background: none; border: 0; padding: 0; color: inherit; }
.brand .mark { width: 30px; height: 30px; color: var(--fg); display: block; flex: none; }
.brand .mark svg { width: 100%; height: 100%; display: block; }
.brand .wm { display: flex; flex-direction: column; line-height: 1.05; text-align: left; }
.brand .wm .n { font-family: var(--font-serif); font-size: 16px; font-weight: 500; letter-spacing: -0.01em; }
.brand .wm .r { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-subtle); margin-top: 2px; }

.wmenu { display: flex; align-items: center; gap: 2px; }
.wmenu .witem {
  position: relative;
  display: inline-flex; align-items: baseline; white-space: nowrap;
  font-family: var(--font-sans); font-size: 14px; font-weight: 500;
  color: var(--fg-muted);
  background: none; border: 0; cursor: pointer;
  padding: 8px 10px; border-radius: var(--radius-sm);
  transition: color var(--dur-base) var(--ease), background var(--dur-base) var(--ease);
}
.wmenu .witem .full {
  display: inline-block; max-width: 0; overflow: hidden; opacity: 0;
  white-space: nowrap; color: var(--fg-subtle);
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.01em;
  transition: max-width var(--dur-medium) var(--ease), opacity var(--dur-base) var(--ease), margin var(--dur-medium) var(--ease);
  vertical-align: baseline;
}
.wmenu .witem:hover { color: var(--fg); }
.wmenu .witem:hover .full { max-width: 280px; opacity: 1; margin-left: 5px; }
.wmenu .witem.active { color: var(--fg); }
.wmenu .witem.active::after {
  content: ''; position: absolute; left: 10px; right: 10px; bottom: 3px;
  height: 1.5px; background: var(--accent);
}
.topbar .glass-toggle {
  background: none; border: 1px solid var(--border); color: var(--fg-muted);
  width: 34px; height: 34px; border-radius: 50%; cursor: pointer;
  display: grid; place-items: center; flex: none;
  transition: color var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.topbar .glass-toggle:hover { color: var(--fg); border-color: var(--border-strong); }
.topbar .glass-toggle:active { transform: scale(0.92); }
.wmenu-wrap { display:flex; align-items:center; gap: 14px; }
.menu-toggle { display: none; }
@media (max-width: 860px){
  .wmenu .witem .full { display: none; }
  .wmenu .witem { padding: 8px 7px; }
  .brand .wm .r { display:none; }
}
@media (max-width: 600px){
  /* Collapse the seven-item nav into a hamburger menu */
  .wmenu-wrap { position: relative; gap: 10px; }
  .menu-toggle {
    display: grid; place-items: center; flex: none;
    width: 40px; height: 40px; border-radius: 50%;
    background: none; border: 1px solid var(--border); color: var(--fg); cursor: pointer;
    transition: border-color var(--dur-base) var(--ease), transform var(--dur-fast) var(--ease);
  }
  .menu-toggle:hover { border-color: var(--border-strong); }
  .menu-toggle:active { transform: scale(0.94); }
  .wmenu {
    position: absolute; top: calc(100% + 12px); right: 0; z-index: 70;
    flex-direction: column; align-items: stretch; gap: 6px;
    min-width: 232px; max-width: min(86vw, 320px); padding: 10px;
    background: var(--bg-raised); border: 1px solid var(--border);
    border-radius: var(--radius-lg); box-shadow: var(--shadow-2);
    opacity: 0; transform: translateY(-6px) scale(0.985); pointer-events: none;
    transition: opacity var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
  }
  .wmenu-wrap.open .wmenu { opacity: 1; transform: none; pointer-events: auto; }
  .wmenu .witem {
    display: flex;
    width: 100%; justify-content: flex-start; align-items: baseline;
    min-height: 48px; padding: 13px 14px; font-size: 16px; border-radius: var(--radius-md);
  }
  .wmenu .witem:hover, .wmenu .witem.active { color: var(--fg); background: var(--bg-sunk); }
  .wmenu .witem.active::after { display: none; }
  .wmenu .witem .full {
    display: inline-block; max-width: none; opacity: 1; margin-left: 6px;
    font-family: var(--font-mono); font-size: 11.5px; color: var(--fg-subtle);
  }
}

/* =============================================================
   Home — hero + prompt
   ============================================================= */
.home { position: relative; }
.hero {
  position: relative;
  padding: clamp(64px, 11vh, 132px) 0 64px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  overflow: hidden;
}
/* faint oversized brand watermark behind hero */
.hero .aura {
  position: absolute; top: 50%; left: 50%;
  width: min(820px, 120vw); aspect-ratio: 1;
  transform: translate(-50%, -54%);
  color: var(--fg);
  opacity: 0.045; pointer-events: none; z-index: 0;
}
[data-theme="dark"] .hero .aura { opacity: 0.06; }
.hero .aura svg { width: 100%; height: 100%; display: block; }
.hero .aura path { opacity: 0.3; }
.hero > * { position: relative; z-index: 1; }

.hero .kicker {
  display: inline-flex; align-items: center; gap: 9px; margin-bottom: 26px;
}
.hero .kicker .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); animation: breathe 2.6s var(--ease) infinite; }
@keyframes breathe { 0%,100%{ opacity:.35; transform: scale(1);} 50%{ opacity:1; transform: scale(1.25);} }

.hero h1 {
  font-family: var(--font-serif); font-weight: 300;
  font-size: clamp(40px, 6.4vw, 84px); line-height: 1.02;
  letter-spacing: -0.035em; margin: 0; max-width: 14ch;
}
.hero h1 em { font-style: italic; color: var(--accent); }
.hero .sub {
  font-family: var(--font-serif); font-weight: 300;
  font-size: clamp(18px, 2.1vw, 23px); line-height: 1.5;
  color: var(--fg-muted); margin: 24px auto 0; max-width: 50ch;
}

/* prompt field — the generative centerpiece */
.prompt {
  margin: 40px auto 0; width: min(680px, 100%);
  background: var(--bg-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-1);
  text-align: left;
  transition: border-color var(--dur-base) var(--ease), box-shadow var(--dur-medium) var(--ease), transform var(--dur-base) var(--ease);
}
.prompt.focused { border-color: var(--accent); box-shadow: var(--shadow-2); }
.prompt-top { display: flex; align-items: flex-start; gap: 12px; padding: 18px 18px 6px; }
.prompt-top .ico { flex: none; width: 26px; height: 26px; margin-top: 2px; color: var(--accent); }
.prompt-top .ico svg { width: 100%; height: 100%; display: block; }
.prompt input {
  flex: 1; border: 0; background: none; outline: none;
  font-family: var(--font-serif); font-size: clamp(18px, 2.4vw, 22px);
  color: var(--fg); padding: 2px 0; min-width: 0; font-weight: 400;
}
.prompt input::placeholder { color: var(--fg-subtle); }
.prompt-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 14px 14px; gap: 12px;
}
.prompt-hint {
  font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle);
  letter-spacing: 0.02em; min-height: 16px;
  transition: color var(--dur-base) var(--ease);
}
.prompt-hint b { color: var(--accent); font-weight: 500; }
.prompt-send {
  flex: none; width: 38px; height: 38px; border-radius: var(--radius-md);
  background: var(--accent); color: var(--fg-on-accent);
  border: 0; cursor: pointer; display: grid; place-items: center;
  transition: background var(--dur-base) var(--ease), transform var(--dur-base) var(--ease), opacity var(--dur-base) var(--ease);
}
.prompt-send:hover { background: var(--accent-hover); }
.prompt-send:active { transform: scale(0.92); }
.prompt-send:disabled { opacity: 0.4; cursor: default; }
.prompt-send svg { width: 18px; height: 18px; }
.prompt.thinking input { opacity: 0.5; }
.prompt.thinking .prompt-hint { color: var(--accent); }

/* suggestion chips */
.chips { display: flex; flex-wrap: wrap; gap: 9px; justify-content: center; margin: 22px auto 0; max-width: 720px; }
.chip {
  font-family: var(--font-sans); font-size: 13.5px; color: var(--fg-muted);
  background: var(--bg-raised); border: 1px solid var(--border-soft);
  padding: 8px 15px; border-radius: 999px; cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
  transition: all var(--dur-base) var(--ease);
}
.chip .arr { color: var(--fg-subtle); transition: transform var(--dur-base) var(--ease); }
.chip:hover { border-color: var(--accent); color: var(--fg); }
.chip:hover .arr { transform: translateX(2px); color: var(--accent); }
@media (max-width: 600px){
  /* On phones the prompt chips offer three quick doors: Who, Why, How */
  .chips { flex-direction: column; align-items: stretch; gap: 10px; max-width: 320px; padding: 0 10px; }
  .chips .chip { display: none; }
  .chips .chip[data-to="who"],
  .chips .chip[data-to="why"],
  .chips .chip[data-to="how"] {
    display: inline-flex; justify-content: space-between;
    padding: 14px 20px; font-size: 15px; min-height: 48px; border-radius: var(--radius-md);
  }
  .chips .chip[data-to="who"] { order: 1; }
  .chips .chip[data-to="why"] { order: 2; }
  .chips .chip[data-to="how"] { order: 3; }
}

/* ---------- client / logo strip ---------- */
.clients { margin-top: clamp(56px, 9vh, 104px); }
.clients .lbl { text-align: center; margin-bottom: 26px; }
.logo-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px;
}
.logo-slot {
  --slot-h: 64px;
  height: var(--slot-h);
  display: grid; place-items: center; position: relative; overflow: hidden;
  background: transparent;
}
.logo-img {
  max-height: 30px; max-width: 100%; width: auto; object-fit: contain;
  box-sizing: content-box;
  padding: 12px 20px;
  border-radius: 10px;
  background: #efeae0;
  filter: grayscale(100%);
  opacity: 0.78;
  transition: filter var(--dur-medium) var(--ease), opacity var(--dur-medium) var(--ease);
}
.logo-slot:hover .logo-img { filter: grayscale(0%); opacity: 1; }
@media (max-width: 900px){ .logo-grid { grid-template-columns: repeat(3,1fr);} }
@media (max-width: 480px){ .logo-grid { grid-template-columns: repeat(2,1fr);} }

/* horizontal auto-scrolling marquee (right → left) */
.logo-marquee {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 7%, #000 93%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 7%, #000 93%, transparent 100%);
}
.logo-track {
  display: flex; width: max-content;
  animation: logo-scroll 46s linear infinite;
}
.logo-marquee:hover .logo-track { animation-play-state: paused; }
.logo-marquee .logo-slot { flex: 0 0 auto; width: auto; padding: 0 38px; }
@keyframes logo-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .logo-track { animation: none; }
}

/* =============================================================
   Tiles (six doors)
   ============================================================= */
.doors-head { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin: clamp(64px,10vh,120px) 0 28px; }
.doors-head h2 { font-family: var(--font-serif); font-weight: 300; font-size: clamp(26px,3.4vw,40px); letter-spacing:-0.025em; margin:0; }
.doors-head .note { font-family: var(--font-mono); font-size:11px; color: var(--fg-subtle); letter-spacing:0.04em; max-width: 34ch; text-align:right; }

/* layout: grid (default) */
.doors.grid-layout { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.doors.grid-layout .door { min-height: 220px; }
/* layout: index list */
.doors.index-layout { display:flex; flex-direction:column; border-top:1px solid var(--fg); }
.doors.index-layout .door {
  min-height: 0; border:0; border-bottom:1px solid var(--border-soft); border-radius:0;
  display:grid; grid-template-columns: 64px 1.1fr 2fr auto; align-items:center; gap:28px;
  padding: 26px 16px;
}
.doors.index-layout .door .d-teaser { display:block; }
.doors.index-layout .door .d-word { font-size: clamp(28px,3.4vw,44px); }
.doors.index-layout .door .d-foot { display:none; }
/* layout: mosaic */
.doors.mosaic-layout { display:grid; grid-template-columns: repeat(6,1fr); grid-auto-rows: 150px; gap:14px; }
.doors.mosaic-layout .door:nth-child(1){ grid-column: span 3; grid-row: span 2; }
.doors.mosaic-layout .door:nth-child(2){ grid-column: span 3; grid-row: span 1; }
.doors.mosaic-layout .door:nth-child(3){ grid-column: span 3; grid-row: span 1; }
.doors.mosaic-layout .door:nth-child(4){ grid-column: span 2; grid-row: span 1; }
.doors.mosaic-layout .door:nth-child(5){ grid-column: span 2; grid-row: span 1; }
.doors.mosaic-layout .door:nth-child(6){ grid-column: span 2; grid-row: span 1; }

.door {
  position: relative; text-align: left; cursor: pointer;
  background: var(--bg-raised); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: 22px 22px 18px;
  display: flex; flex-direction: column; gap: 8px; overflow: hidden;
  color: inherit;
  transition: border-color var(--dur-base) var(--ease), background var(--dur-base) var(--ease), transform var(--dur-medium) var(--ease);
}
.door::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:0; background: var(--accent);
  transition: width var(--dur-medium) var(--ease);
}
.door:hover { border-color: var(--border-strong); transform: translateY(-2px); }
.door:hover::before { width: 3px; }
.door .d-num { font-family: var(--font-mono); font-size: 11px; color: var(--accent); letter-spacing: 0.08em; }
.door .d-word { font-family: var(--font-serif); font-weight: 300; font-size: clamp(30px,3.6vw,46px); line-height:1; letter-spacing:-0.03em; }
.door .d-full { font-family: var(--font-sans); font-size: 13px; color: var(--fg); font-weight: 500; }
.door .d-teaser { font-size: 13.5px; line-height: 1.5; color: var(--fg-muted); }
.door .d-foot { margin-top: auto; display:flex; align-items:center; gap:8px; font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); letter-spacing: 0.04em; padding-top: 12px; }
.door .d-foot .arr { transition: transform var(--dur-base) var(--ease); }
.door:hover .d-foot .arr { transform: translateX(3px); }
.door:hover .d-foot { color: var(--accent); }
@media (max-width: 860px){
  .doors.grid-layout, .doors.mosaic-layout { grid-template-columns: repeat(2,1fr); grid-auto-rows:auto; }
  .doors.mosaic-layout .door { grid-column: span 1 !important; grid-row: span 1 !important; }
  .doors.index-layout .door { grid-template-columns: 44px 1fr; }
  .doors.index-layout .door .d-teaser { grid-column: 2; }
}
@media (max-width: 540px){ .doors.grid-layout { grid-template-columns: 1fr; } }

/* =============================================================
   Section view shell
   ============================================================= */
.section-view { min-height: 100vh; padding-bottom: 96px; animation: viewIn var(--dur-slow) var(--ease); }
@keyframes viewIn { from { opacity:0; transform: translateY(10px);} to { opacity:1; transform:none; } }
.sv-head { padding: clamp(40px,7vh,80px) 0 36px; border-bottom: 1px solid var(--border-soft); margin-bottom: 56px; }
.sv-crumbs { display:flex; align-items:center; gap: 14px; margin-bottom: 30px; }
.back-btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.03em;
  color: var(--fg-muted); background: none; border: 1px solid var(--border);
  padding: 7px 14px 7px 11px; border-radius: 999px; cursor: pointer;
  transition: all var(--dur-base) var(--ease);
}
.back-btn:hover { color: var(--fg); border-color: var(--border-strong); }
.back-btn .arr { transition: transform var(--dur-base) var(--ease); }
.back-btn:hover .arr { transform: translateX(-3px); }
.sv-tag { font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); letter-spacing: 0.08em; text-transform: uppercase; }
.sv-titlewrap { display: grid; grid-template-columns: 160px 1fr; gap: 40px; align-items: baseline; }
.sv-num { font-family: var(--font-mono); font-size: 13px; color: var(--accent); letter-spacing: 0.1em; padding-top: 12px; }
.sv-title { font-family: var(--font-serif); font-weight: 300; font-size: clamp(38px,5.4vw,72px); line-height:1.02; letter-spacing:-0.035em; margin:0; }
.sv-title em { font-style: italic; color: var(--accent); }
.sv-intro { font-family: var(--font-serif); font-weight: 300; font-size: clamp(19px,2vw,26px); line-height: 1.45; color: var(--fg-muted); margin: 22px 0 0; max-width: 62ch; }
@media (max-width: 760px){ .sv-titlewrap { grid-template-columns: 1fr; gap: 8px; } .sv-num { padding-top:0; } }

.prose { max-width: var(--content-prose); }
.prose p { font-size: var(--text-md); line-height: 1.62; margin: 0 0 22px; color: var(--ink-soft); }
.prose p:last-child { margin-bottom: 0; }
.prose em { font-style: italic; color: var(--accent); }

/* =============================================================
   1 — How (approaches)
   ============================================================= */
.approach-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border-soft); border: 1px solid var(--border-soft); border-radius: var(--radius-md); overflow: hidden; }
.approach { background: var(--bg); padding: 28px 26px; min-height: 210px; display:flex; flex-direction:column; gap: 12px; transition: background var(--dur-base) var(--ease); }
.approach:hover { background: var(--bg-sunk); }
.approach .top { display:flex; align-items:center; justify-content:space-between; }
.approach .n { font-family: var(--font-mono); font-size: 12px; color: var(--accent); letter-spacing: 0.08em; }
.approach .phase { font-family: var(--font-mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-subtle); border:1px solid var(--border); padding: 3px 9px; border-radius: 999px; }
.approach h3 { font-family: var(--font-serif); font-weight: 400; font-size: 30px; letter-spacing: -0.02em; margin: 0; }
.approach p { font-size: 14px; line-height: 1.55; color: var(--fg-muted); margin: 0; }
.approach .see-how {
  align-self: flex-start; margin-top: auto;
  font-family: var(--font-sans); font-size: 12.5px; font-weight: 500;
  color: var(--fg-subtle); background: transparent;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 7px 14px; cursor: not-allowed; opacity: 0.55;
}
.approach.placeholder { background: repeating-linear-gradient(135deg, transparent, transparent 9px, var(--bg-sunk) 9px, var(--bg-sunk) 10px); }
.approach.placeholder h3 { color: var(--fg-subtle); font-style: italic; }
.approach.placeholder .phase { border-style: dashed; }
@media (max-width: 900px){ .approach-grid { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 560px){ .approach-grid { grid-template-columns: 1fr;} }

/* =============================================================
   2 — Which (artefacts)
   ============================================================= */
.artefact-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.artefact { border:1px solid var(--border); border-radius: var(--radius-md); overflow:hidden; background: var(--bg-raised); display:flex; flex-direction:column; transition: border-color var(--dur-base) var(--ease), transform var(--dur-medium) var(--ease); }
.artefact:hover { border-color: var(--border-strong); transform: translateY(-3px); }
.artefact .sample { aspect-ratio: 16/10; background: var(--bg-sunk); border-bottom: 1px solid var(--border-soft); display:grid; place-items:center; color: var(--fg); padding: 18px; }
.artefact .sample svg { width: 100%; height: 100%; display:block; }
.artefact .body { padding: 18px 20px 22px; display:flex; flex-direction:column; gap: 8px; }
.artefact .body .nm { font-family: var(--font-serif); font-size: 21px; font-weight: 500; letter-spacing:-0.01em; }
.artefact .body p { font-size: 13.5px; line-height: 1.55; color: var(--fg-muted); margin: 0; }
.artefact .body .tag { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-subtle); }
@media (max-width: 900px){ .artefact-grid { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 560px){ .artefact-grid { grid-template-columns: 1fr;} }

/* =============================================================
   3 — Who / 4 — Why (editorial)
   ============================================================= */
.who-wrap { display:grid; grid-template-columns: 1fr 300px; gap: 64px; align-items: start; }
.who-portrait { position: sticky; top: 100px; }
.who-portrait .frame { border:1px solid var(--border); border-radius: var(--radius-md); overflow:hidden; aspect-ratio: 4/5; background: var(--bg-sunk); }
.who-portrait image-slot { width:100%; height:100%; }

/* animated portrait reel */
.reel { position: relative; width: 100%; height: 100%; }
.reel-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: 0;
  transform: scale(1.06);
  transition: opacity 1100ms var(--ease);
}
.reel-img.on {
  opacity: 1;
  transform: scale(1);
  transition: opacity 1100ms var(--ease), transform 5200ms linear;
}
.reel-cap {
  position: absolute; left: 0; right: 0; bottom: 0;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.04em;
  color: #fff; padding: 28px 14px 12px;
  background: linear-gradient(to top, rgba(20,18,15,0.62), transparent);
  pointer-events: none;
}
.reel-dots {
  position: absolute; top: 12px; left: 0; right: 0;
  display: flex; gap: 5px; justify-content: center;
}
.reel-dot {
  width: 5px; height: 5px; border-radius: 50%; padding: 0; border: 0;
  background: rgba(255,255,255,0.5); cursor: pointer;
  transition: background var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.reel-dot.on { background: #fff; transform: scale(1.35); }
@media (prefers-reduced-motion: reduce) {
  .reel-img { transition: opacity 200ms linear; transform: none; }
  .reel-img.on { transform: none; }
}
.who-portrait .cap { font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); margin-top: 10px; letter-spacing: 0.03em; }
.who-lead { font-family: var(--font-serif); font-weight: 300; font-size: clamp(28px,3.4vw,44px); line-height: 1.2; letter-spacing: -0.025em; margin: 0 0 28px; }
.who-lead em { font-style: italic; color: var(--accent); }
.facts { margin-top: 36px; border-top: 1px solid var(--border-soft); }
.facts .f { display:grid; grid-template-columns: 160px 1fr; gap: 20px; padding: 14px 0; border-bottom: 1px solid var(--border-soft); }
.facts .f .k { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-subtle); }
.facts .f .v { font-size: 15px; color: var(--fg); }
@media (max-width: 820px){ .who-wrap { grid-template-columns: 1fr; gap: 40px; } .who-portrait { position: static; max-width: 280px; } }

.why-statement { font-family: var(--font-serif); font-weight: 300; font-size: clamp(32px,5vw,64px); line-height: 1.08; letter-spacing: -0.03em; margin: 0 0 56px; max-width: 18ch; }
.why-statement em { font-style: italic; color: var(--accent); }
.why-body { display: grid; grid-template-columns: minmax(160px, 224px) 1fr; gap: 56px; align-items: start; }
.why-figure { position: sticky; top: 104px; margin: 0; }
.why-art { width: 100%; height: auto; display: block; color: var(--fg); }
.why-figure .cap { font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); letter-spacing: 0.03em; margin-top: 16px; }
@media (max-width: 820px){ .why-body { grid-template-columns: 1fr; gap: 28px; } .why-figure { position: static; max-width: 188px; } }
.pillars { display:grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 48px; }
.pillar { border-top: 2px solid var(--accent); padding-top: 18px; }
.pillar .k { font-family: var(--font-serif); font-size: 22px; font-weight: 500; margin-bottom: 8px; }
.pillar .v { font-size: 14px; line-height: 1.55; color: var(--fg-muted); }
@media (max-width: 760px){ .pillars { grid-template-columns: 1fr; } }

/* =============================================================
   5 — What (portfolio)
   ============================================================= */
.work-toolbar { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom: 28px; flex-wrap: wrap; }
.work-toolbar .count { font-family: var(--font-mono); font-size: 12px; color: var(--fg-subtle); letter-spacing: 0.04em; }

/* gallery */
.work.gallery { display:grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.work.gallery .pcard { display:flex; flex-direction:column; }
.work.gallery .pcard .cover { display:block; }
/* mosaic */
.work.mosaic { columns: 3; column-gap: 20px; }
.work.mosaic .pcard { break-inside: avoid; margin-bottom: 20px; }
.work.mosaic .pcard:nth-child(3n+1) .cover { aspect-ratio: 4/5; }
.work.mosaic .pcard:nth-child(3n+2) .cover { aspect-ratio: 16/11; }
.work.mosaic .pcard:nth-child(3n) .cover { aspect-ratio: 1/1; }
/* index (table) */
.work.index { display:flex; flex-direction:column; border-top: 1px solid var(--fg); }

.pcard { background: var(--bg-raised); border:1px solid var(--border); border-radius: var(--radius-md); overflow:hidden; cursor: pointer; transition: border-color var(--dur-base) var(--ease), transform var(--dur-medium) var(--ease), box-shadow var(--dur-medium) var(--ease); }
.pcard:hover { border-color: var(--border-strong); transform: translateY(-3px); box-shadow: var(--shadow-1); }
.pcard .cover { aspect-ratio: 4/3; position: relative; overflow:hidden; background: var(--bg-sunk); display:grid; place-items:center; }
.pcard .cover image-slot { position:absolute; inset:0; width:100%; height:100%; display:block; }
.pcard .cover .mark-wm { width: 46%; color: var(--fg); opacity: 0.10; }
.pcard .cover .mark-wm svg { width:100%; height:100%; display:block; }
.pcard .cover .pidx {
  position:absolute; top:10px; left:10px; z-index:2; pointer-events:none;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em;
  color:#fff; background: rgba(20,18,15,0.5);
  padding: 3px 7px; border-radius: var(--radius-xs);
  -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
}
.pcard .cover .phbadge { position:absolute; top:12px; right:12px; font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-subtle); border:1px dashed var(--border-strong); padding: 2px 7px; border-radius: 999px; }
.pcard .pbody { padding: 18px 20px 20px; display:flex; flex-direction:column; gap: 10px; }
.pcard .pmeta { display:flex; align-items:center; justify-content:space-between; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--fg-subtle); text-transform: uppercase; }
.pcard h3 { font-family: var(--font-serif); font-weight: 400; font-size: 22px; line-height: 1.15; letter-spacing: -0.015em; margin: 0; }
.pcard .skills { display:flex; flex-wrap:wrap; gap: 6px; }
.pcard .skills span { font-family: var(--font-sans); font-size: 11px; color: var(--fg-muted); border:1px solid var(--border-soft); padding: 3px 9px; border-radius: 999px; }
.pcard .impact { font-size: 13.5px; line-height: 1.5; color: var(--fg); display:flex; gap: 8px; align-items: baseline; }
.pcard .impact::before { content:'→'; color: var(--accent); }
.pcard { cursor: default; }
.case-btn {
  align-self: flex-start; margin-top: 4px;
  font-family: var(--font-sans); font-size: 13px; font-weight: 500;
  color: var(--fg-subtle); background: transparent;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 9px 16px; cursor: not-allowed; opacity: 0.6;
}
.case-btn[disabled] { pointer-events: auto; }

/* index row variant */
.work.index .pcard { border:0; border-bottom:1px solid var(--border-soft); border-radius:0; background:none; display:grid; grid-template-columns: 54px 1.4fr 1fr 0.8fr 1.4fr; gap: 24px; align-items: center; padding: 22px 14px; }
.work.index .pcard:hover { transform:none; box-shadow:none; background: var(--bg-raised); }
.work.index .pcard .cover, .work.index .pcard .skills, .work.index .pcard .phbadge { display:none; }
.work.index .pcard .pidx-inline { font-family: var(--font-mono); font-size: 12px; color: var(--accent); }
.work.index .pcard h3 { font-size: 20px; }
.work.index .pcard .ic { font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); text-transform: uppercase; letter-spacing: 0.05em; }
.work.index .pcard .impact { font-size: 13px; color: var(--fg-muted); }
.work.index .pcard .impact::before { content:''; }
.pidx-inline { display:none; }
.work.index .pidx-inline { display:block; }
@media (max-width: 1000px){ .work.gallery { grid-template-columns: repeat(2,1fr);} .work.mosaic { columns: 2; } }
@media (max-width: 720px){
  .work.gallery { grid-template-columns: 1fr;} .work.mosaic { columns: 1; }
  .work.index .pcard { grid-template-columns: 40px 1fr; }
  .work.index .pcard .ic, .work.index .pcard .impact { grid-column: 2; }
}

/* =============================================================
   6 — Where (inspiration) — flat grid, no categories
   ============================================================= */
.insp-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.insp-card {
  display: flex; flex-direction: column; justify-content: space-between; gap: 28px;
  min-height: 132px; padding: 22px 24px;
  border: 1px solid var(--border); border-radius: var(--radius-md);
  background: var(--bg-raised); text-decoration: none; color: var(--fg);
  position: relative; overflow: hidden;
  transition: border-color var(--dur-base) var(--ease), transform var(--dur-medium) var(--ease), color var(--dur-base) var(--ease);
}
.insp-card::before { content:''; position:absolute; left:0; top:0; bottom:0; width:0; background: var(--accent); transition: width var(--dur-medium) var(--ease); }
.insp-card:hover { border-color: var(--border-strong); transform: translateY(-3px); color: var(--accent); }
.insp-card:hover::before { width: 3px; }
.insp-card .nm { font-family: var(--font-serif); font-size: 24px; font-weight: 400; letter-spacing: -0.015em; line-height: 1.12; }
.insp-card .host { font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); letter-spacing: 0.02em; transition: color var(--dur-base) var(--ease); }
.insp-card:hover .host { color: var(--accent); }
@media (max-width: 860px){ .insp-cards { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 520px){ .insp-cards { grid-template-columns: 1fr; } }

/* =============================================================
   7 — When (contact)
   ============================================================= */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 72px; }
.contact-lead h3 { font-family: var(--font-serif); font-weight: 300; font-size: clamp(28px,3vw,40px); line-height:1.15; letter-spacing:-0.025em; margin:0 0 20px; }
.contact-lead p { font-size: var(--text-md); line-height: 1.6; color: var(--fg-muted); margin: 0 0 28px; max-width: 42ch; }
.contact-direct { font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); letter-spacing: 0.06em; }
.contact-direct .em { display:inline-flex; align-items:center; gap:10px; font-family: var(--font-serif); font-size: 22px; color: var(--fg); letter-spacing:-0.01em; margin-top: 8px; cursor:pointer; border-bottom:1px solid var(--fg); padding-bottom: 5px; background:none; border-left:0;border-right:0;border-top:0; transition: color var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease); }
.contact-direct .em:hover { color: var(--accent); border-color: var(--accent); }
.contact-direct .copied { color: var(--sage); }

.form { display:flex; flex-direction:column; gap: 24px; }
.field { display:flex; flex-direction:column; gap: 8px; }
.field label { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-subtle); }
.field input, .field textarea {
  font-family: var(--font-sans); font-size: 16px; background: transparent;
  border:0; border-bottom: 1px solid var(--border); padding: 9px 0 12px; color: var(--fg);
  outline: none; border-radius: 0; transition: border-color var(--dur-base) var(--ease); width:100%;
}
.field textarea { resize: vertical; min-height: 96px; }
.field input:focus, .field textarea:focus { border-bottom-color: var(--accent); }
.field input::placeholder, .field textarea::placeholder { color: var(--fg-subtle); }
.chip-row { display:flex; flex-wrap:wrap; gap: 8px; }
.fchip { font-family: var(--font-sans); font-size: 13px; color: var(--fg-muted); background: transparent; border:1px solid var(--border); padding: 7px 14px; border-radius: 999px; cursor: pointer; transition: all var(--dur-base) var(--ease); }
.fchip:hover { border-color: var(--border-strong); color: var(--fg); }
.fchip.on { background: var(--fg); color: var(--bg); border-color: var(--fg); }
.submit {
  align-self: flex-start; background: var(--accent); color: var(--fg-on-accent);
  border:0; font-family: var(--font-sans); font-size: 15px; font-weight: 500;
  padding: 15px 28px; border-radius: 999px; cursor: pointer; margin-top: 6px;
  display:inline-flex; align-items:center; gap: 12px;
  transition: background var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.submit:hover { background: var(--accent-hover); }
.submit:disabled { opacity: 0.55; cursor: default; }
.form-err { font-size: 13.5px; line-height: 1.5; color: var(--danger); margin: 2px 0 0; }
.form-err a { color: var(--danger); text-decoration-color: var(--danger); }
.submit:active { transform: scale(0.98); }
.submit .arr { display:grid; place-items:center; width:20px;height:20px;border-radius:50%; background: var(--fg-on-accent); color: var(--accent); transition: transform var(--dur-base) var(--ease); }
.submit:hover .arr { transform: translateX(2px); }
.confirm { border:1px solid var(--sage); background: var(--sage-wash); border-radius: var(--radius-md); padding: 28px 28px; }
[data-theme="dark"] .confirm { background: color-mix(in srgb, var(--sage) 18%, transparent); }
.confirm .ttl { font-family: var(--font-serif); font-size: 26px; font-weight: 400; margin-bottom: 10px; }
.confirm p { font-size: 14.5px; line-height: 1.6; color: var(--fg-muted); margin: 0; }
.confirm .again { margin-top:18px; font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); background:none;border:0;cursor:pointer; text-decoration: underline; text-underline-offset: 3px; }
@media (max-width: 820px){ .contact-grid { grid-template-columns: 1fr; gap: 44px; } }

/* =============================================================
   Footer
   ============================================================= */
.foot { border-top: 1px solid var(--border-soft); margin-top: clamp(72px,12vh,140px); padding: 56px 0 44px; }
.foot-grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.foot .blurb { font-family: var(--font-serif); font-weight: 300; font-size: 17px; line-height: 1.5; color: var(--fg-muted); max-width: 34ch; margin: 14px 0 0; }
.foot .fcol .h { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-subtle); margin-bottom: 14px; }
.foot .fcol a, .foot .fcol button { display:block; font-size: 14px; color: var(--fg); text-decoration: none; background:none;border:0;padding:4px 0;cursor:pointer;font-family:inherit;text-align:left; transition: color var(--dur-base) var(--ease); }
.foot .fcol a:hover, .foot .fcol button:hover { color: var(--accent); }
.foot-bottom { display:flex; align-items:center; justify-content:space-between; padding-top: 22px; border-top: 1px solid var(--border-soft); font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); letter-spacing: 0.04em; flex-wrap: wrap; gap: 12px; }
@media (max-width: 700px){ .foot-grid { grid-template-columns: 1fr 1fr; } }

/* reveal */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity 560ms var(--ease), transform 560ms var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity:1; transform:none; } .section-view{ animation: none; } }
