/* =========================================================================
   Caviar d'Eden — HOMEPAGE PREMIUM REVAMP (isolated, reversible).
   9-zone editorial tempo: ivory / petrol-dark / full-bleed media / split.
   Loaded last; overrides v4/v5 for the front page only (.cde-v4-body scope).
   ========================================================================= */
.cde-v4-body{ --gutter:clamp(20px,6vw,88px); }

/* light-on-dark helpers */
.eyebrow--light{ color:rgba(244,240,232,.72) !important; }
.h2--light{ color:var(--paper) !important; }
.lede--light{ color:rgba(244,240,232,.82) !important; }
.tlink--light{ color:var(--paper); }
.tlink--light:hover{ color:rgba(244,240,232,.7); }

/* ---- HEADER: enlarge the wordmark so it reads as a maison ---- */
.hdr__logo{ font-family:var(--serif); font-size:clamp(1.35rem,2vw,1.7rem) !important; letter-spacing:.01em; line-height:1; }
.hdr__logo small{ letter-spacing:.28em; font-size:.5em; }

/* ---- 1 · HERO: copy lower-left, petrol side-scrim, trust whisper ---- */
.hero.hero--video{ min-height:min(92svh,860px); display:flex; align-items:flex-end; }
.hero__overlay,.hero__scrim{ position:absolute; inset:0;
  background:linear-gradient(90deg,rgba(15,44,39,.74) 0%,rgba(15,44,39,.34) 44%,rgba(15,44,39,0) 72%),
             linear-gradient(0deg,rgba(20,24,19,.62) 0%,rgba(20,24,19,0) 34%); }
.hero__inner{ position:relative; z-index:2; text-align:left !important; max-width:none !important;
  margin:0 !important; padding:0 var(--gutter) clamp(40px,7vh,92px); align-items:flex-start !important; }
.hero__eyebrow{ color:rgba(244,240,232,.78); }
.hero__title{ font-family:var(--serif); font-weight:400; color:var(--paper); line-height:1.02;
  font-size:clamp(2.6rem,6vw,4.6rem); letter-spacing:-.01em; margin:.5rem 0 1rem; max-width:16ch; }
.hero__title em{ font-style:italic; }
.hero__sub{ color:rgba(244,240,232,.85); max-width:44ch; font-size:clamp(1rem,1.3vw,1.1rem); line-height:1.6;
  display:block !important; -webkit-line-clamp:none !important; overflow:visible !important; text-overflow:clip !important; }
.hero__cta{ justify-content:flex-start !important; margin-top:1.5rem; }
.hero__whisper{ margin:1.1rem 0 0; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(244,240,232,.62); }
.hero__trust{ display:none; }

/* ---- 2 · PROVENANCE RIBBON (petrol-deep, instant contrast beat) ---- */
.rv-ribbon{ background:var(--petrol-deep); color:var(--paper); }
.rv-ribbon__row{ max-width:var(--maxw,1240px); margin-inline:auto; display:flex; align-items:center;
  justify-content:center; gap:clamp(14px,2.6vw,40px); padding:1.15rem var(--gutter);
  font-size:.72rem; letter-spacing:.11em; text-transform:uppercase; }
.rv-ribbon__row > span{ display:inline-flex; align-items:center; gap:.55rem; white-space:nowrap; position:relative; }
.rv-ribbon__row > span + span::before{ content:""; position:absolute; left:calc(-1 * clamp(7px,1.3vw,20px)); top:50%;
  transform:translateY(-50%); width:1px; height:1.1em; background:rgba(244,240,232,.2); }
.rv-ribbon__row svg{ width:20px; height:20px; opacity:.85; }

/* ---- 3 · COLLECTION (ivory: header row on top, centred carousel below) ---- */
.rv-collection{ background:var(--paper); padding-block:clamp(3rem,6vw,5.5rem); }
.rv-collection__in{ display:block; }
.rv-collection__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:2rem;
  margin-bottom:clamp(1.7rem,3vw,2.6rem); }
.rv-collection__head .h2{ margin:.4rem 0 .9rem; font-size:clamp(1.9rem,3.2vw,2.8rem); }
.rv-collection__head .lede{ margin:0; max-width:56ch; }
.rv-collection__aside{ display:flex; flex-direction:column; align-items:flex-end; gap:.9rem; flex:none; padding-bottom:.2rem; }
@media (max-width:700px){
  .rv-collection__head{ flex-direction:column; align-items:flex-start; gap:1.2rem; }
  .rv-collection__aside{ flex-direction:row; align-items:center; width:100%; justify-content:space-between; }
}
/* full-collection carousel: native scroll-snap track (no JS layout), arrows
   in the rail, staggered reveal + editorial vertical offset on even cards */
