/* ============================================================
   Mantello Cigars Co — homepage craft layer (home.css)
   Dark "Ember & Oak" cigar-lounge luxe. Bespoke per-section layouts.
   Builds on styles.css tokens. ~deep, hand-built, not auto-grids.
   ============================================================ */

:root{
  --cedar:#7A4A26; --cedar-lite:#9A6435; --ember-soft:#E08A4A;
  --gold-soft:#E7C77E; --ink:#0B0908;
  --halo: 0 0 60px -10px color-mix(in srgb,var(--primary) 50%,transparent);
  --frame: inset 0 0 0 1px color-mix(in srgb,var(--primary) 22%,transparent);
}

/* warm-up the base a touch for the lounge feel */
body{ background:
   radial-gradient(120% 80% at 50% -10%, color-mix(in srgb,var(--accent) 9%,transparent), transparent 60%),
   var(--background); }
::selection{ background:var(--primary); color:var(--ink); }

/* section rhythm + numbered ornament */
.section{ position:relative; padding:clamp(72px,11vw,150px) 0; }
.section--tight{ padding:clamp(48px,7vw,90px) 0; }
.eyebrow{ display:inline-flex; align-items:center; gap:12px; font-family:var(--font-body);
  font-size:.72rem; font-weight:600; letter-spacing:.32em; text-transform:uppercase;
  color:var(--primary); margin:0 0 22px; }
.eyebrow::before{ content:""; width:34px; height:1px; background:linear-gradient(90deg,var(--primary),transparent); }
.eyebrow--c{ justify-content:center; }
.eyebrow--c::after{ content:""; width:34px; height:1px; background:linear-gradient(270deg,var(--primary),transparent); }
.display{ font-family:var(--font-head); font-weight:600; line-height:1.02; letter-spacing:-.01em;
  font-size:clamp(2.6rem,6vw,5.2rem); margin:0 0 .35em; }
.display em{ font-style:italic; color:var(--primary); }
.script{ font-family:var(--font-head); font-style:italic; }
.lead{ font-size:clamp(1.05rem,1.5vw,1.3rem); line-height:1.7; color:color-mix(in srgb,var(--foreground) 82%,transparent); max-width:60ch; }
.center{ text-align:center; margin-inline:auto; }

/* gold gradient display text (premium kit) */
.text-gold{ background:linear-gradient(92deg,var(--gold-soft),var(--primary) 55%,var(--accent));
  -webkit-background-clip:text; background-clip:text; color:transparent; }

/* hairline rule with center ornament */
.rule{ display:flex; align-items:center; justify-content:center; gap:18px; color:var(--primary); opacity:.7; margin:0; }
.rule::before,.rule::after{ content:""; height:1px; flex:1; max-width:160px;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--primary) 60%,transparent)); }
.rule::after{ background:linear-gradient(270deg,transparent,color-mix(in srgb,var(--primary) 60%,transparent)); }

/* ============ HEADER brand mark ============ */
.brand{ display:inline-flex; align-items:center; gap:13px; }
.brand__crest{ width:38px; height:38px; flex:none; color:var(--primary); filter:drop-shadow(0 0 10px color-mix(in srgb,var(--primary) 40%,transparent)); }
.brand__word{ font-family:var(--font-head); font-weight:600; font-size:1.42rem; letter-spacing:.16em;
  color:var(--foreground); line-height:1; }
.brand__word small{ display:block; font-size:.46rem; letter-spacing:.5em; color:var(--primary); margin-top:3px; font-family:var(--font-body); font-weight:600; }
.site-header .container{ gap:24px; }
.nav-desktop a{ font-family:var(--font-body); font-size:.82rem; letter-spacing:.06em; text-transform:uppercase; }
.btn--amz{ background:linear-gradient(180deg,var(--primary),#B9863A); color:var(--ink); font-size:.82rem; padding:11px 20px; }
.btn--amz:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -10px var(--primary); color:var(--ink); }

/* ============ HERO ============ */
.hero{ min-height:100svh; padding-top:90px; }
.hero__poster{ background:
   radial-gradient(80% 60% at 72% 22%, color-mix(in srgb,var(--accent) 30%,transparent), transparent 60%),
   radial-gradient(90% 70% at 20% 80%, color-mix(in srgb,var(--cedar) 26%,transparent), transparent 65%),
   var(--background); }
#hero-gl{ opacity:1; }
.hero__veil{ position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 40%, transparent 40%, color-mix(in srgb,var(--ink) 70%,transparent) 100%); }
.hero__grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; width:100%; }
.hero__watermark{ position:absolute; left:-2%; bottom:-8%; z-index:0; font-family:var(--font-head); font-weight:700;
  font-size:30vw; line-height:.8; letter-spacing:-.04em; color:transparent;
  -webkit-text-stroke:1px color-mix(in srgb,var(--primary) 12%,transparent); pointer-events:none; user-select:none; }
