/* =========================================================
   DESIGN SYSTEM
   Palette  : Paper / Ink / Stone / Wine (one disciplined accent)
   Type     : Bricolage Grotesque (display) + Inter (body/UI)
   Mood     : quiet, editorial, lots of air — Zara/Massimo Dutti tier
   ========================================================= */

:root{
  --paper:      #FAFAFA;
  --mist:       #F1EFEA;
  --ink:        #16151A;
  --ink-soft:   #3A3833;
  --stone:      #6E685F; /* darkened from #8A847C — old value failed WCAG AA contrast (3.55:1) on --paper */
  --line:       #E3DFD8;
  --wine:       #5C1A2B;
  --wine-deep:  #46141F;
  --paper-on-wine: #F7EFE9;

  --font-display: 'Bricolage Grotesque', 'Inter', system-ui, sans-serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;

  --container: 1320px;
  --gap: clamp(16px, 3vw, 32px);
  --radius: 2px;

  --ease: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
input,select,textarea{ font-family:inherit; font-size:1rem; }

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0;
}
h1{ font-size:clamp(2.4rem,5vw,4.6rem); line-height:0.98; font-weight:700; }
h2{ font-size:clamp(1.7rem,3vw,2.6rem); line-height:1.05; }
h3{ font-size:1.25rem; }

.eyebrow{
  font-family:var(--font-body);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--stone);
}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gap);
}

.visually-hidden{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }

.skip-link{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--ink); color:var(--paper); padding:.8rem 1.2rem; font-size:.85rem;
}
.skip-link:focus{ left:8px; top:8px; }

