/* =========================================================
   Vlada Haikara — Portfolio
   Design system (finalized tokens). Signature green→peach
   gradient reserved for hero + section-break bands only;
   body/case pages stay warm-neutral light for readability.
   ========================================================= */

:root {
  /* ---- finalized palette ---- */
  --paper:       #FBFAF5;   /* warm off-white base */
  --paper-2:     #F4F2E9;   /* recessed panels */
  --card:        #FFFFFF;   /* cards */
  --forest:      #233D2C;   /* deep-green headings + text */
  --forest-deep: #1A2D20;
  --ink:         #233D2C;   /* body text */
  --ink-soft:    #5A6B5E;   /* muted green-grey */
  --line:        #E4E2D6;   /* hairline */
  --rust:        #B54E2B;   /* action / accent — used sparingly */
  --orange:      #B54E2B;   /* alias */

  /* signature gradient stops */
  --g1: #E8F0C4;            /* green */
  --g2: #F6E2B8;            /* mid */
  --g3: #F2C79A;            /* peach */
  --lime:       #E8F0C4;
  --lime-soft:  #EEF2D0;
  --peach:      #F2C79A;
  --peach-soft: #F6E2B8;
  --gradient: linear-gradient(140deg, var(--g1) 0%, var(--g2) 52%, var(--g3) 100%);

  --r-sm: 10px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-xl: 40px;

  --maxw: 1180px;
  --maxw-read: 760px;
  --gutter: clamp(20px, 5vw, 64px);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* layered depth scale (warm green-tinted shadows) */
  --shadow-sm: 0 1px 2px rgba(35,61,44,.06), 0 3px 8px -3px rgba(35,61,44,.14);
  --shadow-md: 0 4px 10px -4px rgba(35,61,44,.18), 0 16px 32px -16px rgba(35,61,44,.30);
  --shadow-lg: 0 8px 20px -8px rgba(35,61,44,.22), 0 32px 60px -28px rgba(35,61,44,.45);
  --shadow-xl: 0 12px 28px -10px rgba(35,61,44,.26), 0 48px 90px -36px rgba(35,61,44,.55);
  --ring-hairline: inset 0 0 0 1px rgba(255,255,255,.55);
  --glow-rust: 0 18px 40px -18px rgba(181,78,43,.45);

  /* fluid type scale */
  --fs-eyebrow: 0.78rem;
  --fs-body: clamp(1rem, 0.97rem + 0.2vw, 1.12rem);
  --fs-lead: clamp(1.1rem, 1rem + 0.6vw, 1.35rem);
  --fs-h3: clamp(1.3rem, 1.1rem + 0.9vw, 1.75rem);
  --fs-h2: clamp(2rem, 1.4rem + 2.6vw, 3.4rem);
  --fs-display: clamp(2.6rem, 1.2rem + 6vw, 6rem);
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: "Inter", system-ui, sans-serif;
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* subtle paper grain — adds warmth/texture without muddying contrast */
body::before {
  content: ""; position: fixed; inset: 0; z-index: 1; pointer-events: none;
  opacity: .035; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@media (prefers-reduced-motion: no-preference) { body::before { will-change: auto; } }

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; }

::selection { background: var(--forest); color: var(--lime); }

/* visible keyboard focus everywhere */
:focus-visible {
  outline: 2.5px solid var(--rust);
  outline-offset: 3px;
  border-radius: 4px;
}

.skip-link {
  position: absolute; left: 16px; top: -60px;
  background: var(--forest); color: var(--paper);
  padding: 10px 16px; border-radius: 0 0 var(--r-sm) var(--r-sm);
  z-index: 200; transition: top .2s var(--ease);
}
.skip-link:focus { top: 0; }

/* ---------- shared bits ---------- */
.eyebrow {
  font-family: "Space Mono", monospace;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rust);
  display: inline-flex; align-items: center; gap: 8px;
}
.eyebrow .paw-mark { color: var(--rust); }

/* paw mark easter-egg tooltip — hover reveals "why a paw?" */
.paw-tip { position: relative; display: inline-flex; vertical-align: middle; cursor: help; }
.paw-tip::after {
  content: attr(data-tip);
  position: absolute; top: calc(100% + 9px); left: -6px;
  width: max-content; max-width: 210px;
  background: var(--card); color: var(--forest);
  border: 1px solid var(--line); border-radius: 10px;
  font-family: "Space Mono", monospace; font-size: 0.7rem; line-height: 1.45; letter-spacing: 0.01em;
  padding: 8px 11px; box-shadow: var(--shadow-lg);
  opacity: 0; transform: translateY(-4px); pointer-events: none;
  transition: opacity .2s var(--ease), transform .2s var(--ease);
  z-index: 70;
}
.paw-tip:hover::after { opacity: 1; transform: translateY(0); }
/* eyebrow paws (e.g. the CTA "Let's talk") have text below them, so open the tooltip upward */
.eyebrow .paw-tip::after { top: auto; bottom: calc(100% + 9px); transform: translateY(4px); }
.eyebrow .paw-tip:hover::after { transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .paw-tip::after, .paw-tip:hover::after { transform: none; transition: opacity .2s; }
}

.section-head { text-align: center; margin-bottom: clamp(40px, 6vw, 72px); }
.section-head__kicker {
  font-family: "Space Mono", monospace; font-size: var(--fs-eyebrow);
  letter-spacing: 0.1em; color: var(--ink-soft); font-style: italic;
}
.section-head__title {
  font-family: "Fraunces", serif; font-weight: 400; font-size: var(--fs-h2);
  line-height: 1.05; color: var(--forest); margin-top: 12px; letter-spacing: -0.01em;
}
.section-head__title em { font-style: italic; }

/* buttons */
.btn {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: "Inter", sans-serif; font-weight: 500; font-size: 0.95rem;
  padding: 13px 22px; border-radius: 100px; border: 1px solid transparent;
  cursor: pointer; touch-action: manipulation; transition: transform .35s var(--ease), background .25s, box-shadow .35s var(--ease);
  will-change: transform;
}
.btn svg { transition: transform .35s var(--ease); }
.btn--dark { background: var(--forest); color: var(--paper); }
.btn--dark:hover { background: var(--forest-deep); box-shadow: 0 14px 30px -12px rgba(35,61,44,.55); }
.btn--dark:hover svg { transform: translate(2px, -2px); }
.btn--lg { padding: 16px 30px; font-size: 1.02rem; }

/* =========================================================
   NAV
   ========================================================= */
.nav {
  position: sticky; top: 0; z-index: 100;
  padding: 14px var(--gutter);
  background: color-mix(in srgb, var(--paper) 82%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, background .3s, padding .3s var(--ease);
}
.nav.is-scrolled {
  border-bottom-color: var(--line); padding-top: 10px; padding-bottom: 10px;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  box-shadow: 0 6px 24px -16px rgba(35,61,44,.5);
}
.nav__inner {
  max-width: var(--maxw); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.nav__brand { display: flex; align-items: center; gap: 11px; }
.nav__brand-mark { color: var(--rust); display: inline-flex; }
.nav__brand-mark .paw-mark { width: 24px; height: 24px; }
.nav__brand-text {
  font-family: "Fraunces", serif; font-size: 1.18rem; font-weight: 500;
  color: var(--forest); line-height: 1.1; display: flex; flex-direction: column;
}
.nav__brand-sub {
  font-family: "Space Mono", monospace; font-size: 0.62rem;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-soft);
  font-weight: 400; margin-top: 2px;
}
.nav__menu { display: flex; align-items: center; gap: 24px; }
.nav__links { display: flex; gap: 30px; }
.nav__links a { font-size: 0.92rem; color: var(--ink); position: relative; padding: 4px 0; }
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 1.5px;
  background: var(--rust); transform: scaleX(0); transform-origin: left;
  transition: transform .3s var(--ease);
}
.nav__links a:hover::after { transform: scaleX(1); }
.nav__links a[aria-current="page"]::after { transform: scaleX(1); }
.nav__links a[aria-current="page"] { color: var(--forest); font-weight: 600; }
.nav__cta { padding: 10px 18px; }
.nav__toggle {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: 0; cursor: pointer; padding: 8px;
}
.nav__toggle span {
  width: 22px; height: 2px; background: var(--forest); border-radius: 2px;
  transition: transform .3s var(--ease), opacity .3s;
}
.nav.is-open .nav__toggle span:first-child { transform: translateY(7px) rotate(45deg); }
.nav.is-open .nav__toggle span:nth-child(2) { opacity: 0; }
.nav.is-open .nav__toggle span:last-child { transform: translateY(-7px) rotate(-45deg); }

