/* =========================================================================
   CAVIAR D'EDEN — v4  ·  "Maison du Caviar" — Kaviari-grade ivory ecommerce
   Below the approved video hero: restrained, product-forward, hairlines not
   shadows, one solid button on the whole site, petrol as punctuation.
   Ivory canvas · ink type · deep petrol accent · Newsreader + Inter.
   ========================================================================= */

:root{
  /* Surfaces — ivory / beige scale */
  --paper:#F4F0E8; --paper-2:#EDE7DB; --paper-3:#E5DDCD; --card:#FBF9F4;
  /* Ink */
  --ink:#1B1813; --ink-2:#3A352C; --ink-mute:#857C6B;
  /* Accent — restrained petrol */
  --petrol:#143A33; --petrol-deep:#0F2C27; --petrol-tint:#E7EBE7;
  /* Lines */
  --line:#DAD2C4; --line-2:#C8BFAE; --line-soft:#E7E0D2;
  /* Functional */
  --gold-quiet:#9A7B3F; --ok:#2F6B4F;
  /* Night (hero/footer dark) */
  --night:#14130E; --line-night:rgba(244,240,232,.18);
  /* Type */
  --serif:"Newsreader",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  /* Rhythm */
  --maxw:1200px; --gx:clamp(1.25rem,5vw,3rem); --sy:clamp(3.25rem,8vw,6rem);
  --silk:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%;}
