/* ═══════════════════════════════════════════════════════════════════════
   THE BISCUIT TIN — bespoke build
   Direction: artisan patisserie. Warm cream paper, charcoal ink, gold
   botanical line-work (from the wreath logo), pink + mint as joyful pops.
   Editorial, asymmetric, tactile. Original layout — not a template.
   ═══════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,500;1,9..144,600&family=Inter:wght@400;500;600;700&family=Caveat:wght@600;700&display=swap');

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

:root{
  --paper:#FBF5E9;        /* warm cream base */
  --paper-2:#F4E9D5;      /* deeper cream panel */
  --paper-3:#FFFDF8;      /* near-white card */
  --ink:#22190F;          /* espresso-charcoal text */
  --ink-2:#5d5345;        /* muted */
  --line:#E6D8BE;         /* hairline on cream */
  --gold:#B07C1E;         /* readable gold on cream */
  --gold-bright:#D9A93F;  /* logo gold for fills/lines */
  --pink:#E4548A;         /* vivid raspberry-icing pink */
  --pink-soft:#F8D6E2;
  --mint:#1FA98A;         /* vivid pistachio mint */
  --mint-soft:#CDEBDF;
  --black:#1A140C;        /* footer / ribbon ink band */
  --display:'Fraunces',Georgia,serif;
  --body:'Inter',system-ui,sans-serif;
  --script:'Caveat',cursive;
  --max:1240px;
  --pad:clamp(18px,4vw,52px);
  --r:14px;
  --r-lg:26px;
  --shadow:0 18px 50px -22px rgba(74,48,12,.45);
  --shadow-sm:0 8px 24px -14px rgba(74,48,12,.4);
}