.hero__content{ position:relative; z-index:2; }
.hero h1{ font-family:var(--font-head); font-weight:600; letter-spacing:-.01em;
  font-size:clamp(3rem,7.2vw,6.4rem); line-height:.98; margin:.1em 0 .3em; }
.hero h1 .line{ display:block; overflow:hidden; }
.hero .lede{ max-width:46ch; font-size:clamp(1.05rem,1.5vw,1.28rem); }
.hero__cta{ margin-top:34px; display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.hero__meta{ margin-top:40px; display:flex; gap:30px; flex-wrap:wrap; align-items:center;
  border-top:1px solid var(--border); padding-top:22px; }
.hero__meta .m{ display:flex; flex-direction:column; gap:2px; }
.hero__meta .m b{ font-family:var(--font-head); font-size:1.7rem; color:var(--primary); line-height:1; }
.hero__meta .m span{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:color-mix(in srgb,var(--foreground) 60%,transparent); }
/* hero product pedestal */
.hero__show{ position:relative; z-index:2; display:grid; place-items:center; }
.pedestal{ position:relative; width:min(540px,96%); aspect-ratio:1/1; display:grid; place-items:center; padding:7%;
  background:radial-gradient(72% 72% at 50% 30%, #F3EAD7, #DBC9A6 70%, #C6B089);
  border:1px solid color-mix(in srgb,var(--primary) 30%,transparent); border-radius:24px;
  box-shadow:0 44px 80px -34px rgba(0,0,0,.78), var(--halo); }
.pedestal::before{ display:none; }
.pedestal__ring{ display:none; }
.pedestal img{ position:relative; z-index:2; width:100%; mix-blend-mode:multiply; filter:drop-shadow(0 18px 22px rgba(60,40,20,.3)); }
@keyframes spin{ to{ transform:rotate(360deg); } }
@media (prefers-reduced-motion:reduce){ .pedestal__ring{ animation:none; } }
.hero__badge{ position:absolute; top:6%; right:2%; z-index:3; background:color-mix(in srgb,var(--surface) 86%,transparent);
  border:1px solid var(--border); border-radius:var(--radius-pill); padding:8px 16px; backdrop-filter:blur(8px);
  font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--primary); display:flex; align-items:center; gap:8px; }
.hero__badge svg{ width:15px; height:15px; }
.scrollcue{ position:absolute; left:50%; bottom:26px; translate:-50% 0; z-index:3; display:flex; flex-direction:column;
  align-items:center; gap:8px; color:color-mix(in srgb,var(--foreground) 55%,transparent); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; }
.scrollcue svg{ width:16px; height:26px; animation:cue 1.8s var(--ease-premium) infinite; }
@keyframes cue{ 0%,100%{ transform:translateY(0); opacity:.5; } 50%{ transform:translateY(6px); opacity:1; } }

/* ============ MARQUEE strip ============ */
.marquee{ overflow:hidden; border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  background:color-mix(in srgb,var(--surface) 50%,transparent); padding:18px 0; }
.marquee__track{ display:flex; gap:46px; width:max-content; animation:slide 32s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__track span{ font-family:var(--font-head); font-style:italic; font-size:1.45rem; color:color-mix(in srgb,var(--foreground) 70%,transparent); display:inline-flex; align-items:center; gap:46px; white-space:nowrap; }
.marquee__track span::after{ content:""; width:6px; height:6px; border-radius:50%; background:var(--primary); }
@keyframes slide{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marquee__track{ animation:none; } }

/* ============ THE STANDARD (editorial split) ============ */
.standard{ position:relative; }
.standard__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,90px); align-items:start; }
.standard__lede .display{ max-width:14ch; }
.pillars{ display:grid; gap:2px; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; background:var(--border); }
.pillar{ background:var(--surface); padding:28px 26px; display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:start;
  transition:background .4s var(--ease-premium); position:relative; }
