/* ─────────────────────────────────────────────────────────────
   Jillai — Human-Centered AI
   Stacked rounded color bands. Editorial pastel system.
   ───────────────────────────────────────────────────────────── */

:root{
  /* palette */
  --cream:        #FBF6EA;
  --cream-deep:   #F4ECDA;
  --lila:         #E7DEF2;
  --lila-deep:    #D6C9E8;
  --sage:         #D3E0CE;
  --sage-deep:    #7A9A7B;
  --peach:        #F6E0CB;
  --peach-deep:   #ECC9A6;
  --aubergine:    #3D2B56;
  --aubergine-2:  #2C1F40;
  --amber:        #E8A33D;
  --amber-deep:   #C9851F;
  --ink:          #241B33;
  --ink-mute:     #6B5E7A;

  /* type */
  --serif: "Playfair Display", "Iowan Old Style", Georgia, serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* layout */
  --container: 1240px;
  --pad: clamp(20px, 4vw, 56px);
  --r-band: clamp(28px, 4vw, 56px);
  --r-card: clamp(20px, 2.4vw, 32px);
  --section-y: clamp(96px, 11vw, 160px);
}

*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin: 0;
  background: var(--aubergine);     /* peeks behind the rounded bands */
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  text-wrap: pretty;
}
a{ color: inherit; text-decoration: none; }
img,svg{ display: block; max-width: 100%; }
button{ font: inherit; color: inherit; }

.wrap{
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--pad);
}

/* ── Typography ────────────────────────────────────────────── */
.display{
  font-family: var(--serif);
  font-weight: 500;
  color: var(--aubergine);
  letter-spacing: -0.012em;
  line-height: 1.04;
  text-wrap: balance;
  margin: 0;
}
.h1{ font-size: clamp(40px, 5.6vw, 88px); line-height: 1.04; }
.h2{ font-size: clamp(38px, 5vw, 68px); line-height: 1.06; }
.h3{ font-size: clamp(24px, 2.4vw, 32px); line-height: 1.18; font-weight: 500; }
em.it{ font-style: italic; font-weight: 400; }

