/* ============================================================
   Boomtown Bartenders — Landing page styles
   Extracted from inline <style> in boomtown/index.html (WO-037)
   ============================================================ */
:root {
  --crude:  #15120E;
  --crude-2:#1E1A14;
  --crude-3:#26211A;
  --canvas: #ECE3D1;
  --canvas-2:#CFC6B4;
  --gold:   #DE9E2C;
  --gold-2: #F2BB55;
  --gold-soft: rgba(222,158,44,0.14);
  --steel:  #44484A;
  --steel-2:#33363A;
  --rust:   #BC4A22;
  --muted:  #8C8576;
  --muted-2:#6E685C;
  --line:   rgba(236,227,209,0.13);
  --line-2: rgba(236,227,209,0.07);
  --disp:   'Anton', 'Oswald', 'Arial Narrow', sans-serif;
  --sans:   'Space Grotesk', 'Poppins', system-ui, sans-serif;
  --shadow: 0 18px 40px -18px rgba(0,0,0,.6);
  --shadow-lg: 0 32px 64px -22px rgba(0,0,0,.7);
  --r-sm: 6px; --r: 10px; --r-lg: 14px; --r-xl: 18px;

  /* Brand kit --bt-* aliases (see BrandKit_Boomtown/tokens.css) */
  --bt-crude: var(--crude); --bt-crude-2: var(--crude-2); --bt-canvas: var(--canvas);
  --bt-gold: var(--gold); --bt-gold-2: var(--gold-2); --bt-gold-soft: var(--gold-soft);
  --bt-steel: var(--steel); --bt-rust: var(--rust); --bt-muted: var(--muted);
  --bt-disp: var(--disp); --bt-sans: var(--sans);
  --bt-r-sm: var(--r-sm); --bt-r: var(--r); --bt-r-lg: var(--r-lg); --bt-r-xl: var(--r-xl);
}
html { scroll-behavior: smooth; }
body { background: var(--crude); color: var(--canvas); font-family: var(--sans); line-height: 1.55; -webkit-font-smoothing: antialiased; margin: 0; }
h1,h2,h3,h4 { margin: 0; font-weight: 400; }
a { color: inherit; text-decoration: none; }
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 40px; }
.eyebrow { font-family: var(--sans); font-size: 11px; font-weight: 700; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); }
.badge-top, .badge-bot { font-family: var(--sans); font-weight: 600; letter-spacing: 0.14em; }

/* Nav */
.site-nav { position: sticky; top: 0; z-index: 30; background: rgba(21,18,14,0.9); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.site-nav .inner { max-width: 1120px; margin: 0 auto; padding: 13px 40px; display: flex; align-items: center; gap: 16px; }
.site-nav .brand { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.site-nav .nm { font-family: var(--disp); font-size: 19px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--canvas); }
.site-nav .links { display: flex; gap: 20px; }
.site-nav .links a { font-size: 12px; font-weight: 500; color: var(--muted); letter-spacing: 0.03em; transition: color .15s; }
.site-nav .links a:hover { color: var(--canvas); }
.site-nav .sp { flex: 1; }
.btn-primary { font-family: var(--sans); font-weight: 600; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; background: var(--gold); color: var(--crude); padding: 10px 18px; border-radius: var(--r-sm); border: none; cursor: pointer; transition: background .15s, transform .15s; display: inline-flex; align-items: center; gap: 6px; }
.btn-primary:hover { background: var(--gold-2); transform: translateY(-1px); }
.btn-primary:active { transform: scale(.985); }
.btn-primary:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }
.btn-ghost:focus-visible { outline: 2px solid var(--canvas); outline-offset: 2px; }
a:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; border-radius: 4px; }
.cross-card:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }
#travelZip:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(222,158,44,.25); }
.btn-ghost { font-family: var(--sans); font-weight: 500; font-size: 13px; color: var(--muted); background: none; border: 1px solid var(--line); padding: 10px 18px; border-radius: var(--r-sm); cursor: pointer; transition: color .15s, transform .15s; }
.btn-ghost:hover { color: var(--canvas); }
.btn-ghost:active { transform: scale(.985); }

/* Hero */
.hero { text-align: center; padding: 80px 0 78px; position: relative; overflow: hidden; }
.hero::before { content:''; position:absolute; inset:0; background: radial-gradient(60% 80% at 50% -10%, rgba(222,158,44,0.14), transparent 60%); pointer-events:none; }
.hero .lockup { position: relative; display: inline-flex; flex-direction: column; align-items: center; gap: 26px; }
.hero .word { font-family: var(--disp); font-size: clamp(58px, 11vw, 132px); line-height: 0.86; letter-spacing: 0.01em; text-transform: uppercase; }
.hero .sub-line { display:flex; align-items:center; gap:16px; justify-content:center; margin-top: 14px; }
.hero .sub-line span { font-family: var(--sans); font-weight: 600; letter-spacing: 0.5em; text-transform: uppercase; font-size: clamp(11px,1.6vw,15px); color: var(--gold); padding-left: 0.5em; }
.hero .sub-line i { height:1px; width:42px; background: var(--line); display:block; }
.hero .tag { font-family: var(--disp); text-transform: uppercase; font-size: clamp(20px,3vw,32px); margin: 38px 0 0; letter-spacing: 0.01em; text-wrap: balance; }
.hero h1 { text-wrap: balance; }
.hero .tag b { color: var(--gold); }
.hero .lede { font-size: 15.5px; color: var(--muted); margin: 16px auto 0; max-width: 470px; text-wrap: balance; }
.hero .stamp { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-top: 30px; }
.hero-actions { display: flex; gap: 12px; justify-content: center; margin-top: 32px; flex-wrap: wrap; }
.hero-actions svg { width: 16px; height: 16px; }
.chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 9px; margin-top: 28px; }
.chip { font-size: 11px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--canvas); border: 1px solid var(--line); border-radius: 4px; padding: 7px 14px; }