html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--ink);text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.05;letter-spacing:-.01em;color:var(--ink)}
::selection{background:var(--pink);color:#fff}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--body);font-weight:600;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold-bright)}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--gold-bright)}
.script{font-family:var(--script);font-weight:700;letter-spacing:0}

/* ── Buttons ─────────────────────────────────────────────────────────── */
.btn{
  --bg:var(--ink);--fg:var(--paper);
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--body);font-weight:600;font-size:14px;letter-spacing:.01em;
  padding:15px 26px;border-radius:999px;border:1.5px solid var(--bg);
  background:var(--bg);color:var(--fg);cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.btn:active{transform:translateY(-1px)}
.btn svg{width:18px;height:18px}
.btn-primary{--bg:var(--pink);--fg:#fff}
.btn-primary:hover{--bg:#d23f79}
.btn-ink{--bg:var(--ink);--fg:var(--paper)}
.btn-gold{--bg:var(--gold);--fg:#fff}
.btn-mint{--bg:var(--mint);--fg:#fff}
.btn-ghost{--bg:transparent;--fg:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{--bg:var(--ink);--fg:var(--paper)}
.btn-outline{--bg:transparent;--fg:var(--ink);border-color:var(--line)}
.btn-outline:hover{--bg:transparent;--fg:var(--pink);border-color:var(--pink)}
.btn-block{width:100%}
.btn-sm{padding:10px 18px;font-size:13px}
.btn-lg{padding:17px 32px;font-size:15px}

/* ── Marquee ribbon ──────────────────────────────────────────────────── */
.ribbon{background:var(--black);color:var(--paper);overflow:hidden;border-bottom:1px solid #00000022;pointer-events:none;user-select:none}
.ribbon-track{display:flex;width:max-content;gap:0;white-space:nowrap;animation:marquee 28s linear infinite;will-change:transform}
.ribbon-track span{flex:0 0 auto;display:inline-flex;align-items:center;gap:14px;padding:9px 0;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.ribbon-track span::after{content:"✶";color:var(--gold-bright);margin:0 26px;font-size:10px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ribbon-track{animation:none}}

/* ── Header / nav ────────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:200;background:var(--mint-soft);border-bottom:none}
.site-header::after{content:"";position:absolute;left:0;right:0;top:100%;height:32px;background:linear-gradient(to bottom,var(--mint-soft),rgba(205,235,223,0));pointer-events:none;z-index:199}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;height:88px}
.nav-logo img{height:64px;width:auto;transition:transform .3s}
.nav-logo:hover img{transform:rotate(-2deg) scale(1.03)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-weight:500;font-size:15px;color:var(--ink);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--mint);transition:right .28s cubic-bezier(.2,.8,.2,1)}
.nav-links a:hover::after,.nav-links a.is-active::after{right:0}
.nav-actions{display:flex;align-items:center;gap:14px}
.nav-cart{position:relative;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;border:1.5px solid color-mix(in srgb,var(--mint) 55%,transparent);color:var(--ink);transition:.2s}
.nav-cart:hover{border-color:var(--mint);transform:translateY(-2px)}
.nav-cart svg{width:20px;height:20px}
.cart-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:var(--pink);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--body)}
.nav-burger{display:none;width:46px;height:46px;border:1.5px solid color-mix(in srgb,var(--mint) 55%,transparent);border-radius:12px;background:none;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.nav-burger span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:300;background:var(--paper);transform:translateY(-100%);transition:transform .4s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;padding:26px var(--pad);overflow-y:auto}
.drawer.open{transform:translateY(0)}
.drawer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.drawer-close{width:46px;height:46px;border:1.5px solid var(--line);border-radius:12px;background:none;font-size:22px;cursor:pointer;color:var(--ink)}
.drawer nav{display:flex;flex-direction:column;gap:6px}
.drawer nav a{font-family:var(--display);font-size:30px;font-weight:600;padding:10px 0;border-bottom:1px solid var(--line)}
.drawer nav a:last-child{border-bottom:none}
.drawer-foot{margin-top:auto;padding-top:26px;color:var(--ink-2);font-size:14px}

/* ── Hero (asymmetric) ───────────────────────────────────────────────── */
.hero{position:relative;padding:clamp(40px,6vw,84px) 0 clamp(56px,7vw,96px)}
.hero::before{content:"";position:absolute;top:-60px;right:-120px;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,var(--pink-soft),transparent 68%);z-index:0;pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-80px;left:-140px;width:460px;height:460px;border-radius:50%;
  background:radial-gradient(circle,var(--mint-soft),transparent 68%);z-index:0;pointer-events:none}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,64px);align-items:center}
.hero-copy h1{font-size:clamp(2.7rem,6.5vw,5rem);line-height:.96;margin:18px 0 0}
.hero-copy h1 .script{display:block;color:var(--pink);font-size:1.18em;line-height:.8;margin:2px 0 -6px;transform:rotate(-3deg)}
.hero-copy p{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-2);max-width:46ch;margin:24px 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.hero-meta div{font-size:13px;color:var(--ink-2)}
.hero-meta b{display:block;font-family:var(--display);font-size:26px;color:var(--ink);font-weight:600;line-height:1}
/* hero visual: stacked tin/biscuit disc with depth */
.hero-art{position:relative;aspect-ratio:1/1;max-width:520px;margin-inline:auto;width:100%}
.hero-disc{position:absolute;inset:0;background:none;display:flex;align-items:center;justify-content:center}
.hero-logo-badge{width:90%;height:auto;filter:drop-shadow(0 12px 26px rgba(74,48,12,.18))}
.hero-chip{position:absolute;background:var(--paper-3);border:1px solid var(--line);border-radius:18px;padding:12px 16px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px}
.hero-chip svg{width:22px;height:22px}
.hero-chip.c1{top:2%;left:-4%;color:var(--pink)}
.hero-chip.c2{bottom:8%;right:-6%;color:var(--mint)}
.hero-chip.c3{bottom:-3%;left:14%;color:var(--gold)}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.hero-chip{animation:floaty 5s ease-in-out infinite}
.hero-chip.c2{animation-delay:1.2s}
.hero-chip.c3{animation-delay:2.4s}
@media (prefers-reduced-motion:reduce){.hero-chip{animation:none}}

/* ── Section scaffolding ─────────────────────────────────────────────── */
.section{padding:clamp(56px,8vw,104px) 0;position:relative}
.section.paper-2{background:var(--paper-2)}
.sec-head{max-width:680px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.3rem);margin:14px 0 0}
.sec-head .lede{color:var(--ink-2);font-size:1.1rem;margin-top:16px}
.sprig{display:block;margin:0 auto 4px;color:var(--gold-bright)}

/* ── How it works (staggered) ────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,34px);margin-top:54px}
.step{position:relative;background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 28px 30px}
.step:nth-child(2){transform:translateY(26px)}
.step-no{font-family:var(--display);font-size:60px;font-weight:600;color:var(--pink-soft);line-height:.8;margin-bottom:6px}
.step-ico{position:absolute;top:30px;right:28px;width:40px;height:40px;color:var(--gold)}
.step h3{font-size:1.5rem;margin-bottom:8px}
.step p{color:var(--ink-2);font-size:.98rem}
@media (max-width:820px){.steps{grid-template-columns:1fr}.step:nth-child(2){transform:none}}

/* ── Bento category grid ─────────────────────────────────────────────── */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px;margin-top:48px}
.tile{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);background:var(--paper-3);padding:26px;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .3s,box-shadow .3s;color:var(--ink)}
.tile:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.tile .tile-ico{position:absolute;top:22px;left:22px;width:34px;height:34px;opacity:.9}
.tile h3{font-size:1.55rem}
.tile span{font-size:13px;color:var(--ink-2);display:flex;align-items:center;gap:6px;margin-top:4px}
.tile span svg{width:15px;height:15px;transition:transform .25s}
.tile:hover span svg{transform:translateX(5px)}
.tile.big{grid-column:span 2;grid-row:span 2}
.tile.wide{grid-column:span 2}
.tile.pink{background:linear-gradient(150deg,var(--pink-soft),var(--paper-3))}
.tile.mint{background:linear-gradient(150deg,var(--mint-soft),var(--paper-3))}
.tile.gold{background:linear-gradient(150deg,#F3E2BC,var(--paper-3))}
.tile.ink{background:var(--black);color:var(--paper)}
.tile.ink h3{color:var(--paper)}
.tile.ink span{color:#d8cdbb}
@media (max-width:900px){.bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}.tile.big{grid-row:span 1}}
@media (max-width:560px){.bento{grid-template-columns:1fr}.tile,.tile.big,.tile.wide{grid-column:span 1}}

/* ── Birthday Box feature + interactive personaliser ─────────────────── */
.bday{position:relative;overflow:hidden;background:
   radial-gradient(circle at 85% 15%,var(--pink-soft),transparent 40%),
   radial-gradient(circle at 8% 90%,var(--mint-soft),transparent 42%),
   var(--paper-2)}
.bday-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.bday-copy h2{font-size:clamp(2.1rem,4.6vw,3.4rem)}
.bday-copy h2 .script{color:var(--mint);display:inline-block;transform:rotate(-2deg)}
.bday-copy p{color:var(--ink-2);margin-top:16px;font-size:1.06rem;max-width:48ch}
.bday-list{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:24px 0 30px}
.bday-list li{display:inline-flex;align-items:center;gap:8px;background:var(--paper-3);border:1px solid var(--line);border-radius:999px;padding:8px 15px;font-size:13px;font-weight:600}
.bday-list svg{width:16px;height:16px;color:var(--pink)}
/* live preview biscuit */
.personaliser{background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow)}
.biscuit{position:relative;width:230px;height:230px;margin:4px auto 26px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,#e7b873,#c98c43 70%,#b27c34);
  box-shadow:inset 0 -10px 24px rgba(120,74,20,.45),inset 0 8px 18px rgba(255,225,180,.5),var(--shadow-sm);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.biscuit::before{content:"";position:absolute;inset:16px;border-radius:50%;border:5px dotted rgba(255,255,255,.85)}
.biscuit .ice-name{font-family:var(--script);font-size:46px;line-height:.9;color:#fff;text-shadow:0 1px 0 var(--pink),0 2px 6px rgba(0,0,0,.18);max-width:80%;word-break:break-word}
.biscuit .ice-age{font-family:var(--display);font-weight:700;font-size:30px;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.2)}
.biscuit .ice-age b{color:var(--mint-soft)}
.pz-fields{display:grid;grid-template-columns:1fr 90px;gap:12px}
.pz-fields label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);display:block;margin-bottom:6px}
.pz-fields input{width:100%;background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:13px 14px;font-family:var(--body);font-size:15px;color:var(--ink)}
.pz-fields input:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px var(--pink-soft)}
.personaliser .btn{margin-top:18px}
@media (max-width:820px){.bday-grid{grid-template-columns:1fr}}

/* ── Testimonials ────────────────────────────────────────────────────── */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.quote{background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 28px;position:relative}
.quote .stars{color:var(--gold-bright);letter-spacing:3px;font-size:14px;margin-bottom:12px}
.quote p{font-family:var(--display);font-size:1.18rem;font-style:italic;line-height:1.4}
.quote cite{display:block;margin-top:16px;font-style:normal;font-weight:600;font-size:14px}
.quote cite span{color:var(--ink-2);font-weight:400}
@media (max-width:820px){.quotes{grid-template-columns:1fr}}

/* ── Final CTA band ──────────────────────────────────────────────────── */
.cta-band{background:var(--black);color:var(--paper);border-radius:var(--r-lg);padding:clamp(40px,6vw,72px);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;top:-40%;left:-10%;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--pink) 50%,transparent),transparent 70%)}
.cta-band::after{content:"";position:absolute;bottom:-50%;right:-8%;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--mint) 45%,transparent),transparent 70%)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:var(--paper);font-size:clamp(2rem,4.5vw,3.2rem)}
.cta-band p{color:#e3d9c8;max-width:50ch;margin:14px auto 28px}

/* ── Product card ────────────────────────────────────────────────────── */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
.product-card{display:block;background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .3s,box-shadow .3s}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pc-media{position:relative;aspect-ratio:4/3;background:linear-gradient(150deg,var(--paper-2),var(--paper-3));display:flex;align-items:center;justify-content:center;overflow:hidden}
.pc-media img{width:100%;height:100%;object-fit:cover}
.pc-media .pc-ph{width:78px;height:78px;color:var(--gold-bright);opacity:.6}
.pc-badge{position:absolute;top:14px;left:14px;background:var(--pink);color:#fff;font-size:11px;font-weight:700;letter-spacing:.04em;padding:5px 12px;border-radius:999px}
.pc-badge.gift{background:var(--mint)}
.pc-body{padding:20px 22px 24px}
.pc-cat{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.pc-name{font-family:var(--display);font-size:1.4rem;font-weight:600;margin:6px 0 10px}
.pc-foot{display:flex;align-items:center;justify-content:space-between}
.pc-price{font-family:var(--display);font-size:1.3rem;font-weight:600}
.pc-price .was{font-size:.8em;color:var(--ink-2);text-decoration:line-through;margin-right:6px;font-weight:400}
.pc-go{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--pink)}
.pc-go svg{width:15px;height:15px;transition:transform .25s}
.product-card:hover .pc-go svg{transform:translateX(5px)}
@media (max-width:900px){.product-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.product-grid{grid-template-columns:1fr}}

/* ── Shop ────────────────────────────────────────────────────────────── */
.page-head{padding:clamp(40px,6vw,72px) 0 0;text-align:center}
.page-head h1{font-size:clamp(2.4rem,5.5vw,4rem)}
.page-head p{color:var(--ink-2);margin-top:12px}
.shop-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:34px 0 44px}
.chip{font-size:13px;font-weight:600;padding:9px 18px;border-radius:999px;border:1.5px solid var(--line);color:var(--ink);background:var(--paper-3);transition:.2s}
.chip:hover{border-color:var(--pink);color:var(--pink)}
.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.empty{grid-column:1/-1;text-align:center;padding:80px 20px;color:var(--ink-2)}

/* ── Product detail ──────────────────────────────────────────────────── */
.pd{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,60px);align-items:start}
.pd-media{position:sticky;top:108px}
.pd-main{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);min-height:320px;max-height:620px;background:linear-gradient(150deg,var(--paper-2),var(--paper-3));display:flex;align-items:center;justify-content:center;padding:10px}
.pd-main img{max-width:100%;max-height:600px;width:auto;height:auto;object-fit:contain}
.pd-main .pc-ph{width:120px;height:120px;color:var(--gold-bright);opacity:.55}
.pd-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.pd-thumbs img{width:84px;height:84px;object-fit:cover;border-radius:12px;border:2px solid transparent;cursor:pointer;opacity:.7;transition:.2s}
.pd-thumbs img.active,.pd-thumbs img:hover{border-color:var(--pink);opacity:1}
.crumbs{font-size:12px;letter-spacing:.04em;color:var(--ink-2);margin-bottom:22px;display:flex;gap:8px;flex-wrap:wrap}
.crumbs a{color:var(--ink-2)}.crumbs a:hover{color:var(--pink)}
.pd-cat{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.pd-info h1{font-size:clamp(2rem,4vw,3rem);margin:8px 0 14px}
.pd-price{font-family:var(--display);font-size:2rem;font-weight:600;display:flex;align-items:baseline;gap:12px}
.pd-price .was{font-size:1.1rem;color:var(--ink-2);text-decoration:line-through}
.pd-desc{color:var(--ink-2);margin:18px 0 26px;font-size:1.05rem}
.vlabel{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);display:block;margin-bottom:10px}
.vpills{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}
.vpill{padding:11px 18px;border:1.5px solid var(--line);background:var(--paper-3);border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:.18s;color:var(--ink)}
.vpill:hover,.vpill.selected{border-color:var(--pink);color:var(--pink);background:var(--pink-soft)}
.stock-line{min-height:22px;font-weight:600;font-size:14px;margin-bottom:14px}
.qty-add{display:flex;gap:14px;align-items:stretch;margin-bottom:14px}
.qtybox{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;background:var(--paper-3)}
.qtybox button{width:42px;height:50px;border:none;background:none;font-size:20px;cursor:pointer;color:var(--ink)}
.qtybox span{width:40px;text-align:center;font-weight:600}
.qty-add .btn{flex:1}
.atc-msg{min-height:20px;font-size:14px;font-weight:600}
.pd-trust{display:flex;flex-direction:column;gap:10px;margin:26px 0;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-size:14px;color:var(--ink-2)}
.pd-trust div{display:flex;align-items:center;gap:10px}
.pd-trust svg{width:18px;height:18px;color:var(--gold);flex-shrink:0}
.acc-item{border-bottom:1px solid var(--line)}
.acc-trig{width:100%;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:18px 0;font-family:var(--body);font-weight:600;font-size:15px;color:var(--ink)}
.acc-trig .ico{font-size:22px;transition:transform .25s;color:var(--pink)}
.acc-trig.open .ico{transform:rotate(45deg)}
.acc-body{display:none;padding:0 0 20px;color:var(--ink-2);line-height:1.8}
.acc-body.open{display:block}
.acc-body ul{padding-left:20px}
@media (max-width:820px){.pd{grid-template-columns:1fr}.pd-media{position:static}}