.badge--low{ background:#fff; border:1px solid var(--wine); color:var(--wine); }
.stock-urgency{ font-size:.78rem; color:var(--wine); font-weight:600; margin-top:.5rem; }

:focus-visible{ outline:2px solid var(--wine); outline-offset:3px; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.95rem 1.8rem;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  border:1px solid var(--ink);
  border-radius:var(--radius);
  background:var(--ink);
  color:var(--paper);
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), transform .25s var(--ease);
}
.btn:hover{ background:var(--paper); color:var(--ink); }
.btn:active{ transform:scale(.98); }
.btn--outline{ background:transparent; color:var(--ink); }
.btn--outline:hover{ background:var(--ink); color:var(--paper); }
.btn--wine{ background:var(--wine); border-color:var(--wine); color:var(--paper-on-wine); }
.btn--wine:hover{ background:var(--wine-deep); border-color:var(--wine-deep); color:var(--paper-on-wine); }
.btn--block{ width:100%; }
.btn--ghost{ background:transparent; border-color:transparent; padding:.4rem .2rem; }

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(250,250,250,.92);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar{
  display:flex; align-items:center; justify-content:center;
  gap:1rem;
  background:var(--ink);
  color:var(--paper);
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:.5rem 1rem;
}
.nav{
  position:relative;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem 0;
}
.nav__logo{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.5rem;
  letter-spacing:.02em;
}
.nav__links{ display:flex; gap:2rem; }
.nav__links a{
  font-size:.82rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  position:relative; padding-bottom:4px;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--wine);
  transition:width .3s var(--ease);
}
.nav__links a:hover::after{ width:100%; }
.nav__actions{ display:flex; align-items:center; gap:1.1rem; }
.nav__icon-btn{
  position:relative; display:flex; align-items:center; justify-content:center;
  width:38px; height:38px; background:none; border:none; color:var(--ink);
}
.nav__icon-btn svg{ width:21px; height:21px; }
.nav__badge{
  position:absolute; top:-2px; right:-2px;
  background:var(--wine); color:#fff; font-size:.62rem; font-weight:700;
  width:16px; height:16px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.nav__burger{ display:none; background:none; border:none; }

/* ---- Mobile nav (was completely non-functional: burger had no breakpoint
   to appear, links had no breakpoint to hide, and .nav-open had no rule) ---- */
@media (max-width:880px){
  .nav__links{
    display:none;
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; gap:0;
    background:var(--paper); border-bottom:1px solid var(--line);
    padding:.5rem 0 1rem;
    box-shadow:0 16px 28px rgba(0,0,0,.08);
  }
  .nav__links a{ padding:.85rem var(--gap); width:100%; }
  .nav__links a::after{ display:none; }
  .nav__burger{ display:flex; }
  body.nav-open .nav__links{ display:flex; }
}

.search-flyout{
  position:absolute; left:0; right:0; top:100%;
  background:var(--paper); border-bottom:1px solid var(--line);
  padding:1.5rem 0; box-shadow:0 12px 28px rgba(0,0,0,.06);
  display:none;
}
.search-flyout.is-open{ display:block; }
.search-flyout input{
  width:100%; border:none; border-bottom:2px solid var(--ink);
  background:transparent; font-family:var(--font-display); font-size:1.6rem;
  padding:.4rem 0;
}
.search-flyout input:focus{ outline:none; }
.search-suggestions{ margin-top:1rem; display:grid; gap:.6rem; }
.search-suggestions a{ display:flex; gap:.8rem; align-items:center; font-size:.9rem; }
.search-suggestions img{ width:42px; height:54px; object-fit:cover; background:var(--mist); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  display:grid; grid-template-columns: 1fr 1.15fr;
  align-items:stretch;
  min-height:min(86vh, 760px);
  background:var(--mist);
  overflow:hidden;
}
.hero__copy{
  position:relative; z-index:2;
  display:flex; flex-direction:column; justify-content:center;
  padding: var(--gap) clamp(24px,6vw,72px);
  gap:1.6rem;
}
.hero__title{ margin-right:-10%; }
.hero__title em{ font-style:normal; color:var(--wine); }
.hero__sub{ max-width:340px; color:var(--ink-soft); font-size:1.02rem; }
.hero__media{
  position:relative;
  background:linear-gradient(160deg,#d8d2c6,#b9b09f);
  overflow:hidden;
}
.hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero__scroll{
  position:absolute; bottom:28px; left:clamp(24px,6vw,72px);
  display:flex; align-items:center; gap:.6rem;
  font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--stone);
}
.hero__scroll .line{ width:1px; height:34px; background:var(--stone); animation:scrollline 2.2s var(--ease) infinite; }
@keyframes scrollline{ 0%{transform:scaleY(0); transform-origin:top;} 50%{transform:scaleY(1); transform-origin:top;} 50.1%{transform-origin:bottom;} 100%{transform:scaleY(0); transform-origin:bottom;} }

.hero__dots{ position:absolute; bottom:28px; right:clamp(24px,6vw,72px); display:flex; gap:.5rem; z-index:3; }
.hero__dots button{ width:8px; height:8px; border-radius:50%; border:1px solid var(--ink); background:transparent; padding:0; }
.hero__dots button.is-active{ background:var(--ink); }

@media (max-width:880px){
  .hero{ grid-template-columns:1fr; min-height:auto; }
  .hero__media{ height:56vh; order:-1; }
  .hero__title{ margin-right:0; }
}

/* =========================================================
   MARQUEE / PROMO STRIP
   ========================================================= */
.marquee{
  background:var(--ink); color:var(--paper);
  overflow:hidden; white-space:nowrap;
  padding:.7rem 0; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase;
}
.marquee__track{ display:inline-flex; gap:3rem; animation:marquee 26s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* =========================================================
   SECTION HEADINGS
   ========================================================= */
.section{ padding: clamp(48px,8vw,96px) 0; }
.section--mist{ background:var(--mist); }
.section__head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:1rem; margin-bottom:2.4rem; border-bottom:1px solid var(--line); padding-bottom:1.4rem;
}
.section__head h2{ margin-top:.4rem; }
.section__head .link-all{ font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; white-space:nowrap; border-bottom:1px solid var(--ink); padding-bottom:2px; }

/* =========================================================
   CATEGORY STRIP
   ========================================================= */
.cat-grid{
  display:grid; grid-template-columns:repeat(6,1fr); gap:var(--gap);
}
.cat-card{ text-align:center; }
.cat-card__img{
  aspect-ratio:1; border-radius:50%; overflow:hidden; background:var(--mist);
  margin-bottom:.9rem; transition:transform .4s var(--ease);
}
.cat-card:hover .cat-card__img{ transform:translateY(-6px); }
.cat-card__img img{ width:100%; height:100%; object-fit:cover; }
.cat-card__name{ font-size:.82rem; font-weight:600; letter-spacing:.04em; }
@media (max-width:980px){ .cat-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:560px){ .cat-grid{ grid-template-columns:repeat(2,1fr); gap:18px; } }

/* =========================================================
   PRODUCT GRID / CARD
   ========================================================= */
.product-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gap);
}
@media (max-width:980px){ .product-grid{ grid-template-columns:repeat(2,1fr); } }