.rv-carousel{ position:relative; min-width:0; /* centred within the wrap — products sit in the page middle */
  -webkit-mask-image:linear-gradient(90deg,#000 0,#000 calc(100% - 72px),transparent);
          mask-image:linear-gradient(90deg,#000 0,#000 calc(100% - 72px),transparent); }
.rv-carousel__track{ display:flex; gap:clamp(14px,1.6vw,22px); overflow-x:auto; scroll-snap-type:x mandatory;
  padding:26px 72px 30px 4px; margin:-26px -4px -8px; scrollbar-width:none; -ms-overflow-style:none; }
.rv-carousel__track::-webkit-scrollbar{ display:none; }
.rv-carousel__track .pcard{ flex:0 0 clamp(236px,17.5vw,300px); scroll-snap-align:start; }
.rv-carousel__nav{ display:flex; gap:.55rem; }
/* hard override of Astra/theme base button styles (padding, dark focus fill) */
.rv-carousel__btn{ appearance:none; -webkit-appearance:none; box-sizing:border-box; width:44px; height:44px;
  padding:0 !important; margin:0; display:grid; place-items:center; line-height:1;
  background:transparent !important; border:1px solid var(--line-2) !important; border-radius:50% !important;
  color:var(--ink) !important; font-size:1rem; cursor:pointer; box-shadow:none !important;
  transition:border-color .3s, background .3s, color .3s; }
.rv-carousel__btn:hover,.rv-carousel__btn:active{ background:var(--petrol) !important;
  border-color:var(--petrol) !important; color:var(--paper) !important; }
.rv-carousel__btn:focus{ outline:none; background:transparent; }
.rv-carousel__btn:focus-visible{ outline:2px solid var(--petrol); outline-offset:2px; }

/* ---- 4 · CAVIARO SOMMELIER (deep petrol tasting chamber) ---- */
.rv-somm{ background:var(--petrol-deep); color:var(--paper); padding-block:clamp(3.5rem,7vw,6.5rem);
  position:relative; overflow:hidden; }
.rv-somm .wrap{ position:relative; z-index:1; }
.rv-somm__head{ text-align:center; max-width:640px; margin:0 auto clamp(2rem,4vw,3rem); }
.rv-somm__head .h2{ font-size:clamp(2rem,4vw,3.4rem); margin:.4rem 0 .7rem; }
.rv-somm .tguide{ max-width:1080px; margin-inline:auto; }
.rv-somm .tguide__stage{ display:grid; grid-template-columns:52fr 48fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.rv-somm .tguide__viz{ position:relative; aspect-ratio:1/1; display:grid; place-items:center; }
.rv-somm .tguide__viz::before{ content:""; position:absolute; inset:8%; border-radius:50%;
  background:radial-gradient(circle at 50% 45%, rgba(30,64,56,.9), rgba(9,22,20,0) 68%);
  border:1px solid rgba(244,240,232,.14); }
.rv-somm .tguide__roe{ position:absolute; top:50%; left:50%; width:clamp(230px,32vw,420px); aspect-ratio:1/1; object-fit:cover;
  clip-path:circle(47% at 50% 47%); opacity:0; transform:translate(-50%,-50%) scale(.96); transition:opacity .42s var(--silk),transform .6s var(--silk);
  filter:drop-shadow(0 26px 44px rgba(0,0,0,.55)); }
.rv-somm .tguide__roe.is-on{ opacity:1; transform:translate(-50%,-50%) scale(1); }
.rv-somm .tguide__viz:hover .tguide__roe.is-on{ transform:translate(-50%,-50%) scale(1.03); }
.rv-somm .tguide__info{ position:relative; min-height:16rem; }
.rv-somm .tguide__panel{ position:absolute; inset:0; opacity:0; transform:translateY(10px);
  transition:opacity .38s var(--silk),transform .38s var(--silk); pointer-events:none; }
.rv-somm .tguide__panel.is-on{ opacity:1; transform:none; pointer-events:auto; position:relative; }
.rv-somm .tguide__sub{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(244,240,232,.6); }
.rv-somm .tguide__name{ font-family:var(--serif); font-weight:400; font-size:clamp(2rem,3.4vw,2.9rem);
  color:var(--paper); margin:.35rem 0 .9rem; line-height:1.02; }
.rv-somm .tguide__tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1.1rem; }
.rv-somm .tguide__tags span{ font-size:.68rem; letter-spacing:.06em; text-transform:uppercase; color:rgba(244,240,232,.85);
  border:1px solid rgba(244,240,232,.24); border-radius:999px; padding:.42em 1em; }
.rv-somm .tguide__desc{ color:rgba(244,240,232,.82); line-height:1.65; max-width:42ch; margin:0 0 .4rem; }
.rv-somm .tguide__serve{ font-size:.8rem; color:rgba(244,240,232,.6); margin:0 0 1.4rem; }
.rv-somm .tguide__cta{ display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap; }
.rv-somm .tguide__cta .btn--solid{ background:var(--paper); color:var(--ink) !important; border-color:var(--paper); }
.rv-somm .tguide__cta .btn--solid:hover{ background:#fff; }
.rv-somm .tguide__price{ font-family:var(--sans); font-weight:600; font-size:1.15rem; color:var(--paper); }
/* intensity meter */
.rv-somm .tguide__meter{ display:flex; align-items:center; gap:1rem; max-width:640px; margin:clamp(2rem,4vw,3rem) auto 0; }
.rv-somm .tguide__end{ font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(244,240,232,.55); white-space:nowrap; }
.rv-somm .tguide__track{ position:relative; flex:1; height:3px; border-radius:3px;
  background:linear-gradient(90deg,rgba(244,240,232,.16),rgba(244,240,232,.4)); }
.rv-somm .tguide__fill{ position:absolute; inset:0 auto 0 0; background:var(--paper); border-radius:3px; transition:width .52s var(--silk); }
.rv-somm .tguide__dot{ position:absolute; top:50%; transform:translate(-50%,-50%); width:13px; height:13px; border-radius:50%;
  background:var(--paper); border:2px solid var(--petrol-deep); box-shadow:0 0 0 1px rgba(244,240,232,.4); cursor:pointer; padding:0; }
.rv-somm .tguide__dot.is-on{ transform:translate(-50%,-50%) scale(1.25); }
/* tin-thumbnail tabs */
.rv-somm .tguide__tabs{ display:flex; justify-content:center; gap:clamp(.6rem,1.4vw,1.2rem); margin-top:clamp(2rem,4vw,3rem); flex-wrap:wrap; }
.rv-somm .tguide__tab{ display:flex; align-items:center; gap:.7rem; background:rgba(244,240,232,.04);
  border:1px solid rgba(244,240,232,.16); border-radius:4px; padding:.6rem .9rem; cursor:pointer; transition:border-color .3s,background .3s; }
.rv-somm .tguide__tab:hover,.rv-somm .tguide__tab.is-on{ border-color:rgba(244,240,232,.6); background:rgba(244,240,232,.09); }
.rv-somm .tguide__tab img{ width:38px; height:38px; object-fit:contain; }
.rv-somm .tguide__tab b{ font-family:var(--serif); font-weight:400; font-size:1rem; color:var(--paper); display:block; }
.rv-somm .tguide__tab span{ font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(244,240,232,.55); }

/* ---- FULL-BLEED MEDIA BANDS (occasion, final CTA) ---- */
.rv-fbm{ position:relative; display:flex; align-items:flex-end; overflow:hidden; }
.rv-fbm__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; z-index:0;
  transform:scale(1.04); transition:transform 1.1s cubic-bezier(.16,1,.3,1); }
.rv-fbm.in .rv-fbm__img{ transform:scale(1); }
.rv-fbm__scrim{ position:absolute; inset:0; z-index:1; }
.rv-fbm__inner{ position:relative; z-index:2; padding:clamp(2.5rem,7vh,6rem) var(--gutter); max-width:640px; }
.rv-fbm__inner .h2{ margin:.4rem 0 1rem; }
.rv-fbm__inner p{ color:rgba(244,240,232,.86); line-height:1.65; max-width:42ch; margin:0 0 1.6rem; }
.rv-fbm__cta{ display:flex; align-items:center; gap:1.3rem; flex-wrap:wrap; }

/* 5 · OCCASION yacht band */
/* 1600×893 source: the still life (tin base, spoon, napkin, blinis) sits in
   the bottom third — anchor the cover-crop low so the crop eats open sea at
   the top, never the composition; slightly taller band eases both ends */
.rv-occ{ min-height:clamp(560px,78vh,880px); }
.rv-occ .rv-fbm__img{ object-position:55% 82%; }
.rv-occ .rv-fbm__scrim{ background:linear-gradient(90deg,rgba(15,44,39,.66) 0%,rgba(15,44,39,.28) 46%,transparent 74%); }

/* ---- 6 · GIFTS — band layout provided by the .rvb system (end of file) ----
   The gift options are a maison carte (hairline rows, serif names), NOT image
   cards: the band photo already shows the real composed gift set, so the two
   cutout-tin thumbnails were pasted-on noise and are gone. */
.rv-carte{ border-top:1px solid var(--line-2); margin-bottom:1.7rem; }
.rv-carte__row{ display:block; padding:1.3rem .2rem 1.25rem; border-bottom:1px solid var(--line-2);
  text-decoration:none; transition:background .3s var(--silk); }
.rv-carte__row:hover{ background:rgba(20,58,51,.035); }
.rv-carte__head{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem; }
.rv-carte__name{ font-family:var(--serif); font-weight:400; font-size:clamp(1.5rem,1.6vw,1.85rem); color:var(--ink); line-height:1; }
.rv-carte__name::after{ content:"\2192"; margin-left:.55rem; font-size:1.05rem; color:var(--petrol);
  opacity:0; display:inline-block; transform:translateX(-6px); transition:opacity .3s,transform .3s var(--silk); }
.rv-carte__row:hover .rv-carte__name::after{ opacity:1; transform:none; }
.rv-carte__price{ font-size:.82rem; color:var(--ink-mute); white-space:nowrap; }
.rv-carte__price b{ font-family:var(--sans); font-weight:600; font-size:1.12rem; color:var(--ink); }
.rv-carte__meta{ display:block; margin-top:.4rem; font-size:.86rem; color:var(--ink-mute); line-height:1.5; }
.rv-carte__occasions{ margin:0 0 .9rem; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); }

/* ---- 7 · PROVENANCE — band layout provided by the .rvb system (end of file) ---- */
.rv-steps{ list-style:none; margin:0 0 1.4rem; padding:0; }
.rv-steps li{ display:grid; grid-template-columns:auto 1fr; gap:1.3rem; align-items:baseline;
  padding:1.15rem 0; border-top:1px solid var(--line); }
.rv-steps li:last-child{ border-bottom:1px solid var(--line); }
.rv-steps__n{ font-family:var(--sans); font-weight:600; font-size:1.15rem; color:var(--petrol); font-variant-numeric:tabular-nums; }
.rv-steps h3{ font-family:var(--serif); font-weight:400; font-size:1.25rem; color:var(--ink); margin:0 0 .25rem; }
.rv-steps p{ font-size:.92rem; color:var(--ink-mute); line-height:1.55; margin:0; max-width:52ch; }
.rvb__panel .delivery__note{ margin:0 0 1.1rem; font-size:.92rem; color:var(--ink-2); }

/* ---- 8 · RITUAL — band layout provided by the .rvb system (end of file) ---- */
.rv-steps--dark li{ border-color:rgba(244,240,232,.16); }
.rv-steps--dark li:last-child{ border-bottom-color:rgba(244,240,232,.16); }
.rv-steps--dark .rv-steps__n{ color:rgba(244,240,232,.7); }
.rv-steps--dark h3{ color:var(--paper); }
.rv-steps--dark p{ color:rgba(244,240,232,.66); }
.rv-chip{ display:inline-flex; align-items:center; gap:.9rem; margin-top:1.4rem;
  background:rgba(244,240,232,.05); border:1px solid rgba(244,240,232,.18); border-radius:4px; padding:.7rem .95rem; transition:border-color .3s; }
.rv-chip:hover{ border-color:rgba(244,240,232,.5); }
.rv-chip img{ width:52px; height:52px; border-radius:3px; object-fit:cover; }
.rv-chip b{ font-family:var(--serif); font-weight:400; font-size:1.05rem; color:var(--paper); display:block; }
.rv-chip span{ font-size:.74rem; color:rgba(244,240,232,.6); }
.rv-chip .tlink--light{ margin-left:.5rem; font-size:.74rem; }

/* ---- 9 · FINAL CTA — band layout provided by the .rvb system (end of file) ---- */
.rv-close__title{ font-family:var(--serif); font-weight:400; color:var(--paper); line-height:1.04;
  font-size:clamp(2.2rem,4vw,3.4rem); margin:.5rem 0 1rem; }
.rv-close__copy{ color:rgba(244,240,232,.82); line-height:1.65; max-width:42ch; margin:0 0 1.8rem; }
.rv-close__cta{ display:flex; align-items:center; gap:1.3rem; flex-wrap:wrap; margin-bottom:1.8rem; }
.rv-close__trust{ display:flex; flex-wrap:wrap; gap:.8rem 1.7rem; padding-top:1.3rem; border-top:1px solid rgba(244,240,232,.18); }
.rv-close__trust span{ position:relative; font-size:.72rem; letter-spacing:.09em; text-transform:uppercase; color:rgba(244,240,232,.74); }
.rv-close__trust span + span::before{ content:"·"; position:absolute; left:-.95rem; color:rgba(244,240,232,.4); }

/* =========================================================================
   CONTENT-PAGE LUXURY PASS — editorial page heads, numbered value cols,
   premium FAQ (sticky index + hairline accordions). Shared across
   about-us / explore / our-caviar / qa; RVB bands carry the rest.
   ========================================================================= */
/* editorial page head: bigger serif, centered hairline sign-off */
.cde-edhead .sec__head--center{ max-width:760px; margin-inline:auto; }
.cde-edhead__title{ font-size:clamp(2.4rem,4.6vw,4rem) !important; letter-spacing:-.01em; }
.cde-edhead__rule{ display:block; width:64px; height:1px; background:var(--line-2); margin:1.8rem auto 0; }
.cde-edhead{ padding-block:clamp(3.2rem,7vw,5.6rem) clamp(2.4rem,5vw,4rem); }

/* three promises: numbered, hairline-ruled columns instead of plain cards */
.cvals__grid--lux{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.4rem,3vw,3rem); }
.cvals__grid--lux .cval{ background:transparent; border:0; border-top:1px solid var(--line-2); padding:1.4rem .1rem 0; border-radius:0; box-shadow:none; }
.cvals__grid--lux .cval__n{ font-family:var(--sans); font-weight:600; font-size:.8rem; color:var(--petrol); letter-spacing:.08em; display:block; margin-bottom:.7rem; }
.cvals__grid--lux .cval__t{ font-family:var(--serif); font-weight:400; font-size:1.45rem; color:var(--ink); margin:0 0 .5rem; }
.cvals__grid--lux .cval__p{ font-size:.95rem; color:var(--ink-mute); line-height:1.6; margin:0; }
@media (max-width:700px){ .cvals__grid--lux{ grid-template-columns:1fr; } }

/* premium FAQ: sticky category index + hairline accordions */
.faqwrap--lux{ display:grid; grid-template-columns:250px 1fr; gap:clamp(2rem,4.5vw,4.5rem); align-items:start; }
.faqindex{ position:sticky; top:6.5rem; display:flex; flex-direction:column; gap:.15rem; border-top:1px solid var(--line-2); padding-top:1.2rem; }
.faqindex__label{ font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:.7rem; }
.faqindex a{ font-size:.92rem; color:var(--ink-2); text-decoration:none; padding:.42rem 0; border-bottom:1px solid var(--line-soft); transition:color .25s, padding-left .25s var(--silk); }
.faqindex a:hover{ color:var(--petrol); padding-left:.35rem; }
.faqindex__ask{ margin-top:1rem; color:var(--petrol) !important; border-bottom:0 !important; font-weight:600; }
.faqwrap--lux .faqgroup{ margin-bottom:clamp(2rem,4vw,3rem); }
.faqwrap--lux .faqgroup__title{ font-family:var(--serif); font-weight:400; font-size:1.6rem; color:var(--ink);
  margin:0 0 1rem; padding-bottom:.7rem; border-bottom:1px solid var(--line-2); }
.faqwrap--lux .faq{ background:transparent; border:0; border-bottom:1px solid var(--line-soft); border-radius:0; }
.faqwrap--lux .faq__q{ font-family:var(--serif); font-size:1.08rem; padding:1.05rem .1rem; }
.faqwrap--lux .faq__a{ padding:0 .1rem 1.2rem; max-width:62ch; }
.rvb--qa{ min-height:0 !important; }
.rvb--qa .rvb__in{ padding-block:clamp(2.6rem,5vw,4.2rem); }
@media (max-width:900px){ .faqwrap--lux{ grid-template-columns:1fr; } .faqindex{ display:none; } }

/* =========================================================================
   SHOP CINEMATIC HERO — full-bleed video banner, same language as the home
   hero: cover video, petrol side-scrim, lower-left copy, trust whisper.
   Breaks out of the 1200 container; ancestor overflow-x:clip eats the
   scrollbar-width sliver so the page never gains horizontal overflow.
   ========================================================================= */
.post-type-archive-product .site-content,.tax-product_cat .site-content,.tax-product_tag .site-content{ overflow-x:clip; }
/* banner sits flush under the header (Astra puts 64px margin on .content-area) */
.post-type-archive-product .content-area,.tax-product_cat .content-area,.tax-product_tag .content-area{ margin-top:0 !important; }
.shophero--cine{ display:flex !important; grid-template-columns:none !important; gap:0 !important;
  position:relative; align-items:flex-end; overflow:hidden; margin:0 calc(50% - 50vw) !important;
  min-height:clamp(460px,66vh,740px); background:var(--petrol-deep); }
.shophero--cine .shophero__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
  border:0; border-radius:0; }
