/* ============================================================
   Bad Girls of Butte — Hi-Fi System
   Warm paper + wine + dark teal + sparing gold.
   Fraunces (display) / Alegreya Sans (text).
   ============================================================ */

:root{
  --paper:   #f5efe6;
  --paper-2: #ece2d3;   /* alt band */
  --paper-3: #e3d7c4;   /* deeper cream for slots */
  --ink:     #261c17;
  --ink-soft:#6a5d51;
  --line:    #d8ccb7;
  --line-2:  #c9bca4;
  --dark:    #003943;   /* dark teal */
  --dark-2:  #002a32;
  --dark-line:#1d4f59;
  --accent:  #782d3e;   /* wine */
  --accent-d:#5e2230;
  --gold:    #e2a31d;
  --radius:  4px;
  --maxw:    1180px;
}

*{ box-sizing:border-box; }
html,body{ margin:0; }
body{
  background:var(--paper);
  color:var(--ink);
  font-family:"Alegreya Sans", system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
}

/* ---------- Stage / device (query container) ---------- */
.stage{ display:block; }
.device{
  background:var(--paper);
  width:100%;
  container-type:inline-size;
  overflow-x:clip;   /* clip horizontal overflow without becoming a scroll container, so position:sticky still works on descendants (e.g. .sticky-tix) */
  position:relative;
}