body{background:var(--paper); color:var(--ink-2); font-family:var(--sans);
  font-weight:400; font-size:15px; line-height:1.65; letter-spacing:.003em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
::selection{background:var(--petrol); color:var(--paper);}

/* ---------- type primitives ---------- */
.eyebrow{font-size:.6875rem; text-transform:uppercase; letter-spacing:.18em; font-weight:600;
  color:var(--ink-mute); display:inline-block;}
.eyebrow--petrol{color:var(--petrol);}
.eyebrow--paper{color:rgba(244,240,232,.7);}
.h2{font-family:var(--serif); font-weight:400; line-height:1.12; letter-spacing:-.008em;
  font-size:clamp(1.65rem,3.2vw,2.25rem); color:var(--ink);}
.h3{font-family:var(--serif); font-weight:400; font-size:1.375rem; color:var(--ink); line-height:1.2;}
.lede{font-size:1rem; line-height:1.6; color:var(--ink-mute); max-width:54ch;}
.rule{width:42px; height:1px; background:var(--petrol); border:0; display:block;}

/* ---------- buttons & links (ONE solid button site-wide) ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:.55rem; font-family:var(--sans);
  font-size:.8125rem; font-weight:600; letter-spacing:.02em; padding:.95em 1.9em; border-radius:2px;
  border:1px solid var(--line); color:var(--ink); background:transparent; cursor:pointer;
  transition:background .35s var(--silk),color .35s var(--silk),border-color .35s;}
.btn:hover{background:var(--paper-2); border-color:var(--line-2); color:var(--ink);}
.btn--solid{background:var(--petrol-deep); border-color:var(--petrol-deep); color:var(--paper); letter-spacing:.04em;}
.btn--solid:hover{background:var(--petrol); border-color:var(--petrol); color:var(--paper);}
/* over-dark hero buttons (carried, refined) */
.btn--paper{border-color:rgba(244,240,232,.55); color:var(--paper); border-radius:2px;}
.btn--paper:hover{background:var(--paper); color:var(--ink); border-color:var(--paper);}
.btn--ghostpaper{border-color:transparent; color:var(--paper); padding-inline:.2em; letter-spacing:.02em;}
.btn--ghostpaper:hover{background:transparent; color:#fff;}
/* text-link CTA — the default everywhere except the one solid button */
.tlink{display:inline-flex; align-items:center; gap:.4rem; font-size:.875rem; font-weight:600; letter-spacing:.01em;
  color:var(--petrol); font-family:var(--sans);}
.tlink::after{content:"\2192"; transition:transform .3s var(--silk);}
.tlink:hover{color:var(--ink);}
.tlink:hover::after{transform:translateX(4px);}
.tlink--center{justify-content:center;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gx);}
.sec{padding-block:var(--sy);}
.sec--paper{background:var(--paper);}
.sec--paper2{background:var(--paper-2);}
.sec__head{text-align:center; max-width:60ch; margin:0 auto clamp(2rem,4vw,3rem);}
.sec__head .eyebrow{margin-bottom:.9rem;}
.sec__head .lede{margin:.9rem auto 0;}
.sec__cta{text-align:center; margin-top:clamp(2rem,4vw,3rem);}

/* =========================================================================
   HEADER — slim, transparent over hero → solid on scroll (homepage .hdr)
   ========================================================================= */
.hdr{position:fixed; inset:0 0 auto 0; z-index:50;
  padding-block:1.05rem; padding-inline:max(var(--gx), calc((100% - 1200px) / 2));
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
  transition:background .5s var(--silk),box-shadow .5s,padding .4s;}
.hdr.is-solid{background:rgba(244,240,232,.94); backdrop-filter:blur(14px); box-shadow:0 1px 0 var(--line-soft); padding-block:.8rem;}
.hdr__nav{display:flex; gap:2rem;}
.hdr__nav a{font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; font-weight:500; color:var(--paper); transition:color .3s;}
.hdr.is-solid .hdr__nav a,.hdr.is-solid .hdr__logo,.hdr.is-solid .hdr__right a{color:var(--ink);}
.hdr__nav a:hover{color:#fff;}
.hdr.is-solid .hdr__nav a:hover{color:var(--petrol);}
.hdr__logo{justify-self:center; font-family:var(--serif); font-size:1.4rem; letter-spacing:.01em; color:var(--paper); line-height:1; text-align:center;}
.hdr__logo small{display:block; font-family:var(--sans); font-size:.5rem; text-transform:uppercase; letter-spacing:.4em; margin-top:.3rem; opacity:.72;}
.hdr__right{justify-self:end; display:flex; gap:1.3rem; align-items:center;}
.hdr__right a{font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; font-weight:500; color:var(--paper);}
.hdr__buy{border:1px solid rgba(244,240,232,.55); padding:.6em 1.25em; border-radius:2px; transition:background .3s,color .3s,border-color .3s;}
.hdr__buy:hover{background:var(--paper); color:var(--ink)!important; border-color:var(--paper);}
.hdr.is-solid .hdr__buy{border-color:var(--petrol); color:var(--petrol)!important;}
.hdr.is-solid .hdr__buy:hover{background:var(--petrol); color:var(--paper)!important;}
.hdr__burger{display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px;}
.hdr__burger span{width:23px; height:1.5px; background:var(--paper); transition:background .3s;}
.hdr.is-solid .hdr__burger span{background:var(--ink);}

/* =========================================================================
   HERO — APPROVED video banner (carried from v3, unchanged in spirit)
   ========================================================================= */
.hero{position:relative; min-height:100svh; display:flex; align-items:flex-end; color:var(--paper); overflow:hidden;}
.hero--video{background:var(--night);}
.hero__video{position:absolute; inset:0; z-index:0; width:100%; height:100%; object-fit:cover; object-position:50% 38%;}
.hero__overlay{position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg,rgba(10,9,7,.5) 0%,rgba(10,9,7,.14) 30%,rgba(10,9,7,.5) 70%,rgba(10,9,7,.88) 100%);}
.hero__inner{position:relative; z-index:2; max-width:var(--maxw); margin-inline:auto; width:100%; padding:0 var(--gx) clamp(3.5rem,8vh,7rem);}
.hero__eyebrow{color:rgba(244,240,232,.82); margin-bottom:1.5rem; font-size:.6875rem; text-transform:uppercase; letter-spacing:.2em; font-weight:600; display:inline-block;}
.hero__title{font-family:var(--serif); font-weight:400; color:var(--paper);
  font-size:clamp(2.6rem,6vw,4.6rem); line-height:1.04; letter-spacing:-.015em; max-width:15ch; margin-bottom:1.3rem;}
.hero__title em{font-style:italic;}
.hero__sub{color:rgba(244,240,232,.88); font-size:clamp(1rem,1.4vw,1.15rem); max-width:46ch; margin-bottom:2rem; line-height:1.55;}
.hero__cta{display:flex; gap:1.2rem; align-items:center; flex-wrap:wrap; margin-bottom:2.2rem;}
.hero__cta--center{justify-content:center;}
.hero__trust{display:flex; gap:2rem; flex-wrap:wrap; padding-top:1.5rem; border-top:1px solid var(--line-night);}
.hero__trust span{font-size:.74rem; letter-spacing:.04em; color:rgba(244,240,232,.72);}
.hero__trust b{color:var(--paper); font-weight:600; display:block; font-size:.78rem; margin-bottom:.15rem; text-transform:uppercase; letter-spacing:.08em;}
.hero__scroll{position:absolute; left:50%; bottom:1.7rem; transform:translateX(-50%); z-index:3;
  width:25px; height:40px; border:1px solid rgba(244,240,232,.45); border-radius:999px; display:flex; justify-content:center; padding-top:8px;}
.hero__scroll span{width:2px; height:7px; background:rgba(244,240,232,.85); border-radius:2px; animation:scrolldot 1.9s var(--silk) infinite;}
@keyframes scrolldot{0%{opacity:0; transform:translateY(-3px);}40%{opacity:1;}80%{opacity:0; transform:translateY(8px);}100%{opacity:0;}}

/* =========================================================================
   (a) SERVICE STRIP — slim reassurance row
   ========================================================================= */
.svc{background:var(--paper-2); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft);}
.svc__row{max-width:var(--maxw); margin-inline:auto; padding:1.05rem var(--gx);
  display:flex; justify-content:center; align-items:center; flex-wrap:wrap; gap:.6rem 1.9rem;}
