:root{
  --bg:#0a0a0a;
  --bg-soft:#121212;
  --panel:#151515;
  --ink:#ececec;
  --muted:#bdbdbd;
  --accent:#FFC107;
  --accent-ink:#111;
  --line:#242424;
  --shadow:0 12px 36px rgba(0,0,0,.35);

  /* Header tuned to exact logo height */
  --header-h:72px;
}

/* Base */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,Segoe UI,Arial,sans-serif;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none}
a:hover{opacity:.9}

/* Container width matches your mock */
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.center{text-align:center}
.mt-24{margin-top:24px}

/* Header */
.site-header{position:sticky;top:0;z-index:20;height:var(--header-h);background:#0b0b0b;backdrop-filter:saturate(130%) blur(8px);border-bottom:1px solid var(--line)}
.nav{height:var(--header-h);display:flex;align-items:center;justify-content:space-between}
.main-nav a{margin-left:18px;white-space:nowrap}

/* Hat-only logo — sized like your mockup */
.brand-logo{height:60px;width:auto;filter:drop-shadow(0 4px 12px rgba(0,0,0,.35))}
@media (min-width:900px){.brand-logo{height:64px}}
main{scroll-padding-top:var(--header-h)}

/* HERO — pull tagline right under header */
.hero{
  position:relative;isolation:isolate;
  padding:calc(0px + var(--header-h)) 0 30px; /* no extra top gap */
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(1400px 600px at 20% -10%, rgba(255,193,7,.10), transparent 60%),
    radial-gradient(900px 500px at 85% 10%, rgba(255,193,7,.06), transparent 60%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.02) 0 2px, rgba(0,0,0,.02) 2px 4px),
    linear-gradient(#0d0d0d, #0a0a0a);
}
h1{
  font-family:'Bebas Neue', system-ui, sans-serif;
  letter-spacing:.02em;font-weight:400;
  font-size:clamp(48px,7vw,96px);line-height:1;margin:0 0 6px;
}
h2.section-title{
  font-family:'Bebas Neue', system-ui, sans-serif;
  font-size:clamp(28px,4vw,44px);margin:0 0 10px;letter-spacing:.02em;
}
h3{font-weight:800;margin:.2rem 0 .5rem}
.lead{font-size:1.12rem;opacity:.95;max-width:72ch}
.hero-lead{max-width:none;margin-top:6px}
.accent{color:var(--accent)}

/* Pills */
.hero-points{display:flex;gap:12px;flex-wrap:wrap;padding:0;margin:12px 0 0;list-style:none}
.hero-points li{background:#161616;border:1px solid #242424;border-radius:999px;padding:6px 12px}

/* Sections */
.section{padding:40px 0}
.section-tight-top{padding-top:12px}
.section-dark{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* WEEKLY EVENTS CARD — full-width under pills */
.show-card{
  background:linear-gradient(180deg,#1b1b1b, #151515);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
  width:100%;
  margin:10px 0 0;
  overflow:hidden;
}
.show-card-img{padding:14px 14px 0}
.show-card-img img{
  width:100%;height:100%;object-fit:contain;
  background:#0f0f0f;border-radius:16px;border:1px solid #232323;
}
.show-card-body{padding:16px}
.pill{
  display:inline-block;background:#201a00;border:1px solid #3a2f00;color:#ffd34d;
  font-weight:800;border-radius:999px;padding:6px 10px;margin-bottom:8px;font-size:.9rem
}
.show-title{font-size:1.35rem;margin:.25rem 0 .4rem}
.show-blurb{color:var(--muted);margin:.25rem 0 .9rem}

/* Meta grid */
.meta-grid{display:grid;gap:8px}
.meta-row{display:grid;grid-template-columns:120px 1fr;gap:8px;align-items:center}
.meta-label{color:#d2d2d2;font-weight:700;opacity:.9}
.meta-value{color:var(--ink)}

/* Buttons */
.btn{display:inline-block;padding:12px 18px;border-radius:12px;border:1px solid #222;background:#161616;color:var(--ink);box-shadow:var(--shadow);font-weight:700}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:#000}
.btn-outline{background:transparent;border:1px solid var(--ink)}
.btn-accent{background:var(--accent);color:var(--accent-ink);border-color:#000}
.btn-dark{background:#000;color:var(--ink)}
.btn-small{padding:8px 12px;border-radius:10px}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px}

/* Layout helpers */
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}

/* Book section — left column wider like the mock */
.book-grid{grid-template-columns:1.4fr 1fr}
.book-lead{max-width:60ch;margin-bottom:18px}

/* Form & checklist */
.form-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px}
label{display:block;margin:10px 0 6px;font-weight:700}
input,textarea{width:100%;padding:12px;border-radius:10px;border:1px solid #2a2a2a;background:#0f0f0f;color:var(--ink)}
input:focus,textarea:focus{outline:2px solid var(--accent)}
.checklist{padding-left:1.2rem}
.checklist li{margin-bottom:.5rem}

/* FAQ */
.faq{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px;margin:10px 0}
.faq summary{cursor:pointer;font-weight:800}

/* FOOTER — tight, not loose */
.site-footer{border-top:1px solid var(--line);background:#0b0b0b}
.footer-bar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:12px 0;
}
.footer-left{display:flex;align-items:center;gap:10px}
.footer-logo{height:28px;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.35))}
.footer-nav{display:flex;gap:18px;flex-wrap:wrap}
.footer-nav a{color:var(--ink);opacity:.9}
.footer-contact{display:flex;gap:18px;flex-wrap:wrap}
.footer-bottom{padding:8px 0 14px;text-align:center}
.tiny{font-size:.86rem}
.muted{color:var(--muted)}

/* --- MOBILE RESPONSIVE TWEAKS --- */
@media (max-width: 768px) {
  /* Header logo smaller on mobile */
  .brand-logo { height:48px; }

  /* Hero breathing room */
  .hero { padding: calc(8px + var(--header-h)) 0 28px; }
  h1 { font-size: clamp(36px, 8vw, 64px); }

  /* Weekly Events card full width */
  .show-card { margin: 12px 0 0; border-radius: 14px; }
  .show-card-img { padding: 10px; }

  /* Book grid collapses to vertical stack */
  .book-grid { grid-template-columns: 1fr; }
  .book-lead { margin-bottom: 16px; }
  .form-card { margin-top: 16px; }

  /* Footer stacks */
  .footer-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 14px 0;
  }
  .footer-nav,
  .footer-contact {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .footer-bottom { padding: 10px 0; }
}

/* Ultra-small phones */
@media (max-width: 480px) {
  .container { padding: 0 16px; }
  .brand-logo { height:44px; }
  h1 { font-size: clamp(32px, 9.5vw, 56px); }
  .btn { padding: 10px 14px; border-radius: 10px; }
  .meta-row { grid-template-columns: 96px 1fr; }
}