/* =========================================================
   HERO  (intro on top · photo + questions below)
   ========================================================= */
.hero {
  position: relative; max-width: var(--maxw); margin: 0 auto;
  padding: clamp(40px, 7vw, 88px) var(--gutter) clamp(40px, 6vw, 72px);
}
.hero__glow {
  position: absolute; inset: -14% -20% auto -20%; height: 72%;
  background:
    radial-gradient(58% 78% at 22% 28%, var(--g1) 0%, transparent 60%),
    radial-gradient(54% 70% at 50% 18%, var(--g2) 0%, transparent 64%),
    radial-gradient(70% 92% at 84% 34%, var(--g3) 0%, transparent 62%);
  filter: blur(50px); opacity: .9; z-index: -1;
  animation: drift 16s ease-in-out infinite alternate;
}
@keyframes drift { to { transform: translate3d(2%, 2%, 0) scale(1.06); } }

/* TOP: title + about-me text */
.hero__intro { max-width: 720px; }
.hero__intro .eyebrow { margin-bottom: 16px; }
.hero__title {
  font-family: "Fraunces", serif; font-weight: 300; font-style: italic;
  font-size: clamp(1.9rem, 1rem + 3.1vw, 3.6rem); line-height: 1.12;
  color: var(--forest); letter-spacing: -0.01em;
}
.hero__title-part { white-space: nowrap; }
.hero__title-key { color: var(--rust); }
.hero__title-dot { color: var(--rust); font-style: normal; margin: 0 0.12em; }
.hero__about { margin-top: 20px; font-size: var(--fs-lead); color: var(--ink); line-height: 1.55; max-width: 60ch; }

/* BELOW: photo (left) + questions (right) */
.hero__row {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: clamp(24px, 4vw, 48px); margin-top: clamp(36px, 5vw, 60px);
}
.hero__figure { position: relative; flex: none; padding: 6px; }
/* stacked gradient frame behind the portrait → depth + warmth */
.hero__figure::before {
  content: ""; position: absolute; z-index: -1;
  inset: 14px -16px -16px 14px; border-radius: var(--r-lg);
  background: var(--gradient); transform: rotate(-3.5deg);
  box-shadow: var(--shadow-md);
}
.hero__photo {
  position: relative;
  width: clamp(210px, 23vw, 290px); aspect-ratio: 3/3.4; overflow: hidden;
  border-radius: var(--r-lg);
  background: radial-gradient(120% 90% at 30% 15%, var(--lime-soft), transparent 60%), var(--gradient);
  display: grid; place-items: center;
  box-shadow: var(--shadow-xl);
  outline: 5px solid var(--card); outline-offset: -1px;
  transition: transform .5s var(--ease);
}
.hero__figure:hover .hero__photo { transform: translateY(-4px) rotate(.5deg); }
.hero__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 46%; }
.hero__photo-mark { font-family: "Fraunces", serif; font-style: italic; font-size: 2.8rem; color: rgba(35,61,44,.45); }

/* questions column */
.hero__questions { width: 100%; max-width: 440px; display: flex; flex-direction: column; gap: 12px; }
.hero__qtitle {
  font-family: "Fraunces", serif; font-weight: 400;
  font-size: clamp(1.4rem, 1.1rem + 1vw, 1.9rem); color: var(--forest);
  line-height: 1.12; margin-bottom: 6px;
}

/* =========================================================
   ASK ME (canned Q&A — bubble + chips, lives in the hero)
   ========================================================= */
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* speech bubble — to the RIGHT of the photo, slightly overlapping it, tail pointing left */
.ask__bubble {
  position: absolute;
  top: 20px; left: calc(100% - 44px);
  width: max-content; max-width: 240px;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 15px 17px; color: var(--ink); font-size: 0.95rem; line-height: 1.5;
  box-shadow: var(--shadow-lg); z-index: 5;
}
/* tail pointing LEFT toward photo */
.ask__bubble::after {
  content: ""; position: absolute;
  right: 100%; top: 22px;
  border: 9px solid transparent; border-right-color: var(--card);
}
.ask__bubble::before {
  content: ""; position: absolute;
  right: 100%; top: 21px; margin-right: -1px;
  border: 10px solid transparent; border-right-color: var(--line);
}
.ask__bubble[data-empty] {
  color: var(--ink-soft); font-family: "Space Mono", monospace; font-size: 0.8rem;
  letter-spacing: 0.04em;
}
.ask__bubble a {
  color: inherit; font-weight: inherit;
  text-decoration: underline; text-decoration-color: var(--ink-soft);
  text-underline-offset: 3px; text-decoration-thickness: 1px;
  transition: color .15s var(--ease), text-decoration-color .15s var(--ease);
}
.ask__bubble a:hover, .ask__bubble a:focus-visible { color: var(--rust); text-decoration-color: var(--rust); }
.ask__bubble strong { color: var(--forest); font-weight: 600; }
.ask__bubble.is-pop { animation: bubblePop .4s var(--ease); }
@keyframes bubblePop {
  0%   { opacity: 0; transform: translateX(-8px) scale(.97); }
  100% { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) { .ask__bubble.is-pop { animation: none; } }

/* typing dots inside the bubble */
.ask-dots { display: inline-flex; gap: 5px; align-items: center; padding: 2px 0; }
.ask-dots i { width: 7px; height: 7px; border-radius: 50%; background: var(--ink-soft); opacity: .5; animation: askDot 1.1s infinite ease-in-out; }
.ask-dots i:nth-child(2) { animation-delay: .15s; }
.ask-dots i:nth-child(3) { animation-delay: .3s; }
@keyframes askDot { 0%, 60%, 100% { transform: translateY(0); opacity: .4; } 30% { transform: translateY(-4px); opacity: 1; } }

/* question chips */
.ask__chips { display: flex; flex-direction: column; gap: 10px; align-items: stretch; }
.ask-chip {
  font-family: "Inter", sans-serif; font-size: 0.95rem; color: var(--forest); text-align: left;
  background: var(--card); border: 1px solid color-mix(in srgb, var(--rust) 24%, var(--line));
  padding: 13px 18px; border-radius: var(--r-md); cursor: pointer; touch-action: manipulation;
  box-shadow: var(--shadow-sm);
  transition: background .25s, transform .3s var(--ease-spring), border-color .25s, box-shadow .3s var(--ease);
}
.ask-chip:hover:not([aria-pressed="true"]) {
  transform: translateX(4px);
  border-color: color-mix(in srgb, var(--forest) 14%, var(--line));
  background: color-mix(in srgb, var(--g1) 30%, var(--card));
  box-shadow: var(--shadow-sm);
}
.ask-chip[aria-pressed="true"] {
  background: var(--gradient); border-color: transparent;
  box-shadow: var(--shadow-md), var(--ring-hairline);
  transform: translateX(4px);
}

/* "Any other questions?" → contact */
.ask-contact {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  margin-top: 16px; padding: 14px 18px; border-radius: var(--r-md);
  background: var(--forest); color: var(--paper);
  transition: background .25s, transform .25s var(--ease), box-shadow .25s;
}
.ask-contact:hover { background: var(--forest-deep); transform: translateY(-2px); box-shadow: 0 16px 30px -18px rgba(35,61,44,.6); }
.ask-contact__lead { font-size: 0.95rem; }
.ask-contact__cta {
  display: inline-flex; align-items: center; gap: 7px; flex: none;
  font-family: "Space Mono", monospace; font-size: 0.8rem; letter-spacing: 0.04em; color: var(--g1);
}
.ask-contact__cta svg { transition: transform .3s var(--ease); }
.ask-contact:hover .ask-contact__cta svg { transform: translate(2px, -2px); }

/* stack the hero row on narrow viewports */
@media (max-width: 820px) {
  .hero__title { white-space: normal; }
  .hero__title-part { white-space: normal; }
  .hero__row { flex-direction: column; align-items: stretch; gap: 0; margin-top: clamp(32px, 6vw, 56px); }
  /* figure stacks the answer bubble above the photo in normal flow → it can't cover the questions */
  .hero__figure {
    align-self: center; order: 2; margin-top: clamp(28px, 7vw, 44px);
    display: flex; flex-direction: column; align-items: center; gap: 18px;
  }
  .hero__figure::before { display: none; } /* drop the offset frame so it doesn't sit behind the bubble */
  .hero__photo { width: clamp(180px, 56vw, 230px); }
  .hero__questions { max-width: none; order: 1; }
  /* bubble flows above the photo and pushes it down, instead of floating up over the questions */
  .ask__bubble {
    position: relative; top: auto; bottom: auto; left: auto; transform: none;
    width: max-content; max-width: min(340px, 86vw);
  }
  .ask__bubble::after {
    right: auto; top: 100%; left: 50%; margin-left: -9px; margin-right: 0;
    border-right-color: transparent; border-top-color: var(--card);
  }
  .ask__bubble::before {
    right: auto; top: 100%; left: 50%; margin-left: -10px; margin-right: 0; margin-top: 1px;
    border-right-color: transparent; border-top-color: var(--line);
  }
  .ask__bubble.is-pop { animation: bubblePopMobile .4s var(--ease); }
}
@keyframes bubblePopMobile {
  0%   { opacity: 0; transform: translateY(8px) scale(.97); }
  100% { opacity: 1; transform: none; }
}

/* =========================================================
   GATEWAYS (two nav cards: Work + About)
   ========================================================= */
.gateways {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(40px, 6vw, 72px) var(--gutter);
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 3vw, 32px);
}
.gateway {
  position: relative; overflow: hidden; isolation: isolate;
  display: flex; flex-direction: column; align-items: flex-start; gap: 12px;
  padding: clamp(28px, 4vw, 44px);
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s;
}
/* gradient wash slides up on hover */
.gateway::before {
  content: ""; position: absolute; inset: 0; z-index: -1; opacity: 0;
  background: radial-gradient(120% 100% at 100% 0%, var(--g3) 0%, transparent 55%),
              radial-gradient(120% 100% at 0% 100%, var(--g1) 0%, transparent 55%);
  transition: opacity .45s var(--ease);
}
.gateway:hover {
  transform: translateY(-6px); box-shadow: var(--shadow-lg);
  border-color: color-mix(in srgb, var(--rust) 30%, var(--line));
}
.gateway:hover::before { opacity: .5; }
.gateway__title {
  font-family: "Fraunces", serif; font-weight: 500;
  font-size: clamp(1.5rem, 1.1rem + 1.4vw, 2.1rem); color: var(--forest); line-height: 1.1;
}
.gateway__desc { color: var(--ink-soft); line-height: 1.6; max-width: 34ch; }
.gateway__link {
  margin-top: 6px; display: inline-flex; align-items: center; gap: 9px;
  font-family: "Space Mono", monospace; font-size: 0.8rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--forest);
  border-bottom: 1.5px solid var(--rust); padding-bottom: 3px;
}
.gateway__link svg { color: var(--rust); transition: transform .3s var(--ease); }
.gateway:hover .gateway__link svg { transform: translateX(4px); }