.shophero--cine .shophero__scrim{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(90deg,rgba(15,44,39,.8) 0%,rgba(15,44,39,.45) 44%,rgba(15,44,39,0) 76%),
             linear-gradient(0deg,rgba(20,24,19,.6) 0%,rgba(20,24,19,0) 40%); }
.shophero--cine .shophero__inner{ position:relative; z-index:2; width:100%; max-width:var(--maxw,1200px);
  margin-inline:auto; padding:clamp(2.5rem,7vh,4.8rem) var(--gx,clamp(1.25rem,5vw,3rem)); }
/* !important: v4-woo heading rules force var(--ink) on archive h1 — the
   "black text on video" bug */
.shophero--cine .shophero__title{ color:var(--paper) !important; font-size:clamp(2.3rem,4.4vw,3.8rem); margin:.45rem 0 .9rem; }
.shophero--cine .shophero__lede{ color:rgba(244,240,232,.86) !important; max-width:46ch; }
.shophero--cine .shophero__cta{ margin:1.4rem 0 0; }
.shophero__whisper{ margin:1.3rem 0 0; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  color:rgba(244,240,232,.62); }
@media (max-width:700px){ .shophero--cine{ min-height:clamp(420px,72vh,560px); } }

/* ---- category context band: description + specification (maison catalogue) ---- */
.shopintro{ display:grid; grid-template-columns:minmax(0,1.35fr) minmax(0,1fr); gap:clamp(2rem,5vw,5rem);
  align-items:start; padding:clamp(2.2rem,4.5vw,3.8rem) 0 clamp(1.6rem,3vw,2.4rem);
  border-bottom:1px solid var(--line-soft); margin-bottom:clamp(1.4rem,2.5vw,2rem); }