.eyebrow{
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.24em;
  color: var(--aubergine);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.eyebrow::before{
  content: "";
  width: 22px;
  height: 1px;
  background: currentColor;
  opacity: 0.55;
}

.lead{
  font-size: clamp(17px, 1.35vw, 20px);
  line-height: 1.55;
  color: var(--ink);
  max-width: 56ch;
  margin: 0;
}
.muted{ color: var(--ink-mute); }

/* ── Stacked rounded bands ─────────────────────────────────── */
.bands{
  /* the body is aubergine; bands stack on top */
}
.band{
  position: relative;
  border-radius: var(--r-band) var(--r-band) 0 0;
  padding-block: var(--section-y);
  margin-top: calc(var(--r-band) * -1);
  isolation: isolate;
}
.band:first-of-type{ margin-top: 0; }
.band--cream     { background: var(--cream); color: var(--ink); }
.band--lila      { background: var(--lila); }
.band--sage      { background: var(--sage); }
.band--peach     { background: var(--peach); }
.band--aubergine { background: var(--aubergine); color: var(--cream); }
.band--aubergine .display,
.band--aubergine .eyebrow { color: var(--cream); }
.band--last{ border-radius: var(--r-band); }

/* ── Pill button (text + circular icon badge on the right) ─── */
.pill{
  --pill-bg: var(--aubergine);
  --pill-fg: var(--cream);
  --pill-badge-bg: var(--amber);
  --pill-badge-fg: var(--aubergine);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 16px;
  padding: 7px 7px 7px 26px;
  font-family: var(--sans);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.01em;
  background: var(--pill-bg);
  color: var(--pill-fg);
  border: 1px solid transparent;
  border-radius: 999px;
  cursor: pointer;
  transition: transform 240ms cubic-bezier(.2,.0,.0,1),
              background 220ms ease, color 220ms ease, border-color 220ms ease;
  white-space: nowrap;
}
.pill > .badge{
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: var(--pill-badge-bg);
  color: var(--pill-badge-fg);
  display: grid;
  place-items: center;
  transition: transform 320ms cubic-bezier(.2,.0,.0,1);
  flex: 0 0 auto;
}
.pill > .badge svg{ width: 16px; height: 16px; }
.pill:hover{ transform: translateY(-2px); }
.pill:hover > .badge{ transform: rotate(-45deg); }

.pill--lg{ padding: 9px 9px 9px 32px; font-size: 15px; }
.pill--lg > .badge{ width: 46px; height: 46px; }
.pill--lg > .badge svg{ width: 18px; height: 18px; }

.pill--ghost{
  background: transparent;
  color: var(--aubergine);
  border-color: color-mix(in srgb, var(--aubergine) 22%, transparent);
  --pill-badge-bg: var(--aubergine);
  --pill-badge-fg: var(--cream);
}
.pill--ghost:hover{ border-color: var(--aubergine); }

.pill--amber{ --pill-bg: var(--amber); --pill-fg: var(--aubergine); --pill-badge-bg: var(--aubergine); --pill-badge-fg: var(--cream); }
.pill--cream{ --pill-bg: var(--cream); --pill-fg: var(--aubergine); --pill-badge-bg: var(--amber); --pill-badge-fg: var(--aubergine); }
.pill--sage { --pill-bg: var(--sage-deep); --pill-fg: var(--cream); --pill-badge-bg: var(--cream); --pill-badge-fg: var(--aubergine); }

/* ── Tag pill ──────────────────────────────────────────────── */
.tag{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px 6px 12px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  border-radius: 999px;
  background: color-mix(in srgb, var(--aubergine) 8%, transparent);
  color: var(--aubergine);
  border: 1px solid color-mix(in srgb, var(--aubergine) 14%, transparent);
}
.tag::before{
  content: "";
  width: 7px; height: 7px; border-radius: 999px;
  background: var(--sage-deep);
}
.tag--amber::before{ background: var(--amber); }
.tag--lila::before{ background: var(--lila-deep); }
.tag--peach::before{ background: var(--peach-deep); }

/* ── Brand seal (rotates) ──────────────────────────────────── */
.seal{
  width: 100%;
  aspect-ratio: 1;
  display: block;
  color: var(--aubergine);
}
.seal-ring{
  transform-box: fill-box;
  transform-origin: 50% 50%;
  animation: seal-spin 70s linear infinite;
}
@keyframes seal-spin{
  from{ transform: rotate(0deg); }
  to  { transform: rotate(360deg); }
}
@media (prefers-reduced-motion: reduce){
  .seal-ring{ animation: none; }
}
.seal-wrap{
  position: relative;
  width: clamp(80px, 9vw, 132px);
  border-radius: 999px;
  background: var(--cream);
  padding: 10px;
  box-shadow: 0 12px 36px -16px rgba(36, 27, 51, 0.25);
}
.seal-wrap--overlap{
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  z-index: 5;
}
.seal-wrap--lila    { background: var(--lila); }
.seal-wrap--sage    { background: var(--sage); }
.seal-wrap--peach   { background: var(--peach); }
.seal-wrap--aubergine{ background: var(--aubergine); }
.seal-wrap--aubergine .seal{ color: var(--cream); }
.seal-wrap--aubergine .seal .seal-dot{ fill: var(--amber); }

/* ── Header / nav ──────────────────────────────────────────── */
.site-header{
  position: sticky;
  top: 0;
  z-index: 80;
  padding-block: 18px;
  background: var(--cream);
  border-bottom: 1px solid color-mix(in srgb, var(--aubergine) 8%, transparent);
  transition: box-shadow 240ms ease, border-color 240ms ease;
}
.site-header.is-scrolled{
  box-shadow: 0 8px 30px -22px rgba(36, 27, 51, 0.35);
  border-bottom-color: color-mix(in srgb, var(--aubergine) 12%, transparent);
}
.nav{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
}
.nav-links{
  display: flex;
  gap: 32px;
  list-style: none;
  margin: 0; padding: 0;
  font-size: 14px;
  justify-self: start;
}
.nav-links a{ color: var(--ink); transition: color 220ms ease; }
.nav-links a:hover{ color: var(--aubergine); }
.nav-brand{
  justify-self: center;
  font-family: var(--serif);
  font-weight: 500;
  font-size: 26px;
  color: var(--aubergine);
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
}
.nav-brand .dot{ color: var(--sage-deep); }
.nav-cta{ justify-self: end; }
@media (max-width: 880px){
  .nav{ grid-template-columns: 1fr auto auto; }
  .nav-links{ display: none; }
}

/* ── HERO ──────────────────────────────────────────────────── */
.hero{
  position: relative;
  min-height: 93vh;
  display: flex;
  align-items: center;
  padding-block: clamp(48px, 6vw, 100px) clamp(40px, 5vw, 84px);
  overflow: hidden;
  border-radius: 0 0 var(--r-band) var(--r-band);
  background: linear-gradient(135deg, var(--lila), var(--peach));
  isolation: isolate;
}
#hero-shader{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 0;
  pointer-events: none;
}
.hero > .wrap{ position: relative; z-index: 1; width: 100%; }