.svc__i{display:inline-flex; align-items:center; gap:.5rem; font-size:.8125rem; letter-spacing:.02em; color:var(--ink-2); white-space:nowrap;}
.svc__i svg{width:15px; height:15px; color:var(--petrol); flex:none;}
.svc__i+.svc__i{position:relative;}
.svc__i+.svc__i::before{content:""; position:absolute; left:-.95rem; top:50%; width:1px; height:14px; background:var(--line-2); transform:translateY(-50%);}

/* =========================================================================
   PRODUCT CARD — the category-match unit (clean grid, no chrome)
   ========================================================================= */
.pgrid{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2vw,1.5rem);}
.pcard{display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:2px;
  padding:clamp(1.2rem,2vw,1.6rem); transition:background .3s var(--silk),border-color .3s;}
.pcard:hover{background:var(--card); border-color:var(--line-2);}
.pcard__eyebrow{font-size:.625rem; text-transform:uppercase; letter-spacing:.16em; color:var(--ink-mute); margin-bottom:.7rem; min-height:.9rem;}
.pcard__img{display:flex; align-items:center; justify-content:center; min-height:208px; margin-bottom:1rem;}
.pcard__img img{max-height:200px; width:auto; object-fit:contain; transition:transform .7s var(--silk);}
.pcard:hover .pcard__img img{transform:scale(1.035);}
.pcard__name{font-family:var(--serif); font-size:1.0625rem; color:var(--ink); line-height:1.25;}
.pcard__note{font-size:.8125rem; color:var(--ink-mute); margin-top:.25rem;}
.pcard__price{font-size:1rem; font-weight:500; color:var(--ink); margin-top:.65rem;}
.pcard__price small{color:var(--ink-mute); font-weight:400; font-size:.8125rem;}
.pcard__act{display:flex; align-items:center; justify-content:space-between; margin-top:1rem; padding-top:1rem; border-top:1px solid var(--line);}
.pcard__choose{font-size:.8125rem; font-weight:600; letter-spacing:.02em; color:var(--petrol); display:inline-flex; align-items:center; gap:.4rem;}
.pcard__choose::after{content:"\2192"; transition:transform .3s var(--silk);}
.pcard:hover .pcard__choose{text-decoration:underline; text-underline-offset:3px;}
.pcard:hover .pcard__choose::after{transform:translateX(3px);}

