/* ===================================================
   PAINTED CAT — Brand stylesheet
   B2B wine site. Hand-drawn warmth + clean trade UX.
   =================================================== */

:root{
  /* Brand */
  --pc-cream:       #F6EFE2;
  --pc-cream-deep: #ECE0C7;
  --pc-paper:      #FBF6EA;
  --pc-ink:        #1E1A16;
  --pc-ink-soft:   #4A413A;
  --pc-line:       #2A211B;

  --pc-wine:       #7A1E2C;   /* deep wine red */
  --pc-wine-dark:  #4E121C;
  --pc-terracotta: #D8632B;
  --pc-mustard:    #E2A22A;
  --pc-leaf:       #4F7A3A;
  --pc-sky:        #2E6E8E;
  --pc-rose:       #E37BA1;

  /* Capsule colors (per SKU accents) */
  --cap-lisboa-gold: #C9A24A;
  --cap-lisboa-red:  #B0252A;
  --cap-cab:         #E388B0;
  --cap-vineyard:    #D86A21;
  --cap-beach:       #4DBA3A;
  --cap-pinot:       #5FC9C0;
  --cap-sauv:        #B7DDE0;
  --cap-temp:        #B0252A;

  /* Type */
  --font-display: "Caveat Brush", "Patrick Hand", system-ui, sans-serif;
  --font-hand:    "Caveat", "Patrick Hand", cursive;
  --font-body:    "Inter", "Helvetica Neue", system-ui, sans-serif;

  /* Layout */
  --maxw: 1240px;
  --radius: 14px;
  --radius-lg: 22px;
  --shadow-sm: 0 2px 6px rgba(30,26,22,.08);
  --shadow-md: 0 14px 38px rgba(30,26,22,.14);
  --shadow-lg: 0 30px 60px rgba(30,26,22,.18);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--font-body);
  color:var(--pc-ink);
  background:var(--pc-paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit;}

/* ---------- Paper texture (subtle) ---------- */
body::before{
  content:"";
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(216,99,43,.07), transparent 60%),
    radial-gradient(900px 500px at 110% 10%, rgba(46,110,142,.06), transparent 60%);
}
main, header, footer{position:relative;z-index:1;}

/* ---------- Typography ---------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:400;
  line-height:1.05;
  letter-spacing:.5px;
  color:var(--pc-ink);
  margin:0 0 .4em;
}
h1{font-size:clamp(2.6rem, 6vw, 5rem);}
h2{font-size:clamp(2rem, 4vw, 3.4rem);}
h3{font-size:clamp(1.4rem, 2.4vw, 2rem);}
h4{font-size:1.25rem;}
.eyebrow{
  font-family:var(--font-hand);
  font-size:1.25rem;
  color:var(--pc-wine);
  letter-spacing:1px;
  margin:0 0 .25em;
  text-transform:lowercase;
}
.lede{font-size:1.15rem;color:var(--pc-ink-soft);max-width:62ch;}
p{margin:0 0 1em;}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.section{padding:96px 0;}
.section--tight{padding:64px 0;}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;}
.split--reverse{grid-template-columns:.95fr 1.05fr;}

/* Two-column utilities used in contact + trade pages */
.two-col{display:grid;grid-template-columns:1.4fr .9fr;gap:48px;}
.two-col-flip{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start;}
.bottle-grid-mini{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
  justify-items:center;
  align-items:end;
}
.bottle-grid-mini img{
  height:130px !important;       /* override any inline / stretched height */
  width:auto !important;
  max-width:40px;                 /* hard cap: bottle is ~34px wide at 130px tall */
  object-fit:contain;
  filter:drop-shadow(0 8px 12px rgba(30,26,22,.15));
  justify-self:center;
}
@media (max-width:480px){
  .bottle-grid-mini img{height:110px !important;max-width:34px;}
}

