/* ============================================================
   IseMatilda design system
   Palette: warm cream + espresso charcoal + antique gold
   Type: Fraunces (display) / Hanken Grotesk (body)
   ============================================================ */

:root{
  --cream:    #FAF6EE;
  --cream-2:  #F3EBDB;
  --cream-3:  #ECE0CB;
  --ink:      #2A2520;
  --ink-soft: #6E6457;
  --gold:     #B0823C;
  --gold-deep:#8C6529;
  --line:     #E4D8C2;
  --white:    #ffffff;

  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Hanken Grotesk', system-ui, -apple-system, sans-serif;

  --wrap: 1240px;
  --radius: 6px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{ font-family:var(--font-display); font-weight:500; line-height:1.08; letter-spacing:-0.01em; }
h1{ font-size:clamp(2.6rem,6vw,4.4rem); }
h2{ font-size:clamp(2rem,4vw,3rem); }
h3{ font-size:1.3rem; }

.eyebrow{
  font-family:var(--font-body);
  font-size:.72rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:1rem;
}

.dot{ opacity:.45; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--font-body); font-weight:600; font-size:.82rem;
  letter-spacing:.06em; text-transform:uppercase;
  padding:1rem 1.9rem; border-radius:var(--radius);
  border:1.5px solid transparent; cursor:pointer;
  transition:all .25s var(--ease); white-space:nowrap;
}
.btn--primary{ background:var(--ink); color:var(--cream); }
.btn--primary:hover{ background:#000; }
.btn--ghost{ background:transparent; border-color:var(--ink); color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--cream); }
.btn--block{ width:100%; }

/* ---------- announcement bar ---------- */
.announce{
  background:var(--ink); color:var(--cream);
  position:relative; height:42px; overflow:hidden;
}
.announce__rotator{ position:relative; height:100%; }
.announce__item{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center; text-align:center;
  padding:0 1.2rem; font-size:.78rem; letter-spacing:.04em;
  opacity:0;
}
.announce__item.is-active{ opacity:1; animation:barFade .55s ease; }
@keyframes barFade{ from{ opacity:0; } to{ opacity:1; } }

/* ---------- header ---------- */
.header{
  position:sticky; top:0; z-index:50;
  background:var(--cream);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s var(--ease);
}
.header.scrolled{ box-shadow:0 6px 24px rgba(42,37,32,.07); }
.header__inner{
  max-width:var(--wrap); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:.9rem 1.5rem; gap:1rem;
}
.nav{ display:flex; gap:1.6rem; flex:1; align-items:center; }
.nav--right{ justify-content:flex-end; }
.nav a{ font-size:.82rem; font-weight:500; letter-spacing:.02em; transition:color .2s; }
.nav a:hover{ color:var(--gold-deep); }
.header__logo{ flex-shrink:0; }
.header__logo img{ height:46px; width:auto; }

.cart-btn{
  background:none; border:none; cursor:pointer; font-family:var(--font-body);
  font-size:.82rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:.45rem; color:var(--ink);
}
.cart-count{
  background:var(--gold); color:var(--white);
  font-size:.68rem; font-weight:700;
  min-width:1.25rem; height:1.25rem; padding:0 .3rem;
  border-radius:99px; display:inline-flex; align-items:center; justify-content:center;
}

.header__menu{ display:none; flex-direction:column; gap:4px; background:none; border:none; cursor:pointer; padding:4px; }
.header__menu span{ width:22px; height:2px; background:var(--ink); transition:.3s; }

/* mobile menu */
.mobile-menu{
  position:fixed; top:0; left:0; bottom:0; width:78%; max-width:340px;
  background:var(--cream); z-index:120; padding:5rem 2rem 2rem;
  transform:translateX(-100%); transition:transform .35s var(--ease);
  display:flex; flex-direction:column; gap:.4rem;
}
.mobile-menu.open{ transform:translateX(0); }
.mobile-menu a{
  font-family:var(--font-display); font-size:1.5rem; padding:.7rem 0;
  border-bottom:1px solid var(--line);
}
.overlay{
  position:fixed; inset:0; background:rgba(42,37,32,.4); z-index:110;
  opacity:0; visibility:hidden; transition:.3s;
}
.overlay.open{ opacity:1; visibility:visible; }