/* =========================================================================
   (c) TASTE GUIDE — signature interactive taste selector
   ========================================================================= */
.tguide{max-width:940px; margin:0 auto;}
.tguide__axis{display:flex; align-items:center; gap:1rem; margin:.5rem 0 clamp(2rem,4vw,3rem);}
.tguide__end{font-size:.7rem; text-transform:uppercase; letter-spacing:.14em; color:var(--ink-mute); flex:none;}
.tguide__track{position:relative; flex:1; height:2px; background:var(--line); border-radius:2px;}
.tguide__fill{position:absolute; left:0; top:0; height:100%; width:50%; background:var(--petrol); border-radius:2px; transition:width .55s var(--silk);}
.tguide__dot{position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:13px; height:13px; border-radius:50%;
  background:var(--paper-2); border:1.5px solid var(--line-2); cursor:pointer; padding:0;
  transition:transform .3s var(--silk),background .3s,border-color .3s,box-shadow .3s;}
.tguide__dot:hover{border-color:var(--petrol);}
.tguide__dot.is-on{background:var(--petrol); border-color:var(--petrol); transform:translate(-50%,-50%) scale(1.25); box-shadow:0 0 0 5px var(--petrol-tint);}
.tguide__dot:focus-visible{outline:2px solid var(--petrol); outline-offset:3px;}
.tguide__stage{display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center; min-height:290px;}
.tguide__viz{position:relative; aspect-ratio:1/1; width:100%; max-width:330px; margin:0 auto;}
.tguide__roe{position:absolute; inset:0; width:100%; height:100%; object-fit:contain; opacity:0; transform:scale(.9) rotate(-4deg);
  transition:opacity .5s var(--silk),transform .7s var(--silk); filter:drop-shadow(0 16px 26px rgba(27,24,19,.16));}
.tguide__roe.is-on{opacity:1; transform:scale(1) rotate(0);}
.tguide__info{display:grid;}
.tguide__panel{grid-area:1/1; opacity:0; transform:translateY(10px); pointer-events:none; transition:opacity .45s var(--silk),transform .45s var(--silk);}
.tguide__panel.is-on{opacity:1; transform:none; pointer-events:auto;}
.tguide__sub{display:block; font-size:.66rem; text-transform:uppercase; letter-spacing:.16em; color:var(--ink-mute); margin-bottom:.5rem;}
.tguide__name{font-family:var(--serif); font-weight:400; font-size:clamp(1.8rem,3vw,2.4rem); color:var(--ink); line-height:1.05; margin-bottom:.7rem;}
.tguide__tags{display:flex; flex-wrap:wrap; gap:.45rem; margin-bottom:.9rem;}
.tguide__tags span{font-size:.64rem; text-transform:uppercase; letter-spacing:.1em; color:var(--petrol); border:1px solid var(--line); border-radius:999px; padding:.34em .85em;}
.tguide__desc{font-size:.98rem; line-height:1.6; color:var(--ink-2); max-width:42ch; margin-bottom:1.4rem;}
.tguide__cta{display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap;}
.tguide__price{font-size:1rem; font-weight:500; color:var(--ink);}
.tguide__price .from,.tguide__price small{color:var(--ink-mute); font-weight:400; font-size:.82rem;}
.tguide__tabs{display:grid; grid-template-columns:repeat(3,1fr); gap:.8rem; margin-top:clamp(2rem,4vw,3rem);}
.tguide__tab{display:flex; flex-direction:column; gap:.2rem; align-items:flex-start; text-align:left; cursor:pointer;
  background:#fff; border:1px solid var(--line); border-radius:3px; padding:.9rem 1.1rem;
  transition:border-color .3s var(--silk),background .3s,transform .3s var(--silk),box-shadow .35s var(--silk);}