.shopintro__title{ font-family:var(--serif); font-weight:400; color:var(--ink); line-height:1.08;
  font-size:clamp(1.5rem,2.2vw,2rem); margin:.45rem 0 .8rem; }
.shopintro__p{ font-size:.98rem; line-height:1.7; color:var(--ink-mute); max-width:58ch; margin:0 0 1.3rem; }
.shopintro__p em{ font-style:italic; color:var(--ink-2); }
.shopintro__cats{ display:flex; flex-wrap:wrap; align-items:center; gap:.5rem; }
.shopintro__catlabel{ font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); margin-right:.3rem; }
.shopintro__cats a{ font-size:.78rem; letter-spacing:.04em; color:var(--ink-2); text-decoration:none;
  border:1px solid var(--line-2); border-radius:999px; padding:.45em 1.1em; transition:border-color .3s, color .3s, background .3s; }
.shopintro__cats a:hover{ border-color:var(--petrol); color:var(--petrol); background:var(--petrol-tint); }
.shopintro__meta{ list-style:none; margin:.5rem 0 0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:0 2rem; }
.shopintro__meta li{ display:flex; flex-direction:column; gap:.15rem; padding:.9rem 0; border-top:1px solid var(--line-soft); }
.shopintro__meta b{ font-family:var(--sans); font-weight:600; font-size:1.02rem; color:var(--ink); letter-spacing:.01em; }
.shopintro__meta span{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); }
@media (max-width:860px){
  .shopintro{ grid-template-columns:1fr; gap:1.4rem; }
  .shopintro__meta{ margin-top:0; }
}