/* ── Personalise box (Birthday Box on product page) ──────────────────── */
.personalise-box{margin:6px 0 24px;padding:22px;border:1.5px solid var(--pink);border-radius:var(--r);background:var(--pink-soft)}
.pb-title{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px;letter-spacing:.04em;color:#bb2e63;margin-bottom:4px}
.pb-title svg{width:18px;height:18px}
.pb-sub{font-size:13.5px;color:#8a4a63;margin-bottom:14px}
.pb-grid{display:grid;grid-template-columns:1fr 100px;gap:12px}
.pb-grid label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#a23b66;display:block;margin-bottom:6px}
.pb-grid input{width:100%;border:1.5px solid #e2a9c1;border-radius:10px;padding:12px 13px;font-family:var(--body);font-size:15px;background:#fff;color:var(--ink)}
.pb-grid input:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px rgba(228,84,138,.18)}
@media (max-width:480px){.pb-grid{grid-template-columns:1fr}}

/* ── Cart ────────────────────────────────────────────────────────────── */
.cart-grid{display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start}
.cart-row{display:grid;grid-template-columns:92px 1fr auto;gap:18px;align-items:center;padding:20px 0;border-bottom:1px solid var(--line)}
.cart-row .ph,.cart-row img{width:92px;height:92px;border-radius:14px;object-fit:cover;background:var(--paper-2);display:flex;align-items:center;justify-content:center;color:var(--gold-bright)}
.cart-name{font-family:var(--display);font-size:1.2rem;font-weight:600}
.cart-variant{font-size:13px;color:var(--ink-2);margin-top:2px}
.cart-pers{font-size:13px;color:var(--mint);font-weight:600;margin-top:4px}
.cart-pers b{color:var(--ink)}
.cart-qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;margin-top:8px}
.cart-qty button{width:34px;height:36px;border:none;background:none;cursor:pointer;font-size:17px;color:var(--ink)}
.cart-qty span{width:34px;text-align:center;font-weight:600}
.cart-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.cart-line-total{font-family:var(--display);font-weight:600;font-size:1.15rem}
.cart-remove{background:none;border:none;cursor:pointer;color:var(--ink-2);font-size:13px}
.cart-remove:hover{color:var(--pink)}
.summary{background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;position:sticky;top:108px}
.summary h3{font-family:var(--body);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);margin-bottom:18px}
.sum-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line);font-size:15px;color:var(--ink-2)}
.sum-row.total{border-bottom:none;font-family:var(--display);font-size:1.35rem;font-weight:600;color:var(--ink);padding-top:14px}
.ship-note{font-size:13px;color:var(--mint);text-align:center;padding:10px 0;font-weight:600}
.summary .btn{margin-top:16px}
.empty-cart{text-align:center;padding:90px 20px}
.empty-cart svg{width:64px;height:64px;color:var(--gold-bright);opacity:.5;margin-bottom:18px}
.empty-cart h2{font-size:2rem;margin-bottom:10px}
.empty-cart p{color:var(--ink-2);margin-bottom:24px}
@media (max-width:900px){.cart-grid{grid-template-columns:1fr}.summary{position:static}}