/* Sections */
.band { padding: 80px 0; border-top: 1px solid var(--line); }
.band.canvas-bg { background: var(--crude-2); }
.sec-head { text-align: center; max-width: 580px; margin: 0 auto 48px; }
.sec-head h2 { font-family: var(--disp); font-size: clamp(28px, 4vw, 42px); text-transform: uppercase; margin-top: 12px; text-wrap: balance; }
.sec-head p { font-size: 15px; color: var(--muted); margin-top: 12px; text-wrap: balance; }

/* Features */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
@media (max-width: 768px) { .feature-grid { grid-template-columns: 1fr; } }
.feature { background: var(--crude-2); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 32px; transition: transform .2s, box-shadow .2s; }
.feature:hover { transform: translateY(-2px); box-shadow: 0 12px 28px -10px rgba(0,0,0,.5); }
.feature .ic { width: 44px; height: 44px; border-radius: 10px; background: rgba(222,158,44,0.12); display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.feature .ic svg { width: 22px; height: 22px; color: var(--gold); }
.feature h3 { font-family: var(--disp); font-size: 20px; text-transform: uppercase; margin-bottom: 8px; }
.feature p { font-size: 14px; color: var(--muted); text-wrap: balance; }

/* Rate card */
.rates { max-width: 640px; margin: 0 auto; }
.rate-row { display: grid; grid-template-columns: 2fr 1fr 1.2fr; gap: 16px; padding: 18px 0; border-bottom: 1px dotted var(--line); align-items: center; transition: background .15s; }
.rate-row:not(.head):hover { background: var(--crude-2); border-radius: var(--r); }
@media (max-width: 640px) { .rate-row { grid-template-columns: 1fr 1fr; } .ratio { display: none; } .rate-row.head span:last-child { display: none; } }
.rate-row.head { font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.role { font-weight: 600; }
.role small { display: block; font-size: 12px; color: var(--muted); font-weight: 400; margin-top: 2px; }
.rate { color: var(--gold); font-family: var(--disp); font-size: 22px; }
.rate span { font-family: var(--sans); font-size: 13px; color: var(--muted); font-weight: 400; }
.ratio { font-size: 12px; color: var(--muted); }

/* How it works */
.howrow { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; text-align: center; }
@media (max-width: 768px) { .howrow { grid-template-columns: 1fr; } }
.step-c { background: var(--crude-2); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 32px; transition: transform .2s, box-shadow .2s; }
.step-c:hover { transform: translateY(-2px); box-shadow: 0 12px 28px -10px rgba(0,0,0,.5); }
.step-c .n { font-family: var(--disp); font-size: 38px; color: var(--gold); }
.step-c h3 { font-family: var(--disp); font-size: 20px; text-transform: uppercase; margin: 8px 0; }
.step-c p { font-size: 14px; color: var(--muted); text-wrap: balance; }

/* Cross-brand */
.cross-links { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; max-width: 900px; margin: 0 auto; }
@media (max-width: 768px) { .cross-links { grid-template-columns: 1fr !important; } }
.cross-card { box-sizing: border-box; max-width: 100%; display: block; padding: 24px; border: 1px solid var(--line); border-radius: var(--r-lg); transition: background .15s, transform .2s, box-shadow .2s; }
.cross-card:hover { background: var(--crude-2); transform: translateY(-2px); box-shadow: 0 12px 28px -10px rgba(0,0,0,.4); }
.cross-card .cn { font-family: var(--disp); font-size: 18px; text-transform: uppercase; margin-bottom: 6px; }
.cross-card p { font-size: 13px; color: var(--muted); line-height: 1.5; text-wrap: balance; }
.cross-card .cta { font-size: 12px; font-weight: 600; color: var(--gold); margin-top: 8px; display: block; }

/* Footer */
.site-footer { border-top: 1px solid var(--line); padding: 24px 0; }
.site-footer .inner { max-width: 1120px; margin: 0 auto; padding: 0 40px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.site-footer .fn { font-family: var(--disp); font-size: 15px; text-transform: uppercase; }
.site-footer .fs { font-size: 11px; color: var(--muted); }
.site-footer .fl { display: flex; gap: 20px; font-size: 12px; }
.site-footer .fl a { color: var(--muted); transition: color .15s; }
.site-footer .fl a:hover { color: var(--canvas); }
@media (max-width: 768px) {
  .wrap { padding: 0 20px; }
  .hero { padding: 48px 0 40px; }
  .band { padding: 48px 0; }
  .hero .lede { font-size: 15px; }
  .hero-actions { flex-direction: column; align-items: center; }
  .hero-actions .btn-primary, .hero-actions .btn-ghost { width: 100%; justify-content: center; }
  .sec-head h2 { font-size: clamp(24px, 4vw, 36px); }
  .cross-links { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { transition-duration: 0.01ms !important; } }