/* ---------- hero ---------- */
.hero{
  max-width:var(--wrap); margin:0 auto;
  display:grid; grid-template-columns:1.05fr 1fr; align-items:center; gap:3rem;
  padding:4.5rem 1.5rem 3rem;
}
.hero__copy h1{ margin-bottom:1.3rem; }
.hero__sub{ font-size:1.12rem; color:var(--ink-soft); max-width:30rem; margin-bottom:2rem; }
.hero__actions{ display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:2.4rem; }
.hero__marks{
  list-style:none; display:flex; gap:1.6rem; flex-wrap:wrap;
  font-size:.78rem; letter-spacing:.04em; color:var(--ink-soft);
}
.hero__marks li{ position:relative; padding-left:1.1rem; }
.hero__marks li::before{ content:"·"; position:absolute; left:0; color:var(--gold); font-weight:700; }
.hero__media{ position:relative; display:flex; justify-content:center; align-items:center; }
.hero__disc{
  position:absolute; width:88%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 50% 40%, var(--cream-2), var(--cream-3));
  z-index:0;
}
.hero__media img{ position:relative; z-index:1; max-height:460px; width:auto; filter:drop-shadow(0 24px 40px rgba(42,37,32,.14)); }

/* ---------- trust belt ---------- */
.belt{
  background:var(--ink); color:var(--cream);
  position:relative; height:46px; overflow:hidden;
}
.belt__rotator{ position:relative; height:100%; }
.belt__item{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center; text-align:center;
  padding:0 1.2rem; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  opacity:0;
}
.belt__item.is-active{ opacity:1; animation:barFade .55s ease; }

/* ---------- section heads ---------- */
.section-head{ text-align:center; max-width:40rem; margin:0 auto 3rem; }

/* ---------- categories ---------- */
.cats{ max-width:var(--wrap); margin:0 auto; padding:5rem 1.5rem; }
.cats__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.cat{ display:block; group:cat; }
.cat__img{
  background:var(--cream-2); border-radius:var(--radius); overflow:hidden;
  aspect-ratio:4/5; display:flex; align-items:center; justify-content:center; padding:2rem;
  margin-bottom:1.1rem;
}
.cat__img img{ max-height:100%; width:auto; mix-blend-mode:multiply; transition:transform .5s var(--ease); }
.cat:hover .cat__img img{ transform:scale(1.05); }
.cat h3{ margin-bottom:.3rem; }
.cat__link{ font-size:.82rem; color:var(--gold-deep); font-weight:600; }

/* ---------- feature ---------- */
.feature{
  max-width:var(--wrap); margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center;
  padding:4rem 1.5rem;
}
.feature__media{
  background:var(--cream-2); border-radius:var(--radius);
  padding:3rem; display:flex; justify-content:center;
}
.feature__media img{ max-height:420px; width:auto; mix-blend-mode:multiply; }
.feature__copy p{ color:var(--ink-soft); margin:1.2rem 0 1.8rem; max-width:30rem; }
.feature__price{ display:flex; align-items:baseline; gap:.9rem; margin-bottom:1.8rem; }

/* ---------- price tokens ---------- */
.price{ font-family:var(--font-display); font-size:1.5rem; font-weight:600; }
.price-was{ color:var(--ink-soft); text-decoration:line-through; font-size:1rem; }
.save-tag{
  background:var(--cream-3); color:var(--gold-deep); font-weight:600;
  font-size:.72rem; letter-spacing:.04em; padding:.3rem .7rem; border-radius:99px;
}