/* ── Forms / checkout ────────────────────────────────────────────────── */
.co-grid{display:grid;grid-template-columns:1fr 380px;gap:44px;align-items:start}
.fs{margin-bottom:30px}
.fs h3{font-family:var(--body);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:18px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.full{grid-column:1/-1}
.field label{display:block;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);margin-bottom:7px}
.field input,.field textarea,.field select{width:100%;background:var(--paper-3);border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--body);font-size:15px;color:var(--ink)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px var(--pink-soft)}
.req{color:var(--pink)}
.payopts{display:flex;flex-direction:column;gap:12px}
.payopt{display:flex;gap:13px;align-items:flex-start;border:1.5px solid var(--line);border-radius:14px;padding:16px 18px;cursor:pointer;transition:.2s;background:var(--paper-3)}
.payopt:hover,.payopt.active{border-color:var(--pink);background:var(--pink-soft)}
.payopt input{margin-top:3px;accent-color:var(--pink)}
.payopt b{display:block;font-size:15px}
.payopt span{font-size:13px;color:var(--ink-2)}
.trust-mini{display:flex;gap:18px;flex-wrap:wrap;margin:18px 0;font-size:13px;color:var(--ink-2)}
.trust-mini div{display:flex;align-items:center;gap:7px}
.trust-mini svg{width:16px;height:16px;color:var(--mint)}
.co-item{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.co-item-name{font-family:var(--display);font-weight:600}
.co-item-sub{font-size:12px;color:var(--ink-2)}
.co-item-pers{font-size:12px;color:var(--mint);font-weight:600}
.co-item-price{font-weight:600;white-space:nowrap}
@media (max-width:900px){.co-grid{grid-template-columns:1fr}.fgrid{grid-template-columns:1fr}}

/* ── Confirmation ────────────────────────────────────────────────────── */
.confirm{max-width:740px;margin:0 auto;text-align:center}
.confirm-card{background:var(--paper-3);border:1px solid var(--line);border-top:4px solid var(--mint);border-radius:var(--r-lg);padding:clamp(30px,5vw,56px)}
.confirm-ico{width:72px;height:72px;margin:0 auto 18px;color:var(--mint)}
.confirm h1{font-size:2.4rem}
.confirm-msg{color:var(--ink-2);margin:14px auto 22px;max-width:50ch}
.confirm-msg b{color:var(--ink)}
.order-no{display:inline-block;border:1px solid var(--gold);background:#fbf1da;border-radius:12px;padding:12px 24px;margin-bottom:30px}
.order-no small{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2)}
.order-no b{font-family:var(--display);font-size:18px;letter-spacing:.06em;color:var(--gold)}
.confirm-tbl{width:100%;border-collapse:collapse;text-align:left;font-size:14px;margin-top:8px}
.confirm-tbl th{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);padding:8px 10px;border-bottom:1px solid var(--line)}
.confirm-tbl td{padding:11px 10px;border-bottom:1px solid var(--line);color:var(--ink-2)}
.confirm-next{text-align:left;background:var(--paper-2);border-radius:var(--r);padding:24px;margin-top:24px}
.confirm-next h3{font-family:var(--body);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--mint);margin-bottom:10px}
.confirm-next ol{padding-left:20px;color:var(--ink-2);line-height:1.9}
.confirm-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:28px}