/* =========================================================
   PAGE HEADER (Work / About subpages)
   ========================================================= */
.page {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(36px, 6vw, 72px) var(--gutter) clamp(40px, 6vw, 72px);
}
.page-hero { max-width: var(--maxw-read); margin-bottom: clamp(40px, 6vw, 64px); }
.page-hero .eyebrow { margin-bottom: 16px; }
.page-hero__title {
  font-family: "Fraunces", serif; font-weight: 300; font-style: italic;
  font-size: clamp(2.2rem, 1.4rem + 3vw, 3.6rem); color: var(--forest);
  line-height: 1.02; letter-spacing: -0.02em;
}
.page-hero__lead { margin-top: 20px; font-size: var(--fs-lead); color: var(--ink); line-height: 1.55; }
.page-hero__lead strong { color: var(--forest); font-weight: 600; }
.page-hero__lead a { color: var(--rust); border-bottom: 1.5px solid currentColor; }

/* =========================================================
   WORK PAGE — project blocks, split case cards, testimonials
   ========================================================= */
:root { --case-green: #DCE8BE; }

.work-page .page { counter-reset: project; }
.project-block {
  counter-increment: project;
  position: relative;
  margin-top: clamp(20px, 2.5vw, 28px);
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(28px, 4vw, 52px);
  box-shadow: var(--shadow-sm);
}
.project-block:hover { box-shadow: var(--shadow-md); transition: box-shadow .2s; }
.project-block__head {
  max-width: var(--maxw-read); margin-bottom: clamp(24px, 3vw, 40px);
  position: relative;
}
.project-block__head::after {
  content: '0' counter(project);
  position: absolute; right: -4px; top: -8px;
  font-family: "Fraunces", serif; font-style: italic;
  font-size: clamp(5rem, 7vw, 8rem);
  color: var(--forest); opacity: .05;
  line-height: 1; pointer-events: none; user-select: none;
}
.project-block__tags {
  font-family: "Space Mono", monospace; font-size: 0.78rem; letter-spacing: 0.04em;
  color: var(--ink-soft); margin-bottom: 14px;
}
.project-block__title {
  font-family: "Fraunces", serif; font-weight: 500;
  font-size: clamp(1.9rem, 1.3rem + 1.8vw, 2.8rem); color: var(--forest); line-height: 1.1;
}
.project-block__title a { color: inherit; border-bottom: 2px solid transparent; transition: border-color .25s; }
.project-block__title a:hover { border-bottom-color: var(--rust); }
.project-block__desc { margin-top: 14px; color: var(--ink-soft); line-height: 1.6; }
.cases-label {
  font-family: "Space Mono", monospace; font-size: 0.72rem;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--rust); margin-bottom: 14px;
}
.project-block .testimonial,
.project-block .testimonials-pair {
  border-top: 1px solid var(--line);
  padding-top: clamp(24px, 3.5vw, 40px);
}
.project-divider {
  border: 0;
  border-top: 1.5px solid color-mix(in srgb, var(--rust) 25%, var(--line));
  margin: clamp(52px, 7vw, 88px) 0 0;
}

/* split case card: peach text panel overlapping a green photo panel */
.cases-pair { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 3vw, 36px); }

.case-card {
  position: relative; display: grid; grid-template-columns: 1.02fr 0.98fr;
  align-items: stretch; color: inherit;
  transition: transform .35s var(--ease);
}
.case-card:hover { transform: translateY(-6px); }
.case-card__text {
  position: relative; z-index: 2;
  background: var(--gradient);
  border-radius: var(--r-lg); padding: clamp(24px, 2.6vw, 34px);
  display: flex; flex-direction: column;
  box-shadow: var(--shadow-md);
  transition: box-shadow .4s var(--ease);
}
.case-card:hover .case-card__text { box-shadow: var(--shadow-lg); }
.case-card__photo {
  position: relative; margin-left: clamp(-30px, -2vw, -18px);
  background:
    radial-gradient(140% 120% at 85% 12%, color-mix(in srgb, var(--g1) 70%, #fff) 0%, transparent 55%),
    var(--case-green);
  border-radius: var(--r-lg);
  display: grid; place-items: center; min-height: 230px; padding: 20px;
  box-shadow: inset 0 0 0 1px rgba(35,61,44,.06), var(--shadow-sm);
}
/* faint dotted texture so empty photo panels don't read as dead space */
.case-card__photo::after {
  content: ""; position: absolute; inset: 12px; border-radius: var(--r-md);
  background-image: radial-gradient(rgba(35,61,44,.10) 1px, transparent 1.4px);
  background-size: 14px 14px; opacity: .5; pointer-events: none;
}
.case-card__photo-label {
  position: relative; z-index: 1;
  font-family: "Space Mono", monospace; font-size: 0.82rem; color: var(--forest); opacity: .55;
}
.case-card__badge {
  position: absolute; top: 16px; right: 16px; z-index: 2;
  display: inline-flex; align-items: center; gap: 6px;
  font-family: "Space Mono", monospace; font-size: 0.75rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--forest);
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  border: 1px solid color-mix(in srgb, var(--forest) 12%, var(--line));
  padding: 5px 10px; border-radius: 100px; backdrop-filter: blur(4px);
}
.lock-glyph {
  width: 9px; height: 11px; border: 1.3px solid currentColor; border-radius: 2px;
  border-top: 0; position: relative; display: inline-block; margin-top: 3px;
}
.lock-glyph::before {
  content: ""; position: absolute; left: 50%; bottom: 100%; transform: translateX(-50%);
  width: 7px; height: 6px; border: 1.3px solid currentColor; border-bottom: 0;
  border-radius: 4px 4px 0 0;
}
.case-card__title {
  font-family: "Fraunces", serif; font-weight: 500;
  font-size: clamp(1.4rem, 1.1rem + 1vw, 1.9rem); color: var(--forest); margin-bottom: 10px;
}
.case-card__label {
  font-family: "Space Mono", monospace; font-size: 0.74rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--rust); margin-bottom: 14px;
}
.case-card__label strong { font-weight: 700; }
.case-card__body {
  font-family: "Space Mono", monospace; font-size: 0.84rem; line-height: 1.7; color: var(--forest);
}
.case-card__link {
  margin-top: auto; padding-top: 18px;
  font-family: "Space Mono", monospace; font-size: 0.82rem; color: var(--forest);
}
.case-card__link--muted { color: var(--ink-soft); }