@media (max-width:1080px){
  .container{padding:0 24px;}
}
@media (max-width:880px){
  .split,.split--reverse,.two-col,.two-col-flip{grid-template-columns:1fr;gap:32px;}
  .section{padding:64px 0;}
  .bottle-grid-mini{grid-template-columns:repeat(4,1fr);gap:8px;}
}
@media (max-width:680px){
  .container{padding:0 18px;}
  .section{padding:52px 0;}
  .section--tight{padding:44px 0;}
}
@media (max-width:480px){
  .container{padding:0 14px;}
  .section{padding:44px 0;}
  .bottle-grid-mini{grid-template-columns:repeat(2,1fr);gap:14px;}
}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,246,234,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(42,33,27,.08);
}
.site-header .container{
  display:flex;align-items:center;gap:16px;
  height:74px;
}
.brand{
  display:flex;align-items:center;
  margin-right:auto;        /* push everything else to the right */
  flex-shrink:0;
}
.brand-logo{
  height:44px;width:auto;display:block;
}
@media (max-width:680px){
  .site-header .container{height:64px;}
  .brand-logo{height:36px;}
}
@media (max-width:400px){
  .brand-logo{height:30px;}
}
.brand-mark{
  width:42px;height:42px;border-radius:50%;
  background:var(--pc-wine);
  display:grid;place-items:center;color:var(--pc-cream);
  box-shadow:var(--shadow-sm);
  flex-shrink:0;
}
/* Footer text-based brand (image version would lose detail when inverted) */
.brand-text{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-display);font-size:1.9rem;line-height:1;
  color:var(--pc-cream);
  text-decoration:none;
}
.brand-text .brand-mark{
  background:var(--pc-mustard);
  color:var(--pc-ink);
  box-shadow:none;
}
nav.primary{display:flex;align-items:center;gap:28px;}
nav.primary a{
  font-family:var(--font-body);font-weight:500;font-size:.95rem;
  color:var(--pc-ink-soft);position:relative;padding:6px 0;
}
nav.primary a:hover, nav.primary a.is-active{color:var(--pc-wine);}
nav.primary a.is-active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:3px;
  background:var(--pc-wine);border-radius:3px;transform:rotate(-1deg);
}
/* Header CTA — "sticker / stamp" style that echoes the brand's tape labels */
.nav-cta{
  background:var(--pc-mustard);
  color:var(--pc-ink)!important;
  padding:12px 26px 13px;
  border-radius:5px;
  font-family:var(--font-hand);
  font-size:1.3rem;
  font-weight:700;
  letter-spacing:.4px;
  line-height:1;
  display:inline-block;
  margin-left:10px;
  box-shadow:
    0 3px 0 0 var(--pc-wine-dark),
    0 5px 12px rgba(30,26,22,.10);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.nav-cta:hover{
  background:#F2B73E;            /* slightly lighter mustard for hover */
  transform:translateY(-2px);
  box-shadow:
    0 5px 0 0 var(--pc-wine-dark),
    0 9px 18px rgba(30,26,22,.16);
}
.nav-cta:active{
  transform:translateY(2px);
  box-shadow:
    0 1px 0 0 var(--pc-wine-dark),
    0 1px 4px rgba(30,26,22,.10);
}
.nav-cta:focus-visible{
  outline:none;
  box-shadow:
    0 0 0 3px var(--pc-wine),
    0 3px 0 0 var(--pc-wine-dark),
    0 5px 12px rgba(30,26,22,.10);
}
@media (max-width:780px){
  /* Inside mobile drawer — wider, less elevated */
  .nav-cta{
    margin:10px 28px;
    text-align:center;
    box-shadow:0 3px 0 0 var(--pc-wine-dark);
    padding:14px 22px;
  }
}

/* language switcher */
.lang-switcher{
  font:inherit; font-size:.9rem; font-weight:500;
  color:var(--pc-ink-soft);
  background:transparent;
  border:1.5px solid rgba(42,33,27,.15);
  border-radius:999px;
  padding:8px 36px 8px 14px;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='%234A413A'><path d='M6 8L0 0h12z'/></svg>");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:9px;
  margin-right:6px;
  transition:border-color .15s ease;
}
.lang-switcher:hover{ border-color:var(--pc-wine); color:var(--pc-wine); }
.lang-switcher:focus{ outline:none; border-color:var(--pc-wine); box-shadow:0 0 0 3px rgba(122,30,44,.12); }
@media (max-width:780px){
  /* keep visible but compact when nav collapses to hamburger */
  .lang-switcher{font-size:.84rem;padding:6px 28px 6px 10px;background-position:right 9px center;background-size:7px;margin-right:0;}
}
@media (max-width:400px){
  .lang-switcher{max-width:130px;}
}

/* mobile nav — use higher specificity (button.nav-toggle) so .btn doesn't override display */
button.nav-toggle{display:none;}
@media (max-width:780px){
  nav.primary{
    position:absolute;top:74px;left:0;right:0;
    background:var(--pc-paper);
    flex-direction:column;align-items:stretch;gap:0;
    padding:8px 0 14px;
    border-bottom:1px solid rgba(42,33,27,.08);
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:opacity .2s, transform .2s;
    z-index:60;
  }
  nav.primary.is-open{opacity:1;transform:none;pointer-events:auto;}
  nav.primary a{padding:14px 28px;}
  nav.primary .nav-cta{margin:8px 28px;text-align:center;}
  button.nav-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-size:.88rem;}
}
@media (max-width:680px){
  nav.primary{top:64px;}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:999px;
  font-weight:600;font-size:.98rem;letter-spacing:.2px;
  transition:transform .15s ease, background .15s ease, box-shadow .15s ease;
  box-shadow:var(--shadow-sm);
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn-primary{background:var(--pc-wine);color:var(--pc-cream);}
.btn-primary:hover{background:var(--pc-wine-dark);}
.btn-ghost{background:transparent;color:var(--pc-ink);border:1.5px solid var(--pc-ink);box-shadow:none;}
.btn-ghost:hover{background:var(--pc-ink);color:var(--pc-cream);}

/* ---------- Hero ---------- */
.hero{
  padding:90px 0 60px;
  background:linear-gradient(180deg, var(--pc-cream) 0%, var(--pc-paper) 100%);
  border-bottom:1px dashed rgba(42,33,27,.18);
  overflow:hidden;
  position:relative;
}
.hero .container{position:relative;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
@media (max-width:880px){.hero-grid{grid-template-columns:1fr;gap:24px;}}
@media (max-width:680px){.hero{padding:56px 0 36px;}}
.hero h1 span.accent{color:var(--pc-wine);display:inline-block;transform:rotate(-1.5deg);}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:14px;margin-top:28px;
}
.hero-meta .chip{
  background:var(--pc-cream-deep);
  padding:8px 14px;border-radius:999px;font-size:.88rem;color:var(--pc-ink-soft);
  border:1px solid rgba(42,33,27,.08);
}

.hero-bottles{
  position:relative;display:flex;justify-content:center;align-items:end;
  min-height:520px;
  margin-left:-10px;
}
.hero-bottles .bottle{
  width:clamp(110px, 14vw, 160px);
  height:auto;transform-origin:bottom center;
  filter:drop-shadow(0 30px 30px rgba(30,26,22,.25));
  transition:transform .35s ease;
}
.hero-bottles .bottle:nth-child(1){transform:rotate(-9deg) translateY(8px);}
.hero-bottles .bottle:nth-child(2){transform:rotate(-3deg) translateY(-12px);z-index:2;width:clamp(125px, 16vw, 180px);}
.hero-bottles .bottle:nth-child(3){transform:rotate(3deg) translateY(-6px);}
.hero-bottles .bottle:nth-child(4){transform:rotate(9deg) translateY(10px);}
.hero-bottles .bottle:hover{transform:translateY(-14px) rotate(0);}
.hero-bottles .bottle + .bottle{margin-left:-26px;}

@media (max-width:880px){
  .hero-bottles{min-height:auto;margin-top:8px;}
  .hero-bottles .bottle{width:clamp(95px, 22vw, 150px);}
  .hero-bottles .bottle:nth-child(2){width:clamp(110px, 25vw, 170px);}
}
@media (max-width:480px){
  .hero-bottles .bottle + .bottle{margin-left:-18px;}
}

/* ---------- Value props ---------- */
.values{background:var(--pc-cream);border-block:1px solid rgba(42,33,27,.08);}
.values-grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:28px;
}
@media (max-width:880px){.values-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.values-grid{grid-template-columns:1fr;}}
.value{
  background:var(--pc-paper);
  border:1px solid rgba(42,33,27,.08);
  border-radius:var(--radius-lg);
  padding:26px;box-shadow:var(--shadow-sm);
}
.value .num{
  font-family:var(--font-display);font-size:2.6rem;color:var(--pc-wine);
  line-height:1;margin-bottom:4px;
}
.value h4{margin:.4em 0 .3em;}
.value p{font-size:.95rem;color:var(--pc-ink-soft);margin:0;}

