:root {
  --bg: #06070a;
  --bg-soft: #101217;
  --card: rgba(255,255,255,.06);
  --card-strong: rgba(255,255,255,.1);
  --text: #f6f7fb;
  --muted: #b8beca;
  --red: #f11818;
  --red-dark: #980b0b;
  --gold: #ffb22c;
  --line: rgba(255,255,255,.13);
  --shadow: 0 25px 70px rgba(0,0,0,.45);
  --radius: 24px;
  --radius-sm: 16px;
  --max: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 20% -10%, rgba(241,24,24,.35), transparent 30%),
    radial-gradient(circle at 85% 5%, rgba(255,178,44,.17), transparent 24%),
    linear-gradient(135deg, #050507, #111318 55%, #06070a);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(45deg, rgba(255,255,255,.035) 25%, transparent 25%, transparent 50%, rgba(255,255,255,.035) 50%, rgba(255,255,255,.035) 75%, transparent 75%, transparent);
  background-size: 18px 18px;
  opacity: .22;
  mix-blend-mode: screen;
  z-index: -1;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(var(--max), calc(100% - 40px)); margin: 0 auto; }
.skip-link { position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus { left:20px; top:20px; width:auto; height:auto; z-index:999; padding:10px 14px; background:#fff; color:#000; border-radius:12px; }
.site-header {
  position: sticky; top: 0; z-index: 100;
  backdrop-filter: blur(18px);
  background: rgba(5,6,8,.72);
  border-bottom: 1px solid var(--line);
}
.navbar { height: 84px; display:flex; align-items:center; justify-content:space-between; gap:20px; }
.brand { display:flex; align-items:center; gap:12px; min-width:max-content; }
.brand img { width: 164px; height:auto; }
.brand-text { display:none; font-weight:900; letter-spacing:.02em; }
.nav-links { display:flex; align-items:center; gap:8px; }
.nav-links a { padding: 10px 13px; color: var(--muted); font-weight: 750; font-size: .94rem; border-radius:999px; }
.nav-links a:hover, .nav-links a.active { color: var(--text); background: var(--card); }
.nav-actions { display:flex; align-items:center; gap:10px; }
.menu-toggle { display:none; border:1px solid var(--line); background:var(--card); color:var(--text); width:44px; height:44px; border-radius:14px; font-size:1.2rem; }
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  min-height: 46px; padding: 12px 18px; border-radius: 999px;
  font-weight: 900; letter-spacing:.01em; border:1px solid transparent;
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
  cursor: pointer;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: linear-gradient(135deg, var(--red), var(--red-dark)); color:#fff; box-shadow:0 15px 40px rgba(241,24,24,.34); }
.btn-secondary { background: rgba(255,255,255,.08); color:#fff; border-color: var(--line); }
.btn-ghost { color:#fff; border-color: var(--line); background: rgba(0,0,0,.24); }
.badge { display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; background:rgba(241,24,24,.12); color:#ffdedb; border:1px solid rgba(241,24,24,.32); font-weight:850; font-size:.9rem; }
.hero { padding: 82px 0 54px; position:relative; }
.hero-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap:52px; align-items:center; }
.eyebrow { color:#ffcac8; text-transform:uppercase; letter-spacing:.16em; font-size:.78rem; font-weight:950; margin:0 0 16px; }
h1, h2, h3 { line-height:1.05; margin:0; }
h1 { font-size: clamp(3rem, 7vw, 6.5rem); letter-spacing:-.07em; max-width: 850px; }
h2 { font-size: clamp(2.15rem, 4vw, 4rem); letter-spacing:-.045em; }
h3 { font-size:1.25rem; letter-spacing:-.02em; }
.lead { color: var(--muted); font-size: clamp(1.05rem, 2vw, 1.28rem); margin:24px 0 0; max-width:720px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }
.hero-meta { display:grid; grid-template-columns: repeat(3,1fr); gap:12px; margin-top:34px; }
.meta-card { padding:16px; border:1px solid var(--line); background:var(--card); border-radius:var(--radius-sm); }
.meta-card strong { display:block; font-size:1.05rem; }
.meta-card span { color:var(--muted); font-size:.92rem; }
.hero-visual { position:relative; }
.logo-orb { border-radius: 36px; padding: 26px; background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.04)); border:1px solid var(--line); box-shadow:var(--shadow); transform: rotate(-1.5deg); }
.logo-orb img { border-radius:28px; box-shadow: inset 0 0 0 1px rgba(255,255,255,.16); }
.floating-card { position:absolute; right:-10px; bottom:-22px; width:min(320px, 82%); background:rgba(12,14,20,.92); border:1px solid var(--line); border-radius:24px; padding:20px; box-shadow: var(--shadow); }
.status-dot { display:inline-block; width:10px; height:10px; border-radius:50%; margin-right:8px; background:#25d366; box-shadow:0 0 18px #25d366; }
.section { padding: 74px 0; }
.section-tight { padding: 48px 0; }
.section-head { display:flex; align-items:end; justify-content:space-between; gap:24px; margin-bottom:30px; }
.section-head p { margin:0; color:var(--muted); max-width:560px; }
.grid-3 { display:grid; grid-template-columns: repeat(3,1fr); gap:18px; }
.grid-2 { display:grid; grid-template-columns: repeat(2,1fr); gap:22px; }
.card { border:1px solid var(--line); background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)); border-radius:var(--radius); padding:26px; box-shadow:0 18px 55px rgba(0,0,0,.2); }
.card:hover { border-color: rgba(241,24,24,.42); }
.icon { width:48px; height:48px; border-radius:16px; display:grid; place-items:center; margin-bottom:18px; background:linear-gradient(135deg, rgba(241,24,24,.24), rgba(255,178,44,.13)); border:1px solid rgba(241,24,24,.25); font-size:1.35rem; }
.card p, .muted { color:var(--muted); }
.card ul { padding-left:20px; color:var(--muted); }
.service-row { display:grid; grid-template-columns: 64px 1fr; gap:18px; align-items:start; padding:22px; border:1px solid var(--line); background:var(--card); border-radius:22px; }
.service-row .icon { margin:0; }
.band { background:linear-gradient(135deg, rgba(241,24,24,.18), rgba(255,255,255,.06)); border-block:1px solid var(--line); }
.location-card { display:grid; grid-template-columns: .85fr 1.15fr; gap:18px; align-items:stretch; }
.info-list { display:grid; gap:14px; margin-top:22px; }
.info-item { display:flex; align-items:flex-start; gap:12px; padding:14px; border-radius:18px; background:rgba(255,255,255,.055); border:1px solid var(--line); }
.info-item b { display:block; }
.info-item span { color:var(--muted); }
.map-wrap { min-height:430px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); background:#111; }
.map-wrap iframe { width:100%; height:100%; min-height:430px; border:0; filter: grayscale(.2) contrast(1.05); }
.hours-table { width:100%; border-collapse:collapse; margin-top:18px; overflow:hidden; border-radius:18px; }
.hours-table td { padding:11px 12px; border-bottom:1px solid var(--line); color:var(--muted); }
.hours-table tr.today td { color:#fff; background:rgba(241,24,24,.12); font-weight:900; }
.review-card { min-height:178px; display:flex; flex-direction:column; justify-content:space-between; }
.stars { color:var(--gold); letter-spacing:.06em; font-size:1.1rem; }
.form { display:grid; gap:14px; }
.form label { font-weight:850; }
.input, textarea, select { width:100%; min-height:48px; border:1px solid var(--line); background:rgba(255,255,255,.07); color:#fff; border-radius:16px; padding:12px 14px; font:inherit; outline:none; }
textarea { min-height:150px; resize:vertical; }
.input:focus, textarea:focus, select:focus { border-color:rgba(241,24,24,.65); box-shadow:0 0 0 4px rgba(241,24,24,.12); }
.footer { border-top:1px solid var(--line); background:rgba(0,0,0,.28); padding:40px 0; }
.footer-grid { display:grid; grid-template-columns: 1.2fr .8fr .8fr; gap:30px; }
.footer img { width:170px; }
.footer a { color:var(--muted); display:block; margin:8px 0; }
.footer a:hover { color:#fff; }
.copyright { color:var(--muted); padding-top:24px; margin-top:24px; border-top:1px solid var(--line); font-size:.92rem; }
.page-hero { padding:70px 0 34px; }
.breadcrumb { color:var(--muted); margin-bottom:18px; }
.breadcrumb a { color:#fff; }
.notice { background: rgba(255,178,44,.12); border:1px solid rgba(255,178,44,.35); color:#ffe7bb; border-radius:18px; padding:16px; }
@media (max-width: 900px) {
  .navbar { height:74px; }
  .brand img { width:142px; }
  .menu-toggle { display:block; }
  .nav-links { position:absolute; top:74px; left:20px; right:20px; flex-direction:column; align-items:stretch; background:rgba(8,9,13,.96); border:1px solid var(--line); border-radius:20px; padding:12px; transform:translateY(-16px); opacity:0; pointer-events:none; transition:.2s ease; }
  .nav-links.open { opacity:1; transform:translateY(0); pointer-events:auto; }
  .nav-links a { padding:14px; }
  .nav-actions .btn { display:none; }
  .hero-grid, .location-card, .grid-2 { grid-template-columns:1fr; }
  .grid-3 { grid-template-columns:1fr; }
  .hero-meta { grid-template-columns:1fr; }
  .section-head { align-items:flex-start; flex-direction:column; }
  .footer-grid { grid-template-columns:1fr; }
  .floating-card { position:static; width:100%; margin-top:14px; }
}
@media (max-width: 560px) {
  .container { width:min(var(--max), calc(100% - 28px)); }
  .hero { padding-top:52px; }
  .btn { width:100%; }
  h1 { font-size:3.15rem; }
  .logo-orb { padding:14px; border-radius:24px; }
  .section { padding:54px 0; }
}

/* Update: header/footer logo is a horizontal crop so it stays inside the nav bar */
.brand img { width: auto; height: 54px; max-width: 230px; object-fit: contain; }
.footer img { width: min(260px, 100%); height: auto; }

/* Make native dropdown options readable on all browsers */
select option { color: #111; background: #fff; }

.social-links { display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; }
.social-link { display:inline-flex !important; align-items:center; gap:9px; width:max-content; margin:0 !important; padding:9px 12px; border:1px solid var(--line); border-radius:999px; background:rgba(255,255,255,.06); }
.social-link svg { width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:2; }
.social-link:nth-child(2) svg { fill:currentColor; stroke:none; }
.social-link:hover { background:rgba(241,24,24,.14); border-color:rgba(241,24,24,.42); }

.reviews-marquee { overflow:hidden; border-radius:var(--radius); position:relative; }
.reviews-marquee::before,
.reviews-marquee::after { content:""; position:absolute; top:0; bottom:0; width:70px; z-index:2; pointer-events:none; }
.reviews-marquee::before { left:0; background:linear-gradient(90deg, var(--bg), transparent); }
.reviews-marquee::after { right:0; background:linear-gradient(270deg, var(--bg), transparent); }
.reviews-track { display:flex; gap:18px; width:max-content; animation: review-scroll 42s linear infinite; }
.reviews-marquee:hover .reviews-track { animation-play-state: paused; }
.reviews-track .review-card { width:360px; flex:0 0 auto; min-height:235px; }
@keyframes review-scroll { from { transform:translateX(0); } to { transform:translateX(-50%); } }

@media (max-width: 900px) {
  .brand img { height: 48px; max-width: 205px; }
}
@media (max-width: 560px) {
  .brand img { height: 42px; max-width: 180px; }
  .reviews-track .review-card { width: 310px; }
}

.section-head .hero-actions .btn { text-align:center; justify-content:center; }


.footer-bottom { display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; }
.legal-links { display:flex; gap:14px; flex-wrap:wrap; margin-left:auto; }
.legal-links a { margin:0; color:var(--muted); }
.legal-links a:hover { color:#fff; }
.form .check-row { display:flex; align-items:flex-start; gap:10px; padding:14px; border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.045); color:var(--muted); font-size:.92rem; }
.form .check-row input { margin-top:4px; width:18px; height:18px; accent-color:var(--red); flex:0 0 auto; }
.form .check-row label { font-weight:650; line-height:1.45; }
.legal-page .card h2 { margin-top:4px; font-size: clamp(1.55rem, 2.5vw, 2.25rem); }
.legal-page .card h3 { margin-top:24px; }
.legal-page .card p { color:var(--muted); }
@media (max-width: 560px) { .footer-bottom { align-items:flex-start; } .legal-links { margin-left:0; flex-direction:column; gap:8px; } }

/* Update 4: footer legal links aligned bottom-right with separator */
.footer-bottom { display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; }
.footer-bottom .legal-links { margin-left:auto; display:flex; justify-content:flex-end; align-items:center; gap:14px; text-align:right; }
.footer-bottom .legal-links a { display:inline-flex; align-items:center; margin:0; }
.footer-bottom .legal-links a + a::before { content:"|"; color:var(--muted); opacity:.75; margin-right:14px; }

/* Update 4: keep review CTA text perfectly centered */
.reviews-page .hero-actions .btn,
a.btn[href*="maps.app.goo.gl"] { justify-content:center; text-align:center; line-height:1.2; }

@media (max-width: 560px) {
  .footer-bottom .legal-links { margin-left:0; justify-content:flex-start; text-align:left; flex-direction:row; gap:12px; }
  .footer-bottom .legal-links a + a::before { margin-right:12px; }
}


/* Footer legal links visibility override */
.footer .footer-bottom {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
}
.footer .footer-bottom .legal-links {
  margin-left: auto !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  gap: 10px !important;
  text-align: right !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.footer .footer-bottom .legal-links a {
  display: inline-flex !important;
  color: var(--muted) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}
.footer .footer-bottom .legal-links a:hover { color: #fff !important; }
.footer .footer-bottom .legal-links a + a::before { content: none !important; }
.footer .footer-bottom .legal-separator { color: var(--muted); opacity: .75; }
@media (max-width: 640px) {
  .footer .footer-bottom { align-items: flex-start !important; }
  .footer .footer-bottom .legal-links { margin-left: 0 !important; justify-content: flex-start !important; text-align: left !important; }
}

/* Update 7: lock footer legal links and Google reviews CTA layout */
.footer .footer-bottom {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) max-content !important;
  align-items: center !important;
  column-gap: 18px !important;
  row-gap: 10px !important;
}
.footer .footer-bottom > span {
  min-width: 0 !important;
}
.footer .footer-bottom .legal-links {
  justify-self: end !important;
  display: inline-flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  min-width: max-content !important;
  white-space: nowrap !important;
  margin-left: 0 !important;
}
.footer .footer-bottom .legal-links a,
.footer .footer-bottom .legal-separator {
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
}
.footer .footer-bottom .legal-separator {
  width: auto !important;
  min-width: 0 !important;
  line-height: 1 !important;
}
@media (max-width: 640px) {
  .footer .footer-bottom {
    grid-template-columns: 1fr !important;
  }
  .footer .footer-bottom .legal-links {
    justify-self: end !important;
  }
}
.reviews-cta .btn,
.reviews-cta a.btn,
a.google-reviews-btn,
a.btn.google-reviews-btn,
a.btn[href="https://maps.app.goo.gl/ZdeAZzB5eoBVRnvd8"] {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  line-height: 1.2 !important;
}
@media (max-width: 560px) {
  .reviews-cta .btn,
  a.google-reviews-btn {
    width: 100% !important;
  }
}