/* ResearchOps wide variant */
.case-card--wide { grid-template-columns: 1.18fr 0.82fr; }
.case-card--wide .case-card__photo { min-height: 320px; }

/* Customer-journey "coming soon" — single peach panel, no photo */
.case-card--soon { display: block; max-width: 460px; }
.case-card--soon:hover { transform: none; }
.case-card--soon .case-card__text { border-radius: var(--r-lg); }

/* testimonials */
.testimonial {
  display: grid; grid-template-columns: 150px 1fr; gap: clamp(20px, 3vw, 36px);
  align-items: start; margin-top: clamp(28px, 4vw, 44px);
}
.testimonial__aside { position: sticky; top: 90px; }
.testimonial__photo {
  aspect-ratio: 1 / 1.05; border-radius: var(--r-md);
  background: var(--gradient);
  display: grid; place-items: center; margin-bottom: 14px; overflow: hidden;
}
.testimonial__photo span { font-family: "Space Mono", monospace; font-size: 0.78rem; color: var(--forest); opacity: .55; }
.testimonial__photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.testimonial__label {
  font-family: "Space Mono", monospace; font-size: 0.72rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--rust); line-height: 1.7;
}
.testimonial__quote {
  position: relative; margin: 0; background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: clamp(22px, 2.6vw, 34px);
  box-shadow: var(--shadow-md);
}
.testimonial__quote::before {
  content: "\201C"; position: absolute; top: -0.18em; right: 0.34em;
  font-family: "Fraunces", serif; font-style: italic; font-size: 4.5rem;
  line-height: 1; color: var(--g3); opacity: .55; pointer-events: none;
}
.testimonial__quote p {
  font-family: "Space Mono", monospace; font-size: 0.82rem; line-height: 1.75; color: var(--forest);
}
.testimonial__quote p + p { margin-top: 1em; }

.testimonials-pair { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 48px); }
.testimonial--compact { grid-template-columns: 110px 1fr; gap: 18px; margin-top: clamp(28px, 4vw, 44px); }
.testimonial--compact .testimonial__quote { padding: clamp(18px, 2vw, 26px); }
.testimonial--compact .testimonial__quote p { font-size: 0.76rem; line-height: 1.7; }

.testimonial__more {
  display: inline-block; margin-top: 22px;
  font-family: "Space Mono", monospace; font-size: 0.82rem; color: var(--forest);
  border-bottom: 1.5px solid var(--rust); padding-bottom: 2px;
}

/* =========================================================
   SNAPSHOT (Visma role + projects)
   ========================================================= */
.snapshot {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(48px, 7vw, 100px) var(--gutter) clamp(40px, 6vw, 70px);
  border-top: 1px solid var(--line);
}
.snapshot__intro {
  max-width: var(--maxw-read); margin: 0 auto clamp(44px, 6vw, 72px);
  text-align: center;
}
.snapshot__intro p { color: var(--ink); font-size: var(--fs-lead); line-height: 1.5; }
.snapshot__meta {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-top: 24px;
}
.snapshot__meta li {
  font-family: "Space Mono", monospace; font-size: 0.74rem;
  letter-spacing: 0.04em; color: var(--ink-soft);
  padding: 7px 14px; border: 1px solid var(--line); border-radius: 100px;
  background: var(--card);
}

/* project cards */
.projects { display: grid; gap: clamp(28px, 4vw, 44px); }
.project {
  display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(24px, 4vw, 56px);
  align-items: center;
}
.project:nth-child(even) { grid-template-columns: 1fr 1.05fr; }
.project:nth-child(even) .project__media { order: 2; }

.project__media {
  display: block; position: relative; border-radius: var(--r-lg);
  overflow: hidden; border: 1px solid var(--line);
}
.project__thumb {
  aspect-ratio: 4/3; width: 100%; transition: transform .6s var(--ease);
}
.project__media:hover .project__thumb { transform: scale(1.04); }
.project__thumb--1 { background: var(--gradient); }
.project__thumb--2 { background: linear-gradient(140deg, var(--g2) 0%, var(--g1) 100%); }
.project__thumb--3 { background: linear-gradient(140deg, var(--lime-soft) 0%, var(--g3) 100%); }

.project__lock {
  position: absolute; top: 14px; right: 14px;
  display: inline-flex; align-items: center; gap: 6px;
  font-family: "Space Mono", monospace; font-size: 0.68rem;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--forest); background: color-mix(in srgb, var(--paper) 88%, transparent);
  border: 1px solid var(--line); padding: 5px 10px; border-radius: 100px;
  backdrop-filter: blur(4px);
}
.project__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.project__tags span {
  font-family: "Space Mono", monospace; font-size: 0.72rem; letter-spacing: 0.04em;
  color: var(--ink-soft); border: 1px solid var(--line); padding: 4px 11px; border-radius: 100px;
}
.project__title {
  font-family: "Fraunces", serif; font-weight: 500; font-size: var(--fs-h3);
  color: var(--forest); line-height: 1.1; margin-bottom: 4px;
}
.project__kicker {
  font-family: "Space Mono", monospace; font-size: 0.78rem;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--rust); margin-bottom: 12px;
}
.project__desc { color: var(--ink-soft); line-height: 1.6; margin-bottom: 16px; }
.project__action {
  font-family: "Space Mono", monospace; font-size: 0.82rem; color: var(--forest);
  border-bottom: 1.5px solid var(--rust); padding-bottom: 2px;
}
.project--placeholder { opacity: .72; }
.project--placeholder .project__thumb { filter: grayscale(0.25); }

/* =========================================================
   APPROACH / STEPS
   ========================================================= */
.approach { max-width: var(--maxw); margin: 0 auto; padding: clamp(48px, 7vw, 90px) var(--gutter); }
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; position: relative; }
.step {
  position: relative; overflow: hidden; isolation: isolate;
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: clamp(26px, 3vw, 38px);
  box-shadow: var(--shadow-sm);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s;
}
.step::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 4px;
  background: var(--gradient); transform: scaleX(0); transform-origin: left;
  transition: transform .45s var(--ease);
}
.step:hover {
  transform: translateY(-8px); box-shadow: var(--shadow-lg);
  border-color: color-mix(in srgb, var(--rust) 26%, var(--line));
}
.step:hover::before { transform: scaleX(1); }
.step--mid { transform: translateY(22px); }
.step--mid:hover { transform: translateY(14px); }
.step__num {
  font-family: "Fraunces", serif; font-size: 3rem; font-style: italic;
  line-height: 1; display: block; margin-bottom: 18px;
  background: linear-gradient(135deg, var(--rust), var(--g3));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.step__title {
  font-family: "Fraunces", serif; font-weight: 500; font-size: var(--fs-h3);
  color: var(--forest); margin-bottom: 10px;
}
.step__body { color: var(--ink-soft); font-size: 0.98rem; line-height: 1.6; }

/* =========================================================
   ABOUT
   ========================================================= */
.about { max-width: var(--maxw); margin: 0 auto; padding: clamp(48px, 7vw, 100px) var(--gutter); }
.about__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px, 5vw, 64px); align-items: start; }
.about__bio { position: relative; }
.about__photo {
  position: relative;
  aspect-ratio: 4/3.4; border-radius: var(--r-lg); overflow: hidden;
  display: grid; place-items: center;
  background:
    radial-gradient(120% 90% at 70% 20%, var(--g2), transparent 55%), var(--gradient);
  box-shadow: var(--shadow-xl);
  outline: 5px solid var(--card); outline-offset: -1px;
}
.about__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 40%; }
.about__photo span { font-family: "Fraunces", serif; font-style: italic; font-size: 3rem; color: rgba(35,61,44,.4); }
/* bio photos — desktop: stacked, mobile: carousel */
.bio-photos { display: flex; flex-direction: column; gap: 20px; }
.bio-photos__frame { display: flex; flex-direction: column; gap: 20px; }
.bio-photos__slide {
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--shadow-sm); display: flex; flex-direction: column;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
}
.bio-photos__slide:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.bio-photos__img {
  width: 100%; aspect-ratio: 4 / 3;
  background: var(--gradient);
  display: grid; place-items: center; overflow: hidden;
}
.bio-photos__img img { width: 100%; height: 100%; object-fit: cover; object-position: center 40%; display: block; }
.bio-photos__caption {
  padding: 14px 18px;
  font-family: "Space Mono", monospace; font-size: 0.72rem;
  color: var(--ink-soft); line-height: 1.6; letter-spacing: 0.01em;
}
.bio-photos__controls { display: none; }