.tguide__tab:hover{border-color:var(--line-2); transform:translateY(-2px);}
.tguide__tab.is-on{border-color:var(--petrol); background:var(--card); box-shadow:0 14px 30px -20px rgba(27,24,19,.3);}
.tguide__tab b{font-family:var(--serif); font-weight:400; font-size:1.1rem; color:var(--ink);}
.tguide__tab span{font-size:.66rem; text-transform:uppercase; letter-spacing:.12em; color:var(--ink-mute);}
.tguide__tab.is-on span{color:var(--petrol);}
.tguide__tab:focus-visible{outline:2px solid var(--petrol); outline-offset:2px;}
@media (max-width:880px){
  .tguide__stage{grid-template-columns:1fr; gap:1.4rem; text-align:center; min-height:0;}
  .tguide__viz{max-width:210px;}
  .tguide__info{justify-items:center;}
  .tguide__desc{margin-left:auto; margin-right:auto;}
  .tguide__cta,.tguide__tags{justify-content:center;}
  .tguide__tab{padding:.7rem .55rem; align-items:center; text-align:center;}
}
@media (prefers-reduced-motion:reduce){
  .tguide__fill,.tguide__roe,.tguide__panel,.tguide__dot,.tguide__tab{transition:none !important;}
}

/* =========================================================================
   (d) GIFTS — real sellable modules anchored by lifestyle image
   ========================================================================= */
.gifts__in{display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center;}
.gifts__media{position:relative; aspect-ratio:4/5; overflow:hidden; border-radius:2px; border:1px solid var(--line);}
.gifts__media img{width:100%; height:100%; object-fit:cover;}
.gifts__body .eyebrow{margin-bottom:.9rem;}
.gifts__body .h2{margin-bottom:.7rem;}
.gifts__body .lede{margin-bottom:1.6rem;}
.giftmods{display:flex; flex-direction:column; gap:.9rem; margin-bottom:1.6rem;}
.giftmod{display:grid; grid-template-columns:auto 1fr auto; gap:1.1rem; align-items:center;
  background:var(--card); border:1px solid var(--line); border-radius:2px; padding:1rem 1.2rem; transition:border-color .3s,background .3s;}
.giftmod:hover{border-color:var(--line-2); background:var(--paper);}
.giftmod__img{width:64px; height:64px; display:flex; align-items:center; justify-content:center; background:#fff; border:1px solid var(--line-soft); border-radius:2px; overflow:hidden;}
.giftmod__img img{max-height:54px; width:auto;}
.giftmod__name{display:block; font-family:var(--serif); font-size:1.15rem; color:var(--ink); line-height:1.15;}
.giftmod__desc{display:block; font-size:.8125rem; color:var(--ink-mute); margin-top:.2rem;}
.giftmod__price{font-size:.95rem; font-weight:500; color:var(--ink); white-space:nowrap; display:flex; flex-direction:column; align-items:flex-end; gap:.3rem;}
.giftmod__price .tlink{font-size:.78rem;}
.chips{display:flex; flex-wrap:wrap; gap:.45rem; margin-bottom:1.6rem;}
.chips span{font-size:.6875rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-mute); border:1px solid var(--line); border-radius:999px; padding:.42em 1em; transition:border-color .3s,color .3s;}
.chips span:hover{border-color:var(--petrol); color:var(--petrol);}

/* =========================================================================
   (e) MAISON — credibility, 3 clean columns
   ========================================================================= */
.maison__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2vw,1.5rem);}
.mcard{background:var(--card); border:1px solid var(--line); border-radius:2px; padding:clamp(1.6rem,2.5vw,2.2rem); transition:border-color .3s;}
.mcard:hover{border-color:var(--line-2);}
.mcard__ic{width:38px; height:38px; color:var(--petrol); margin-bottom:1.2rem; display:block;}
.mcard__ic svg{width:100%; height:100%; display:block; stroke-width:1.2;}
.mcard h3{font-family:var(--serif); font-weight:400; font-size:1.2rem; color:var(--ink); margin-bottom:.6rem;}
.mcard p{font-size:.9rem; color:var(--ink-2); line-height:1.6;}