/* ---- results toolbar: quiet hairline row instead of floating defaults ---- */
.post-type-archive-product .woocommerce-result-count,.tax-product_cat .woocommerce-result-count{
  font-size:.7rem !important; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute) !important;
  margin:0 0 1.6rem !important; padding-top:.55rem; }
.post-type-archive-product .woocommerce-ordering,.tax-product_cat .woocommerce-ordering{ margin:0 0 1.4rem !important; }
.woocommerce-ordering select{ appearance:none; -webkit-appearance:none; background-color:transparent;
  border:1px solid var(--line-2) !important; border-radius:2px !important; cursor:pointer;
  padding:.6em 2.4em .6em 1.1em !important; font:500 .78rem var(--sans) !important; color:var(--ink-2) !important;
  background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%23857C6B' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .9em center; }
.woocommerce-ordering select:focus{ outline:none; border-color:var(--petrol) !important; }

/* =========================================================================
   CHECKOUT CRO — sticky order summary, quiet checkbox labels, tidy totals,
   trust rows in the review card, security microcopy under the pay button.
   Presentation only — no payment/Paysera logic touched.
   ========================================================================= */
/* order summary follows the customer while they fill the long form */
.woocommerce-checkout #order_review{ position:sticky; top:6rem; }
/* checkbox labels: sentence case (global label rule uppercases everything) */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper label,
.woocommerce-checkout .form-row label.checkbox,
.woocommerce-checkout label.woocommerce-form__label-for-checkbox{
  text-transform:none !important; letter-spacing:.01em !important; font-size:.86rem !important;
  color:var(--ink-2) !important; font-weight:400 !important; }
.woocommerce-checkout .optional{ text-transform:lowercase; font-size:.9em; color:var(--ink-mute); letter-spacing:0; }
/* review table: product line breathes, amounts never wrap */
.woocommerce-checkout-review-order-table td.product-name{ line-height:1.5; }
.woocommerce-checkout-review-order-table td.product-name strong{
  display:inline !important; white-space:nowrap; color:var(--ink-mute); font-weight:400; }
.woocommerce-checkout-review-order-table .amount,
.woocommerce-checkout-review-order-table td[class*="total"]{ white-space:nowrap; }
.woocommerce-checkout-review-order-table .includes_tax{ display:block; font-size:.74rem; color:var(--ink-mute); white-space:nowrap; }
.woocommerce-checkout-review-order-table .order-total .amount{ font-size:1.15rem; }
/* trust rows inside the review card */
.cde-review-trust td{ padding-top:1rem !important; border-top:1px solid var(--line-soft); }
.cde-review-trust ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.55rem; }
.cde-review-trust li{ display:flex; align-items:center; gap:.6rem; font-size:.8rem; color:var(--ink-2); }
.cde-review-trust .cde-ic{ width:16px; height:16px; color:var(--petrol); flex:none; }
/* security microcopy under MOKĖTI (clear the floated button, full row) */
.cde-pay-note{ display:flex; align-items:flex-start; gap:.5rem; margin:.9rem 0 0; font-size:.76rem;
  line-height:1.5; color:var(--ink-mute); clear:both; width:100%; text-align:left; }
.cde-pay-note .cde-ic{ width:15px; height:15px; color:var(--petrol); flex:none; margin-top:.1em; }
/* free-shipping progress notice: brand it (plugin renders its own colors) */
.woocommerce-checkout .br-notice-content,.br_notice_type_default{ font-size:.9rem; }
@media (max-width:900px){
  .woocommerce-checkout #order_review{ position:static; }
}

/* =========================================================================
   PDP MAX — premium product page: framed stage, jewel buy panel, dark
   full-bleed taste band (RVB language), hairline facts, refined related.
   ========================================================================= */
.single-product .site-content{ overflow-x:clip; }

/* gallery: taller framed stage with a slow breathe on hover */
.single-product .cde-pdp-stage{ background:var(--card); border:1px solid var(--line-soft); border-radius:5px;
  overflow:hidden; box-shadow:0 24px 48px rgba(20,30,25,.06); }
.single-product .cde-pdp-stage__img{ width:100%; aspect-ratio:1/1; object-fit:cover; display:block;
  transform:scale(1.02); transition:transform 1.2s var(--silk); }
.single-product .cde-pdp-stage:hover .cde-pdp-stage__img{ transform:scale(1.05); }

/* variation labels + pills: quiet caps labels, petrol-filled selection */
.single-product table.variations label,.single-product table.variations th{
  font-family:var(--sans) !important; font-size:.64rem !important; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-mute) !important; font-weight:600 !important; }
.single-product .cde-pill{ appearance:none; background:transparent !important; border:1px solid var(--line-2) !important;
  border-radius:2px !important; padding:.62em 1.15em !important; font:500 .78rem var(--sans) !important;
  letter-spacing:.05em; color:var(--ink-2) !important; cursor:pointer; box-shadow:none !important;
  transition:border-color .25s, background .25s, color .25s; }
.single-product .cde-pill:hover{ border-color:var(--petrol) !important; color:var(--petrol) !important; }
.single-product .cde-pill.is-on{ background:var(--petrol) !important; border-color:var(--petrol) !important; color:var(--paper) !important; }

/* money CTA: full-width petrol, clear disabled state (max specificity —
   v5 targets .summary .single_add_to_cart_button with !important) */
.single-product .summary .single_add_to_cart_button,
.single-product form.cart .single_add_to_cart_button{ display:block; width:100% !important; background:var(--petrol) !important; color:var(--paper) !important;
  border:1px solid var(--petrol) !important; border-radius:3px !important; letter-spacing:.12em; text-transform:uppercase;
  font-size:.8rem !important; font-weight:600 !important; padding:1.05em 1.4em !important; transition:background .3s, color .3s !important; }