@media (max-width: 700px) {
  .bio-photos__frame { gap: 0; }
  .bio-photos__slide { display: none; }
  .bio-photos__slide.is-active { display: flex; }
  .bio-photos__controls {
    display: flex; align-items: center; justify-content: center; gap: 12px; margin-top: 16px;
  }
  .bio-photos__btn {
    display: grid; place-items: center;
    width: 44px; height: 44px; border-radius: 50%;
    border: 1px solid var(--line); background: var(--card);
    cursor: pointer; color: var(--forest); touch-action: manipulation;
    transition: border-color 0.15s, box-shadow 0.15s;
  }
  .bio-photos__btn:hover { border-color: var(--forest); box-shadow: var(--shadow-sm); }
  .bio-photos__dots { display: flex; gap: 0; align-items: center; }
  .bio-photos__dot {
    padding: 16px;
    width: 7px; height: 7px; border-radius: 50%;
    border: none; background-color: var(--line);
    background-clip: content-box;
    cursor: pointer; touch-action: manipulation;
    transition: background-color 0.2s;
  }
  .bio-photos__dot.is-active { background-color: var(--forest); }
}

.about__text p { color: var(--ink); margin-bottom: 18px; max-width: 56ch; }
.about__text p.about__lead { font-size: clamp(1.15rem, 1.05rem + 0.5vw, 1.3rem); line-height: 1.55; color: var(--forest); margin-bottom: 22px; }
.about__text strong { color: var(--forest); font-weight: 600; }
.cv { width: 100%; border-collapse: collapse; margin-top: 28px; }
.cv tr { border-top: 1px solid var(--line); }
.cv tr:last-child { border-bottom: 1px solid var(--line); }
.cv th, .cv td { text-align: left; padding: 16px 8px; vertical-align: baseline; }
.cv th { font-family: "Fraunces", serif; font-weight: 500; font-size: 1.05rem; color: var(--forest); }
.cv td { color: var(--ink-soft); font-size: 0.92rem; }
.cv__company-desc { display: block; font-size: 0.78rem; color: var(--ink-soft); margin-top: 3px; }
.cv__years { font-family: "Space Mono", monospace; font-size: 0.82rem; text-align: right !important; white-space: nowrap; }
.cv tr[data-placeholder] th, .cv tr[data-placeholder] td { opacity: .55; }

/* =========================================================
   CTA
   ========================================================= */
.cta {
  position: relative; text-align: center; overflow: hidden;
  margin: clamp(40px, 6vw, 80px) var(--gutter) 0;
  border-radius: var(--r-xl); padding: clamp(64px, 10vw, 130px) var(--gutter);
  background: var(--gradient);
  box-shadow: var(--shadow-xl), inset 0 1px 0 rgba(255,255,255,.5);
}
.cta--case { margin-top: clamp(56px, 8vw, 110px); }
.cta__glow { position: absolute; inset: 0; z-index: 0; background: radial-gradient(50% 60% at 50% 0%, rgba(255,255,255,.5), transparent 60%); }
.cta > * { position: relative; z-index: 1; }
.cta .eyebrow { color: var(--forest-deep); margin-bottom: 16px; }
.cta .eyebrow .paw-mark { color: var(--forest-deep); }
.cta__title {
  font-family: "Fraunces", serif; font-weight: 300;
  font-size: clamp(2.4rem, 1.4rem + 4vw, 4.6rem);
  color: var(--forest-deep); line-height: 1; letter-spacing: -0.02em;
}
.cta__lead { max-width: 44ch; margin: 22px auto 34px; color: var(--forest); font-size: var(--fs-lead); }
.cta__actions { display: flex; gap: 22px; align-items: center; justify-content: center; flex-wrap: wrap; }
.cta__link {
  font-family: "Space Mono", monospace; font-size: 0.9rem; color: var(--forest-deep);
  border-bottom: 1.5px solid currentColor; padding-bottom: 2px; transition: opacity .25s;
}
.cta__link:hover { opacity: .65; }

/* =========================================================
   PROJECT OVERVIEW (public parent page)
   ========================================================= */
.overview { max-width: var(--maxw); margin: 0 auto; padding: clamp(40px, 7vw, 90px) var(--gutter) clamp(56px, 8vw, 100px); }
.overview__inner { max-width: var(--maxw-read); }
.overview .eyebrow { margin: 22px 0 18px; }
.overview__title {
  font-family: "Fraunces", serif; font-weight: 300;
  font-size: clamp(2.2rem, 1.4rem + 3vw, 3.8rem); color: var(--forest);
  line-height: 1.02; letter-spacing: -0.02em;
}
.overview__lead { font-size: var(--fs-lead); color: var(--ink); margin-top: 22px; line-height: 1.55; }
.overview__note {
  margin-top: 26px; font-size: 0.95rem; color: var(--ink-soft);
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.overview__note a { color: var(--rust); border-bottom: 1.5px solid currentColor; }
.lock-inline { color: var(--rust); display: inline-flex; }

.overview__cases { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 3vw, 32px); margin-top: clamp(40px, 6vw, 64px); }
.overview-case {
  display: flex; flex-direction: column; position: relative;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: clamp(26px, 3vw, 38px);
  box-shadow: var(--shadow-sm);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s;
}
.overview-case:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: color-mix(in srgb, var(--rust) 40%, var(--line)); }
.overview-case__lock {
  align-self: flex-start; display: inline-flex; align-items: center; gap: 6px;
  font-family: "Space Mono", monospace; font-size: 0.68rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--rust);
  border: 1px solid var(--line); padding: 5px 10px; border-radius: 100px; margin-bottom: 18px;
}
.overview-case__role { font-family: "Space Mono", monospace; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); }
.overview-case__title { font-family: "Fraunces", serif; font-weight: 500; font-size: var(--fs-h3); color: var(--forest); line-height: 1.12; margin: 8px 0 12px; }
.overview-case__teaser { color: var(--ink-soft); line-height: 1.6; margin-bottom: 20px; }
.overview-case__action { margin-top: auto; font-family: "Space Mono", monospace; font-size: 0.82rem; color: var(--forest); border-bottom: 1.5px solid var(--rust); padding-bottom: 2px; align-self: flex-start; }

.soon-badge {
  font-family: "Space Mono", monospace; font-size: 0.7rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--forest);
  background: var(--gradient); padding: 5px 12px; border-radius: 100px;
}
.overview--soon { min-height: 50vh; }

/* =========================================================
   CASE STUDY
   ========================================================= */
.case-back {
  font-family: "Space Mono", monospace; font-size: 0.78rem; color: var(--ink-soft);
  display: inline-block; padding: 7px 15px;
  border: 1px solid var(--line); border-radius: 100px;
  transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.case-back:hover { color: var(--rust); border-color: color-mix(in srgb, var(--rust) 50%, var(--line)); background: color-mix(in srgb, var(--rust) 6%, transparent); }

.case-hero { max-width: var(--maxw); margin: 0 auto; padding: clamp(36px, 6vw, 72px) var(--gutter) 0; }
.case-hero__inner { max-width: var(--maxw-read); }
.case-hero__eyebrow { display: flex; width: fit-content; max-width: 100%; margin: 32px 0 18px; }
.case-hero__title {
  font-family: "Fraunces", serif; font-weight: 400;
  font-size: clamp(2.4rem, 1.5rem + 3vw, 3.9rem); color: var(--forest);
  line-height: 1.04; letter-spacing: -0.02em;
}
.case-hero__role { margin-top: 16px; font-size: 0.95rem; color: var(--ink-soft); }
.case-hero__role-label {
  font-family: "Space Mono", monospace; font-size: 0.7rem; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--rust); margin-right: 8px;
}
.case-hero__summary { margin-top: 20px; font-size: var(--fs-lead); color: var(--ink); line-height: 1.5; }
.case-hero__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
.case-hero__tags li {
  font-family: "Space Mono", monospace; font-size: 0.72rem; letter-spacing: 0.04em;
  color: var(--ink-soft); border: 1px solid var(--line); padding: 4px 11px; border-radius: 100px;
}