.hero-foot{
  margin-top: clamp(72px, 9vw, 140px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.hero-overlay-card{
  background: color-mix(in srgb, var(--cream) 92%, transparent);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 999px;
  padding: 12px 22px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  letter-spacing: 0.02em;
  box-shadow: 0 10px 30px -18px rgba(36, 27, 51, 0.4);
  width: fit-content;
}
.hero-overlay-card .dot{
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--sage-deep);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--sage-deep) 22%, transparent);
}
.hero-tagstrip{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.hero-tagstrip .tag{
  background: color-mix(in srgb, var(--cream) 88%, transparent);
  border-color: transparent;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.hero-head{
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 0.6fr);
  align-items: end;
  gap: clamp(24px, 4vw, 80px);
}
@media (max-width: 900px){
  .hero-head{ grid-template-columns: 1fr; }
}
.hero-side{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding-bottom: 8px;
}
.hero-side-card{
  position: relative;
  background: color-mix(in srgb, var(--cream) 92%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--r-card);
  padding: clamp(24px, 2.4vw, 36px) clamp(22px, 2.2vw, 32px) clamp(22px, 2.2vw, 30px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-shadow: 0 18px 40px -22px rgba(36, 27, 51, 0.28);
  margin-top: clamp(36px, 4vw, 56px);  /* room for avatar overlap */
}
.hero-side-card p{
  margin: 0;
  color: var(--ink);
  font-size: 15.5px;
  line-height: 1.55;
}
.hero-avatar{
  position: absolute;
  top: clamp(-92px, -8vw, -60px);
  right: clamp(-32px, -3vw, -8px);
  width: clamp(96px, 10vw, 128px);
  height: clamp(96px, 10vw, 128px);
  border-radius: 999px;
  object-fit: cover;
  background: var(--cream);
  border: 4px solid var(--cream);
  box-shadow: 0 14px 30px -14px rgba(36, 27, 51, 0.35);
  pointer-events: none;
  z-index: 3;
}
.hero-side p{ margin: 0; color: var(--ink); font-size: 16px; max-width: 38ch; }
.hero h1{
  margin: 18px 0 0;
  text-shadow: 0 1px 0 color-mix(in srgb, var(--cream) 35%, transparent);
}
.hero h1 em{
  font-style: italic;
  font-weight: 400;
  color: var(--sage-deep);
}
.hero-side{
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-items: flex-start;
  padding-bottom: 8px;
}
.hero-side p{ margin: 0; color: var(--ink); font-size: 16px; }

/* ── Two-up section head ───────────────────────────────────── */
.section-head{
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: clamp(32px, 5vw, 80px);
  align-items: end;
  margin-bottom: clamp(48px, 6vw, 88px);
}
@media (max-width: 820px){
  .section-head{ grid-template-columns: 1fr; }
}
.section-head h2{ margin-top: 18px; }

/* ── Pillars (lila band) ───────────────────────────────────── */
.pillars{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.4vw, 36px);
}
@media (max-width: 860px){ .pillars{ grid-template-columns: 1fr; } }
.pillar{
  background: color-mix(in srgb, var(--cream) 60%, transparent);
  border-radius: var(--r-card);
  padding: clamp(28px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  gap: 18px;
  transition: transform 320ms cubic-bezier(.2,.0,.0,1);
}
.pillar:hover{ transform: translateY(-4px); }
.pillar .ico-badge{
  width: 56px; height: 56px;
  border-radius: 999px;
  background: var(--amber);
  color: var(--aubergine);
  display: grid;
  place-items: center;
  align-self: flex-start;
}
.pillar h3{
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(22px, 2vw, 28px);
  color: var(--aubergine);
  margin: 0;
  line-height: 1.15;
}
.pillar p{ margin: 0; color: var(--ink); max-width: 32ch; font-size: 15.5px; line-height: 1.55; }

/* ── Service cards (cream band) ────────────────────────────── */
.services{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2vw, 28px);
}
@media (max-width: 980px){ .services{ grid-template-columns: 1fr; } }
.service{
  background: var(--cream-deep);
  border-radius: var(--r-card);
  padding: clamp(28px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  gap: 22px;
  min-height: 480px;
  transition: transform 320ms cubic-bezier(.2,.0,.0,1), background 320ms ease;
  position: relative;
  overflow: hidden;
}
.service:hover{ transform: translateY(-4px); }
.service--lila { background: var(--lila); }
.service--peach{ background: var(--peach); }
.service--sage { background: var(--sage); }

.service .num{
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  color: var(--ink-mute);
  letter-spacing: 0.02em;
}
.service h3{
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(26px, 2.4vw, 34px);
  line-height: 1.1;
  color: var(--aubergine);
  margin: 0;
  text-wrap: balance;
}
.service .desc{ margin: 0; color: var(--ink); font-size: 15.5px; line-height: 1.55; }
.service .feat{
  list-style: none;
  margin: auto 0 0;
  padding: 20px 0 0;
  border-top: 1px solid color-mix(in srgb, var(--aubergine) 14%, transparent);
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 14px;
  color: var(--ink);
}
.service .feat li{
  display: flex; align-items: center; gap: 12px;
}
.service .feat li::before{
  content: "";
  width: 14px; height: 1px; background: var(--sage-deep); flex: 0 0 auto;
}
.service .service-cta{
  margin-top: 22px;
}

/* ── Stats / proof (sage band) ─────────────────────────────── */
.proof-row{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(24px, 3vw, 48px);
  align-items: start;
}
@media (max-width: 900px){ .proof-row{ grid-template-columns: repeat(2, 1fr); } }
.stat-badge{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
}
.stat-circle{
  width: clamp(120px, 12vw, 156px);
  height: clamp(120px, 12vw, 156px);
  border-radius: 999px;
  background: var(--cream);
  border: 1px solid color-mix(in srgb, var(--aubergine) 12%, transparent);
  display: grid;
  place-items: center;
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(40px, 4.4vw, 56px);
  color: var(--aubergine);
  line-height: 1;
  text-align: center;
}
.stat-circle .small{
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 6px;
}
.stat-circle--amber{ background: var(--amber); color: var(--aubergine); border-color: transparent; }
.stat-circle--auber{ background: var(--aubergine); color: var(--cream); border-color: transparent; }
.stat-badge .lbl{ font-size: 14px; color: var(--ink); max-width: 22ch; line-height: 1.5; }
.proof-cta-row{
  margin-top: clamp(56px, 6vw, 88px);
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
}

/* ── Carousel (testimonials) ───────────────────────────────── */
.carousel{
  position: relative;
}
.carousel-track{
  display: flex;
  gap: clamp(20px, 2vw, 28px);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding-bottom: 12px;
  scroll-padding-left: 0;
}
.carousel-track::-webkit-scrollbar{ display: none; }
.testi{
  flex: 0 0 min(560px, 90%);
  scroll-snap-align: start;
  background: var(--cream-deep);
  border-radius: var(--r-card);
  padding: clamp(28px, 3vw, 44px);
  display: flex;
  flex-direction: column;
  gap: 22px;
  min-height: 340px;
}
.testi blockquote{
  margin: 0;
  font-family: var(--serif);
  font-weight: 500;
  font-style: italic;
  font-size: clamp(20px, 1.9vw, 26px);
  line-height: 1.3;
  color: var(--aubergine);
  text-wrap: balance;
}
.testi-meta{
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: auto;
}
.testi-avatar{
  width: 56px; height: 56px;
  border-radius: 999px;
  background: linear-gradient(140deg, var(--lila), var(--peach));
  border: 1px solid color-mix(in srgb, var(--aubergine) 16%, transparent);
  flex: 0 0 auto;
  display: grid; place-items: center;
  font-family: var(--serif);
  font-size: 22px;
  color: var(--aubergine);
}
.testi-name{ font-weight: 500; font-size: 15px; color: var(--aubergine); }
.testi-role{ font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }

.carousel-nav{
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: clamp(32px, 3vw, 48px);
}
.carousel-arrow{
  width: 56px; height: 56px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--aubergine) 22%, transparent);
  background: transparent;
  color: var(--aubergine);
  display: grid; place-items: center;
  cursor: pointer;
  transition: background 220ms ease, color 220ms ease, transform 220ms ease, border-color 220ms ease;
}
.carousel-arrow:hover{ background: var(--aubergine); color: var(--cream); border-color: var(--aubergine); }
.carousel-arrow:active{ transform: scale(0.96); }
.carousel-progress{
  flex: 1;
  height: 1px;
  background: color-mix(in srgb, var(--aubergine) 14%, transparent);
  position: relative;
  overflow: hidden;
  border-radius: 999px;
}
.carousel-progress span{
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 22%;
  background: var(--aubergine);
  border-radius: 999px;
  transition: left 320ms ease, width 320ms ease;
}