/* =========================================================================
   (f) RITUAL — editorial serving ritual: image + guidance tiles + product feature
   ========================================================================= */
.ritual__in{display:grid; grid-template-columns:5fr 7fr; grid-template-rows:auto 1fr;
  grid-template-areas:"media head" "media aside"; align-items:start;
  column-gap:clamp(1.6rem,4vw,3.5rem); row-gap:clamp(1.4rem,3vw,2.2rem);}
.ritual__fig{grid-area:media; align-self:stretch; position:relative; margin:0; overflow:hidden;
  border:1px solid var(--line); border-radius:2px; min-height:440px;}
.ritual__fig img{width:100%; height:100%; object-fit:cover; object-position:50% 20%; display:block;}
.ritual__head{grid-area:head;}
.ritual__head .eyebrow{margin-bottom:.9rem;}
.ritual__head .h2{margin-bottom:.7rem;}
.ritual__intro{font-size:1rem; line-height:1.6; color:var(--ink-mute); max-width:46ch; margin:0;}
.ritual__aside{grid-area:aside; display:flex; flex-direction:column; gap:clamp(1rem,2vw,1.3rem); align-self:stretch;}
.ritual__tiles{display:grid; grid-template-columns:1fr 1fr; gap:clamp(.8rem,1.6vw,1.1rem);}
.rtile{background:var(--card); border:1px solid var(--line); border-radius:2px; padding:1.2rem 1.3rem;
  transition:background .3s var(--silk),border-color .3s;}