/* metric chips */
.metrics {
  display: flex; flex-wrap: wrap; gap: 16px; margin-top: 32px;
  padding: 24px; border: 1px solid var(--line); border-radius: var(--r-md);
  background:
    radial-gradient(130% 100% at 100% 0%, color-mix(in srgb, var(--g3) 30%, var(--card)) 0%, var(--card) 55%);
  box-shadow: var(--shadow-md);
}
.metric { min-width: 150px; }
.metric__label { font-family: "Space Mono", monospace; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); }
.metric__value { font-family: "Fraunces", serif; font-weight: 500; font-size: clamp(1.8rem, 1.3rem + 1.6vw, 2.6rem); color: var(--rust); line-height: 1; margin-top: 6px; }
.metric__note { font-size: 0.78rem; color: var(--ink-soft); margin-top: 6px; max-width: 28ch; }

/* case intro summary block */
.case-intro {
  max-width: var(--maxw);
  margin: clamp(44px, 6vw, 76px) auto 0;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 16px;
}
.case-intro__left { display: flex; flex-direction: column; gap: 16px; }
.case-intro__problem {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(24px, 3vw, 36px);
  box-shadow: var(--shadow-sm);
}
.case-intro__problem-eyebrow {
  font-family: "Space Mono", monospace;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  margin-bottom: 14px;
}
.case-intro__problem-title {
  font-family: "Fraunces", serif;
  font-weight: 500;
  font-size: clamp(1.4rem, 1rem + 1.2vw, 2rem);
  color: var(--forest);
  line-height: 1.15;
}
.case-intro__problem-title em { color: var(--rust); font-style: normal; }
.case-intro__testimonial {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(20px, 2.5vw, 28px);
  box-shadow: var(--shadow-sm);
  flex: 1;
}
.case-intro__testimonial blockquote { margin: 0; }
.case-intro__testimonial blockquote::before {
  content: '\201C';
  font-family: "Fraunces", serif;
  font-size: 2.4rem;
  color: var(--rust);
  line-height: 1;
  display: block;
  margin-bottom: 4px;
}
.case-intro__testimonial p {
  font-size: 0.92rem;
  line-height: 1.6;
  color: var(--ink);
  margin: 0 0 14px;
}
.case-intro__testimonial cite {
  display: flex;
  align-items: center;
  gap: 10px;
  font-style: normal;
  font-size: 0.82rem;
}
.case-intro__avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--g2);
  border: 1.5px solid var(--line);
  overflow: hidden;
  flex: none;
}
.case-intro__avatar img { width: 100%; height: 100%; object-fit: cover; }
.case-intro__cite-name { font-weight: 600; color: var(--forest); }
.case-intro__cite-role { color: var(--ink-soft); }
.case-intro__screens {
  background: var(--gradient);
  border-radius: var(--r-lg);
  min-height: 300px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: var(--ink-soft);
  font-family: "Space Mono", monospace;
  font-size: 0.74rem;
  text-align: center;
  padding: 24px;
  overflow: hidden;
}
.case-intro__screens img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: clamp(16px, 3vw, 32px);
  border-radius: 0;
}
.case-intro__metrics {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
}
.case-intro__metric {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(18px, 2vw, 24px);
  box-shadow: var(--shadow-sm);
}
.case-intro__metric-label {
  font-family: "Space Mono", monospace;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
  margin-bottom: 10px;
}
.case-intro__metric-value {
  font-family: "Fraunces", serif;
  font-weight: 500;
  font-size: clamp(2rem, 1.4rem + 1.8vw, 2.8rem);
  color: var(--rust);
  line-height: 1;
}
.case-intro__metric-note {
  font-size: 0.78rem;
  color: var(--ink-soft);
  margin-top: 6px;
}
@media (max-width: 700px) {
  .case-intro { grid-template-columns: 1fr; }
  .case-intro__screens { min-height: 220px; }
}

/* case body rows: text beside annotated artefact */
.case-body { max-width: var(--maxw); margin: 0 auto; padding: clamp(40px, 6vw, 80px) var(--gutter) 0; }
.case-row {
  display: grid; gap: clamp(24px, 4vw, 48px); align-items: start;
  padding: clamp(28px, 4vw, 52px) 0; border-top: 1px solid var(--line);
}
.case-row:first-child { border-top: 0; }
.case-row--right { grid-template-columns: 1fr 1.1fr; }
.case-row--left { grid-template-columns: 1.1fr 1fr; }
.case-row--left .case-row__text { order: 2; }
.case-row--full { grid-template-columns: 1fr; }
.case-row--full .case-row__text { max-width: var(--maxw-read); }

.case-row__kicker { font-family: "Space Mono", monospace; font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--rust); }
.case-row__heading { font-family: "Fraunces", serif; font-weight: 500; font-size: var(--fs-h3); color: var(--forest); line-height: 1.12; margin: 8px 0 16px; }
.case-row__text p { color: var(--ink); line-height: 1.65; margin-bottom: 14px; max-width: 60ch; }
.case-row__text strong { color: var(--forest); font-weight: 600; }
.case-points { margin: 6px 0 14px; display: grid; gap: 10px; }
.case-points li { position: relative; padding-left: 22px; color: var(--ink); line-height: 1.55; }
.case-points li::before { content: ""; position: absolute; left: 2px; top: 0.6em; width: 8px; height: 8px; border-radius: 50%; background: var(--rust); }

.case-quote {
  margin: 20px 0; padding: 22px 24px; border-left: 3px solid var(--rust);
  background: var(--paper-2); border-radius: 0 var(--r-md) var(--r-md) 0;
}
.case-quote p { font-family: "Fraunces", serif; font-style: italic; font-size: 1.2rem; color: var(--forest); line-height: 1.4; }
.case-quote cite { display: block; margin-top: 12px; font-style: normal; font-family: "Space Mono", monospace; font-size: 0.78rem; color: var(--ink-soft); }

/* annotated artefact placeholder */
.artefact { margin: 0; }
.artefact img { width: 100%; display: block; border-radius: var(--r-md); background: var(--gradient); }
.artefact__placeholder {
  position: relative; display: flex; flex-direction: column; justify-content: center; gap: 12px;
  min-height: 260px; padding: 28px;
  border: 1.5px dashed color-mix(in srgb, var(--rust) 45%, var(--line));
  border-radius: var(--r-md); background: var(--paper-2);
}
.artefact__tag {
  align-self: flex-start; font-family: "Space Mono", monospace; font-size: 0.75rem;
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--rust);
  border: 1px solid color-mix(in srgb, var(--rust) 35%, var(--line)); padding: 4px 9px; border-radius: 100px;
}
.artefact__shows { font-family: "Fraunces", serif; font-style: italic; font-size: 1.05rem; color: var(--forest); line-height: 1.4; }
.artefact__caption {
  margin-top: 12px; display: flex; gap: 8px; align-items: flex-start;
  font-size: 0.82rem; color: var(--ink-soft); line-height: 1.5;
}
.artefact__pin { flex: none; width: 9px; height: 9px; margin-top: 6px; border-radius: 50%; background: var(--rust); box-shadow: 0 0 0 4px color-mix(in srgb, var(--rust) 18%, transparent); }

/* next case */
.case-next { max-width: var(--maxw); margin: 0 auto; padding: clamp(32px, 5vw, 56px) var(--gutter) 0; }
.case-next a { display: flex; flex-direction: column; gap: 4px; padding: 26px 28px; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--card); box-shadow: var(--shadow-sm); transition: transform .35s var(--ease), border-color .3s, box-shadow .35s var(--ease); }
.case-next a:hover { transform: translateY(-4px); border-color: color-mix(in srgb, var(--rust) 40%, var(--line)); box-shadow: var(--shadow-lg); }
.case-next__label { font-family: "Space Mono", monospace; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-soft); }
.case-next__title { font-family: "Fraunces", serif; font-weight: 500; font-size: var(--fs-h3); color: var(--forest); }

/* =========================================================
   UNLOCK (password gate page)
   ========================================================= */