/* ── Partners (aubergine band) ─────────────────────────────── */
.partners{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  align-items: center;
  margin-top: clamp(56px, 5vw, 88px);
}
@media (max-width: 800px){ .partners{ grid-template-columns: repeat(2, 1fr); } }
.partner{
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(20px, 2.4vw, 36px) 18px;
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(20px, 1.8vw, 24px);
  color: color-mix(in srgb, var(--cream) 75%, transparent);
  border: 1px solid color-mix(in srgb, var(--cream) 12%, transparent);
  border-right: 0;
  border-bottom: 0;
  letter-spacing: 0.02em;
}
.partner:nth-child(5n){ border-right: 1px solid color-mix(in srgb, var(--cream) 12%, transparent); }
.partners > *:nth-last-child(-n+5){ border-bottom: 1px solid color-mix(in srgb, var(--cream) 12%, transparent); }

/* ── About Jill (cream band) ───────────────────────────────── */
.about-grid{
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: clamp(40px, 5vw, 88px);
  align-items: center;
}
@media (max-width: 900px){ .about-grid{ grid-template-columns: 1fr; } }
.portrait{
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--r-card);
  overflow: hidden;
  background:
    repeating-linear-gradient(135deg,
      color-mix(in srgb, var(--lila-deep) 38%, var(--cream)) 0 16px,
      color-mix(in srgb, var(--peach-deep) 28%, var(--cream)) 16px 32px);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--aubergine) 10%, transparent);
}
.portrait > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.portrait .placeholder{
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--aubergine) 55%, transparent);
}
.portrait-overlay-card{
  position: absolute;
  left: 50%;
  bottom: -28px;
  transform: translateX(-50%);
  background: var(--cream);
  border-radius: 999px;
  padding: 10px 18px 10px 12px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  color: var(--aubergine);
  box-shadow: 0 14px 36px -20px rgba(36, 27, 51, 0.45);
  white-space: nowrap;
}
.portrait-overlay-card .dot{
  width: 8px; height: 8px; border-radius: 999px; background: var(--sage-deep);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--sage-deep) 22%, transparent);
}
.about-tags{
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 22px 0 0;
}
.about p + p{ margin-top: 16px; }
.about .signature{
  margin-top: 28px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.about .signature .sig{
  font-family: var(--serif);
  font-style: italic;
  font-size: 30px;
  color: var(--aubergine);
}
.about .signature .role{
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ── Klantcases (peach band) ───────────────────────────────── */
.case-tabs{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: clamp(28px, 3vw, 40px);
}
.case-tab{
  padding: 10px 22px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--cream) 70%, transparent);
  border: 1px solid color-mix(in srgb, var(--aubergine) 12%, transparent);
  color: var(--aubergine);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background 220ms ease, color 220ms ease;
}
.case-tab.is-active{
  background: var(--aubergine);
  color: var(--cream);
  border-color: var(--aubergine);
}
.case-card{
  background: var(--cream);
  border-radius: var(--r-card);
  padding: clamp(32px, 4vw, 56px);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: clamp(32px, 4vw, 72px);
  align-items: center;
}
@media (max-width: 880px){ .case-card{ grid-template-columns: 1fr; } }
.case-card h3{
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(28px, 3vw, 40px);
  color: var(--aubergine);
  margin: 14px 0 18px;
  text-wrap: balance;
  line-height: 1.1;
}
.case-card p{ margin: 0 0 24px; color: var(--ink); }
.case-stats{
  display: flex;
  gap: clamp(16px, 2vw, 28px);
  margin-top: 28px;
  flex-wrap: wrap;
}
.case-stats .stat-circle{
  width: clamp(100px, 9vw, 120px);
  height: clamp(100px, 9vw, 120px);
  font-size: clamp(28px, 2.8vw, 36px);
}
.case-photos{
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 14px;
  aspect-ratio: 1;
}
.case-photo{
  border-radius: var(--r-card);
  background: var(--lila);
  display: grid;
  place-items: center;
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--aubergine) 55%, transparent);
  overflow: hidden;
  position: relative;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--aubergine) 10%, transparent);
}
.case-photo > img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.case-photo:nth-child(1){
  background: repeating-linear-gradient(135deg,
    color-mix(in srgb, var(--lila-deep) 40%, var(--cream)) 0 14px,
    color-mix(in srgb, var(--lila) 80%, var(--cream)) 14px 28px);
}
.case-photo:nth-child(2){
  background: repeating-linear-gradient(135deg,
    color-mix(in srgb, var(--peach-deep) 36%, var(--cream)) 0 14px,
    color-mix(in srgb, var(--peach) 80%, var(--cream)) 14px 28px);
  grid-row: span 2;
}
.case-photo:nth-child(3){
  background: repeating-linear-gradient(135deg,
    color-mix(in srgb, var(--sage-deep) 32%, var(--cream)) 0 14px,
    color-mix(in srgb, var(--sage) 80%, var(--cream)) 14px 28px);
}