/* ---------- products grid ---------- */
.products{ max-width:var(--wrap); margin:0 auto; padding:4rem 1.5rem 5rem; }
.products__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.6rem; }
.card__img{
  position:relative; background:var(--cream-2); border-radius:var(--radius); overflow:hidden;
  aspect-ratio:1; display:flex; align-items:center; justify-content:center; padding:1.6rem;
  margin-bottom:1rem;
}
.card__img img{ max-height:100%; width:auto; mix-blend-mode:multiply; transition:transform .5s var(--ease); }
.card:hover .card__img img{ transform:scale(1.05); }
.badge{
  position:absolute; top:.8rem; left:.8rem;
  background:var(--ink); color:var(--cream); font-size:.66rem; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase; padding:.35rem .6rem; border-radius:99px;
}
.card h3{ font-size:1.05rem; margin-bottom:.3rem; line-height:1.25; }
.card__meta{ font-size:.8rem; color:var(--ink-soft); margin-bottom:.7rem; }
.card__price{ display:flex; align-items:baseline; gap:.6rem; margin-bottom:1rem; }
.card__price .price{ font-size:1.2rem; }
.card .btn{ font-size:.74rem; padding:.85rem; background:transparent; border-color:var(--ink); color:var(--ink); }
.card .btn:hover{ background:var(--ink); color:var(--cream); }

/* ---------- story ---------- */
.story{
  display:grid; grid-template-columns:1fr 1fr; align-items:stretch; gap:0;
  background:var(--cream-2); margin:2rem 0;
}
.story__media{ overflow:hidden; min-height:380px; }
.story__media img{ width:100%; height:100%; object-fit:cover; }
.story__copy{ padding:4.5rem 4rem; align-self:center; }
.story__copy p{ color:var(--ink-soft); margin:1.1rem 0; max-width:30rem; }
.story__copy .btn{ margin-top:1rem; }

/* ---------- values ---------- */
.values{
  max-width:var(--wrap); margin:0 auto; padding:5rem 1.5rem;
  display:grid; grid-template-columns:repeat(4,1fr); gap:2.5rem;
}
.value{ border-top:2px solid var(--gold); padding-top:1.2rem; }
.value h3{ margin-bottom:.5rem; }
.value p{ font-size:.92rem; color:var(--ink-soft); }