.rtile:hover{background:#fff; border-color:var(--line-2);}
.rtile__n{font-family:var(--serif); font-size:.9rem; color:var(--petrol); letter-spacing:.06em; font-variant-numeric:tabular-nums;}
.rtile__label{display:block; font-family:var(--serif); font-size:1.2rem; color:var(--ink); margin:.4rem 0 .5rem; line-height:1.15;}
.rtile__p{font-size:.84rem; line-height:1.5; color:var(--ink-2); margin:0;}
/* Kaspian mini-feature (conversion) */
.ritual__feature{display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:1.1rem; margin-top:auto;
  background:var(--card); border:1px solid var(--line); border-radius:2px; padding:.85rem 1.05rem;
  transition:background .3s var(--silk),border-color .3s;}
.ritual__feature:hover{background:#fff; border-color:var(--line-2);}
.ritual__feature-img{width:72px; height:72px; overflow:hidden; border:1px solid var(--line-soft); border-radius:2px;}
.ritual__feature-img img{width:100%; height:100%; object-fit:cover;}
.ritual__feature-txt b{display:block; font-family:var(--serif); font-weight:400; font-size:1.1rem; color:var(--ink); line-height:1.15;}
.ritual__feature-txt span{font-size:.82rem; color:var(--ink-mute);}
.ritual__feature .tlink{white-space:nowrap;}

/* =========================================================================
   (g) DELIVERY / COLD-CHAIN — light service module (NOT a dark split)
   ========================================================================= */
.delivery__steps{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2vw,1.5rem);}
.dstep{background:var(--card); border:1px solid var(--line); border-radius:2px; padding:clamp(1.6rem,2.5vw,2.1rem); transition:border-color .3s;}
.dstep:hover{border-color:var(--line-2);}
.dstep__n{font-family:var(--serif); font-size:.95rem; color:var(--petrol); letter-spacing:.06em; display:block; margin-bottom:1rem;}
.dstep h3{font-family:var(--serif); font-weight:400; font-size:1.2rem; color:var(--ink); margin-bottom:.45rem;}
.dstep p{font-size:.9rem; color:var(--ink-2); line-height:1.55;}
.delivery__note{text-align:center; margin-top:1.8rem; font-size:.8125rem; color:var(--ink-mute);}
.delivery__note b{color:var(--ok); font-weight:600;}

/* =========================================================================
   (h) PROOF — minimal trust band (no fabricated reviews)
   ========================================================================= */
.proof__row{display:flex; justify-content:center; align-items:center; flex-wrap:wrap; gap:.8rem 2.4rem;}
.proof__i{display:inline-flex; align-items:center; gap:.55rem; font-size:.9rem; color:var(--ink-2); letter-spacing:.01em;}
.proof__i svg{width:17px; height:17px; color:var(--petrol);}

/* =========================================================================
   (i) FOOTER — refined ecommerce, the only dark zone
   ========================================================================= */
.foot{background:var(--petrol-deep); color:rgba(244,240,232,.78); padding:clamp(3rem,6vw,5rem) var(--gx) 2.2rem; border-top:1px solid var(--paper-3);}
.foot__top{max-width:var(--maxw); margin-inline:auto; display:grid; grid-template-columns:1.5fr repeat(4,1fr) 1.7fr; gap:2rem;}
.foot__brand .foot__logo{font-family:var(--serif); font-size:1.4rem; color:var(--paper); margin-bottom:.8rem;}
.foot__brand p{font-size:.85rem; color:rgba(244,240,232,.6); max-width:26ch; line-height:1.55;}
.foot__col h5{font-size:.6875rem; text-transform:uppercase; letter-spacing:.16em; color:rgba(244,240,232,.55); margin-bottom:1rem;}
.foot__col a{display:block; color:rgba(244,240,232,.78); font-size:.875rem; padding:.28rem 0; transition:color .3s;}
.foot__col a:hover{color:var(--paper);}
.foot__news h5{font-family:var(--serif); font-size:1.15rem; color:var(--paper); text-transform:none; letter-spacing:0; margin-bottom:.8rem;}
.foot__news p{font-size:.82rem; color:rgba(244,240,232,.6); margin-bottom:.9rem;}
.foot__form{display:flex; gap:.5rem;}
.foot__form input{flex:1; min-width:0; background:rgba(244,240,232,.06); border:1px solid var(--line-night); color:var(--paper); padding:.7em .9em; font-family:var(--sans); font-size:.85rem; border-radius:2px;}
.foot__form input::placeholder{color:rgba(244,240,232,.45);}
.foot__form input:focus{outline:none; border-color:rgba(244,240,232,.5);}
.foot__form button{background:transparent; border:1px solid rgba(244,240,232,.5); color:var(--paper); padding:.7em 1.1em; font-size:.78rem; font-weight:600; letter-spacing:.04em; cursor:pointer; border-radius:2px; transition:background .3s,color .3s;}
.foot__form button:hover{background:var(--paper); color:var(--petrol-deep); border-color:var(--paper);}
.foot__consent{font-size:.7rem; color:rgba(244,240,232,.45); margin-top:.7rem;}
.foot__bottom{max-width:var(--maxw); margin:2.6rem auto 0; padding-top:1.4rem; border-top:1px solid var(--line-night);
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.75rem; color:rgba(244,240,232,.5);}
.foot__bottom a:hover{color:var(--paper);}
.foot__social{display:flex; gap:1rem;}
.foot__social a{display:inline-flex;}
.foot__social svg{width:17px; height:17px;}

/* =========================================================================
   MOTION — reveals (honored via .js)
   ========================================================================= */
.js [data-reveal]{opacity:0; transform:translateY(18px); transition:opacity .9s var(--silk),transform .9s var(--silk); transition-delay:var(--d,0ms);}
.js [data-reveal].in{opacity:1; transform:none;}
.js [data-reveal=clip]{clip-path:inset(0 0 100% 0); transform:none; transition:clip-path 1s var(--silk),opacity .9s;}
.js [data-reveal=clip].in{clip-path:inset(0 0 0 0);}
@media (prefers-reduced-motion:reduce){
  .js [data-reveal]{opacity:1!important; transform:none!important; clip-path:none!important;}
  .hero__scroll span{animation:none;}
}

/* =========================================================================
   MOBILE
   ========================================================================= */
@media (max-width:1023px){
  .pgrid{grid-template-columns:1fr 1fr;}
  .maison__grid,.delivery__steps{grid-template-columns:1fr;}
  .taste__grid{grid-template-columns:1fr;}
  .foot__top{grid-template-columns:1fr 1fr 1fr;}
  .foot__brand{grid-column:1/-1;}
  .foot__news{grid-column:1/-1;}
}
@media (max-width:880px){
  .hdr{grid-template-columns:auto 1fr auto; padding:1rem var(--gx);}
  .hdr__nav,.hdr__right a:not(.hdr__cart){display:none;}
  .hdr__logo{justify-self:start; text-align:left; font-size:1.15rem;}
  .hdr__burger{display:flex;}
  /* mobile menu = clean vertical dropdown drawer (matches inner-page menu) */
  .hdr.is-nav-open{background:rgba(244,240,232,.98); backdrop-filter:blur(14px); box-shadow:0 1px 0 var(--line-soft);}
  .hdr.is-nav-open .hdr__logo,.hdr.is-nav-open .hdr__right a{color:var(--ink);}
  .hdr.is-nav-open .hdr__burger span{background:var(--ink);}
  .hdr.is-nav-open .hdr__nav{display:flex; flex-direction:column; gap:0;
    position:absolute; left:0; right:0; top:100%; background:var(--paper);
    border-top:1px solid var(--line-soft); box-shadow:0 16px 28px rgba(20,30,25,.1); padding:.3rem 0;}
  .hdr.is-nav-open .hdr__nav a{color:var(--ink); padding:1rem var(--gx); font-size:.8rem;
    border-bottom:1px solid var(--line-soft);}
  .hdr.is-nav-open .hdr__nav a:last-child{border-bottom:0;}
  .hdr.is-nav-open .hdr__buy{display:inline-flex; margin-left:.8rem;}
  .hero__video{object-position:56% 36%;}
  .hero__scroll{display:none;}
  .gifts__in{grid-template-columns:1fr; gap:1.6rem;}
  .gifts__media{aspect-ratio:16/10; max-height:340px;}
  .ritual__in{grid-template-columns:1fr; grid-template-rows:none; grid-template-areas:"head" "media" "aside";}
  .ritual__fig{min-height:0; aspect-ratio:4/3;}
  .ritual__fig img{object-position:50% 26%;}
  .foot__top{grid-template-columns:1fr 1fr;}
}
@media (max-width:560px){
  .pgrid{grid-template-columns:1fr;}
  .pcard__img{min-height:200px;}
  .hero__cta{flex-direction:column; align-items:stretch;}
  .hero__cta .btn{width:100%;}
  .svc__i+.svc__i::before{display:none;}
  .ritual__tiles{grid-template-columns:1fr 1fr;}
  .ritual__feature{grid-template-columns:auto 1fr; column-gap:.9rem; row-gap:.5rem;}
  .ritual__feature-img{grid-row:1 / span 2;}
  .ritual__feature .tlink{grid-column:2; justify-self:start;}
  .foot__top{grid-template-columns:1fr;}
  .foot__bottom{flex-direction:column;}
}

/* sticky mobile add-to-cart (product page) */
.sticky-atc{position:fixed; left:0; right:0; bottom:0; z-index:60; display:none; align-items:center; gap:1rem;
  padding:.75rem var(--gx) calc(.75rem + env(safe-area-inset-bottom,0)); background:rgba(251,249,244,.97);
  backdrop-filter:blur(12px); border-top:1px solid var(--line); transform:translateY(110%); transition:transform .4s var(--silk);}
.sticky-atc.in{transform:none;}
.sticky-atc__info{flex:1; min-width:0;}
.sticky-atc__info b{font-family:var(--serif); font-size:1rem; color:var(--ink); display:block; line-height:1.2;}
.sticky-atc__info span{font-size:.82rem; color:var(--ink-mute);}
@media (max-width:880px){.sticky-atc{display:flex;}}