/* ---------- Range strip ---------- */
.range-strip{
  background:var(--pc-ink);color:var(--pc-cream);
  padding:18px 0;overflow:hidden;
}
.range-strip-track{
  display:flex;gap:60px;font-family:var(--font-display);font-size:1.5rem;
  white-space:nowrap;animation:scroll 40s linear infinite;
}
.range-strip-track span{opacity:.85;}
.range-strip-track span::after{content:" • ";opacity:.4;margin-left:60px;}
@keyframes scroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* ---------- Catalog grid ---------- */
.catalog{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
}
@media (max-width:1080px){.catalog{grid-template-columns:repeat(3,1fr);}}
@media (max-width:780px){.catalog{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.catalog{grid-template-columns:1fr;}}

.wine-card{
  background:var(--pc-paper);
  border:1px solid rgba(42,33,27,.08);
  border-radius:var(--radius-lg);
  padding:24px 18px 22px;
  text-align:center;
  position:relative;
  transition:transform .25s ease, box-shadow .25s ease;
  box-shadow:var(--shadow-sm);
}
.wine-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.wine-card .bottle-frame{
  height:280px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  margin-bottom:14px;
  overflow:hidden;
}
.wine-card .bottle-frame img,
.wine-card .bottle-frame svg{
  height:280px !important;       /* explicit height — width derives from aspect ratio */
  width:auto !important;
  max-width:none !important;     /* override reset's max-width:100% */
  object-fit:contain;
  filter:drop-shadow(0 18px 22px rgba(30,26,22,.22));
}
@media (max-width:1080px){
  .wine-card .bottle-frame{height:240px;}
  .wine-card .bottle-frame img{height:240px !important;}
}
@media (max-width:680px){
  .wine-card .bottle-frame{height:220px;}
  .wine-card .bottle-frame img{height:220px !important;}
}
@media (max-width:480px){
  .wine-card .bottle-frame{height:260px;}
  .wine-card .bottle-frame img{height:260px !important;}
}
.wine-card .type{
  display:inline-block;
  font-family:var(--font-body);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;
  padding:4px 10px;border-radius:999px;
  background:var(--pc-cream-deep);color:var(--pc-ink-soft);
  margin-bottom:8px;
}
.wine-card h3{
  font-size:1.55rem;margin:.2em 0 .2em;
}
.wine-card .origin{
  font-family:var(--font-hand);color:var(--pc-wine);font-size:1.15rem;
  margin-bottom:6px;
}
.wine-card .notes{
  font-size:.9rem;color:var(--pc-ink-soft);margin:8px 0 0;
}

/* Wine card detail (catalog page) */
.wine-detail{
  display:grid;grid-template-columns:1fr 1.2fr;gap:48px;
  background:var(--pc-paper);
  border:1px solid rgba(42,33,27,.08);
  border-radius:var(--radius-lg);
  padding:48px;margin-bottom:40px;
  box-shadow:var(--shadow-sm);
}
@media (max-width:880px){
  .wine-detail{grid-template-columns:1fr;padding:28px;gap:24px;}
}
@media (max-width:480px){
  .wine-detail{padding:22px 18px;margin-bottom:28px;}
}
.wine-detail .bottle-frame{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:380px;
}
.wine-detail .bottle-frame img,
.wine-detail .bottle-frame svg{
  height:480px !important;
  max-height:60vh !important;
  width:auto !important;
  max-width:none !important;
  object-fit:contain;
  filter:drop-shadow(0 28px 30px rgba(30,26,22,.22));
}
@media (max-width:880px){
  .wine-detail .bottle-frame img{height:380px !important;}
}
@media (max-width:480px){
  .wine-detail .bottle-frame{min-height:280px;}
  .wine-detail .bottle-frame img{height:300px !important;}
}
.spec-table{
  width:100%;border-collapse:collapse;margin-top:18px;
  font-size:.95rem;
}
.spec-table th,.spec-table td{
  text-align:left;padding:10px 0;border-bottom:1px dashed rgba(42,33,27,.18);
  vertical-align:top;
}
.spec-table th{
  font-family:var(--font-body);font-weight:600;color:var(--pc-ink-soft);width:42%;
  font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;
}
@media (max-width:480px){
  .spec-table{font-size:.88rem;}
  .spec-table th,.spec-table td{padding:8px 0;}
  .spec-table th{width:38%;}
}

/* ---------- Story / about ---------- */
.story-card{
  background:var(--pc-cream);
  border-radius:var(--radius-lg);
  padding:48px;border:1px solid rgba(42,33,27,.08);
}
.story-card h3{margin-top:0;}
.scribble-list{list-style:none;padding:0;margin:18px 0 0;}
.scribble-list li{
  padding:10px 0 10px 38px;position:relative;color:var(--pc-ink);
  border-bottom:1px dashed rgba(42,33,27,.18);
}
.scribble-list li::before{
  content:"";position:absolute;left:6px;top:14px;
  width:18px;height:18px;border-radius:50%;
  background:var(--pc-wine);
  box-shadow:0 0 0 4px rgba(122,30,44,.12);
}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;}
@media (max-width:780px){.stats{grid-template-columns:repeat(2,1fr);}}
.stat .big{
  font-family:var(--font-display);font-size:3.4rem;color:var(--pc-wine);
  line-height:1;
}
.stat .lbl{color:var(--pc-ink-soft);font-size:.95rem;letter-spacing:.05em;}