/* ── Contact / about shared ──────────────────────────────────────────── */
.split{display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(28px,4vw,56px);align-items:start}
.card-soft{background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(24px,3vw,36px)}
.cform{display:flex;flex-direction:column;gap:16px}
.cform label{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);display:flex;flex-direction:column;gap:7px}
.cform input,.cform textarea{background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--body);font-size:15px;color:var(--ink);text-transform:none;letter-spacing:0;font-weight:400}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px var(--pink-soft)}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.info-list{list-style:none;display:flex;flex-direction:column;gap:20px}
.info-list li{display:flex;gap:14px;align-items:flex-start}
.info-ico{width:44px;height:44px;border-radius:12px;background:var(--pink-soft);color:var(--pink);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-ico svg{width:20px;height:20px}
.info-list b{display:block;font-family:var(--display);font-size:1.05rem}
.info-list a{color:var(--ink-2)}.info-list a:hover{color:var(--pink)}
@media (max-width:820px){.split{grid-template-columns:1fr}.cform .row{grid-template-columns:1fr}}

/* about */
.about-hero{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,60px);align-items:center}
.about-hero .frame{aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;background:
  radial-gradient(circle at 30% 30%,var(--pink-soft),transparent 60%),
  radial-gradient(circle at 75% 75%,var(--mint-soft),transparent 60%)}
