/* ============================================================
   Howl at the Moon — Iceland Bathing Expedition
   Concept landing pages (V1/V2/V3). Shared brand styles.
   Brand: Epilogue (headings) + Poppins (body), teal #3AA8C1,
   wolf/pack voice, founder-forward. Built by EMG, 2026-06-21.
   Per-page accent + hero treatment set via inline <style>.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Epilogue:wght@500;600;700;800&family=Poppins:wght@300;400;500;600&family=Pacifico&display=swap');

:root{
  --teal:#3AA8C1;
  --teal-dk:#2C8298;
  --ink:#1B2227;
  --night:#10171C;
  --night-2:#1c2a33;
  --cream:#F6F3EC;
  --paper:#FFFFFF;
  --muted:#5f6b72;
  --line:#e7e1d6;
  --accent:var(--teal);          /* overridden per version */
  --hero-a:#16242c;              /* overridden per version */
  --hero-b:#0c1418;
  --maxw:1080px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:'Poppins',-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;
  font-weight:400; font-size:17px; line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{ font-family:'Epilogue',system-ui,sans-serif; line-height:1.1; margin:0 0 .4em; color:var(--ink); letter-spacing:-.01em; }
h1{ font-size:clamp(2.4rem,6vw,4.2rem); font-weight:800; }
h2{ font-size:clamp(1.7rem,3.6vw,2.7rem); font-weight:700; }
h3{ font-size:1.25rem; font-weight:600; }
p{ margin:0 0 1rem; }
a{ color:var(--teal-dk); }
strong{ color:var(--ink); font-weight:600; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.tight{ max-width:760px; }

/* ---- buttons ---- */
.btn{ display:inline-block; font-family:'Epilogue',serif; font-weight:600; font-size:1.02rem;
  padding:16px 30px; border-radius:999px; text-decoration:none; cursor:pointer; border:2px solid transparent;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease; }
.btn-primary{ background:var(--accent); color:#fff; box-shadow:0 8px 24px -8px var(--accent); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 32px -10px var(--accent); }
.btn-ghost{ background:transparent; border-color:rgba(255,255,255,.6); color:#fff; }
.btn-ghost:hover{ background:rgba(255,255,255,.12); }
.btn-ghost.on-light{ border-color:var(--ink); color:var(--ink); }
.btn-ghost.on-light:hover{ background:rgba(0,0,0,.05); }
.cta-row{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

/* ---- scarcity pill ---- */
.pill{ display:inline-flex; align-items:center; gap:9px; font-family:'Epilogue',serif; font-weight:600;
  font-size:.86rem; letter-spacing:.04em; text-transform:uppercase; padding:8px 16px; border-radius:999px;
  background:rgba(255,255,255,.14); color:#fff; border:1px solid rgba(255,255,255,.28); }
.pill .dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 35%, transparent); }

/* ---- hero ---- */
.hero{ position:relative; color:#fff; min-height:92vh; display:flex; align-items:center;
  background:linear-gradient(160deg,var(--hero-a),var(--hero-b)); overflow:hidden; }
.hero::after{ /* subtle image slot texture */ content:""; position:absolute; inset:0;
  background:radial-gradient(120% 80% at 78% 18%, color-mix(in srgb,var(--accent) 26%, transparent), transparent 60%); opacity:.9; }
.hero .wrap{ position:relative; z-index:2; padding-top:90px; padding-bottom:90px; }
.hero h1{ color:#fff; max-width:16ch; }
.hero .sub{ font-size:clamp(1.05rem,2vw,1.3rem); max-width:46ch; color:rgba(255,255,255,.9); margin-top:.6rem; }
.hero .eyebrow{ font-family:'Epilogue',serif; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  font-size:.8rem; color:var(--accent); margin-bottom:18px; }
.hero .cta-row{ margin-top:28px; }
.hero .meta{ margin-top:26px; font-size:.92rem; color:rgba(255,255,255,.72); }

/* ---- sections ---- */
section{ padding:84px 0; }
.section-cream{ background:var(--cream); }
.section-night{ background:var(--night); color:#e9eef1; }
.section-night h2,.section-night h3{ color:#fff; }
.section-night p{ color:rgba(233,238,241,.84); }
.eyebrow-dark{ font-family:'Epilogue',serif; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  font-size:.8rem; color:var(--teal-dk); margin-bottom:14px; }
.lead{ font-size:clamp(1.2rem,2.4vw,1.6rem); line-height:1.45; font-family:'Epilogue',serif; font-weight:500; }

/* ---- image art-direction slots ---- */
.imgslot{ position:relative; border-radius:14px; min-height:300px; display:flex; align-items:flex-end;
  background:linear-gradient(150deg,var(--night-2),#0e1519); border:1px dashed rgba(58,168,193,.5);
  color:rgba(255,255,255,.82); overflow:hidden; }
.imgslot::before{ content:"◍ IMAGE"; position:absolute; top:12px; left:14px; font-family:'Epilogue',serif;
  font-size:.7rem; letter-spacing:.18em; color:var(--accent); opacity:.9; }
.imgslot .cap{ font-size:.82rem; line-height:1.4; padding:16px 18px; background:linear-gradient(0deg,rgba(0,0,0,.55),transparent); width:100%; }
.imgslot.tall{ min-height:460px; }
.imgslot.wide{ min-height:240px; }

/* ---- grids ---- */
.grid{ display:grid; gap:24px; }
.grid-2{ grid-template-columns:1fr 1fr; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
.card{ background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:26px; }
.section-cream .card{ background:#fff; }
.card h3{ margin-bottom:.3rem; }
.card .num{ font-family:'Epilogue',serif; font-weight:800; font-size:1.1rem; color:var(--accent); }

/* ---- carry-home beats ---- */
.beat{ border-left:3px solid var(--accent); padding:4px 0 4px 20px; }
.beat h3{ font-size:1.15rem; }
.beat .q{ font-style:italic; color:var(--muted); font-size:.95rem; }

/* ---- testimonials ---- */
.quote{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:28px; position:relative; }
.section-cream .quote{ background:var(--paper); }
.quote::before{ content:"\201C"; font-family:'Epilogue',serif; font-size:3.4rem; color:var(--accent); line-height:.6; }
.quote p{ font-size:1.05rem; }
.quote .slotnote{ display:block; margin-top:10px; font-size:.78rem; color:#b08900; background:#fff7e0;
  border:1px solid #f0e0a8; border-radius:8px; padding:7px 10px; }
.quote .who{ font-family:'Epilogue',serif; font-weight:600; color:var(--ink); font-size:.95rem; }

/* ---- for-you-if ---- */
.fit{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.fit .col{ border-radius:14px; padding:28px; }
.fit .yes{ background:color-mix(in srgb,var(--teal) 10%, #fff); border:1px solid color-mix(in srgb,var(--teal) 35%,#fff); }
.fit .no{ background:#faf7f2; border:1px solid var(--line); }
.fit ul{ list-style:none; margin:0; padding:0; }
.fit li{ padding:8px 0 8px 30px; position:relative; }
.fit .yes li::before{ content:"✓"; position:absolute; left:0; color:var(--teal-dk); font-weight:700; }
.fit .no li::before{ content:"—"; position:absolute; left:0; color:var(--muted); }

/* ---- included list ---- */
.incl{ columns:2; column-gap:40px; }
.incl li{ break-inside:avoid; margin-bottom:10px; }

/* ---- hosts ---- */
.host{ text-align:center; }
.host .imgslot{ border-radius:14px; aspect-ratio:4/5; min-height:0; margin:0 0 16px; }

/* ---- price band ---- */
.price{ text-align:center; }
.price .fig{ font-family:'Epilogue',serif; font-weight:800; font-size:clamp(2rem,5vw,3.2rem); color:#fff; }
.price .note{ color:rgba(255,255,255,.7); font-size:.95rem; }

/* ---- FAQ ---- */
.faq details{ border-bottom:1px solid var(--line); padding:18px 0; }
.faq summary{ font-family:'Epilogue',serif; font-weight:600; font-size:1.12rem; cursor:pointer; list-style:none;
  display:flex; justify-content:space-between; gap:16px; align-items:center; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; color:var(--accent); font-size:1.5rem; line-height:1; }
.faq details[open] summary::after{ content:"–"; }
.faq details[open] summary{ margin-bottom:12px; }

/* ---- final cta / capture ---- */
.capture{ display:flex; gap:12px; flex-wrap:wrap; max-width:520px; }
.capture input{ flex:1; min-width:220px; padding:15px 18px; border-radius:999px; border:1px solid var(--line);
  font-family:'Poppins',sans-serif; font-size:1rem; }

/* ---- concept banner (review aid; not part of final page) ---- */
.concept-bar{ background:var(--accent); color:#fff; font-family:'Epilogue',serif; font-weight:600;
  font-size:.85rem; text-align:center; padding:8px 16px; letter-spacing:.02em; }
.concept-bar a{ color:#fff; text-decoration:underline; }

/* ---- footer ---- */
footer{ background:var(--night); color:rgba(255,255,255,.66); padding:48px 0; font-size:.9rem; }
footer .logo{ font-family:'Epilogue',serif; font-weight:800; color:#fff; font-size:1.2rem; }

/* ---- responsive ---- */
/* ---- gallery (flood of imagery) ---- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:172px; gap:14px; }
.gallery .imgslot{ min-height:0; height:100%; border-radius:12px; }
.gallery .g-wide{ grid-column:span 2; }
.gallery .g-tall{ grid-row:span 2; }
.gallery .imgslot .cap{ font-size:.78rem; }

/* ---- inline section image strip ---- */
.imgstrip{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:30px; }
.imgstrip .imgslot{ min-height:200px; border-radius:12px; }

/* ---- real image fill ---- */
.imgslot.has-img{ border:0; background:#0e1519; }
.imgslot.has-img::before{ display:none; }
.imgslot img.ph{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.imgslot.has-img .cap{ position:relative; z-index:2; }

@media (max-width:820px){
  .grid-2,.grid-3,.grid-4,.fit{ grid-template-columns:1fr; }
  .incl{ columns:1; }
  section{ padding:60px 0; }
  .hero{ min-height:auto; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:140px; }
  .gallery .g-tall{ grid-row:span 1; }
  .imgstrip{ grid-template-columns:1fr; }
}

/* ---- hero background video (V3) ---- */
.hero-vid{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.hero-scrim{ position:absolute; inset:0; z-index:1; background:linear-gradient(155deg,rgba(8,16,18,.42),rgba(8,16,18,.78)); }
@media (prefers-reduced-motion: reduce){ .hero-vid{ display:none; } }

/* ---- fix: cards inside dark sections (accommodations room tiers) ---- */
.section-night .card{ background:#fff; }
.section-night .card h3{ color:var(--ink); }
.section-night .card p{ color:var(--muted); }

/* ---- Iceland script accent (mirrors her flyer wordmark) ---- */
.iceland-script{ font-family:'Pacifico', cursive; text-transform:none; letter-spacing:0;
  font-size:1.75em; line-height:1; color:var(--accent); display:inline-block;
  vertical-align:-.18em; margin-right:.12em; font-weight:400; }

/* ---- design-review polish ---- */
:root{ --teal-dk:#226A7C; }                 /* darker for AA contrast on eyebrows/links */
.imgslot .cap{ background:linear-gradient(0deg,rgba(0,0,0,.82),rgba(0,0,0,.18) 62%,transparent); text-shadow:0 1px 3px rgba(0,0,0,.55); }
.gallery{ grid-auto-flow:dense; }           /* backfill the orphan cell */
.hero .btn-primary{ font-size:1.08rem; padding:18px 34px; }   /* primary CTA dominates */

/* ---- sticky consult CTA ---- */
.sticky-cta{ position:fixed; left:0; right:0; bottom:0; z-index:60; display:flex; gap:18px; align-items:center; justify-content:center;
  padding:12px 20px; background:rgba(16,23,28,.96); backdrop-filter:blur(6px); border-top:1px solid rgba(255,255,255,.12);
  transform:translateY(120%); transition:transform .3s ease; }
.sticky-cta.show{ transform:none; }
.sticky-cta .sc-txt{ color:#fff; font-family:'Epilogue',serif; font-weight:600; font-size:.95rem; }
.sticky-cta .btn-primary{ padding:11px 22px; font-size:.98rem; box-shadow:none; }
@media (max-width:600px){ .sticky-cta .sc-txt{ display:none; } .sticky-cta .btn-primary{ width:100%; text-align:center; } }
/* ---- featured room tier ---- */
.card.featured{ border:2px solid var(--teal); position:relative; }
.card .badge{ position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--teal); color:#fff;
  font-family:'Epilogue',serif; font-weight:700; font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; padding:4px 12px; border-radius:999px; white-space:nowrap; }
/* ---- host photo stopgap grade (unify casts; real fix = reshoot/grade) ---- */
.host .imgslot img.ph{ filter:saturate(.82) contrast(1.03); }

/* ============ PREMIUM POLISH PASS (design review) ============ */
section{ padding:104px 0; }
.lead{ font-size:clamp(1.35rem,2.7vw,1.9rem); }
.card{ border-color:transparent; box-shadow:0 12px 34px -18px rgba(16,23,28,.28); transition:transform .2s ease, box-shadow .2s ease; }
.card:hover, .quote:hover{ transform:translateY(-3px); box-shadow:0 20px 46px -20px rgba(16,23,28,.34); }
.card .num{ font-size:1.15rem; color:var(--teal-dk); margin-top:6px; }
.gallery .imgslot{ transition:transform .25s ease; }
.gallery .imgslot:hover{ transform:scale(1.012); }
.hero{ align-items:flex-end; }
.hero-scrim{ background:linear-gradient(165deg, rgba(8,16,18,.22) 0%, rgba(8,16,18,.5) 52%, rgba(8,16,18,.82) 100%); }
.hero-vid{ animation:kenburns 22s ease-in-out infinite alternate; }
@keyframes kenburns{ from{ transform:scale(1); } to{ transform:scale(1.07); } }
@media (prefers-reduced-motion: reduce){ .hero-vid{ animation:none; } }
.site-nav{ position:absolute; top:0; left:0; right:0; z-index:5; display:flex; align-items:center; justify-content:space-between; padding:20px 26px; }
.site-nav .nav-logo{ font-family:'Epilogue',system-ui,sans-serif; font-weight:800; color:#fff; text-decoration:none; font-size:1.05rem; }
.site-nav .nav-cta{ padding:10px 20px; font-size:.92rem; box-shadow:none; }
.hero-reassure{ margin-top:22px; font-size:.95rem; color:rgba(255,255,255,.85); }
.reassure-line{ margin-top:14px; font-size:.92rem; color:rgba(255,255,255,.82); max-width:62ch; margin-left:auto; margin-right:auto; }
.sticky-cta{ border-top:2px solid var(--teal); }
body.reveal-on section{ opacity:0; transform:translateY(18px); }
body.reveal-on section.in{ opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease; }
@media (max-width:600px){ .site-nav{ padding:14px 16px; } .site-nav .nav-logo{ font-size:.95rem; } }

/* ---- trust band (early proof) ---- */
.trustband{ display:flex; flex-wrap:wrap; gap:30px; align-items:center; justify-content:space-between; }
.tb-hosts{ display:flex; gap:22px; flex-wrap:wrap; }
.tb-host{ display:flex; align-items:center; gap:10px; }
.tb-host img{ width:54px; height:54px; border-radius:10px; object-fit:cover; }
.tb-host strong{ display:block; font-family:'Epilogue',system-ui,sans-serif; font-size:.95rem; color:var(--ink); }
.tb-host span{ font-size:.8rem; color:var(--muted); }
.tb-quote{ flex:1; min-width:300px; margin:0; font-family:'Epilogue',system-ui,sans-serif; font-style:italic; font-size:1.05rem; color:var(--ink); border-left:3px solid var(--teal); padding-left:18px; }
.tb-quote cite{ display:block; font-style:normal; font-size:.82rem; color:var(--muted); margin-top:8px; }
/* ---- day-by-day ---- */
.weeklist{ margin-top:22px; padding-left:0; list-style:none; }
.weeklist li{ padding:13px 0; border-bottom:1px solid var(--line); font-size:1rem; }
.weeklist b{ color:var(--ink); }