/* ---------- Layout primitives ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 64px; }
@container (max-width:520px){ .wrap{ padding:0 24px; } }

section{ padding:78px 0; }
@container (max-width:520px){ section{ padding:46px 0; } }

.eyebrow{
  font:600 11px/1 "Alegreya Sans",sans-serif;
  letter-spacing:.24em; text-transform:uppercase; color:var(--accent);
  margin:0 0 16px; display:flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--accent); display:inline-block; }
.eyebrow.center{ justify-content:center; }

h1,h2,h3,h4{ font-family:"Fraunces",serif; color:var(--ink); margin:0; font-weight:560; line-height:1.03; letter-spacing:-.012em; }
h1{ font-size:clamp(36px,6.2cqi,72px); }
h2{ font-size:clamp(27px,4.4cqi,44px); }
h3{ font-size:21px; }
.kicker{ font-family:"Fraunces"; }

p{ font-size:16.5px; line-height:1.62; color:var(--ink-soft); margin:15px 0 0; max-width:62ch; }
p.lede{ font-size:20px; line-height:1.5; color:#41382f; max-width:56ch; }
p strong{ color:var(--ink); font-weight:600; }
@container (max-width:520px){ p{ font-size:15.5px; } p.lede{ font-size:18px; } }

.muted{ color:var(--ink-soft); }

/* ---------- Photo slots ---------- */
.ph{
  position:relative; overflow:hidden;
  background-color:var(--paper-3);
  background-image:
    linear-gradient(150deg, rgba(120,45,62,.09), rgba(0,57,67,.11)),
    repeating-linear-gradient(135deg,transparent 0 12px,rgba(0,0,0,.035) 12px 13px);
  border:1px solid var(--line-2); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center; text-align:center;
  min-height:140px; color:#7c7160;
}
.ph span{
  font:500 11px/1.55 ui-monospace,"Courier New",monospace;
  letter-spacing:.05em; text-transform:uppercase; padding:0 20px; max-width:34ch;
  position:relative; z-index:1;
}
.ph.archival{ background-image:linear-gradient(155deg, rgba(0,57,67,.55), rgba(120,45,62,.45)); color:#e8dcc6; }
.ph.archival span{ color:#efe3cd; }
.ph.night{ background-image:linear-gradient(160deg,#0a2b32,#1a1320); color:#cdbfa8; }
.ph.round{ border-radius:50%; }

/* filled photo slots (real images) */
.ph.filled{ background:#1c1915; }
.ph.filled span{ display:none; }
.ph.filled img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.ph.filled.tint::after{ display:block; content:""; position:absolute; inset:0; background:linear-gradient(160deg, rgba(0,57,67,.18), rgba(120,45,62,.26)); }
.ph.filled.night-tint::after{ display:block; content:""; position:absolute; inset:0; background:linear-gradient(160deg, rgba(0,20,28,.4), rgba(10,8,14,.55)); }
.ph.round.zoom img{ transform:scale(1.7); transform-origin:55% 30%; }

/* Taller tour-card images: +50% desktop, +25% mobile */
.card.tour > .ph{ min-height:285px; }
@container (max-width:520px){ .card.tour > .ph{ min-height:238px; } }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font:600 14.5px/1 "Alegreya Sans",sans-serif;
  padding:14px 24px; border-radius:var(--radius); cursor:pointer;
  border:1.5px solid var(--accent); color:#fff; background:var(--accent);
  transition:transform .14s ease, background .14s ease, box-shadow .14s ease;
  text-decoration:none;
}
.btn:hover{ background:var(--accent-d); transform:translateY(-1px); box-shadow:0 8px 20px rgba(94,34,48,.28); }
.btn .ext{ font-size:11px; opacity:.85; }
.btn.ghost{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn.ghost:hover{ background:rgba(38,28,23,.06); color:var(--ink); box-shadow:none; }
.btn.lg{ padding:17px 30px; font-size:15.5px; }
.btn.gold{ background:var(--gold); border-color:var(--gold); color:#2a1d05; }
.btn.gold:hover{ background:#cf9112; box-shadow:0 8px 20px rgba(226,163,29,.3); }

.chip{ display:inline-flex; align-items:center; gap:7px; font:500 12.5px/1 "Alegreya Sans"; color:var(--ink-soft);
  border:1px solid var(--line-2); border-radius:999px; padding:8px 13px; background:var(--paper); white-space:nowrap; }

/* ---------- Forms ---------- */
.wf-input{ flex:1; min-width:0; font:400 15.5px "Alegreya Sans",sans-serif; padding:13px 15px;
  border:1.5px solid var(--line-2); border-radius:var(--radius); background:#fbf7f0; color:var(--ink); transition:border-color .15s; }
.wf-input:focus{ outline:none; border-color:var(--accent); }
.wf-input::placeholder{ color:#a89e8c; }
.field-label{ display:block; font:600 12px/1 "Alegreya Sans",sans-serif; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:9px; }
textarea.wf-input{ width:100%; resize:vertical; min-height:150px; line-height:1.5; }
.link-out{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; font-weight:500; transition:color .12s; }
.link-out:hover{ color:var(--accent-d); }

.rule{ height:1px; background:var(--line); border:0; margin:0; }

/* inline form status (newsletter / contact) */
.form-status{ margin:16px 0 0; font:600 15.5px/1.5 "Alegreya Sans",sans-serif; color:var(--accent); }
.form-status.is-error{ color:#b3392b; }
.form-status[hidden]{ display:none; }

/* ---------- Header / nav ---------- */
.topbar{ display:flex; align-items:center; gap:20px; padding:20px 0; }
.wordmark{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.wordmark img{ height:46px; width:auto; display:block; }
.wordmark .wm-txt{ font-family:"Fraunces",serif; font-weight:600; font-size:19px; color:var(--ink); line-height:1; }
.navlinks{ display:flex; gap:26px; }
.navlinks a, .navlinks span{ font-size:14.5px; color:var(--ink-soft); text-decoration:none; cursor:pointer; transition:color .12s; position:relative; }
.navlinks a:hover, .navlinks span:hover{ color:var(--ink); }
.navlinks .here{ color:var(--accent); }
@container (max-width:640px){ .navlinks{ display:none; } }
.backlink{ font-size:13.5px; color:var(--ink-soft); text-decoration:none; cursor:pointer; }
.backlink:hover{ color:var(--ink); }

/* ---------- Grid helpers ---------- */
.grid{ display:grid; gap:28px; }
.cols-2{ grid-template-columns:1fr 1fr; }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
@container (max-width:760px){ .cols-3,.cols-4{ grid-template-columns:1fr 1fr; } }
@container (max-width:520px){ .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; } }

/* ---------- Cards ---------- */
.card{ border:1px solid var(--line-2); border-radius:var(--radius); padding:26px; background:#fbf7f0; }
.card.soft{ background:var(--paper-2); }
.card.dark{ background:var(--dark); border-color:var(--dark-line); color:#e8e1cf; }
.card.dark h2,.card.dark h3{ color:#f5efdd; }
.card.dark p{ color:#b3aa95; }
.card.dark .eyebrow{ color:var(--gold); }
.card.dark .eyebrow::before{ background:var(--gold); }

/* tour funnel cards */
.tour{ display:flex; flex-direction:column; gap:18px; padding:0; overflow:hidden; }
.tour .tour-body{ padding:26px 28px 30px; display:flex; flex-direction:column; gap:14px; }
.tour .meta{ display:flex; gap:8px; flex-wrap:wrap; }
.tour .ph{ border-radius:0; border-left:0; border-right:0; border-top:0; }
.tour.dark{ background:var(--dark); border-color:var(--dark-line); }
.tour.dark h3{ color:#f5efdd; }
.tour.dark p{ color:#b3aa95; }
.tour.dark .chip{ background:transparent; color:#cbc3b0; border-color:#3a5860; }
.tour .btn{ align-self:flex-start; }

/* ---------- FAQ ---------- */
.faq dt{ font-family:"Fraunces",serif; font-size:19px; padding:20px 0 6px; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:18px; color:var(--ink); cursor:default; }
.faq dt::after{ content:"+"; color:var(--accent); font-family:"Alegreya Sans"; font-weight:600; }
.faq dd{ margin:0 0 6px; }
.faq dd p{ margin-top:4px; }

/* ---------- Quotes ---------- */
.quote{ border-left:3px solid var(--accent); padding:4px 0 4px 22px; }
.quote q{ font-family:"Fraunces",serif; font-size:21px; line-height:1.32; color:var(--ink); font-style:italic; quotes:"“" "”"; }
.quote cite{ display:block; margin-top:12px; font:500 12px/1 "Alegreya Sans"; letter-spacing:.06em; color:var(--ink-soft); font-style:normal; text-transform:uppercase; }
.quote.lg q{ font-size:25px; }

/* ---------- Footer ---------- */
.foot{ background:var(--dark); color:#cbc3b0; padding:56px 0 48px; }
.foot h3{ color:#efe7d5; }
.foot p{ color:#9b9381; }
.foot .fhead{ font:600 12px/1 "Alegreya Sans",sans-serif; letter-spacing:.14em; text-transform:uppercase; color:#7d7666; margin-bottom:16px; }
.foot .fnav{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.foot .fnav a{ color:#cbc3b0; text-decoration:none; font-size:14.5px; transition:color .12s; cursor:pointer; }
.foot .fnav a:hover{ color:#efe7d5; }
.foot .link-out{ color:var(--gold); }
.foot .link-out:hover{ color:#f2bb47; }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr auto; gap:38px; align-items:start; }
.foot-wm{ display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.foot-wm img{ height:40px; width:auto; }
@container (max-width:760px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:30px 38px; } .foot-grid > div:last-child{ grid-column:1 / -1; justify-self:start !important; text-align:left !important; } }
@container (max-width:440px){ .foot-grid{ grid-template-columns:1fr; gap:28px; } }

/* ---------- Sticky tickets ---------- */
.sticky-tix{
  position:sticky; bottom:0; z-index:20;
  display:flex; align-items:center; gap:16px;
  padding:14px 64px; background:rgba(28,25,21,.97); color:#efe7d5;
  border-top:1px solid #000; backdrop-filter:blur(6px);
}
.sticky-tix .t{ font-family:"Fraunces",serif; font-size:18px; }
.sticky-tix .s{ font-size:12.5px; color:#a89f8b; }
.sticky-tix .spacer{ flex:1; }
@container (max-width:520px){ .sticky-tix{ padding:12px 24px; } .sticky-tix .s{ display:none; } }

/* ---------- Hero helpers ---------- */
.hero{ padding-top:48px; }
.hero .index{ font-family:"Fraunces"; font-weight:560; color:var(--line-2); font-size:15px; }
.hero-figure{ position:relative; }
.hero-figure .stamp{
  position:absolute; right:-10px; bottom:-14px; width:128px; height:auto; z-index:3;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.28));
}
@container (max-width:520px){ .hero-figure .stamp{ width:92px; right:6px; } }

/* detail body */
.detail-body{ display:grid; grid-template-columns:1.55fr 1fr; gap:50px; align-items:start; }
@container (max-width:640px){ .detail-body{ grid-template-columns:1fr; gap:30px; } }
.factlist{ margin:6px 0 0; }
.factlist > div{ display:flex; justify-content:space-between; gap:14px; padding:11px 0; border-bottom:1px solid var(--line); }
.factlist > div:last-child{ border-bottom:0; }
.factlist dt{ color:var(--ink-soft); font-size:14px; }
.factlist dd{ margin:0; font-family:"Fraunces",serif; font-size:15px; }

/* itinerary timeline */
.timeline{ position:relative; margin-top:26px; padding-left:32px; }
.timeline::before{ content:""; position:absolute; left:7px; top:8px; bottom:8px; width:2px; background:var(--line-2); }
.stop{ position:relative; padding:0 0 30px; }
.stop::before{ content:""; position:absolute; left:-32px; top:24px; width:16px; height:16px; border-radius:50%; background:var(--paper); border:2px solid var(--accent); }
.stop:last-child{ padding-bottom:0; }
.stop .time{ font:600 12px/1 "Alegreya Sans",sans-serif; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.stop h3{ font-size:20px; margin:7px 0 0; }
.stop p{ margin-top:5px; }
.timeline.on-dark::before{ background:var(--dark-line); }
.timeline.on-dark .stop::before{ background:var(--dark); border-color:var(--gold); }
.timeline.on-dark .stop .time{ color:var(--gold); }
.timeline.on-dark .stop h3{ color:#f5efdd; }
.timeline.on-dark .stop p{ color:#b3aa95; }

/* pricing */
.price{ border:1px solid var(--line-2); border-radius:var(--radius); padding:26px; background:#fbf7f0; display:flex; flex-direction:column; gap:8px; }
.price .amt{ font-family:"Fraunces",serif; font-size:42px; line-height:1; color:var(--ink); }
.price .amt small{ font-size:15px; color:var(--ink-soft); font-family:"Alegreya Sans"; }
.price p{ margin:2px 0 0; font-size:15px; }
.price.feature{ border-color:var(--accent); border-width:2px; position:relative; }
.price .tag{ align-self:flex-start; font:600 10px/1 "Alegreya Sans"; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:2px; }
.price .btn{ align-self:flex-start; margin-top:8px; }

/* hero subtitle (full brand title) */
.subtitle{ font-family:"Fraunces",serif; font-style:italic; font-weight:500; color:var(--accent); font-size:clamp(20px,2.6cqi,28px); margin:10px 0 0; line-height:1.1; }
.subtitle.on-dark{ color:var(--gold); }

/* season ribbon chip */
.season{ display:inline-flex; align-items:center; gap:8px; font:600 11.5px/1 "Alegreya Sans"; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); background:rgba(120,45,62,.08); border:1px solid rgba(120,45,62,.22); padding:7px 12px; border-radius:999px; }
.season .dot{ width:7px; height:7px; border-radius:50%; background:var(--gold); }

/* After Dark "three ways" experience cards */
.ways{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@container (max-width:640px){ .ways{ grid-template-columns:1fr; } }
.way{ display:flex; flex-direction:column; gap:14px; border:1px solid var(--dark-line); border-radius:var(--radius); background:var(--dark-2); padding:30px; color:#e8e1cf; }
.way.feature{ grid-column:1 / -1; border-color:var(--gold); border-width:1.5px; }
.way .way-top{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.way .tag{ font:600 10px/1 "Alegreya Sans"; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
.way h3{ color:#f5efdd; font-size:25px; margin-top:4px; }
.way .price-amt{ font-family:"Fraunces",serif; font-size:34px; color:#f5efdd; line-height:1; white-space:nowrap; }
.way .price-amt small{ font-size:14px; color:#9b9381; font-family:"Alegreya Sans"; }
.way p{ color:#b8af9a; }
.way .meta{ display:flex; gap:8px; flex-wrap:wrap; }
.way .chip{ background:transparent; color:#cbc3b0; border-color:#3a5860; }
.way .route{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; font:500 13.5px/1.3 "Alegreya Sans"; color:#cdbfa8; padding:13px 0 2px; border-top:1px solid var(--dark-line); }
.way .route .stopn{ color:#f1ead8; }
.way .route .arr{ color:var(--gold); font-size:12px; }
.way .lead{ font-size:14px; color:#9b9381; }
.way .lead b{ color:#e8dcc6; font-weight:600; }
.way .btn{ align-self:flex-start; margin-top:4px; }
.way.feature .feat-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
@container (max-width:640px){ .way.feature .feat-grid{ grid-template-columns:1fr; gap:18px; } }
.way .splitnote{ font-size:13.5px; color:#cdbfa8; background:rgba(226,163,29,.08); border-left:2px solid var(--gold); padding:10px 14px; border-radius:0 3px 3px 0; }

/* people / leaders */
.people{ display:grid; grid-template-columns:1fr 1fr; gap:34px; }
@container (max-width:640px){ .people{ grid-template-columns:1fr; gap:26px; } }
.person{ display:flex; gap:20px; align-items:flex-start; }
.person .ph{ flex:0 0 110px; width:110px; height:110px; min-height:0; }
.person .role{ font:600 11px/1 "Alegreya Sans"; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin:0 0 6px; }
.person h3{ font-size:22px; }

/* big 404 */
.bignum{ font-family:"Fraunces",serif; font-weight:560; line-height:.86; letter-spacing:-.02em;
  font-size:clamp(120px,28cqi,280px); color:var(--accent); margin:8px 0 6px; }
.bignum span{ color:var(--gold); }