.unlock { display: grid; place-items: center; padding: clamp(48px, 9vw, 120px) var(--gutter); min-height: 70vh; }
.unlock__card {
  max-width: 480px; width: 100%; text-align: center;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--r-xl);
  padding: clamp(32px, 5vw, 56px); box-shadow: var(--shadow-xl);
}
.unlock__mark { color: var(--rust); display: flex; justify-content: center; margin-bottom: 16px; }
.unlock__mark .paw-mark { width: 34px; height: 34px; }
.unlock .eyebrow { justify-content: center; }
.unlock__title { font-family: "Fraunces", serif; font-weight: 300; font-size: clamp(1.8rem, 1.3rem + 1.6vw, 2.6rem); color: var(--forest); line-height: 1.1; margin: 14px 0 14px; letter-spacing: -0.01em; }
.unlock__lead { color: var(--ink-soft); line-height: 1.6; margin-bottom: 28px; }
.unlock__lead a { color: var(--rust); border-bottom: 1.5px solid currentColor; }
.unlock__form { text-align: left; }
.unlock__label { font-family: "Space Mono", monospace; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-soft); display: block; margin-bottom: 8px; }
.unlock__field { display: flex; gap: 10px; }
.unlock__field input {
  flex: 1; font-family: "Inter", sans-serif; font-size: 1rem; color: var(--forest);
  padding: 13px 16px; border: 1px solid var(--line); border-radius: 100px; background: var(--paper);
  transition: border-color .25s;
}
.unlock__field input:focus { border-color: var(--rust); }
.unlock__field input:focus:not(:focus-visible) { outline: none; }
.unlock__error { margin-top: 14px; font-size: 0.85rem; color: var(--rust); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer { max-width: var(--maxw); margin: 0 auto; padding: clamp(40px, 5vw, 64px) var(--gutter) 24px; overflow: hidden; }
.footer__top { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; padding-bottom: clamp(24px, 4vw, 48px); }
.footer__brand { display: inline-flex; align-items: center; gap: 9px; font-family: "Fraunces", serif; font-size: 1.05rem; color: var(--forest); }
.footer__brand-mark { color: var(--rust); display: inline-flex; }
.footer__brand-mark .paw-mark { width: 20px; height: 20px; }
.footer__nav { display: flex; gap: 26px; flex-wrap: wrap; }
.footer__nav a { font-size: 0.9rem; color: var(--ink-soft); transition: color .25s; }
.footer__nav a:hover { color: var(--forest); }
.footer__copy { font-family: "Space Mono", monospace; font-size: 0.8rem; color: var(--ink-soft); }
.footer__scene { display: block; width: 100vw; margin-left: 50%; transform: translateX(-50%); height: clamp(150px, 20vw, 280px); margin-top: clamp(24px, 4vw, 48px); }
.footer__scene .flower { transform-box: view-box; transition: transform .55s cubic-bezier(.22,1,.36,1); }
.footer__scene .flower__sway { transform-box: view-box; animation: sway 4.2s ease-in-out infinite; }
.footer__scene .flower:nth-child(2n) .flower__sway { animation-duration: 5.1s; animation-delay: -1.3s; }
.footer__scene .flower:nth-child(3n) .flower__sway { animation-duration: 3.6s; animation-delay: -.7s; }
.footer__scene .flower:nth-child(5n) .flower__sway { animation-duration: 4.8s; animation-delay: -2.1s; }
@keyframes sway { 0%, 100% { transform: rotate(-1.6deg); } 50% { transform: rotate(1.6deg); } }
@media (prefers-reduced-motion: reduce) {
  .footer__scene .flower__sway { animation: none; }
  .footer__scene .flower { transition: none; }
}
.footer__wordmark {
  font-family: "Fraunces", serif; font-style: italic; font-weight: 300;
  font-size: clamp(3rem, 1rem + 13vw, 12rem); line-height: 0.9; color: var(--forest);
  text-align: center; letter-spacing: -0.02em; opacity: .92; margin-top: clamp(8px, 2vw, 24px);
}

/* =========================================================
   NEW PROJECT CARDS (editorial split style)
   ========================================================= */
.proj-cards { display: grid; gap: clamp(20px, 3vw, 30px); }

.proj-card {
  display: grid; grid-template-columns: 1fr;
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--shadow-md); color: inherit;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .3s;
}
.proj-card--soon { opacity: .68; pointer-events: none; }
/* pair layout: two cards side by side */
.proj-cards--pair { grid-template-columns: 1fr 1fr; }
.proj-cards--pair .proj-card__side { min-height: 200px; }
@media (max-width: 700px) { .proj-cards--pair { grid-template-columns: 1fr; } }
.proj-card:hover:not(.proj-card--soon) { transform: translateY(-6px); box-shadow: var(--shadow-xl); border-color: color-mix(in srgb, var(--rust) 30%, var(--line)); }

/* coloured left panel */
.proj-card__side {
  background: var(--gradient);
  padding: clamp(26px, 3vw, 38px);
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; overflow: hidden; min-height: 220px;
}
.proj-card__side-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: top left;
  opacity: 0.9;
  z-index: 0;
}
.proj-card__num,
.proj-card__type { position: relative; z-index: 2; }
.proj-card__num {
  font-family: "Fraunces", serif; font-style: italic; font-size: 3.8rem;
  line-height: 1; color: var(--forest-deep); opacity: .22;
  position: relative; z-index: 1;
}
.proj-card__type { position: relative; z-index: 1; }
.proj-card__type-label {
  font-family: "Space Mono", monospace; font-size: 0.68rem;
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--forest);
  opacity: .7; display: block; margin-bottom: 8px;
}
.proj-card__lock {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: "Space Mono", monospace; font-size: 0.66rem;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--forest);
  background: color-mix(in srgb, var(--paper) 80%, transparent);
  border: 1px solid color-mix(in srgb, var(--forest) 14%, transparent);
  padding: 5px 10px; border-radius: 100px;
  backdrop-filter: blur(4px);
}

/* white right panel */
.proj-card__main {
  padding: clamp(26px, 3vw, 40px);
  display: flex; flex-direction: column; gap: 10px;
}
.proj-card__kicker {
  font-family: "Space Mono", monospace; font-size: 0.74rem;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--rust);
}
/* "Coming soon" reads as a clear badge on the placeholder card */
.proj-card--soon .proj-card__kicker {
  display: inline-block; color: var(--forest); font-weight: 700;
  background: var(--gradient); padding: 5px 12px; border-radius: 100px;
}
.proj-card__title {
  font-family: "Fraunces", serif; font-weight: 500;
  font-size: clamp(1.35rem, 1.1rem + 1vw, 1.9rem); color: var(--forest); line-height: 1.12;
}
.proj-card__desc {
  color: var(--ink-soft); line-height: 1.62; flex: 1;
}
.proj-card__footer {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
  gap: 10px; padding-top: 16px; border-top: 1px solid var(--line); margin-top: 6px;
}
.proj-card__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.proj-card__tags span {
  font-family: "Space Mono", monospace; font-size: 0.75rem; letter-spacing: 0.04em;
  color: var(--ink-soft); border: 1px solid var(--line); padding: 3px 9px; border-radius: 100px;
}
.proj-card__cta {
  font-family: "Space Mono", monospace; font-size: 0.8rem; color: var(--forest);
  border-bottom: 1.5px solid var(--rust); padding-bottom: 2px; white-space: nowrap; flex-shrink: 0;
}
.proj-card__cta--muted { opacity: 0.45; border-bottom-color: var(--line); }

/* =========================================================
   ABOUT — work history section
   ========================================================= */
.cv-section {
  margin-top: clamp(44px, 6vw, 72px);
  padding-top: clamp(32px, 4vw, 52px);
  border-top: 1px solid var(--line);
}
.cv-section__title {
  font-family: "Fraunces", serif; font-weight: 500;
  font-size: clamp(1.5rem, 1.1rem + 1.2vw, 2rem); color: var(--forest); margin-bottom: clamp(16px, 2.5vw, 28px);
}
.cv-section__title .eyebrow { display: block; font-size: var(--fs-eyebrow); margin-bottom: 10px; }

/* =========================================================
   ABOUT — facts / personal photos strip
   ========================================================= */
.facts-section {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(48px, 7vw, 90px) var(--gutter);
}
.facts-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: clamp(12px, 2vw, 20px);
  margin-top: 40px;
}
.fact-card {
  margin: 0;
  display: flex; flex-direction: column; gap: 14px;
}
.fact-card__img {
  aspect-ratio: 3 / 4;
  border-radius: var(--r-lg);
  background: var(--gradient);
  overflow: hidden;
}
.fact-card__img img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
}
.fact-card__caption {
  font-family: "Space Mono", monospace;
  font-size: 0.72rem; line-height: 1.6;
  color: var(--ink-soft); letter-spacing: 0.01em;
}

/* Mobile: horizontal scroll carousel */
@media (max-width: 700px) {
  .facts-strip {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 14px;
    padding-bottom: 12px;
    scrollbar-width: none;
  }
  .facts-strip::-webkit-scrollbar { display: none; }
  .fact-card {
    flex: 0 0 72vw;
    scroll-snap-align: start;
  }
}

/* =========================================================
   ABOUT — knowledge / certificates section
   ========================================================= */
.knowledge-section {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(48px, 7vw, 90px) var(--gutter);
  border-top: 1px solid var(--line);
}
.knowledge-section .section-head { text-align: left; }

