* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.heroes-modern-theme {
  margin: 0;
  color: var(--hm-text);
  background: radial-gradient(circle at top left, rgba(215,25,32,.12), transparent 28%), linear-gradient(135deg, var(--hm-deep), var(--hm-navy));
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
svg { width: 1em; height: 1em; fill: currentColor; }
.hm-container { width: min(var(--hm-container), calc(100% - 40px)); margin-inline: auto; }
.screen-reader-text, .hm-skip-link { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.hm-skip-link:focus { left: 16px; top: 16px; width: auto; height: auto; z-index: 9999; background: #fff; color: #000; padding: 10px 14px; border-radius: 6px; }

.hm-site-header {
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(2, 7, 18, .92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 0 0 rgba(0,0,0,0);
  transition: box-shadow .25s ease, background .25s ease;
}
.hm-site-header.hm-scrolled { box-shadow: 0 20px 50px rgba(0,0,0,.25); background: rgba(2, 7, 18, .98); }
.hm-header-inner { width: min(1280px, calc(100% - 36px)); min-height: 84px; display: flex; align-items: center; gap: 28px; margin: 0 auto; }
.hm-brand { display: flex; align-items: center; gap: 22px; flex-shrink: 0; }
.hm-logo-link img, .custom-logo-link img { width: var(--hm-logo-width); max-width: var(--hm-logo-width); height: auto; }
.hm-text-logo { display: grid; line-height: 1; text-transform: uppercase; font-weight: 900; letter-spacing: .04em; }
.hm-text-logo strong { color: var(--hm-red); font-size: 2.2rem; }
.hm-text-logo span { font-size: .85rem; }
.hm-tagline { color: var(--hm-text); font-style: italic; font-weight: 800; max-width: 115px; line-height: 1.15; text-align: center; }
.hm-tagline::after { content: "★ ★ ★"; display: block; color: var(--hm-red); font-style: normal; letter-spacing: .2em; font-size: .8rem; margin-top: 4px; }
.hm-main-nav { margin-left: auto; }
.hm-menu { list-style: none; display: flex; align-items: center; gap: 4px; margin: 0; padding: 0; }
.hm-menu > li { position: relative; }
.hm-menu a { display: inline-flex; align-items: center; min-height: 44px; padding: 10px 13px; color: var(--hm-text); font-size: .82rem; line-height: 1; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; transition: color .2s ease, background .2s ease; border-radius: 999px; }
.hm-menu a:hover, .hm-menu .current-menu-item > a { color: #fff; background: rgba(215,25,32,.18); }
.hm-header-cta { flex-shrink: 0; }
.hm-menu-toggle { display: none; background: none; border: 0; padding: 10px; width: 48px; height: 48px; margin-left: auto; cursor: pointer; }
.hm-menu-toggle span:not(.screen-reader-text) { display: block; height: 3px; background: #fff; border-radius: 999px; margin: 6px 0; transition: .2s ease; }

.hm-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 50px; padding: 14px 24px; border: 1px solid rgba(255,255,255,.22); border-radius: calc(var(--hm-radius) / 1.3); font-weight: 950; letter-spacing: .08em; text-transform: uppercase; line-height: 1; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; cursor: pointer; }
.hm-btn:hover { transform: translateY(-2px); }
.hm-btn-red { background: linear-gradient(135deg, var(--hm-red), var(--hm-red-dark)); color: #fff; border-color: rgba(255,255,255,.12); box-shadow: 0 16px 40px rgba(215,25,32,.26); }
.hm-btn-red:hover { box-shadow: 0 18px 48px rgba(215,25,32,.38); }
.hm-btn-outline { background: rgba(255,255,255,.04); color: #fff; border-color: rgba(255,255,255,.28); }
.hm-btn-outline:hover { background: rgba(255,255,255,.1); }
.hm-btn-small { min-height: 42px; padding: 11px 17px; font-size: .78rem; }
.hm-btn-icon { line-height: 0; font-size: 1.15rem; }

.hm-hero { min-height: 680px; display: flex; align-items: center; background-size: cover; background-position: center right; border-bottom: 1px solid rgba(255,255,255,.08); position: relative; overflow: hidden; }
.hm-hero::before { content: ""; position: absolute; inset: 0; background: url('../img/stadium-pattern.svg') center/650px repeat; opacity: .34; mix-blend-mode: screen; pointer-events: none; }
.hm-hero-grid { position: relative; display: grid; grid-template-columns: minmax(0, 620px) 1fr; gap: 50px; align-items: center; padding: 100px 0 86px; }
.hm-eyebrow { display: inline-flex; align-items: center; gap: 8px; color: var(--hm-red); font-weight: 950; letter-spacing: .16em; text-transform: uppercase; font-size: .78rem; }
.hm-eyebrow::before, .hm-eyebrow::after { content: ""; width: 28px; height: 2px; background: var(--hm-red); display: inline-block; }
.hm-align-left .hm-eyebrow::before { display: none; }
.hm-hero h1 { margin: 22px 0 18px; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; text-transform: uppercase; font-size: clamp(4.1rem, 9vw, 8.4rem); line-height: .84; letter-spacing: .02em; text-shadow: 0 8px 0 rgba(0,0,0,.12); }
.hm-hero h1 span { display: block; }
.hm-red-text { color: var(--hm-red); }
.hm-hero p { max-width: 600px; color: var(--hm-text); font-size: clamp(1rem, 1.5vw, 1.22rem); font-weight: 650; }
.hm-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hm-hero-stat-card { justify-self: end; align-self: end; max-width: 290px; padding: 26px; border-radius: var(--hm-radius); background: linear-gradient(160deg, rgba(11,24,48,.86), rgba(215,25,32,.23)); border: 1px solid rgba(255,255,255,.16); box-shadow: 0 20px 70px rgba(0,0,0,.32); }
.hm-hero-stat-card span { width: 46px; height: 46px; display: inline-grid; place-items: center; color: var(--hm-red); background: #fff; border-radius: 50%; margin-bottom: 14px; }
.hm-hero-stat-card strong { display: block; font-size: 1.55rem; line-height: 1.1; text-transform: uppercase; letter-spacing: .07em; }
.hm-hero-stat-card p { margin: 8px 0 0; color: var(--hm-muted); font-size: .96rem; }

.hm-section { padding: 78px 0; position: relative; }
.hm-section-heading { margin-bottom: 36px; }
.hm-section-heading.hm-align-center { text-align: center; }
.hm-section-heading.hm-align-left { text-align: left; }
.hm-section-heading h2 { margin: 8px 0 0; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; text-transform: uppercase; letter-spacing: .08em; font-size: clamp(2rem, 4vw, 3.25rem); line-height: 1; }
.hm-intro { background: linear-gradient(180deg, rgba(4,12,28,.98), rgba(6,18,38,.96)); }
.hm-intro-grid { display: grid; grid-template-columns: 1fr 1.25fr; gap: 50px; align-items: stretch; }
.hm-intro-copy { padding: 34px; background: linear-gradient(145deg, rgba(255,255,255,.045), rgba(255,255,255,.018)); border: 1px solid rgba(255,255,255,.1); border-radius: var(--hm-radius); }
.hm-intro-copy p { color: var(--hm-muted); font-size: 1.05rem; }
.hm-punchline { display: block; margin-top: 22px; color: #fff; font-size: 1.08rem; letter-spacing: .05em; text-transform: uppercase; }
.hm-location-stack { display: grid; gap: 18px; }
.hm-location-card { display: grid; grid-template-columns: 240px minmax(0, 1fr); gap: 0; overflow: hidden; border-radius: var(--hm-radius); background: linear-gradient(145deg, var(--hm-card), rgba(255,255,255,.035)); border: 1px solid rgba(255,255,255,.12); box-shadow: 0 18px 50px rgba(0,0,0,.2); }
.hm-location-media { min-height: 210px; background-size: cover; background-position: center; }
.hm-location-content { padding: 28px; }
.hm-location-content h3 { margin: 0 0 12px; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; letter-spacing: .1em; text-transform: uppercase; color: #fff; font-size: 1.75rem; }
.hm-location-content p { margin: 9px 0; color: var(--hm-muted); display: flex; gap: 10px; align-items: flex-start; }
.hm-location-content p span { color: var(--hm-red); margin-top: 2px; }
.hm-card-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; margin-top: 20px; }
.hm-arrow-link { color: var(--hm-red); font-weight: 950; text-transform: uppercase; letter-spacing: .08em; font-size: .85rem; }
.hm-arrow-link span { transition: transform .2s ease; display: inline-block; }
.hm-arrow-link:hover span { transform: translateX(4px); }

.hm-featured-menu { background: linear-gradient(180deg, rgba(2,7,18,.98), rgba(6,18,38,.98)); }
.hm-featured-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.hm-feature-card { overflow: hidden; border-radius: var(--hm-radius); background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025)); border: 1px solid rgba(255,255,255,.12); min-height: 100%; }
.hm-feature-img { display: block; height: 190px; background-size: cover; background-position: center; }
.hm-feature-card > div { padding: 22px; }
.hm-feature-card h3 { margin: 0 0 8px; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; text-transform: uppercase; letter-spacing: .08em; font-size: 1.4rem; }
.hm-feature-card p { margin: 0 0 14px; color: var(--hm-muted); }

.hm-order-band { background: radial-gradient(circle at 15% 40%, rgba(215,25,32,.18), transparent 34%), linear-gradient(135deg, rgba(4,12,28,.98), rgba(13,37,72,.94)); border-block: 1px solid rgba(255,255,255,.08); }
.hm-order-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.hm-order-panel { position: relative; overflow: hidden; padding: 36px; min-height: 260px; border-radius: var(--hm-radius); border: 1px solid rgba(255,255,255,.13); background-size: cover; background-position: center; }
.hm-order-downtown { background-image: linear-gradient(120deg, rgba(60,0,5,.86), rgba(4,12,28,.72)), url('../img/downtown-mobile.svg'); }
.hm-order-west { background-image: linear-gradient(120deg, rgba(4,12,28,.84), rgba(8,31,67,.64)), url('../img/west-mobile.svg'); }
.hm-order-panel h3 { margin: 12px 0 4px; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; text-transform: uppercase; letter-spacing: .1em; font-size: 2rem; }
.hm-order-panel p { color: var(--hm-muted); margin-bottom: 26px; }
.hm-circle-icon { width: 58px; height: 58px; display: grid; place-items: center; border-radius: 50%; color: #fff; background: rgba(215,25,32,.85); border: 1px solid rgba(255,255,255,.18); font-size: 1.4rem; }

.hm-fan-section { background: rgba(255,255,255,.018); }
.hm-features-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.hm-feature-item { padding: 28px; border-radius: var(--hm-radius); background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.1); }
.hm-feature-item span { width: 60px; height: 60px; display: grid; place-items: center; border: 2px solid rgba(255,255,255,.35); border-radius: 50%; margin-bottom: 18px; color: #fff; font-size: 1.55rem; }
.hm-feature-item h3 { margin: 0 0 8px; text-transform: uppercase; letter-spacing: .08em; font-size: 1rem; }
.hm-feature-item p { margin: 0; color: var(--hm-muted); }

.hm-gallery-strip { background: linear-gradient(180deg, rgba(2,7,18,.98), rgba(3,10,23,.98)); }
.hm-gallery-row { display: grid; grid-template-columns: 1.15fr 1fr 1.15fr 1fr 1.15fr 1fr; gap: 10px; }
.hm-gallery-row a, .hm-gallery-tile { min-height: 165px; display: block; border-radius: 14px; background-size: cover; background-position: center; border: 1px solid rgba(255,255,255,.12); transition: transform .2s ease, opacity .2s ease; }
.hm-gallery-row a:hover, .hm-gallery-tile:hover { transform: translateY(-3px); opacity: .88; }
.hm-center-action { text-align: center; margin-top: 28px; }

.hm-final-cta { background: linear-gradient(135deg, var(--hm-red-dark), var(--hm-red)); padding: 54px 0; }
.hm-final-grid { display: flex; justify-content: space-between; align-items: center; gap: 24px; }
.hm-final-grid h2 { margin: 8px 0 0; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; letter-spacing: .06em; text-transform: uppercase; font-size: clamp(1.8rem, 4vw, 3.1rem); line-height: 1; max-width: 700px; }
.hm-final-cta .hm-eyebrow { color: #fff; }
.hm-final-cta .hm-eyebrow::before, .hm-final-cta .hm-eyebrow::after { background: #fff; }
.hm-final-actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: flex-end; }
.hm-final-actions .hm-btn-outline { background: rgba(0,0,0,.18); }

.hm-page-hero { background: radial-gradient(circle at 12% 0%, rgba(215,25,32,.2), transparent 28%), linear-gradient(135deg, var(--hm-deep), var(--hm-navy-2)); padding: 115px 0 70px; border-bottom: 1px solid rgba(255,255,255,.08); }
.hm-page-hero h1 { margin: 10px 0 10px; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; text-transform: uppercase; letter-spacing: .06em; font-size: clamp(3rem, 6vw, 5.8rem); line-height: .96; }
.hm-page-hero p { color: var(--hm-muted); max-width: 760px; font-size: 1.1rem; }
.hm-page-hero-grid { display: grid; grid-template-columns: 1fr auto; gap: 28px; align-items: center; }
.hm-page-hero-actions { display: grid; gap: 12px; min-width: 250px; }
.hm-page-content { color: var(--hm-muted); font-size: 1.06rem; }
.hm-page-content h2, .hm-page-content h3 { color: #fff; }
.hm-page-content a { color: var(--hm-red); }

.hm-menu-board { display: grid; gap: 42px; }
.hm-menu-filter { position: sticky; top: 94px; z-index: 20; display: flex; gap: 10px; overflow-x: auto; padding: 10px; margin: -10px 0 8px; background: rgba(2,7,18,.84); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.08); border-radius: 999px; }
.hm-menu-filter a { flex: 0 0 auto; padding: 10px 14px; border-radius: 999px; background: rgba(255,255,255,.055); color: #fff; font-size: .8rem; font-weight: 900; text-transform: uppercase; letter-spacing: .06em; }
.hm-menu-category h2 { margin: 0 0 18px; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; text-transform: uppercase; letter-spacing: .08em; font-size: 2.4rem; }
.hm-menu-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.hm-menu-row { display: flex; gap: 18px; padding: 16px; border-radius: var(--hm-radius); background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.1); }
.hm-menu-thumb { width: 96px; height: 96px; flex: 0 0 96px; border-radius: 12px; background-size: cover; background-position: center; }
.hm-menu-row-top { display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: start; }
.hm-menu-row h3 { margin: 0; color: #fff; font-size: 1.06rem; text-transform: uppercase; letter-spacing: .04em; }
.hm-menu-row strong { color: var(--hm-red); white-space: nowrap; }
.hm-menu-row p { margin: 6px 0 0; color: var(--hm-muted); }

.hm-two-col-locations { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.hm-two-col-locations .hm-location-card { grid-template-columns: 1fr; }
.hm-two-col-locations .hm-location-media { min-height: 260px; }
.hm-gallery-page-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.hm-gallery-page-grid .hm-gallery-tile { min-height: 260px; }
.hm-contact-grid, .hm-careers-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; align-items: start; }
.hm-form-card, .hm-contact-card, .hm-careers-sidebar { padding: 28px; border-radius: var(--hm-radius); background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.11); }
.hm-form-card { grid-column: span 2; }
.hm-contact-card h2, .hm-form-card h2, .hm-careers-sidebar h2 { margin-top: 0; font-family: Impact, Haettenschweiler, "Arial Narrow Bold", sans-serif; letter-spacing: .06em; text-transform: uppercase; }
.hm-fake-form { display: grid; gap: 12px; }
.hm-fake-form input, .hm-fake-form textarea, .hm-newsletter-form input { width: 100%; min-height: 48px; border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.06); color: #fff; border-radius: 10px; padding: 12px 14px; font: inherit; }
.hm-fake-form textarea { min-height: 130px; resize: vertical; }
.hm-fake-form button, .hm-newsletter-form button { border: 0; background: var(--hm-red); color: #fff; border-radius: 10px; padding: 14px 18px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; cursor: pointer; }
.hm-careers-grid { grid-template-columns: 320px 1fr; }
.hm-careers-form { grid-column: auto; }
.hm-careers-sidebar ul { margin: 0; padding-left: 18px; color: var(--hm-muted); }

.hm-post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.hm-post-card { border-radius: var(--hm-radius); background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); overflow: hidden; }
.hm-post-card > div:not(.hm-post-img) { padding: 22px; }
.hm-post-card h2 { margin-top: 0; }
.hm-post-card p { color: var(--hm-muted); }
.hm-post-img img, .hm-single-thumb img { width: 100%; max-height: 480px; object-fit: cover; }
.hm-single-thumb { margin-bottom: 28px; border-radius: var(--hm-radius); overflow: hidden; }

.hm-site-footer { background: #020712; border-top: 1px solid rgba(255,255,255,.08); padding-bottom: 86px; }
.hm-footer-grid { display: grid; grid-template-columns: 1.3fr .8fr .8fr 1fr; gap: 38px; padding: 56px 0; }
.hm-site-footer h2 { margin: 0 0 14px; font-size: .92rem; letter-spacing: .14em; text-transform: uppercase; }
.hm-footer-brand .hm-logo-link img { width: min(var(--hm-logo-width), 230px); }
.hm-footer-brand p, .hm-footer-hours p, .hm-footer-newsletter p { color: var(--hm-muted); margin: 8px 0; }
.hm-socials { display: flex; gap: 10px; margin-top: 20px; }
.hm-socials a { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.1); font-weight: 900; }
.hm-footer-menu { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.hm-footer-menu a { color: var(--hm-muted); }
.hm-newsletter-form { display: grid; grid-template-columns: 1fr auto; gap: 8px; margin-top: 14px; }
.hm-footer-bottom { background: var(--hm-red); padding: 14px 0; text-align: center; font-size: .9rem; }
.hm-footer-bottom p { margin: 0; }
.hm-sticky-order { position: fixed; left: 50%; transform: translateX(-50%); bottom: 18px; z-index: 998; width: min(560px, calc(100% - 32px)); display: none; }
.hm-sticky-order .hm-btn { width: 100%; border-radius: 999px; }

@media (max-width: 1120px) {
  .hm-header-cta { display: none; }
  .hm-main-nav { position: fixed; inset: 84px 16px auto 16px; opacity: 0; visibility: hidden; transform: translateY(-8px); transition: .2s ease; background: rgba(2,7,18,.98); border: 1px solid rgba(255,255,255,.12); border-radius: 18px; padding: 12px; box-shadow: 0 24px 80px rgba(0,0,0,.45); }
  body.hm-nav-open .hm-main-nav { opacity: 1; visibility: visible; transform: translateY(0); }
  .hm-menu { display: grid; gap: 4px; }
  .hm-menu a { width: 100%; justify-content: center; border-radius: 12px; }
  .hm-menu-toggle { display: block; }
  .hm-hero-grid, .hm-intro-grid, .hm-page-hero-grid { grid-template-columns: 1fr; }
  .hm-hero-stat-card { justify-self: start; }
  .hm-featured-grid, .hm-features-grid { grid-template-columns: repeat(2, 1fr); }
  .hm-footer-grid { grid-template-columns: repeat(2, 1fr); }
  .hm-final-grid { align-items: flex-start; flex-direction: column; }
  .hm-final-actions { justify-content: flex-start; }
}

@media (max-width: 760px) {
  .hm-container { width: min(100% - 28px, var(--hm-container)); }
  .hm-header-inner { min-height: 76px; width: calc(100% - 24px); }
  .hm-brand { gap: 10px; }
  .hm-tagline { display: none; }
  .hm-logo-link img, .custom-logo-link img { width: min(var(--hm-logo-width), 210px); }
  .hm-main-nav { inset: 76px 12px auto 12px; }
  .hm-hero { min-height: auto; background-position: center; }
  .hm-hero-grid { padding: 78px 0 54px; gap: 28px; }
  .hm-hero h1 { font-size: clamp(3.5rem, 18vw, 5.4rem); }
  .hm-hero-actions .hm-btn { width: 100%; }
  .hm-section { padding: 56px 0; }
  .hm-intro-copy { padding: 24px; }
  .hm-location-card { grid-template-columns: 1fr; }
  .hm-location-media { min-height: 180px; }
  .hm-featured-grid, .hm-features-grid, .hm-order-grid, .hm-menu-list, .hm-two-col-locations, .hm-contact-grid, .hm-careers-grid, .hm-post-grid { grid-template-columns: 1fr; }
  .hm-form-card { grid-column: auto; }
  .hm-gallery-row { grid-template-columns: repeat(2, 1fr); }
  .hm-gallery-row a { min-height: 130px; }
  .hm-gallery-page-grid { grid-template-columns: repeat(2, 1fr); }
  .hm-gallery-page-grid .hm-gallery-tile { min-height: 170px; }
  .hm-menu-row { flex-direction: column; }
  .hm-menu-thumb { width: 100%; height: 170px; }
  .hm-footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .hm-newsletter-form { grid-template-columns: 1fr; }
  .hm-sticky-order { display: block; }
  .hm-site-footer { padding-bottom: 102px; }
}

@media (max-width: 420px) {
  .hm-logo-link img, .custom-logo-link img { width: min(var(--hm-logo-width), 180px); }
  .hm-hero-actions { gap: 10px; }
  .hm-btn { padding: 13px 16px; letter-spacing: .06em; }
  .hm-location-content, .hm-order-panel, .hm-feature-item { padding: 22px; }
}