.single-product .summary .single_add_to_cart_button:hover,
.single-product form.cart .single_add_to_cart_button:hover{ background:var(--petrol-deep) !important; border-color:var(--petrol-deep) !important; }
.single-product .summary .single_add_to_cart_button.disabled,
.single-product .summary .single_add_to_cart_button.wc-variation-selection-needed,
.single-product form.cart .single_add_to_cart_button.disabled,
.single-product form.cart .single_add_to_cart_button.wc-variation-selection-needed{
  background:transparent !important; color:var(--ink-mute) !important; border-color:var(--line-2) !important; opacity:1 !important; }
/* selection hint (v5 pseudo): quiet left-aligned microcopy, not a centred banner;
   the outlined-muted button IS the disabled affordance — no extra opacity dim */
.single-product .woocommerce-variation-add-to-cart-disabled::before{
  text-align:left !important; font-size:.72rem !important; letter-spacing:.06em; text-transform:uppercase;
  margin:0 0 .55rem !important; }
.single-product .woocommerce-variation-add-to-cart-disabled .single_add_to_cart_button{ opacity:1 !important; }

/* reassurance: hairline rows */
.single-product .cde-reassure li{ display:flex; align-items:center; gap:.65rem; padding:.7rem 0 !important;
  margin:0 !important; border-bottom:1px solid var(--line-soft); font-size:.84rem; color:var(--ink-2); }
.single-product .cde-reassure li:last-child{ border-bottom:0; }
.single-product .cde-reassure svg{ width:17px; height:17px; color:var(--petrol); flex:none; }

/* dark taste band — breaks out of the 1200 container to full bleed */
.rvb--taste{ margin:clamp(3rem,6vw,5rem) calc(50% - 50vw) 0; }
/* v4-woo forces ink on single-product headings — light band needs !important */
.single-product .rvb--taste .h2,.single-product .rvb--taste h2{ color:var(--paper) !important; }
.single-product .rvb--taste .rvb__in > p{ color:rgba(244,240,232,.82) !important; }
.cde-tastetags{ display:flex; flex-wrap:wrap; gap:.5rem; margin:.2rem 0 1.2rem; }
.cde-tastetags span{ font-size:.68rem; letter-spacing:.06em; text-transform:uppercase; color:rgba(244,240,232,.85);
  border:1px solid rgba(244,240,232,.24); border-radius:999px; padding:.42em 1em; }
.rvb--taste .cde-profile__bars{ display:flex; flex-direction:column; gap:1.05rem; max-width:520px; }
.rvb--taste .cde-prow{ display:grid; grid-template-columns:128px 1fr; gap:1.2rem; align-items:center; margin:0; }
.rvb--taste .cde-prow > span{ font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(244,240,232,.62); }
.rvb--taste .cde-prow .bar{ height:2px; background:rgba(244,240,232,.16); position:relative; border-radius:0; }
.rvb--taste .cde-prow .bar i{ position:absolute; top:0; bottom:0; left:0; background:var(--paper); }
.rvb--taste .cde-prow .bar i::after{ content:""; position:absolute; right:-3px; top:50%; transform:translateY(-50%);
  width:7px; height:7px; border-radius:50%; background:var(--paper); }

/* facts: numbered hairline columns instead of card spam */
.cde-story--lux .cde-facts{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.4rem,3vw,2.8rem); }
.cde-fact{ border-top:1px solid var(--line-2); padding-top:1.25rem; }
.cde-fact__n{ display:block; font-family:var(--sans); font-weight:600; font-size:.76rem; letter-spacing:.08em;
  color:var(--petrol); margin-bottom:.65rem; }
.cde-fact h3{ font-family:var(--serif); font-weight:400; font-size:1.32rem; color:var(--ink); margin:0 0 .5rem; }
.cde-fact p{ font-size:.9rem; color:var(--ink-mute); line-height:1.62; margin:0; }

/* related: hairline-separated closing shelf */
.single-product .cde-related{ border-top:1px solid var(--line-soft); padding-top:clamp(2.2rem,4vw,3.2rem);
  margin-top:clamp(2.6rem,5vw,4rem); }
.single-product .cde-related h2{ font-family:var(--serif); font-weight:400; font-size:clamp(1.7rem,2.6vw,2.3rem);
  color:var(--ink); text-align:center; margin:0 0 clamp(1.6rem,3vw,2.4rem); }

@media (max-width:900px){
  .cde-story--lux .cde-facts{ grid-template-columns:1fr 1fr; }
  .rvb--taste .cde-prow{ grid-template-columns:104px 1fr; gap:.9rem; }
}
@media (max-width:560px){
  .cde-story--lux .cde-facts{ grid-template-columns:1fr; }
}

/* ---- shared: kill floating-tin boxes on product cards (home + shop) ---- */
.pcard__img{ background:var(--card) !important; }
/* EQUAL CARD GEOMETRY: every card image is the same 1:1 stage (staged shots
   are 1150×1150; fallback attachments get cover-cropped to match), and the
   price + hairline + CTA are pinned to the card bottom — so buttons align
   across cards regardless of how many text lines a product has. */