/* ---------- quotes ---------- */
.quotes{ background:var(--cream-2); padding:5rem 1.5rem; }
.quotes__grid{ max-width:var(--wrap); margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.quote{ background:var(--cream); border-radius:var(--radius); padding:2.2rem; }
.stars{ color:var(--gold); letter-spacing:.15em; margin-bottom:1rem; }
.quote blockquote{ font-family:var(--font-display); font-size:1.2rem; line-height:1.4; margin-bottom:1.2rem; }
.quote figcaption{ font-size:.82rem; font-weight:600; letter-spacing:.04em; color:var(--ink-soft); text-transform:uppercase; }

/* ---------- newsletter ---------- */
.news{ padding:5.5rem 1.5rem; text-align:center; }
.news__inner{ max-width:34rem; margin:0 auto; }
.news__sub{ color:var(--ink-soft); margin:1rem 0 2rem; }
.news__form{ display:flex; gap:.7rem; }
.news__form input{
  flex:1; padding:1rem 1.2rem; border:1.5px solid var(--line); border-radius:var(--radius);
  font-family:var(--font-body); font-size:.95rem; background:var(--white);
}
.news__form input:focus{ outline:none; border-color:var(--gold); }

/* ---------- footer ---------- */
.footer{ background:var(--ink); color:var(--cream); padding:4rem 1.5rem 2rem; }
.footer__grid{
  max-width:var(--wrap); margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:3rem;
  border-bottom:1px solid rgba(250,246,238,.15);
}
.footer__brand img{ height:54px; width:auto; margin-bottom:1.2rem; filter:brightness(1.2); }
.footer__brand p{ font-size:.9rem; opacity:.75; max-width:22rem; margin-bottom:1.2rem; }
.footer__social a{ font-size:.85rem; font-weight:600; border-bottom:1px solid var(--gold); padding-bottom:2px; }
.footer__col h4{ font-family:var(--font-body); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; opacity:.6; margin-bottom:1rem; }
.footer__col a, .footer__col span{ display:block; font-size:.9rem; opacity:.85; margin-bottom:.6rem; }
.footer__col a:hover{ opacity:1; color:var(--gold); }
.footer__bar{
  max-width:var(--wrap); margin:0 auto; padding-top:1.5rem;
  display:flex; justify-content:space-between; font-size:.78rem; opacity:.6;
}

/* ---------- cart drawer ---------- */
.cart-overlay{ position:fixed; inset:0; background:rgba(42,37,32,.45); z-index:200; opacity:0; visibility:hidden; transition:.3s; }
.cart-overlay.open{ opacity:1; visibility:visible; }
.cart{
  position:fixed; top:0; right:0; bottom:0; width:420px; max-width:92vw;
  background:var(--cream); z-index:210; transform:translateX(100%);
  transition:transform .35s var(--ease); display:flex; flex-direction:column;
}
.cart.open{ transform:translateX(0); }
.cart__head{ display:flex; justify-content:space-between; align-items:center; padding:1.5rem; border-bottom:1px solid var(--line); }
.cart__head h3{ font-size:1.3rem; }
.cart__head button{ background:none; border:none; font-size:1.1rem; cursor:pointer; color:var(--ink); }
.cart__ship{ padding:1rem 1.5rem; background:var(--cream-2); font-size:.8rem; }
.cart__ship p{ margin-bottom:.5rem; }
.cart__bar{ height:5px; background:var(--cream-3); border-radius:99px; overflow:hidden; }
.cart__bar-fill{ height:100%; width:0; background:var(--gold); transition:width .4s var(--ease); }
.cart__items{ flex:1; overflow-y:auto; padding:1.5rem; }
.cart__empty{ color:var(--ink-soft); text-align:center; padding:3rem 0; }
.cart-item{ display:flex; gap:1rem; margin-bottom:1.3rem; }
.cart-item__img{ width:70px; height:70px; background:var(--cream-2); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; padding:.4rem; flex-shrink:0; }
.cart-item__img img{ max-height:100%; width:auto; mix-blend-mode:multiply; }
.cart-item__body{ flex:1; }
.cart-item__name{ font-size:.9rem; font-weight:600; line-height:1.3; margin-bottom:.2rem; }
.cart-item__price{ font-size:.88rem; color:var(--ink-soft); }
.cart-item__remove{ background:none; border:none; font-size:.74rem; color:var(--ink-soft); text-decoration:underline; cursor:pointer; padding:0; margin-top:.3rem; }
.cart__foot{ padding:1.5rem; border-top:1px solid var(--line); }
.cart__total{ display:flex; justify-content:space-between; font-weight:600; margin-bottom:1rem; font-size:1.05rem; }
.cart__note{ text-align:center; font-size:.74rem; color:var(--ink-soft); margin-top:.7rem; }

/* ============================================================
   responsive
   ============================================================ */
@media (max-width:1000px){
  .products__grid{ grid-template-columns:repeat(2,1fr); }
  .values{ grid-template-columns:repeat(2,1fr); gap:2rem; }
}

@media (max-width:760px){
  .nav{ display:none; }
  .header__menu{ display:flex; }
  .header__inner{ justify-content:space-between; }
  .header__logo{ position:absolute; left:50%; transform:translateX(-50%); }
  .header__logo img{ height:38px; }

  .hero{ grid-template-columns:1fr; padding-top:3rem; text-align:center; }
  .hero__copy{ order:2; }
  .hero__media{ order:1; }
  .hero__media img{ max-height:320px; }
  .hero__actions, .hero__marks{ justify-content:center; }
  .hero__sub{ margin-left:auto; margin-right:auto; }

  .cats__grid{ grid-template-columns:1fr; }
  .feature{ grid-template-columns:1fr; gap:2rem; }
  .feature__media{ order:1; }
  .feature__copy{ order:2; }
  .products__grid{ grid-template-columns:repeat(2,1fr); gap:1rem; }
  .story{ grid-template-columns:1fr; }
  .story__media{ min-height:300px; }
  .story__copy{ padding:3rem 1.8rem; }
  .quotes__grid{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr 1fr; gap:2rem; }
  .footer__brand{ grid-column:1/-1; }
}

@media (max-width:430px){
  .products__grid{ grid-template-columns:1fr; }
  .values{ grid-template-columns:1fr; }
  .news__form{ flex-direction:column; }
  .footer__grid{ grid-template-columns:1fr; }
}

/* ============================================================
   multi-page additions
   ============================================================ */

/* card alignment: equal height, buttons pinned to bottom */
.card{ display:flex; flex-direction:column; }
.card h3 a{ color:inherit; }
.card .btn{ margin-top:auto; }

/* keep marble / coloured-background photos true (skip the white-knockout blend) */
img.no-blend{ mix-blend-mode:normal; }

/* page hero / banner */
.page-hero{ background:var(--cream-2); text-align:center; padding:4rem 1.5rem; }
.page-hero h1{ margin-bottom:.6rem; }
.page-hero p{ color:var(--ink-soft); max-width:34rem; margin:0 auto; }

/* breadcrumb */
.crumb{ max-width:var(--wrap); margin:0 auto; padding:1.5rem 1.5rem 0; font-size:.82rem; color:var(--ink-soft); }
.crumb a:hover{ color:var(--gold-deep); }
.crumb span{ color:var(--ink); }

/* product detail page */
.pdp{ max-width:var(--wrap); margin:0 auto; padding:2rem 1.5rem 3rem; display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:start; }
.pdp__media{ background:var(--cream-2); border-radius:var(--radius); padding:3rem; display:flex; justify-content:center; align-items:center; position:sticky; top:90px; }
.pdp__media img{ max-height:460px; width:auto; mix-blend-mode:multiply; }
.pdp__info h1{ font-size:clamp(2rem,3.5vw,2.8rem); margin:.4rem 0 1rem; }
.pdp__price{ display:flex; align-items:baseline; gap:.9rem; margin-bottom:1.5rem; flex-wrap:wrap; }
.pdp__desc{ color:var(--ink-soft); margin-bottom:1.8rem; }
.pdp__trust{ list-style:none; display:flex; gap:1.4rem; flex-wrap:wrap; margin:1.4rem 0 2rem; font-size:.78rem; letter-spacing:.04em; color:var(--ink-soft); }
.pdp__trust li{ position:relative; padding-left:1rem; }
.pdp__trust li::before{ content:"·"; position:absolute; left:0; color:var(--gold); font-weight:700; }
.pdp__includes{ border-top:1px solid var(--line); padding-top:1.5rem; }
.pdp__includes h4{ font-family:var(--font-body); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:.9rem; }
.pdp__includes ul{ list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:.5rem 1.5rem; }
.pdp__includes li{ font-size:.92rem; color:var(--ink-soft); }
.pdp__specs{ max-width:var(--wrap); margin:0 auto; padding:3rem 1.5rem; border-top:1px solid var(--line); }
.pdp__specs h2{ margin-bottom:1.8rem; }
.specs{ display:grid; grid-template-columns:1fr 1fr; gap:0 4rem; }
.spec{ display:flex; justify-content:space-between; gap:1rem; padding:1rem 0; border-bottom:1px solid var(--line); }
.spec__k{ font-weight:600; }
.spec__v{ color:var(--ink-soft); text-align:right; }
.pdp__related{ max-width:var(--wrap); margin:0 auto; padding:4rem 1.5rem 5rem; }

/* shop filters */
.shop-bar{ max-width:var(--wrap); margin:0 auto; padding:2rem 1.5rem 0; display:flex; gap:.6rem; justify-content:center; flex-wrap:wrap; }
.shop-bar a{ font-size:.8rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase; padding:.6rem 1.2rem; border:1.5px solid var(--line); border-radius:99px; transition:.2s; }
.shop-bar a:hover, .shop-bar a.active{ background:var(--ink); color:var(--cream); border-color:var(--ink); }
.shop-grid{ max-width:var(--wrap); margin:0 auto; padding:2.5rem 1.5rem 5rem; }

/* about */
.about-lead{ max-width:46rem; margin:0 auto; padding:4rem 1.5rem; text-align:center; }
.about-lead p{ font-family:var(--font-display); font-size:clamp(1.3rem,2.4vw,1.7rem); line-height:1.5; }
.about-split{ max-width:var(--wrap); margin:0 auto; padding:2rem 1.5rem 4rem; display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; }
.about-split img{ border-radius:var(--radius); width:100%; }
.about-split p{ color:var(--ink-soft); margin-bottom:1rem; }

/* contact */
.contact-wrap{ max-width:var(--wrap); margin:0 auto; padding:3rem 1.5rem 5rem; display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; }
.contact-info h3{ margin-bottom:1.4rem; }
.contact-info .row{ padding:1.1rem 0; border-bottom:1px solid var(--line); }
.contact-info .row span{ display:block; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:.3rem; }
.contact-info .row a, .contact-info .row p{ font-size:1.05rem; }
.form-field{ margin-bottom:1.2rem; }
.form-field label{ display:block; font-size:.82rem; font-weight:600; margin-bottom:.4rem; }
.form-field input, .form-field textarea{ width:100%; padding:.9rem 1rem; border:1.5px solid var(--line); border-radius:var(--radius); font-family:var(--font-body); font-size:.95rem; background:var(--white); }
.form-field input:focus, .form-field textarea:focus{ outline:none; border-color:var(--gold); }
.form-field textarea{ min-height:130px; resize:vertical; }
.form-success{ color:var(--gold-deep); font-weight:600; padding:1.2rem 0; }
.news .form-success{ text-align:center; }

/* responsive for new pages */
@media (max-width:760px){
  .pdp{ grid-template-columns:1fr; gap:1.5rem; }
  .pdp__media{ position:static; padding:2rem; }
  .pdp__media img{ max-height:300px; }
  .pdp__includes ul{ grid-template-columns:1fr; }
  .specs{ grid-template-columns:1fr; gap:0; }
  .about-split{ grid-template-columns:1fr; gap:2rem; }
  .contact-wrap{ grid-template-columns:1fr; gap:2.5rem; }
}

/* ============================================================
   mobile polish pass
   ============================================================ */
.quotes__dots{ display:none; }

@media (max-width:760px){
  /* categories: horizontal swipe instead of giant stacked tiles */
  .cats{ padding:3.5rem 0 4rem; }
  .cats .section-head{ padding:0 1.5rem; }
  .cats__grid{ display:flex; gap:1rem; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding:0 1.5rem 1rem; }
  .cats__grid .cat{ flex:0 0 70%; scroll-snap-align:start; }
  .cat__img{ aspect-ratio:4/5; margin-bottom:.8rem; }

  /* centrepiece: tighter media box, less empty space */
  .feature{ gap:1.4rem; padding:3.5rem 1.5rem; }
  .feature__media{ padding:1.6rem; }
  .feature__media img{ max-height:230px; }

  /* reviews: one-at-a-time auto-rotating carousel */
  .quotes__grid{ display:block; }
  .quotes__grid .quote{ display:none; }
  .quotes__grid .quote.is-active{ display:block; }
  .quotes__dots{ display:flex; justify-content:center; gap:.5rem; margin-top:1.6rem; }
  .quotes__dot{ width:8px; height:8px; border-radius:50%; border:none; background:var(--cream-3); cursor:pointer; padding:0; transition:background .3s; }
  .quotes__dot.is-active{ background:var(--gold); }
}