.card{ position:relative; }
.card__media{
  position:relative; aspect-ratio:3/4; overflow:hidden; background:var(--mist); margin-bottom:.9rem;
}
.card__media img{
  width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease), opacity .4s var(--ease);
}
.card__media img.alt{ position:absolute; inset:0; opacity:0; }
.card:hover .card__media img.main{ opacity:0; }
.card:hover .card__media img.alt{ opacity:1; }
.card__badges{ position:absolute; top:10px; left:10px; display:flex; flex-direction:column; gap:.35rem; z-index:2; }
.badge{
  font-size:.62rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding:.3rem .55rem; background:var(--paper); border:1px solid var(--ink);
}
.badge--sale{ background:var(--wine); border-color:var(--wine); color:#fff; }
.badge--new{ background:var(--ink); color:var(--paper); }
.card__fav{
  position:absolute; top:10px; right:10px; z-index:2;
  width:34px; height:34px; border-radius:50%; background:rgba(250,250,250,.9); border:none;
  display:flex; align-items:center; justify-content:center;
}
.card__quickadd{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  transform:translateY(100%); transition:transform .35s var(--ease);
  padding:.6rem; background:rgba(250,250,250,.94);
}
.card:hover .card__quickadd{ transform:translateY(0); }
/* Hover can't be relied on for touch devices — keep the control reachable there. */
@media (hover:none){
  .card__quickadd{ position:static; transform:none; background:none; padding:.6rem 0 0; }
}
.card__title{ font-size:.92rem; font-weight:500; margin-bottom:.25rem; }
.card__prices{ display:flex; gap:.55rem; align-items:baseline; font-size:.92rem; }
.card__price--old{ color:var(--stone); text-decoration:line-through; font-size:.82rem; }
.card__price--current{ font-weight:700; }
.card__price--sale{ color:var(--wine); }
.card__oos{ font-size:.78rem; color:var(--stone); margin-top:.2rem; }

/* =========================================================
   ADVANTAGES
   ========================================================= */
.adv-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gap); text-align:center; }
.adv-card svg{ width:32px; height:32px; margin-bottom:1rem; }
.adv-card h3{ font-size:1rem; margin-bottom:.4rem; }
.adv-card p{ color:var(--stone); font-size:.86rem; margin:0; }
@media (max-width:880px){ .adv-grid{ grid-template-columns:repeat(2,1fr); } }

/* =========================================================
   REVIEWS
   ========================================================= */
.review-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
.review-card{ background:var(--paper); border:1px solid var(--line); padding:1.8rem; }
.review-card__stars{ color:var(--wine); letter-spacing:.15em; margin-bottom:.8rem; font-size:.85rem; }
.review-card__text{ font-size:.92rem; color:var(--ink-soft); margin-bottom:1.2rem; }
.review-card__author{ font-size:.78rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; }
@media (max-width:880px){ .review-grid{ grid-template-columns:1fr; } }

/* =========================================================
   INSTAGRAM STRIP
   ========================================================= */
.insta-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:6px; }
.insta-grid a{ position:relative; aspect-ratio:1; overflow:hidden; background:var(--mist); }
.insta-grid img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.insta-grid a:hover img{ transform:scale(1.06); }
@media (max-width:880px){ .insta-grid{ grid-template-columns:repeat(3,1fr); } }

/* =========================================================
   NEWSLETTER
   ========================================================= */
.newsletter{ background:var(--ink); color:var(--paper); text-align:center; padding:clamp(48px,8vw,96px) 0; }
.newsletter h2{ color:var(--paper); margin-bottom:.8rem; }
.newsletter p{ color:#c9c5be; max-width:460px; margin:0 auto 2rem; }
.newsletter form{ display:flex; max-width:420px; margin:0 auto; border-bottom:1px solid #4a473f; }
.newsletter input{ flex:1; background:none; border:none; color:var(--paper); padding:.8rem .2rem; font-size:.95rem; }
.newsletter input::placeholder{ color:#8d8a82; }
.newsletter button{ background:none; border:none; color:var(--paper); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; font-weight:700; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--mist); border-top:1px solid var(--line); padding:64px 0 28px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:var(--gap); margin-bottom:48px; }
.footer-col h4{ font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--stone); margin-bottom:1.2rem; }
.footer-col ul{ display:grid; gap:.65rem; }
.footer-col a{ font-size:.9rem; }
.footer-col a:hover{ color:var(--wine); }
.footer-social{ display:flex; gap:.8rem; margin-top:1.2rem; }
.footer-social a{ width:34px; height:34px; border:1px solid var(--line); border-radius:50%; display:flex; align-items:center; justify-content:center; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--line); padding-top:24px; font-size:.78rem; color:var(--stone); }
@media (max-width:880px){ .footer-grid{ grid-template-columns:1fr 1fr; } }