/* ── Approach accordion (cream band) ───────────────────────── */
.approach{
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.step{
  background: var(--cream-deep);
  border-radius: var(--r-card);
  padding: clamp(24px, 2.6vw, 36px) clamp(28px, 3vw, 44px);
  cursor: pointer;
  transition: background 220ms ease;
}
.step:hover{ background: color-mix(in srgb, var(--cream-deep) 70%, var(--lila)); }
.step-summary{
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: clamp(16px, 2vw, 32px);
  align-items: center;
}
.step-num{
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  color: var(--sage-deep);
}
.step-title{
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(22px, 2vw, 28px);
  color: var(--aubergine);
  margin: 0;
  line-height: 1.15;
}
.step-toggle{
  width: 40px; height: 40px;
  border-radius: 999px;
  background: var(--aubergine);
  color: var(--cream);
  display: grid; place-items: center;
  transition: transform 320ms ease;
}
.step.is-open .step-toggle{ transform: rotate(45deg); }
.step-body{
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 360ms cubic-bezier(.2,.0,.0,1);
}
.step.is-open .step-body{ grid-template-rows: 1fr; }
.step-body > div{
  overflow: hidden;
  min-height: 0;
}
.step-body p{
  margin: 18px 0 0 calc(56px + clamp(16px, 2vw, 32px));
  max-width: 60ch;
  color: var(--ink);
}
@media (max-width: 700px){
  .step-body p{ margin-left: 0; }
}

/* ── Contact band (sage) ───────────────────────────────────── */
.contact-grid{
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(40px, 5vw, 88px);
  align-items: start;
}
@media (max-width: 880px){ .contact-grid{ grid-template-columns: 1fr; } }
.contact-portrait{ display: none; }
.contact-form{
  background: var(--cream);
  border-radius: var(--r-card);
  padding: clamp(28px, 3vw, 44px);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.field{ display: flex; flex-direction: column; gap: 8px; }
.field label{
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--ink-mute);
}
.field input,
.field textarea{
  font: inherit;
  color: var(--ink);
  background: color-mix(in srgb, var(--cream-deep) 60%, var(--cream));
  border: 1px solid color-mix(in srgb, var(--aubergine) 14%, transparent);
  border-radius: 18px;
  padding: 14px 18px;
  outline: none;
  transition: border-color 220ms ease, background 220ms ease;
  resize: vertical;
}
.field textarea{ min-height: 120px; border-radius: 22px; }
.field input:focus,
.field textarea:focus{
  border-color: var(--aubergine);
  background: var(--cream);
}
.contact-form-row{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.contact-form-row .muted{ font-size: 12px; }

.contact-side{
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.contact-side h2{ margin: 14px 0 0; }
.contact-list{
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 12px;
}
.contact-list .row{
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 18px;
  align-items: baseline;
  padding-block: 12px;
  border-top: 1px solid color-mix(in srgb, var(--aubergine) 14%, transparent);
}
.contact-list .row:last-child{ border-bottom: 1px solid color-mix(in srgb, var(--aubergine) 14%, transparent); }
.contact-list .row span:first-child{
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ── Footer (aubergine, last band) ─────────────────────────── */
.site-footer{
  color: var(--cream);
}
.footer-top{
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: start;
  padding-bottom: clamp(48px, 5vw, 80px);
}
@media (max-width: 800px){
  .footer-top{ grid-template-columns: 1fr 1fr; gap: 40px 28px; }
}
.footer-brand .mark{
  font-family: var(--serif);
  font-weight: 500;
  font-size: 40px;
  color: var(--cream);
  line-height: 1;
  display: inline-flex;
  align-items: baseline;
}
.footer-brand .mark .dot{ color: var(--amber); }
.footer-brand p{
  margin: 16px 0 24px;
  font-size: 14px;
  color: color-mix(in srgb, var(--cream) 75%, transparent);
  max-width: 38ch;
  line-height: 1.6;
}
.footer-ctas{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.footer-col h5{
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--cream) 60%, transparent);
  margin: 0 0 18px;
}
.footer-col ul{
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 12px;
  font-size: 14px;
}
.footer-col a{ color: color-mix(in srgb, var(--cream) 82%, transparent); transition: color 220ms ease; }
.footer-col a:hover{ color: var(--cream); }
.footer-bottom{
  border-top: 1px solid color-mix(in srgb, var(--cream) 12%, transparent);
  padding-top: 22px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 12px;
  color: color-mix(in srgb, var(--cream) 55%, transparent);
  letter-spacing: 0.04em;
}
.cookie-bar{
  position: fixed;
  z-index: 90;
  left: 24px; right: 24px; bottom: 24px;
  margin-inline: auto;
  max-width: 720px;
  background: var(--cream);
  color: var(--ink);
  border-radius: 999px;
  padding: 12px 12px 12px 24px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: 0 20px 60px -24px rgba(36, 27, 51, 0.5);
  font-size: 13px;
  flex-wrap: wrap;
  justify-content: center;
  transition: transform 320ms ease, opacity 320ms ease;
}
.cookie-bar.is-hidden{ transform: translateY(120%); opacity: 0; pointer-events: none; }
.cookie-bar .pill{ padding: 6px 6px 6px 18px; font-size: 12px; }
.cookie-bar .pill > .badge{ width: 30px; height: 30px; }
.cookie-bar .pill > .badge svg{ width: 12px; height: 12px; }

/* ── Reveal on scroll ──────────────────────────────────────── */
.js-anim .reveal{
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 800ms cubic-bezier(.2,.0,.0,1), transform 800ms cubic-bezier(.2,.0,.0,1);
}
.js-anim .reveal.in{ opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){
  .js-anim .reveal{ opacity: 1; transform: none; transition: none; }
}