.cert-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: clamp(20px, 2.5vw, 32px);
  margin-top: clamp(28px, 4vw, 40px);
}
.cert-card {
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--shadow-sm); display: flex; flex-direction: column;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
}
.cert-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
/* certificate image area */
.cert-card__img {
  width: 100%; aspect-ratio: 4 / 3;
  background: var(--paper-2);
  display: grid; place-items: center;
  border-bottom: 1.5px dashed color-mix(in srgb, var(--rust) 30%, var(--line));
  overflow: hidden; position: relative;
}
.cert-card__img img { width: 100%; height: 100%; object-fit: cover; }
.cert-card__img--gradient {
  background: var(--gradient);
  border-bottom: none;
}
.cert-card__img-issuer {
  font-family: "Fraunces", serif; font-style: italic;
  font-size: clamp(1.1rem, 1rem + 0.8vw, 1.6rem);
  color: var(--forest); opacity: 0.6; text-align: center; padding: 16px;
  line-height: 1.3;
}
.cert-card__img-placeholder {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  color: var(--ink-soft); text-align: center; padding: 24px;
}
.cert-card__img-icon {
  font-family: "Fraunces", serif; font-style: italic; font-size: 2.4rem; line-height: 1;
  background: linear-gradient(135deg, var(--rust), var(--g3));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.cert-card__img-label {
  font-family: "Space Mono", monospace; font-size: 0.72rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-soft); opacity: .7;
}
/* text area */
.cert-card__body {
  padding: clamp(18px, 2vw, 26px); display: flex; flex-direction: column; gap: 6px; flex: 1;
}
.cert-card__title {
  font-family: "Fraunces", serif; font-weight: 500; font-size: 1.12rem;
  color: var(--forest); line-height: 1.2;
}
.cert-card__issuer {
  font-family: "Space Mono", monospace; font-size: 0.7rem;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--rust);
}
.cert-card__desc { color: var(--ink-soft); font-size: 0.9rem; line-height: 1.55; margin-top: 4px; }
.cert-card__year {
  font-family: "Space Mono", monospace; font-size: 0.72rem; color: var(--ink-soft); margin-top: auto; padding-top: 10px;
}

/* =========================================================
   ABOUT — testimonials carousel (peek style: photo top, text bottom)
   ========================================================= */
.testimonials-section {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(48px, 7vw, 90px) 0;
  border-top: 1px solid var(--line);
}
.testimonials-section > .section-head {
  text-align: left; margin-bottom: clamp(28px, 4vw, 44px);
  padding: 0 var(--gutter);
}
.testimonials-section > .testimonial__more {
  display: inline-block; margin: 24px var(--gutter) 0;
}

.carousel { position: relative; }

/* Stage: arrow · photos · arrow in a row */
.carousel__stage {
  display: flex; align-items: center; gap: clamp(14px, 3vw, 28px);
  margin-bottom: clamp(28px, 4vw, 44px);
}

.carousel__faces {
  flex: 1; display: flex; align-items: flex-end; justify-content: center;
  gap: clamp(10px, 2vw, 20px);
}

/* Side (prev/next) face */
.carousel__face {
  flex: 0 0 clamp(90px, 22vw, 180px);
  height: clamp(90px, 22vw, 180px);
  border-radius: var(--r-md); overflow: hidden;
  background: var(--gradient); flex-shrink: 0;
  filter: grayscale(1); opacity: 0.65;
  transition: filter .4s, opacity .4s;
}

/* Center (active) face */
.carousel__face--active {
  flex: 0 0 clamp(130px, 32vw, 260px);
  height: clamp(160px, 40vw, 340px);
  border-radius: var(--r-lg); box-shadow: var(--shadow-lg);
  filter: none; opacity: 1;
}

.carousel__face img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }

/* Circle arrow buttons */
.carousel__btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: clamp(44px, 7vw, 58px); height: clamp(44px, 7vw, 58px);
  border-radius: 50%; flex-shrink: 0;
  background: var(--card); border: 1.5px solid var(--line); color: var(--forest);
  cursor: pointer; touch-action: manipulation; box-shadow: var(--shadow-sm);
  transition: background .25s, color .25s, transform .25s var(--ease), box-shadow .25s;
}
.carousel__btn:hover { background: var(--forest); color: var(--paper); transform: scale(1.06); box-shadow: var(--shadow-md); }
.carousel__btn:focus-visible { border-radius: 50%; }

/* Text area: centered, only active panel shown */
.carousel__texts {
  text-align: center; max-width: 640px; margin: 0 auto;
}
.carousel__text { display: none; }
.carousel__text.is-active { display: block; }

.carousel__name {
  font-family: "Fraunces", serif; font-weight: 600;
  font-size: clamp(1.1rem, 1rem + 0.7vw, 1.35rem);
  color: var(--forest); margin: 0 0 6px;
}
.carousel__role {
  font-family: "Space Mono", monospace; font-size: 0.7rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--rust); margin-bottom: 20px;
}
.carousel__quote-text p {
  font-family: "Space Mono", monospace; font-size: 0.82rem; line-height: 1.75; color: var(--forest);
}
.carousel__quote-text p + p { margin-top: 0.85em; }

/* Dots */
.carousel__dots {
  display: flex; gap: 0; align-items: center; justify-content: center;
  margin-top: 24px;
}
.carousel__dot {
  padding: 18px;
  width: 8px; height: 8px; border-radius: 50%; border: 0;
  background-color: var(--line);
  background-clip: content-box;
  cursor: pointer; touch-action: manipulation;
  transition: background-color .25s;
}
.carousel__dot.is-active { background-color: var(--rust); }

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
/* One-time fade-in on page load (pure CSS, so content is never gated behind JS or a scroll).
   Base state is visible, so if animations are off the content simply shows. */
.reveal { animation: revealIn .6s var(--ease) both; }
@keyframes revealIn { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: none; } }
/* Desktop: reveal each block as it scrolls into view (a cue there's more below); JS adds .is-in.
   Mobile keeps the load fade above, so content is never hidden waiting on a scroll. */
@media (min-width: 821px) {
  .reveal { animation: none; opacity: 0; transform: translateY(22px); transition: opacity .55s var(--ease), transform .55s var(--ease); }
  .reveal.is-in { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) {
  .reveal { animation: none; opacity: 1; transform: none; }
  .hero__glow { animation: none; }
  .badge__dot { animation: none; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 880px) {
  .nav__menu { display: none; }
  .nav__toggle { display: flex; }
  .nav.is-open .nav__menu {
    display: flex; flex-direction: column; gap: 18px;
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--paper); border-bottom: 1px solid var(--line);
    padding: 24px var(--gutter) 28px;
  }
  .nav.is-open .nav__links { display: flex; flex-direction: column; gap: 18px; }
  .nav.is-open .nav__cta { display: inline-flex; }

  .gateways { grid-template-columns: 1fr; gap: 16px; }

  /* work page: stack proj-cards */
  .proj-card { grid-template-columns: 1fr; }
  .proj-card__side { min-height: 120px; flex-direction: row; align-items: center; justify-content: space-between; }
  .proj-card__num { font-size: 2.4rem; }
  /* old case cards (kept for safety) */
  .cases-pair, .testimonials-pair { grid-template-columns: 1fr; }
  .case-card, .case-card--wide { grid-template-columns: 1fr; }
  .case-card__photo { margin-left: 0; margin-top: -22px; min-height: 180px; }
  .case-card--wide .case-card__photo { min-height: 180px; }
  .testimonial, .testimonial--compact { grid-template-columns: 84px 1fr; gap: 16px; }
  .testimonial__aside { position: static; }

  .steps { grid-template-columns: 1fr; }
  .step--mid { transform: none; }
  .step--mid:hover { transform: translateY(-6px); }

  .project, .project:nth-child(even) { grid-template-columns: 1fr; gap: 20px; }
  .project:nth-child(even) .project__media { order: 0; }

  .about__grid { grid-template-columns: 1fr; }
  .about__photo { max-width: 360px; }

  .overview__cases { grid-template-columns: 1fr; }

  .case-row--right, .case-row--left { grid-template-columns: 1fr; }
  .case-row--left .case-row__text { order: 0; }
}

@media (max-width: 520px) {
  .cta { margin-left: 12px; margin-right: 12px; border-radius: var(--r-lg); }
  .cta__actions { flex-direction: column; }
  .unlock__field { flex-direction: column; }
  .unlock__field .btn { justify-content: center; }
  .footer__top { justify-content: center; text-align: center; }
}