.about-hero .frame img{width:74%;filter:drop-shadow(0 12px 26px rgba(74,48,12,.18))}
.about-hero h1{font-size:clamp(2.2rem,5vw,3.6rem)}
.about-hero p{color:var(--ink-2);margin-top:16px;font-size:1.08rem}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.value{background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px}
.value .v-ico{width:42px;height:42px;color:var(--gold);margin-bottom:14px}
.value h3{font-size:1.4rem;margin-bottom:8px}
.value p{color:var(--ink-2);font-size:.98rem}
@media (max-width:820px){.about-hero{grid-template-columns:1fr}.values{grid-template-columns:1fr}}

/* ── Legal pages ─────────────────────────────────────────────────────── */
.legal-hero{padding:clamp(40px,6vw,72px) 0 0;text-align:center}
.legal-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);margin-top:12px}
.legal-hero p{color:var(--ink-2);margin-top:10px;font-size:14px}
.legal-body{max-width:780px;margin:0 auto;padding:clamp(40px,5vw,64px) var(--pad)}
.legal-body h2{font-size:1.55rem;margin:40px 0 14px;padding-top:14px;border-top:1px solid var(--line)}
.legal-body h2:first-child{border-top:none;margin-top:0}
.legal-body h3{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin:22px 0 8px;font-family:var(--body)}
.legal-body p,.legal-body li{color:var(--ink-2);line-height:1.85;margin-bottom:12px}
.legal-body ul,.legal-body ol{padding-left:22px;margin-bottom:14px}
.legal-body a{color:var(--pink)}
.legal-body strong{color:var(--ink)}
.note-box{background:var(--paper-2);border:1px solid var(--line);border-left:4px solid var(--mint);border-radius:var(--r);padding:20px 24px;margin:26px 0}
.note-box p{margin:0}
.data-table{width:100%;border-collapse:collapse;margin:14px 0 22px;font-size:14px}
.data-table th{background:var(--paper-2);color:var(--ink);text-align:left;padding:10px 14px;font-size:12px;letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.data-table td{padding:10px 14px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:top}
.rights-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
.right-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px}
.right-card strong{display:block;margin-bottom:4px}
.right-card span{font-size:14px;color:var(--ink-2)}
.legal-foot{margin-top:46px;padding-top:30px;border-top:1px solid var(--line);display:flex;gap:12px;flex-wrap:wrap}
@media (max-width:600px){.rights-grid{grid-template-columns:1fr}}