/* =========================================================
   BREADCRUMBS
   ========================================================= */
.breadcrumbs{ font-size:.78rem; color:var(--stone); padding:1.2rem 0; }
.breadcrumbs a:hover{ color:var(--wine); }
.breadcrumbs span{ margin:0 .4rem; }

/* =========================================================
   TOASTS / MINI CART DRAWER
   ========================================================= */
.drawer-overlay{ position:fixed; inset:0; background:rgba(22,21,26,.4); opacity:0; pointer-events:none; transition:opacity .3s var(--ease); z-index:90; }
.drawer-overlay.is-open{ opacity:1; pointer-events:auto; }
.drawer{
  position:fixed; top:0; right:0; bottom:0; width:min(420px,92vw);
  background:var(--paper); z-index:91; transform:translateX(100%);
  transition:transform .4s var(--ease); display:flex; flex-direction:column;
}
.drawer.is-open{ transform:translateX(0); }
.drawer__head{ display:flex; justify-content:space-between; align-items:center; padding:1.4rem; border-bottom:1px solid var(--line); }
.drawer__body{ flex:1; overflow-y:auto; padding:1.4rem; display:grid; gap:1.2rem; }
.drawer__foot{ padding:1.4rem; border-top:1px solid var(--line); }
.line-item{ display:grid; grid-template-columns:64px 1fr auto; gap:.9rem; }
.line-item img{ width:64px; height:80px; object-fit:cover; background:var(--mist); }
.line-item__name{ font-size:.88rem; font-weight:600; }
.line-item__meta{ font-size:.78rem; color:var(--stone); }
.qty-stepper{ display:inline-flex; align-items:center; border:1px solid var(--line); margin-top:.4rem; }
.qty-stepper button{ width:26px; height:26px; background:none; border:none; }
.qty-stepper span{ width:28px; text-align:center; font-size:.85rem; }
.toast{
  position:fixed; bottom:24px; right:24px; background:var(--ink); color:var(--paper);
  padding:1rem 1.4rem; font-size:.85rem; transform:translateY(20px); opacity:0;
  transition:all .35s var(--ease); z-index:99;
}
.toast.is-visible{ transform:translateY(0); opacity:1; }

/* =========================================================
   GENERIC PAGE / FORM ELEMENTS (catalog, product, cart, checkout, account)
   ========================================================= */
.page-head{ padding:2.4rem 0 1rem; }
.field{ display:grid; gap:.45rem; margin-bottom:1.1rem; }
.field label{ font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--stone); }
.field input, .field select, .field textarea{
  border:1px solid var(--line); background:var(--paper); padding:.8rem .9rem; border-radius:var(--radius);
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--ink); }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:0 1.2rem; }
@media (max-width:640px){ .grid-2{ grid-template-columns:1fr; } }

.filters-bar{ display:flex; gap:1rem; align-items:center; justify-content:space-between; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:1rem 0; margin-bottom:2rem; flex-wrap:wrap; }
.filters-bar__group{ display:flex; gap:.8rem; flex-wrap:wrap; }
.chip{ font-size:.78rem; border:1px solid var(--line); padding:.5rem .9rem; border-radius:30px; background:none; }
.chip.is-active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.size-grid{ display:flex; gap:.5rem; flex-wrap:wrap; }
.size-grid button{ min-width:44px; height:44px; border:1px solid var(--line); background:none; font-size:.85rem; }
.size-grid button.is-active{ border-color:var(--ink); background:var(--ink); color:var(--paper); }
.size-grid button:disabled{ color:var(--line); text-decoration:line-through; cursor:not-allowed; }