.pillar:hover{ background:color-mix(in srgb,var(--surface) 70%, var(--muted)); }
.pillar__ico{ width:46px; height:46px; color:var(--primary); flex:none; }
.pillar h3{ font-family:var(--font-head); font-size:1.5rem; font-weight:600; margin:0 0 6px; }
.pillar p{ margin:0; font-size:.96rem; color:color-mix(in srgb,var(--foreground) 76%,transparent); }
.pillar__no{ position:absolute; top:18px; right:20px; font-family:var(--font-head); font-size:.95rem; color:color-mix(in srgb,var(--primary) 55%,transparent); }

/* ============ COLLECTION (product lookbook) ============ */
.collection{ position:relative; }
.collection__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:46px; }
.grid-products{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.product{ position:relative; background:linear-gradient(180deg, color-mix(in srgb,var(--surface) 96%,transparent), var(--surface));
  border:1px solid var(--border); border-radius:18px; overflow:hidden; display:flex; flex-direction:column;
  transition:transform .5s var(--ease-premium), border-color .5s var(--ease-premium), box-shadow .5s var(--ease-premium);
  transform-style:preserve-3d; }
.product:hover{ border-color:color-mix(in srgb,var(--primary) 50%,transparent); box-shadow:0 30px 60px -30px rgba(0,0,0,.8), var(--halo); }
.product::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; z-index:3;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--primary) 70%,transparent),transparent); }
.product__stage{ position:relative; aspect-ratio:4/3; display:grid; place-items:center; padding:14px;
  background:radial-gradient(75% 75% at 50% 30%, #F4ECD9, #D9C7A6 70%, #C2AC85); }
.product__stage img{ width:78%; mix-blend-mode:multiply; filter:drop-shadow(0 16px 20px rgba(60,40,20,.35)); transition:transform .6s var(--ease-premium); }
.product:hover .product__stage img{ transform:translateY(-6px) scale(1.04); }
.product__tag{ position:absolute; top:12px; left:12px; background:color-mix(in srgb,var(--ink) 72%,transparent); color:var(--gold-soft);
  font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; padding:5px 11px; border-radius:var(--radius-pill); backdrop-filter:blur(4px); }
.product__body{ padding:22px 22px 24px; display:flex; flex-direction:column; gap:10px; flex:1; }
.product__body h3{ font-family:var(--font-head); font-size:1.42rem; font-weight:600; margin:0; line-height:1.1; }
.product__body p{ margin:0; font-size:.9rem; color:color-mix(in srgb,var(--foreground) 72%,transparent); flex:1; }
.product__spec{ display:flex; gap:14px; flex-wrap:wrap; font-size:.74rem; color:var(--primary); letter-spacing:.04em; margin-top:2px; }
.product__spec span{ display:inline-flex; align-items:center; gap:6px; }
.product__spec svg{ width:14px; height:14px; }
.product__cta{ margin-top:8px; display:inline-flex; align-items:center; gap:9px; font-family:var(--font-body); font-weight:600;
  font-size:.85rem; color:var(--ink); background:var(--primary); padding:11px 16px; border-radius:10px; align-self:flex-start;
  transition:gap .35s var(--ease-premium), transform .35s var(--ease-premium); }
.product__cta:hover{ gap:14px; transform:translateY(-2px); color:var(--ink); }
.product__cta svg{ width:15px; height:15px; }
.product--wide{ grid-column:span 3; flex-direction:row; }
.product--wide .product__stage{ aspect-ratio:auto; width:42%; }
.product--wide .product__body{ justify-content:center; padding:38px 40px; }

/* ============ SIGNATURE: Find Your Humidor ============ */
.matcher{ position:relative; }
.matcher__panel{ display:grid; grid-template-columns:1fr 1fr; gap:0; border:1px solid var(--border);
  border-radius:22px; overflow:hidden; background:var(--surface); box-shadow:0 40px 80px -50px rgba(0,0,0,.9); }
.matcher__form{ padding:clamp(30px,4vw,52px); border-right:1px solid var(--border); }
.matcher__q{ margin-bottom:30px; }
.matcher__q > p{ font-family:var(--font-body); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:color-mix(in srgb,var(--foreground) 62%,transparent); margin:0 0 14px; display:flex; align-items:center; gap:10px; }
.matcher__q > p b{ width:22px; height:22px; border-radius:50%; border:1px solid var(--primary); color:var(--primary);
  display:grid; place-items:center; font-family:var(--font-head); font-size:.85rem; }
.choices{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.choice{ position:relative; text-align:left; background:color-mix(in srgb,var(--muted) 60%,transparent);
  border:1px solid var(--border); border-radius:12px; padding:14px 16px; cursor:pointer; color:var(--foreground);
  font:inherit; transition:border-color .35s var(--ease-premium), background .35s var(--ease-premium), transform .35s var(--ease-premium); display:flex; gap:12px; align-items:center; }
.choice:hover{ border-color:color-mix(in srgb,var(--primary) 45%,transparent); transform:translateY(-2px); }
.choice.is-on{ border-color:var(--primary); background:color-mix(in srgb,var(--primary) 14%,transparent); }
.choice svg{ width:26px; height:26px; color:var(--primary); flex:none; }
.choice b{ display:block; font-family:var(--font-head); font-size:1.06rem; font-weight:600; }
.choice small{ color:color-mix(in srgb,var(--foreground) 64%,transparent); font-size:.78rem; }
.matcher__result{ padding:clamp(30px,4vw,52px); display:flex; flex-direction:column; justify-content:center; gap:18px;
  background:radial-gradient(120% 90% at 80% 0%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 60%), var(--surface); }
.matcher__result .rlabel{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--primary); }
.matcher__pick{ display:flex; gap:20px; align-items:center; }
.matcher__pick .thumb{ width:120px; aspect-ratio:1; border-radius:14px; flex:none; overflow:hidden;
  background:radial-gradient(70% 70% at 50% 30%, #F4ECD9, #CDB892); display:grid; place-items:center; border:1px solid var(--border); }
.matcher__pick .thumb img{ width:80%; mix-blend-mode:multiply; transition:opacity .4s ease; }
.matcher__pick h3{ font-family:var(--font-head); font-size:1.7rem; font-weight:600; margin:0 0 4px; }
.matcher__pick p{ margin:0; font-size:.9rem; color:color-mix(in srgb,var(--foreground) 76%,transparent); }
.matcher__why{ font-size:.92rem; color:color-mix(in srgb,var(--foreground) 80%,transparent); border-left:2px solid var(--primary); padding-left:14px; margin:0; }
.matcher__result .btn{ align-self:flex-start; }
.matcher__fade{ transition:opacity .35s var(--ease-premium); }
.is-swapping .matcher__fade{ opacity:0; }

/* ============ HUMIDITY / why band ============ */
.why{ background:linear-gradient(180deg,transparent, color-mix(in srgb,var(--surface) 50%,transparent)); }
.why__grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.gauge{ position:relative; width:min(320px,80%); margin-inline:auto; aspect-ratio:1; display:grid; place-items:center; }
.gauge svg{ width:100%; height:100%; transform:rotate(-90deg); }
.gauge__val{ position:absolute; text-align:center; }
.gauge__val b{ font-family:var(--font-head); font-size:3.2rem; color:var(--primary); line-height:1; display:block; }
.gauge__val span{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:color-mix(in srgb,var(--foreground) 64%,transparent); }
.why__list{ display:grid; gap:18px; }
.why__item{ display:grid; grid-template-columns:auto 1fr; gap:16px; align-items:start; padding-bottom:18px; border-bottom:1px solid var(--border); }
.why__item:last-child{ border-bottom:0; }
.why__item svg{ width:30px; height:30px; color:var(--primary); }
.why__item h3{ font-family:var(--font-head); font-size:1.3rem; margin:0 0 4px; font-weight:600; }
.why__item p{ margin:0; font-size:.92rem; color:color-mix(in srgb,var(--foreground) 74%,transparent); }

/* ============ ATMOSPHERE band (real photography, full-bleed parallax) ============ */
.atmos{ position:relative; min-height:64vh; display:grid; align-items:center; overflow:hidden; isolation:isolate; }
.atmos img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 35%; z-index:-2; }
.atmos::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(90deg, color-mix(in srgb,var(--ink) 92%,transparent) 8%, color-mix(in srgb,var(--ink) 52%,transparent) 70%, color-mix(in srgb,var(--ink) 86%,transparent)); }
.atmos__inner{ max-width:660px; padding-block:60px; }
.atmos__q{ font-family:var(--font-head); font-style:italic; font-weight:500; font-size:clamp(1.8rem,4vw,3.3rem); line-height:1.22; margin:0; }
.atmos__q .text-gold{ font-style:italic; }
.atmos cite{ display:block; margin-top:22px; font-style:normal; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--primary); }

/* ============ REVIEWS ============ */
.reviews{ position:relative; }
.reviews__grid{ columns:3; column-gap:22px; }
.review{ break-inside:avoid; margin:0 0 22px; background:var(--surface); border:1px solid var(--border); border-radius:16px;
  overflow:hidden; position:relative; }
.review::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--primary) 60%,transparent),transparent); }
.review img{ width:100%; display:block; }
.review__cap{ padding:12px 16px; font-size:.78rem; color:color-mix(in srgb,var(--foreground) 60%,transparent); display:flex; align-items:center; gap:8px; }
.review__cap svg{ width:14px; height:14px; color:var(--primary); }