/* ---------- Trade panels ---------- */
.trade-panels{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media (max-width:880px){.trade-panels{grid-template-columns:1fr;}}
.trade-panel{
  background:var(--pc-paper);border:1px solid rgba(42,33,27,.08);
  border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;
}
@media (max-width:480px){
  .trade-panel{padding:22px 20px;}
  .story-card{padding:28px 22px;}
}
.trade-panel .corner-cat{
  position:absolute;right:-10px;bottom:-10px;width:90px;opacity:.18;
}
.trade-panel h3{margin-top:0;}

/* ---------- Form ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
@media (max-width:680px){.form-grid{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:6px;}
.field.full{grid-column:1/-1;}
.field label{
  font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--pc-ink-soft);font-weight:600;
}
.field input,.field select,.field textarea{
  font:inherit;color:var(--pc-ink);
  background:var(--pc-paper);
  border:1.5px solid rgba(42,33,27,.18);
  border-radius:12px;padding:14px 16px;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--pc-wine);
  box-shadow:0 0 0 4px rgba(122,30,44,.12);
}
.field textarea{min-height:140px;resize:vertical;}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--pc-ink);color:var(--pc-cream);
  padding:64px 0 32px;margin-top:60px;
}
.site-footer a{color:var(--pc-cream);opacity:.85;}
.site-footer a:hover{opacity:1;color:var(--pc-mustard);}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;
}
@media (max-width:780px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr;}}
.footer-grid h5{
  font-family:var(--font-display);font-weight:400;font-size:1.4rem;
  margin:0 0 14px;color:var(--pc-mustard);
}
.footer-grid ul{list-style:none;padding:0;margin:0;line-height:2;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  margin-top:48px;padding-top:24px;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  font-size:.86rem;opacity:.75;
}
@media (max-width:480px){
  .site-footer{padding:48px 0 28px;}
  .footer-bottom{margin-top:32px;padding-top:18px;font-size:.78rem;}
}

/* ---------- Page hero (interior pages) ---------- */
.page-hero{
  padding:80px 0 56px;
  background:var(--pc-cream);
  border-bottom:1px dashed rgba(42,33,27,.18);
}
.page-hero .eyebrow{font-size:1.4rem;}
.page-hero h1{margin-bottom:12px;}
.page-hero p{max-width:60ch;color:var(--pc-ink-soft);font-size:1.1rem;}
@media (max-width:680px){
  .page-hero{padding:52px 0 36px;}
  .page-hero p{font-size:1rem;}
}

/* ---------- Misc ---------- */
.divider{
  height:24px;background-image:
    radial-gradient(circle at 12px 12px, rgba(42,33,27,.15) 2px, transparent 2.5px);
  background-size:24px 24px;background-position:center;
}
.tape{
  display:inline-block;
  background:var(--pc-mustard);
  padding:4px 14px;
  font-family:var(--font-hand);font-size:1.1rem;
  transform:rotate(-2deg);
  box-shadow:var(--shadow-sm);
}
.gold-bar{
  display:inline-block;width:60px;height:4px;background:var(--pc-wine);
  border-radius:4px;margin-bottom:18px;
}

/* Capsule color helper bottle SVGs */
.bottle-svg .capsule{fill:var(--cap, var(--pc-wine));}

/* Responsive feature-bottle (used in story sections, replaces inline height:440px) */
.feature-bottle{
  height:440px !important;
  width:auto !important;
  max-width:none !important;
  object-fit:contain;
  filter:drop-shadow(0 30px 30px rgba(30,26,22,.25));
}
.feature-bottle--md{
  height:380px !important;
}
@media (max-width:880px){
  .feature-bottle{height:340px !important;}
  .feature-bottle--md{height:300px !important;}
}
@media (max-width:480px){
  .feature-bottle{height:280px !important;}
  .feature-bottle--md{height:260px !important;}
}
.feature-bottle-wrap{
  position:relative;
  display:inline-block;
  max-width:100%;
  vertical-align:middle;
}
@media (max-width:680px){
  .feature-bottle-wrap{text-align:center;display:block;}
}

/* Safer floating tape — never overflow viewport */
.tape--float{
  position:absolute;
  white-space:nowrap;
  z-index:2;
}
@media (max-width:680px){
  .tape--float{position:static;display:inline-block;margin-top:14px;}
}