.pcard__img{ aspect-ratio:1/1; }
.pcard__img img{ width:100%; height:100%; object-fit:cover; display:block; }
.pcard__price{ margin-top:auto !important; padding-top:.5rem; }
.pcard__act{ margin-top:1rem !important; }
.pcard__img img{ transform:scale(1.06); transition:transform .5s var(--silk); }
.pcard:hover .pcard__img img,.woocommerce ul.products li.product:hover .pcard__img img{ transform:scale(1.09); }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:900px){
  .rv-collection__in{ grid-template-columns:1fr; gap:1.6rem; }
  .rv-collection__head{ position:static; }
  .rv-somm .tguide__stage{ grid-template-columns:1fr; gap:1.8rem; text-align:center; }
  .rv-somm .tguide__viz{ aspect-ratio:1/1; max-width:300px; margin-inline:auto; }
  .rv-somm .tguide__roe{ width:min(74vw,300px); }
  .rv-somm .tguide__info{ min-height:0; }
  .rv-somm .tguide__panel{ position:relative; }
  .rv-somm .tguide__panel:not(.is-on){ position:absolute; }
  .rv-somm .tguide__cta,.rv-somm .tguide__tags{ justify-content:center; }
  .rv-somm .tguide__desc{ margin-inline:auto; }
}
@media (max-width:620px){
  .rv-carousel__track .pcard{ flex-basis:74vw; }
  .rv-ribbon__row{ justify-content:flex-start; overflow-x:auto; -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory; padding-inline:20px; }
  .rv-ribbon__row > span{ scroll-snap-align:start; }
  .rv-ribbon__row > span + span::before{ display:none; }
  .rv-somm .tguide__tab b{ font-size:.9rem; }
  .rv-giftrow{ grid-template-columns:auto 1fr; }
  .rv-giftrow__price{ grid-column:2; text-align:left; }
}
@media (prefers-reduced-motion:reduce){
  .rv-fbm__img,.rvb__media img{ transform:none !important; transition:none; }
  .rv-somm .tguide__roe{ transition:opacity .12s linear; transform:translate(-50%,-50%) !important; }
  .rv-somm .tguide__panel{ transition:opacity .12s linear; }
  .pcard__img img,.rv-carousel__track .pcard{ transition:none; }
  .rv-carousel__track .pcard:hover,.rv-carousel__track .pcard:nth-child(even){ transform:none; }
}

/* =========================================================================
   POLISH PASS v2 — timeline, ritual card, header presence, collection, rhythm
   ========================================================================= */
/* header presence: breathing room, nav letterspacing, elegant hover underline
   — applied to BOTH the homepage .hdr and the Astra inner-page header so they
   stay visually identical across home / shop / PDP / our-caviar / qa. */
.cde-v4-body .hdr{ padding-block:1.25rem; }
.cde-v4-body .hdr__nav{ gap:clamp(1.5rem,2.1vw,2.5rem); }
.cde-v4-body .hdr__nav a{ letter-spacing:.15em; position:relative; padding-block:.35rem; }
.cde-v4-body .hdr__nav a::after{ content:""; position:absolute; left:0; right:0; bottom:.05rem; height:1px;
  background:currentColor; opacity:.55; transform:scaleX(0); transform-origin:left; transition:transform .32s var(--silk); }
.cde-v4-body .hdr__nav a:hover::after{ transform:scaleX(1); }
.cde-v4-body .hdr__logo{ letter-spacing:.015em; }
.cde-v4-body .hdr__logo small{ margin-top:.18rem; }
.cde-v4-body .hdr.is-solid{ box-shadow:0 1px 0 rgba(218,210,196,.7); }
.cde-v4-body .hdr__right a{ letter-spacing:.14em; }

/* --- Astra inner-page header: mirror the same polish for consistency --- */
#masthead,.main-header-bar,.site-header,#ast-fixed-header,.ast-header-sticked{ border-bottom-color:rgba(218,210,196,.7)!important; }
.main-header-menu .menu-item > a:not([role="button"]),.ast-builder-menu .menu-item > a:not([role="button"]){
  letter-spacing:.15em!important; position:relative; }
.main-header-menu .menu-item > a:not([role="button"])::after{ content:""; position:absolute; left:.9em; right:.9em; bottom:.15em;
  height:1px; background:var(--petrol); opacity:.55; transform:scaleX(0); transform-origin:left; transition:transform .32s var(--silk); }
.main-header-menu .menu-item > a:not([role="button"]):hover::after{ transform:scaleX(1); }
.custom-logo-link::before{ letter-spacing:.015em!important; }
/* unify PIRKTI CTA to the homepage petrol-bordered treatment.
   Astra renders TWO overlapping anchors here (.ast-custom-button-link, which
   overflows the header 51×94px, and .menu-link) around ONE inner
   div.ast-custom-button. Frame ONLY the inner div; strip every border,
   padding and pseudo-element from both anchors — the stray anchor's border
   corners were the "marks around PIRKTI" artifact. */
.ast-header-button-1 .ast-custom-button-link,.ast-header-button-1 .menu-link{
  background:transparent!important; border:0!important; padding:0!important; box-shadow:none!important; outline:none!important; }
.ast-header-button-1 a::before,.ast-header-button-1 a::after{ content:none!important; display:none!important; }
.ast-header-button-1 .ast-custom-button{
  background:transparent!important; border:1px solid var(--petrol)!important; color:var(--petrol)!important;
  border-radius:2px!important; padding:.6em 1.25em!important; letter-spacing:.14em!important; font-size:.72rem!important;
  box-shadow:none!important; transition:background .3s,color .3s!important; }
.ast-header-button-1 a:hover .ast-custom-button,.ast-header-button-1 .menu-link:hover .ast-custom-button{
  background:var(--petrol)!important; color:var(--paper)!important; }

/* provenance — engineered numbered timeline (nodes on a hairline, no card boxes) */
.rv-steps--timeline li{ position:relative; grid-template-columns:auto 1fr; gap:1.4rem; padding:0 0 1.9rem; border:0 !important; align-items:start; }
.rv-steps--timeline li:last-child{ padding-bottom:0; }
.rv-steps--timeline .rv-steps__n{ position:relative; z-index:1; display:grid; place-items:center; width:2.7rem; height:2.7rem; flex:none;
  border:1px solid var(--line-2); border-radius:50%; background:var(--card); font-size:.82rem; color:var(--petrol); }
.rv-steps--timeline li:not(:last-child)::before{ content:""; position:absolute; left:1.35rem; top:2.7rem; bottom:.4rem; width:1px; background:var(--line); }
.rv-steps--timeline .rv-steps__c h3{ font-family:var(--serif); font-weight:400; font-size:1.35rem; color:var(--ink); margin:.25rem 0 .45rem; }
.rv-steps--timeline .rv-steps__c p{ font-size:.95rem; color:var(--ink-mute); line-height:1.6; margin:0; max-width:52ch; }
.rv-badges{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:.9rem; }
.rv-badges span{ font-family:var(--sans); font-size:.68rem; font-weight:600; letter-spacing:.03em; color:var(--petrol);
  background:var(--petrol-tint); border:1px solid rgba(20,58,51,.12); border-radius:3px; padding:.42em .85em; }

/* ritual — stronger featured CTA card */
.rv-chip{ display:flex; align-items:center; gap:1.1rem; margin-top:1.9rem; width:100%; max-width:480px;
  background:rgba(244,240,232,.05); border:1px solid rgba(244,240,232,.2); border-radius:5px; padding:.9rem 1.05rem;
  transition:border-color .35s var(--silk), background .35s var(--silk), transform .25s var(--silk); }