/* ============ CTA band ============ */
.cta{ position:relative; text-align:center; border:1px solid var(--border); border-radius:26px; overflow:hidden;
  padding:clamp(48px,7vw,88px) clamp(24px,5vw,60px);
  background:radial-gradient(90% 140% at 50% 0%, color-mix(in srgb,var(--accent) 16%,transparent), transparent 55%), var(--surface); }
.cta .display{ max-width:18ch; margin-inline:auto; }
.cta__disclaim{ margin-top:26px; font-size:.74rem; color:color-mix(in srgb,var(--foreground) 50%,transparent); max-width:60ch; margin-inline:auto; line-height:1.6; }

/* ============ FAQ ============ */
.faq__grid{ display:grid; grid-template-columns:.7fr 1.3fr; gap:clamp(32px,5vw,64px); align-items:start; }
.faq details{ border-bottom:1px solid var(--border); padding:6px 0; }
.faq summary{ list-style:none; cursor:pointer; padding:20px 44px 20px 0; position:relative;
  font-family:var(--font-head); font-size:1.28rem; font-weight:600; color:var(--foreground); transition:color .3s var(--ease-premium); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary:hover{ color:var(--primary); }
.faq summary::after{ content:""; position:absolute; right:6px; top:50%; width:13px; height:13px; translate:0 -50%;
  background:no-repeat center/contain; transition:transform .4s var(--ease-premium);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23D2A24C' stroke-width='2'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E"); }
.faq details[open] summary::after{ transform:rotate(135deg); }
.faq details p{ margin:0; padding:0 0 22px; font-size:.96rem; color:color-mix(in srgb,var(--foreground) 76%,transparent); max-width:64ch; }

/* ============ FOOTER ============ */
.site-footer{ background:var(--ink); padding-top:72px; }
.foot__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid var(--border); }
.foot__brand .brand{ margin-bottom:18px; }
.foot__brand p{ font-size:.9rem; color:color-mix(in srgb,var(--foreground) 64%,transparent); max-width:38ch; }
.foot__col h4{ font-family:var(--font-body); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--primary); margin:0 0 16px; }
.foot__col a, .foot__col p{ display:block; font-size:.92rem; color:color-mix(in srgb,var(--foreground) 70%,transparent); margin:0 0 10px; }
.foot__col a:hover{ color:var(--primary); }
.foot__bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding:26px 0 40px; align-items:center; }
.foot__bottom small{ font-size:.78rem; color:color-mix(in srgb,var(--foreground) 50%,transparent); }
.foot__disclaim{ font-size:.72rem; color:color-mix(in srgb,var(--foreground) 42%,transparent); line-height:1.6; max-width:72ch; margin:18px auto 0; text-align:center; padding-bottom:34px; }

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .hero__grid{ grid-template-columns:1fr; gap:30px; } .hero__show{ order:-1; }
  .standard__grid,.why__grid,.faq__grid,.matcher__panel{ grid-template-columns:1fr; }
  .matcher__form{ border-right:0; border-bottom:1px solid var(--border); }
  .grid-products{ grid-template-columns:repeat(2,1fr); } .product--wide{ grid-column:span 2; flex-direction:column; } .product--wide .product__stage{ width:100%; aspect-ratio:4/3; }
  .reviews__grid{ columns:2; }
  .foot__top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .hero h1{ font-size:clamp(2.6rem,12vw,3.6rem); }
  .grid-products{ grid-template-columns:1fr; } .product--wide{ grid-column:span 1; }
  .choices{ grid-template-columns:1fr; }
  .reviews__grid{ columns:1; }
  .hero__meta{ gap:20px; } .foot__top{ grid-template-columns:1fr; }
  .matcher__pick{ flex-direction:column; align-items:flex-start; }
}