/* ── Flash ───────────────────────────────────────────────────────────── */
.flash-wrap{position:fixed;top:96px;left:50%;transform:translateX(-50%);z-index:400;display:flex;flex-direction:column;gap:8px;width:min(440px,92vw);transition:opacity .4s}
.flash{padding:13px 18px;border-radius:12px;font-size:14px;font-weight:600;border:1px solid;box-shadow:var(--shadow-sm)}
.flash-success{background:var(--mint-soft);color:#0c5b46;border-color:var(--mint)}
.flash-error{background:var(--pink-soft);color:#a3265a;border-color:var(--pink)}
.flash-info{background:var(--paper-2);color:var(--ink);border-color:var(--line)}

/* ── Footer ──────────────────────────────────────────────────────────── */
.site-footer{background:var(--black);color:var(--paper);margin-top:30px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:clamp(48px,6vw,80px) 0 44px}
.footer-brand img{height:78px;width:auto;margin-bottom:16px}
.footer-brand p{color:#cabda7;max-width:34ch;font-size:14px}
.footer-col h4{font-family:var(--body);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:16px}
.footer-col a{display:block;color:#d8cdbb;font-size:14px;padding:5px 0;transition:.2s}
.footer-col a:hover{color:#fff;transform:translateX(3px)}
.footer-bottom{border-top:1px solid #ffffff1a;padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:12px;color:#9c9079}
.footer-bottom a{color:#9c9079}.footer-bottom a:hover{color:#fff}
.footer-credit{text-align:center;padding:10px 0 18px;font-size:11px;color:#6f6553}
.footer-credit a{color:#8a7e69}
@media (max-width:760px){.footer-top{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}}

/* ── Cookie banner ───────────────────────────────────────────────────── */
.cookie-banner{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(160%);z-index:500;width:min(640px,calc(100% - 28px));background:var(--paper-3);border:1px solid var(--line);border-top:3px solid var(--pink);border-radius:var(--r);padding:18px 22px;box-shadow:var(--shadow);display:flex;gap:16px;align-items:center;flex-wrap:wrap;transition:transform .45s cubic-bezier(.2,.8,.2,1)}
.cookie-banner.show{transform:translateX(-50%) translateY(0)}
.cookie-banner p{flex:1;min-width:220px;font-size:13px;color:var(--ink-2)}
.cookie-banner p a{color:var(--pink)}
.cookie-actions{display:flex;gap:10px}
@media (max-width:480px){.cookie-actions{width:100%}.cookie-actions .btn{flex:1}}

/* ── Scroll reveal ───────────────────────────────────────────────────── */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}}

/* ── Responsive nav ──────────────────────────────────────────────────── */
@media (max-width:980px){
  .nav-links{display:none}
  .nav-burger{display:flex}
}
@media (min-width:981px){.drawer{display:none}}

/* ═══════════════════════════════════════════════════════════════════════
   More colour — distribute black · gold · pink · mint across the page
   ═══════════════════════════════════════════════════════════════════════ */

/* Tinted section washes */
.section.tint-pink{background:linear-gradient(180deg,#FCE9F1,var(--paper) 92%)}
.section.tint-mint{background:linear-gradient(180deg,#E2F5EE,var(--paper) 92%)}
.section.tint-gold{background:linear-gradient(180deg,#F7ECCF,var(--paper) 92%)}

/* Black section (light text) — gives black real presence mid-page */
.section.ink{background:var(--black);color:var(--paper)}
.section.ink .sec-head h2{color:var(--paper)}
.section.ink .sec-head .lede{color:#d8cdbb}
.section.ink .eyebrow{color:var(--mint)}
.section.ink .quote{background:#241c12;border-color:#3a2f1e}
.section.ink .quote p{color:var(--paper)}
.section.ink .quote cite{color:var(--paper)}
.section.ink .quote cite span{color:#bcae98}

/* Centred heading gets a gold→pink→mint accent stroke */
.sec-head.center h2::after{content:"";display:block;width:54px;height:3px;border-radius:2px;
  margin:18px auto 0;background:linear-gradient(90deg,var(--pink),var(--gold),var(--mint))}

/* Rotate the how-it-works steps through the palette */
.step:nth-child(1){border-top:3px solid var(--pink)}
.step:nth-child(2){border-top:3px solid var(--mint)}
.step:nth-child(3){border-top:3px solid var(--gold)}
.step:nth-child(1) .step-no{color:var(--pink)}
.step:nth-child(2) .step-no{color:var(--mint)}
.step:nth-child(3) .step-no{color:var(--gold)}
.step:nth-child(1) .step-ico{color:var(--pink)}
.step:nth-child(2) .step-ico{color:var(--mint)}
.step:nth-child(3) .step-ico{color:var(--gold)}

/* Punchier hero glows + a gold wash */
.hero::before{background:radial-gradient(circle,#f6bcd2,transparent 66%);opacity:.85}
.hero::after{background:radial-gradient(circle,#aee3d0,transparent 66%);opacity:.9}
.hero-copy h1 .script{text-shadow:0 2px 0 #fff}
.hero-meta b{color:var(--gold)}

/* Hero metric row — tint each stat a different colour */
.hero-meta div:nth-child(1) b{color:var(--pink)}
.hero-meta div:nth-child(2) b{color:var(--mint)}
.hero-meta div:nth-child(3) b{color:var(--gold)}

/* Section eyebrow rotation across the page reads richer */
.section.tint-mint .eyebrow{color:var(--mint)}
.section.tint-pink .eyebrow{color:var(--pink)}

/* Footer accent line at the very top of the black footer */
.site-footer{border-top:4px solid transparent;border-image:linear-gradient(90deg,var(--pink),var(--gold),var(--mint)) 1}

/* ── Reviews page ───────────────────────────────────────────────────── */
.rev-hero{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.rev-note{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);background:var(--paper-3)}
.rev-note::after{content:"";position:absolute;inset:12px;border:2px dashed color-mix(in srgb,var(--gold) 45%,transparent);border-radius:16px;pointer-events:none}
.rev-note img{width:100%;display:block}
.rev-hero h1{font-size:clamp(2.2rem,5vw,3.6rem)}
.rev-hero h1 .script{color:var(--pink);display:block;transform:rotate(-2deg)}
.rev-hero p{color:var(--ink-2);margin-top:16px;font-size:1.08rem;max-width:46ch}
.rev-stat{display:flex;gap:28px;margin-top:26px;flex-wrap:wrap}
.rev-stat b{display:block;font-family:var(--display);font-size:1.9rem;color:var(--gold);line-height:1}
.rev-stat span{font-size:13px;color:var(--ink-2)}
@media (max-width:820px){.rev-hero{grid-template-columns:1fr}.rev-note{max-width:460px;margin:0 auto}}

/* Personalise box — additional info textarea */
.pb-note{margin-top:12px}
.pb-note label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#a23b66;margin-bottom:6px}
.pb-note textarea{width:100%;border:1.5px solid #e2a9c1;border-radius:10px;padding:12px 13px;font-family:var(--body);font-size:15px;background:#fff;color:var(--ink);resize:vertical;min-height:74px}
.pb-note textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px rgba(228,84,138,.18)}

/* Per-tin option selector */
.option-group{margin:6px 0 22px}
.tin-option{width:100%;border:1.5px solid var(--gold);border-radius:10px;padding:12px 13px;font-family:var(--body);font-size:15px;background:#fff;color:var(--ink);cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b8902f' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:40px}
.tin-option:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(184,144,47,.18)}

/* ── Account / auth ──────────────────────────────────────────────────── */
.auth{max-width:480px;margin:0 auto;text-align:center}
.auth .eyebrow{justify-content:center}
.auth h1{font-size:clamp(2rem,4.5vw,2.8rem);margin:12px 0 8px}
.auth .sub{color:var(--ink-2);margin-bottom:26px}
.auth-card{background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(26px,4vw,40px);box-shadow:var(--shadow-sm);text-align:left}
.auth-card .field{margin-bottom:15px}
.auth-card .btn{margin-top:8px}
.auth-foot{text-align:center;margin-top:20px;color:var(--ink-2);font-size:14px}
.auth-foot a{color:var(--pink);font-weight:600}
.auth-err{background:var(--pink-soft);border:1px solid var(--pink);color:#a3265a;border-radius:12px;padding:12px 16px;font-size:14px;margin-bottom:18px;font-weight:500}

.acct-grid{display:grid;grid-template-columns:330px 1fr;gap:32px;align-items:start}
@media(max-width:860px){.acct-grid{grid-template-columns:1fr}}
.acct-hello{font-size:clamp(1.8rem,4vw,2.6rem)}
.acct-card{background:var(--paper-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;margin-bottom:20px}
.acct-card h3{font-family:var(--body);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.acct-card .field{margin-bottom:13px}
.acct-card label{font-size:12px}
.saved-card{display:flex;align-items:center;gap:14px;background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.saved-card .sc-brand{font-weight:600;text-transform:capitalize}
.saved-card .sc-num{font-family:ui-monospace,monospace;color:var(--ink-2);font-size:14px}
.acct-note{font-size:13px;color:var(--ink-2);line-height:1.6}
.order-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.order-row:last-child{border-bottom:none}
.order-row .o-no{font-family:var(--display);font-weight:600}
.order-row .o-meta{font-size:13px;color:var(--ink-2)}
.pill{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 11px;border-radius:999px}
.pill-paid{background:var(--mint-soft);color:#0c7a5e}
.pill-pending{background:#f6e6c4;color:#8a6410}
.pill-other{background:var(--paper-2);color:var(--ink-2)}

/* ── Featured carousel (under hero) ──────────────────────────────────── */
.fcar{position:relative;margin-top:8px}
.fcar-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  scrollbar-width:none;-ms-overflow-style:none;padding:6px 2px 12px}
.fcar-track::-webkit-scrollbar{display:none}
.fcar-slide{flex:0 0 calc((100% - 40px)/3);scroll-snap-align:start;min-width:0}
.fcar-slide .product-card{height:100%}
.fcar-arrow{position:absolute;top:42%;transform:translateY(-50%);width:46px;height:46px;border-radius:999px;
  border:1px solid var(--line);background:var(--paper-3);color:var(--ink);font-size:22px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);z-index:3;
  transition:transform .2s,background .2s,color .2s,opacity .2s;opacity:0}
.fcar:hover .fcar-arrow{opacity:1}
.fcar-arrow:hover{background:var(--pink);color:#fff;border-color:var(--pink)}
.fcar-prev{left:-10px}.fcar-next{right:-10px}
@media(max-width:900px){.fcar-slide{flex-basis:calc((100% - 20px)/2)}.fcar-arrow{opacity:1}}
@media(max-width:560px){.fcar-slide{flex-basis:84%}.fcar-arrow{display:none}.fcar{margin-inline:calc(var(--pad)*-1 + 4px);padding-inline:calc(var(--pad) - 4px)}}

/* Homepage personaliser — additional info */
.pz-note{margin-top:12px}
.pz-note label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);display:block;margin-bottom:6px}
.pz-note textarea{width:100%;background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;font-family:var(--body);font-size:14px;color:var(--ink);resize:vertical;min-height:58px}
.pz-note textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px var(--pink-soft)}

/* Product page — live personalisation preview */
.pp-biscuit{width:190px;height:190px;margin:2px auto 18px}
.pp-biscuit .ice-name{font-size:38px}
.pp-biscuit .ice-age{font-size:24px}

/* ── Mobile hero: stack cleanly, drop the floating chips ─────────────── */
@media (max-width:760px){
  .hero{padding-top:clamp(18px,5vw,40px)}
  .hero-grid{grid-template-columns:1fr;gap:18px}
  .hero-copy{text-align:center}
  .hero-copy h1{font-size:clamp(2.4rem,12vw,3.2rem)}
  .hero-copy p{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  .hero-meta{justify-content:center}
  .hero-art{order:-1;max-width:260px;margin:0 auto}
  .hero-chip{display:none}
}