.rv-chip:hover{ border-color:rgba(244,240,232,.55); background:rgba(244,240,232,.09); transform:translateY(-2px); }
.rv-chip img{ width:66px; height:66px; border-radius:4px; }
.rv-chip > span:not([class]){ flex:1; }
.rv-chip b{ font-size:1.12rem; margin-bottom:.15rem; }
.rv-chip .tlink--light{ margin-left:auto; white-space:nowrap; }

/* collection — refined surface + premium hover lift/shadow, less dead air */
.rv-collection{ padding-block:clamp(2.6rem,5vw,4.6rem); }
.rv-carousel__track .pcard{ border-radius:5px; transition:transform .28s var(--silk), box-shadow .38s var(--silk); }
.rv-carousel__track .pcard:hover{ transform:translateY(-4px); box-shadow:0 22px 42px rgba(20,30,25,.1); }
.rv-carousel__track .pcard__img{ border-radius:5px 5px 0 0; }
/* editorial rhythm: even cards sit a beat lower; hover still lifts 4px */
@media (min-width:901px){
  .rv-carousel__track .pcard:nth-child(even){ transform:translateY(16px); }
  .rv-carousel__track .pcard:nth-child(even):hover{ transform:translateY(12px); }
}
.pcard__img img{ transform:scale(1.05); }
.pcard:hover .pcard__img img,.woocommerce ul.products li.product:hover .pcard__img img{ transform:scale(1.08); }


/* =========================================================================
   RVB — MIRRORED EDITORIAL BANDS (gift → provenance → ritual → final CTA)

   EDGE CONTRACT
   · one shared split axis, mirrored: media 58% / panel 42% (or flipped via
     .rvb--imgR). Only TWO axis positions on the whole lower page.
   · both columns of a band are ALWAYS exactly equal height (grid stretch);
     the image is absolutely-filled, so text length can never distort photo
     geometry, and a photo can never balloon its section.
   · zigzag alternation (gift L → prov R → ritual L → close R): at every band
     seam a photo edge meets a flat panel — an image can never visually merge
     with the neighbouring section's image.
   · art direction by source: wide lifestyle scenes sit on 58% media (gift
     scene 1500×837, ritual 1200×1500), tight detail shots on 42% media
     (ice tin 893×1600, marble tin 1100×1100 → shows ~85% of the square).
   · ONE min-height and ONE padding system for all bands.
   · panel content is anchored: heading block at the top, action/meta row
     pinned to the bottom edge (.rvb__foot) — text bottoms align with image
     bottoms instead of floating in the middle.
   ========================================================================= */
.rvb{ display:grid; grid-template-columns:1fr; position:relative; }
.rvb--ivory{ background:var(--paper); }
.rvb--dark{ background:var(--petrol-deep); color:var(--paper); }
.rvb__media{ position:relative; overflow:hidden; min-height:clamp(240px,62vw,380px); }
.rvb__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
  transform:scale(1.03); transition:transform 1.1s var(--silk); }
.rvb.in .rvb__media img{ transform:scale(1); }
/* ritual portrait: anchor to the TOP of the source at every width so the
   face is always in frame — cover-crop eats the bottom (sequins), never eyes */
.rvb--ritual .rvb__media img{ object-position:50% 0; }
.rvb__panel{ display:flex; }
.rvb__in{ display:flex; flex-direction:column; width:100%; max-width:760px; margin-inline:auto;
  padding:clamp(2.6rem,5vw,5.2rem) clamp(20px,4.8vw,104px); }
.rvb__in .h2{ margin:.4rem 0 .8rem; }
.rvb__in .lede{ margin:0 0 1.6rem; max-width:52ch; }
.rvb--dark .rvb__in > p{ color:rgba(244,240,232,.82); line-height:1.65; margin:0 0 1.4rem; max-width:46ch; }
.rvb__foot{ margin-top:auto; padding-top:1.7rem; }
.rvb__foot .rv-chip{ margin-top:0; }
/* panel body copy: quiet maison assurance line, not a promo notice */
.rvb__panel .delivery__note{ text-align:left; font-size:.9rem; color:var(--ink-mute); }
.rvb__panel .delivery__note b{ color:var(--ink-2); font-weight:600; }
/* closing band: a deliberate hairline marks the ritual→close boundary on the
   low-contrast (dark panel → dark photo) side; bottom overlaps the footer by
   1px to kill the subpixel ivory background leak between two dark surfaces */
.rvb--close{ border-top:1px solid rgba(244,240,232,.14); margin-bottom:-1px; }
.rvb--close .rv-close__cta{ margin-top:auto; }
.rvb--close .rv-close__title{ font-size:clamp(2.4rem,4.4vw,4rem); }
/* back-to-top: ghost utility, not a dark slab over composed imagery */
#ast-scroll-top{ background:rgba(15,44,39,.35) !important; border:1px solid rgba(244,240,232,.35) !important;
  border-radius:2px !important; opacity:.55; transition:opacity .3s; backdrop-filter:blur(2px); }
#ast-scroll-top:hover{ opacity:1; background:var(--petrol) !important; }

@media (min-width:901px){
  /* ONE split axis for the whole lower page: every band divides at 58% from
     the left. imgL bands put the photo left of the axis (wide 58% scenes),
     imgR bands put it right (tight 42% detail shots). The same vertical line
     runs from the gift band to the footer. */
  .rvb{ grid-template-columns:58fr 42fr; min-height:clamp(520px,36vw,680px); }
  .rvb--imgR .rvb__media{ order:2; }
  .rvb--imgR .rvb__panel{ order:1; }
  .rvb__media{ min-height:0; }
  /* subject framing inside the two fixed panel proportions */
  .rvb--gifts  .rvb__media img{ object-position:56% 50%; } /* 1.79 source in 1.6 box — full scene, no vertical crop */
  .rvb--prov   .rvb__media img{ object-position:50% 62%; } /* open tin + label */
  .rvb--close  .rvb__media img{ object-position:50% 50%; } /* centred square tin */
  /* ritual rows: slightly stronger vertical rhythm */
  .rvb--ritual .rv-steps li{ padding:1.35rem 0; }
}
.cde-qty{ color:var(--ink-mute); font-weight:400; white-space:nowrap; }
