:root {
  --green: #2D4A3E;
  --green-dark: #1A1A1A;
  --green-light: #3D5A4E;
  --amber: #FFF200;
  --pink: #E91E8C;
  --lime: #8DC63F;
  --blue: #00AEEF;
  --red: #E85A4B;
  --cream: #F5F2ED;
  --wood: #C49A6C;
  --text-light: rgba(255,255,255,0.84);
  font-family: 'Inter', sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-height: 100vh; background: var(--green-dark); color: white; line-height: 1.55; }
body::before { content: ''; position: fixed; inset: 0; pointer-events: none; background: radial-gradient(circle at 18% 8%, rgba(233,30,140,.28), transparent 28%), radial-gradient(circle at 82% 18%, rgba(255,242,0,.16), transparent 24%), linear-gradient(135deg, rgba(45,74,62,.94), rgba(26,26,26,.98)); z-index: -1; }
h1,h2,h3,p { margin: 0; }
h1,h2,h3,.brand-bedford { font-family: 'Bebas Neue', sans-serif; letter-spacing: 2px; }
h1 { font-size: clamp(4.4rem, 15vw, 9.5rem); line-height: .82; max-width: 850px; text-transform: uppercase; }
h2 { font-size: 2.6rem; line-height: .95; }
h3 { font-size: 1.7rem; }
main, footer, .site-header { width: min(1180px, calc(100% - 30px)); margin: 0 auto; }
.site-header { display: flex; justify-content: space-between; align-items: center; padding: 22px 0; }
.brand { color: white; text-decoration: none; display: grid; line-height: .85; }
.brand-the { font-family: Georgia, serif; font-style: italic; font-size: 1.05rem; }
.brand-bedford { font-size: 2.35rem; }
.nav-cta, .primary-link, .secondary-link, button { border: 0; border-radius: 0; padding: 13px 22px; font-weight: 900; cursor: pointer; text-decoration: none; display: inline-flex; justify-content: center; align-items: center; gap: 8px; transition: transform .2s, filter .2s; }
.nav-cta, .primary-link, .primary { background: var(--amber); color: var(--green-dark); }
.secondary-link, .ghost { background: rgba(255,255,255,.08); color: white; border: 1px solid rgba(255,255,255,.22); }
button:hover, a:hover { transform: translateY(-2px); filter: brightness(1.04); }
.hero { display: grid; grid-template-columns: 1fr 320px; gap: 30px; align-items: end; padding: 45px 0 34px; }
.eyebrow { color: var(--amber); text-transform: uppercase; letter-spacing: .18em; font-weight: 900; font-size: .78rem; margin-bottom: 10px; }
.lead { color: var(--text-light); font-size: clamp(1.05rem, 2vw, 1.28rem); max-width: 720px; margin-top: 18px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 24px; }
.hero-card, .card, .package, .table-showcase article { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); box-shadow: 0 24px 80px rgba(0,0,0,.25); backdrop-filter: blur(18px); }
.hero-card { padding: 24px; border-left: 6px solid var(--pink); }
.hero-card strong { display: block; font-family: 'Bebas Neue', sans-serif; font-size: 2.5rem; line-height: .9; letter-spacing: 1px; margin: 12px 0; }
.hero-card p { color: var(--text-light); }
.screen-badge, .tag { display: inline-flex; background: var(--pink); color: white; padding: 7px 10px; font-size: .78rem; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.packages { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-bottom: 14px; }
.package { text-align: left; color: white; padding: 22px; border-radius: 0; }
.package.active { border-color: var(--amber); box-shadow: 0 0 0 4px rgba(255,242,0,.14); background: rgba(255,242,0,.1); }
.package strong { display: block; font-family: 'Bebas Neue', sans-serif; font-size: 5rem; line-height: .85; color: var(--amber); letter-spacing: 1px; margin-top: 12px; }
.package em { display: block; font-style: normal; font-size: 1.2rem; font-weight: 900; text-transform: uppercase; }
.package small { color: var(--text-light); display: block; margin-top: 7px; }
.tag.pink { background: var(--pink); }
.vault-hire { display: grid; grid-template-columns: 1fr 300px; gap: 18px; align-items: center; margin: 0 0 14px; padding: 24px; background: linear-gradient(135deg, rgba(233,30,140,.28), rgba(255,242,0,.12)); border: 2px solid var(--amber); box-shadow: 0 24px 80px rgba(0,0,0,.28); }
.vault-hire p { color: var(--text-light); margin-top: 8px; }
.vault-price { display: grid; gap: 10px; justify-items: start; }
.vault-price strong { font-family: 'Bebas Neue', sans-serif; font-size: 5rem; line-height: .8; color: var(--amber); letter-spacing: 1px; }
.vault-price span { font-weight: 900; text-transform: uppercase; }
.table-showcase { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 14px; }
.table-showcase article { padding: 18px; }
.table-showcase span { display: block; font-size: 2rem; margin-bottom: 10px; }
.table-showcase strong { display: block; font-size: 1rem; }
.table-showcase small { color: var(--text-light); }
.grid { display: grid; grid-template-columns: 430px 1fr; gap: 14px; align-items: start; }
.card { padding: 22px; }
label { display: grid; gap: 7px; color: var(--text-light); font-size: .86rem; font-weight: 800; margin-bottom: 12px; }
input, select, textarea { width: 100%; border: 1px solid rgba(255,255,255,.18); padding: 14px; background: rgba(0,0,0,.28); color: white; font: inherit; outline: none; border-radius: 0; }
input:focus, select:focus, textarea:focus { border-color: var(--amber); box-shadow: 0 0 0 3px rgba(255,242,0,.12); }
.two { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.primary { width: 100%; font-size: 1rem; }
.summary-box { background: rgba(0,0,0,.25); border: 1px solid rgba(255,255,255,.15); padding: 15px; display: grid; gap: 10px; margin: 14px 0; }
.summary-box div, .section-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.summary-box span, .fine-print, .table-card span, .recent p, footer span, .dojo-panel p { color: var(--text-light); }
.summary-box strong { color: var(--amber); }
.fine-print { font-size: .78rem; margin-top: 10px; line-height: 1.45; }
.table-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.table-card { border: 1px solid rgba(255,255,255,.16); padding: 14px; background: rgba(0,0,0,.24); }
.table-card.available { border-color: rgba(141,198,63,.65); }
.table-card.booked { border-color: rgba(232,90,75,.75); background: rgba(232,90,75,.12); }
.table-card strong { display: block; font-size: 1rem; }
.dojo-panel { margin-top: 16px; border: 2px solid var(--amber); padding: 16px; background: rgba(255,242,0,.08); }
.dojo-panel.hidden { display: none; }
.dojo-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.booking-row { border-top: 1px solid rgba(255,255,255,.14); padding: 10px 0; color: var(--text-light); }
.booking-row strong { color: white; }
.empty { color: var(--text-light); text-align: center; padding: 28px 8px; }
footer { padding: 34px 0 44px; display: flex; justify-content: space-between; gap: 14px; color: white; }
@media (max-width: 860px) {
  main, footer, .site-header { width: min(100% - 22px, 560px); }
  .site-header { padding: 16px 0; }
  .nav-cta { padding: 10px 13px; font-size: .82rem; }
  .hero { grid-template-columns: 1fr; padding-top: 25px; }
  .packages, .grid, .two, .table-cards, .table-showcase, .vault-hire { grid-template-columns: 1fr; }
  .section-head, footer { align-items: stretch; flex-direction: column; }
  .package strong { font-size: 4rem; }
}