.pdp{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:clamp(24px,5vw,64px); }
@media (max-width:880px){
  .pdp{ grid-template-columns:1fr; }
}
.pdp__gallery-main{ aspect-ratio:3/4; background:var(--mist); overflow:hidden; margin-bottom:.6rem; }
.pdp__gallery-main img{ width:100%; height:100%; object-fit:cover; }
.pdp__thumbs{ display:flex; gap:.5rem; }
.pdp__thumbs img{ width:64px; height:80px; object-fit:cover; background:var(--mist); border:1px solid transparent; cursor:pointer; }
.pdp__thumbs img.is-active{ border-color:var(--ink); }
.pdp__price{ font-size:1.6rem; font-weight:700; margin:.8rem 0; }
.pdp__price .old{ font-size:1rem; color:var(--stone); text-decoration:line-through; margin-right:.6rem; font-weight:400; }
.accordion{ border-top:1px solid var(--line); }
.accordion summary{ padding:1rem 0; cursor:pointer; font-weight:600; font-size:.92rem; }

.table{ width:100%; border-collapse:collapse; font-size:.88rem; }
.table th{ text-align:left; font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--stone); padding:.7rem; border-bottom:1px solid var(--line); }
.table td{ padding:.8rem .7rem; border-bottom:1px solid var(--line); }

.status-pill{ font-size:.7rem; letter-spacing:.04em; text-transform:uppercase; padding:.3rem .6rem; border-radius:30px; }
.status-new{ background:#EAE8F5; color:#4B3F9E; }
.status-paid{ background:#E1F0E3; color:#1F7A39; }
.status-packing{ background:#FFF2D9; color:#9A6A09; }
.status-shipped{ background:#DCEEFB; color:#1A5E8B; }
.status-completed{ background:#E1F0E3; color:#1F7A39; }
.status-cancelled{ background:#F8DEDE; color:#9A2A2A; }

.empty-state{ text-align:center; padding:4rem 1rem; color:var(--stone); }

/* =========================================================
   FREE SHIPPING PROGRESS (cart)
   ========================================================= */
.shipping-progress{ margin-bottom:1.4rem; font-size:.84rem; }
.shipping-progress__bar{ height:4px; background:var(--line); margin-top:.5rem; border-radius:4px; overflow:hidden; }
.shipping-progress__fill{ height:100%; background:var(--wine); transition:width .4s var(--ease); }

/* =========================================================
   STICKY MOBILE ADD-TO-CART BAR (product page)
   Without this, the buy button scrolls out of view the moment
   a shopper reads the description/reviews — a real conversion leak.
   ========================================================= */
.sticky-buybar{ display:none; }
@media (max-width:880px){
  .sticky-buybar{
    display:flex; align-items:center; gap:.8rem;
    position:fixed; left:0; right:0; bottom:0; z-index:60;
    background:var(--paper); border-top:1px solid var(--line);
    padding:.8rem var(--gap); padding-bottom:max(.8rem, env(safe-area-inset-bottom));
    transform:translateY(100%); transition:transform .3s var(--ease);
  }
  .sticky-buybar.is-visible{ transform:translateY(0); }
  .sticky-buybar__price{ font-weight:700; white-space:nowrap; }
  .sticky-buybar .btn{ flex:1; }
}

/* =========================================================
   RESPONSIVE CART TABLE
   A 7-column <table> cannot fit a phone screen — instead of
   horizontal scrolling, collapse each row into a labeled card.
   ========================================================= */
@media (max-width:760px){
  .table thead{ display:none; }
  .table, .table tbody, .table tr, .table td{ display:block; width:100%; }
  .table tr{ border-bottom:1px solid var(--line); padding:1rem 0; display:grid; grid-template-columns:64px 1fr; gap:.3rem .9rem; }
  .table tr td:first-child{ grid-row:1 / span 5; }
  .table td{ border:none; padding:.15rem 0; }
  .table td[data-label]::before{ content:attr(data-label); display:inline-block; min-width:84px; font-size:.7rem; letter-spacing:.05em; text-transform:uppercase; color:var(--stone); }
  .table td:last-child{ grid-column:2; }
}

/* =========================================================
   REVIEWS — photo + submission form
   ========================================================= */
.review-card__photo{ width:100%; max-width:160px; aspect-ratio:1; object-fit:cover; margin-bottom:1rem; }
.review-form{ max-width:520px; }
.star-input{ display:flex; gap:.4rem; font-size:1.6rem; }
.star-input button{ background:none; border:none; color:var(--line); padding:0; }
.star-input button.is-active{ color:var(--wine); }
