/* ==========================================================================
   UI — nav, buttons, stats, services bento, location/CTA, footer
   ========================================================================== */

/* ---- Nav ---- */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding: clamp(0.9rem, 0.5rem + 1vw, 1.5rem) var(--gutter);
  transition: background var(--dur-normal) var(--ease-soft),
              backdrop-filter var(--dur-normal) var(--ease-soft),
              border-color var(--dur-normal) var(--ease-soft);
  border-bottom: 1px solid transparent;
}
.nav[data-stuck] {
  background: oklch(10% 0 0 / 0.78);
  backdrop-filter: blur(14px) saturate(1.1);
  border-bottom-color: var(--color-line);
}
.nav__brand {
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  letter-spacing: -0.02em;
  display: inline-flex;
  align-items: baseline;
  gap: 0.45em;
}
.nav__brand { line-height: 0; }
/* Light logo made for dark backgrounds — no filter needed.
   Large when the nav is at the top; shrinks once you scroll (data-stuck). */
.nav__logo {
  height: clamp(56px, 6.8vw, 116px);   /* ~2× — prominent at the top */
  width: auto;
  opacity: 0.96;
  transition: height var(--dur-normal) var(--ease-out),
              opacity var(--dur-fast) var(--ease-soft);
}
.nav[data-stuck] .nav__logo { height: clamp(28px, 2.1vw, 36px); }
.nav__brand:hover .nav__logo { opacity: 1; }

/* ---- Nav menu (desktop links) ---- */
.nav__menu { display: flex; align-items: center; gap: clamp(1rem, 2vw, 2.2rem); }
.nav__menu a {
  position: relative;
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--color-text-soft);
  transition: color var(--dur-fast) var(--ease-soft);
}
.nav__menu a:hover { color: var(--color-text); }
.nav__menu a::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -5px;
  height: 1px;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-normal) var(--ease-out);
}
.nav__menu a:hover::after,
.nav__menu a[aria-current="page"]::after { transform: scaleX(1); }
.nav__sep { color: var(--color-text-mute); opacity: 0.45; font-weight: 400; user-select: none; }

.nav__right { display: flex; align-items: center; gap: var(--space-6); }

/* ---- Mobile menu toggle + overlay ---- */
.nav__toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 42px; height: 42px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--color-line);
  border-radius: 10px;
  cursor: pointer;
}
.nav__toggle span {
  display: block;
  width: 18px; height: 1.5px;
  margin-inline: auto;
  background: var(--color-text);
  transition: transform var(--dur-normal) var(--ease-out), opacity var(--dur-fast) linear;
}
.nav__toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.nav__panel {
  position: fixed;
  inset: 0;
  z-index: 99;
  display: grid;
  place-content: center;
  gap: var(--space-6);
  text-align: center;
  background: oklch(8% 0 0 / 0.97);
  backdrop-filter: blur(16px);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-normal) var(--ease-out);
}
.nav__panel[data-open] { opacity: 1; pointer-events: auto; }
.nav__panel a {
  font-family: var(--font-sans);
  font-size: var(--text-2xl);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
.nav__panel a[aria-current="page"] { color: var(--color-text-mute); }
.nav__panel .nav__panel-call {
  margin-top: var(--space-6);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-accent);
}

@media (max-width: 860px) {
  .nav__menu { display: none; }
  .nav__toggle { display: flex; }
}
.nav__hours {
  font-size: var(--text-sm);
  color: var(--color-text-mute);
  display: inline-flex; align-items: center; gap: 0.5em;
}
.nav__hours .pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--color-green);
  box-shadow: 0 0 0 0 var(--color-green);
  animation: pulse 2.4s var(--ease-in-out) infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 oklch(72% 0.16 152 / 0.6); }
  70%  { box-shadow: 0 0 0 9px oklch(72% 0.16 152 / 0); }
  100% { box-shadow: 0 0 0 0 oklch(72% 0.16 152 / 0); }
}
@media (max-width: 720px) { .nav__hours { display: none; } }

/* ---- Buttons ---- */
.btn {
  --bg: var(--color-accent);
  --fg: var(--color-bg-deep);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.85em 1.4em;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 560;
  letter-spacing: 0.01em;
  color: var(--fg);
  background: var(--bg);
  border: 1px solid transparent;
  border-radius: 100px;
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--dur-fast) var(--ease-out-expo),
              box-shadow var(--dur-normal) var(--ease-soft),
              color var(--dur-normal) var(--ease-soft);
}
.btn::after {
  content: "";
  position: absolute; inset: 0;
  z-index: -1;
  background: var(--color-accent-bright);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-normal) var(--ease-out-expo);
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 34px -10px oklch(0% 0 0 / 0.5); }
.btn:hover::after { transform: scaleX(1); }
.btn:active { transform: scale(0.97); transition-duration: 100ms; }
.btn .arrow { transition: transform var(--dur-normal) var(--ease-out-expo); }
.btn:hover .arrow { transform: translateX(4px); }

.btn--ghost {
  --bg: transparent;
  --fg: var(--color-text);
  border-color: var(--color-line);
}
.btn--ghost::after { background: var(--color-surface-2); }
.btn--lg { padding: 1.05em 1.8em; font-size: var(--text-base); }

/* ---- Stats band ---- */
.stats {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-8);
  padding-block: var(--space-section);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}
.stat__num {
  font-family: var(--font-sans);
  font-size: clamp(2.6rem, 1.4rem + 4vw, 5rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--color-text);
}
.stat__num em { font-style: italic; color: var(--color-accent-bright); }
.stat__label {
  margin-top: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-mute);
  max-width: 24ch;
}

/* ==========================================================================
   Grounded section — solid surface covers the video for practical info
   ========================================================================== */
.ground {
  position: relative;
  z-index: 10;
  background:
    radial-gradient(120% 80% at 80% 0%, var(--glow-accent), transparent 55%),
    linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-deep) 100%);
  border-top: 1px solid var(--color-line);
  box-shadow: 0 -40px 80px -30px oklch(0% 0 0 / 0.6);
}

.section-head {
  position: relative;
  display: grid;
  gap: var(--space-4);
  padding-block: var(--space-section) var(--space-12);
  max-width: 30ch;
}
.section-head::before {
  content: "";
  position: absolute;
  left: -10%; top: 30%;
  width: 60%; aspect-ratio: 1;
  background: radial-gradient(circle, var(--glow-accent), transparent 65%);
  filter: blur(30px);
  pointer-events: none;
  z-index: -1;
}

/* ---- Services bento ---- */
.bento {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(0.75rem, 0.4rem + 1vw, 1.25rem);
  padding-bottom: var(--space-section);
}
.card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--space-12);
  min-height: 260px;
  padding: clamp(1.4rem, 1rem + 1.4vw, 2.2rem);
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--dur-normal) var(--ease-out-expo),
              border-color var(--dur-normal) var(--ease-soft),
              background var(--dur-normal) var(--ease-soft);
}
.card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(80% 60% at 50% 120%, var(--glow-accent), transparent 70%);
  opacity: 0;
  transition: opacity var(--dur-slow) var(--ease-soft);
}
.card:hover {
  transform: translateY(-4px);
  border-color: oklch(100% 0 0 / 0.45);
  background: var(--color-surface-2);
}
.card:hover::before { opacity: 1; }
.card > * { position: relative; }

.card--wide { grid-column: span 4; }
.card--tall { grid-column: span 2; }
.card--half { grid-column: span 3; }
.card--third { grid-column: span 2; }

.card__icon {
  width: 44px; height: 44px;
  display: grid; place-content: center;
  border-radius: 12px;
  background: oklch(100% 0 0 / 0.14);
  border: 1px solid oklch(100% 0 0 / 0.30);
  color: var(--color-accent-bright);
}
.card__title { font-size: var(--text-xl); }
.card__body { margin-top: var(--space-3); font-size: var(--text-base); max-width: 40ch; }

@media (max-width: 860px) {
  .bento { grid-template-columns: repeat(2, 1fr); }
  .card--wide, .card--tall, .card--half, .card--third { grid-column: span 1; }
  .card--wide { grid-column: span 2; }
}
@media (max-width: 520px) {
  .bento { grid-template-columns: 1fr; }
  .card--wide { grid-column: span 1; }
}

/* ---- Location / CTA ---- */
.locate {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(1.5rem, 1rem + 3vw, 4rem);
  align-items: stretch;
  padding-bottom: var(--space-section);
}
@media (max-width: 800px) { .locate { grid-template-columns: 1fr; } }

.locate__card {
  padding: clamp(1.6rem, 1.2rem + 2vw, 3rem);
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
}
.locate__cta {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-6);
  padding: clamp(1.6rem, 1.2rem + 2vw, 3rem);
  background:
    radial-gradient(90% 90% at 100% 0%, var(--glow-acid), transparent 60%),
    linear-gradient(155deg, oklch(28% 0 0), oklch(16% 0 0));
  border-radius: var(--radius-lg);
  color: oklch(98% 0.008 95);
}
.locate__cta h3 { font-size: var(--text-2xl); max-width: 16ch; }
.locate__cta .btn { --bg: var(--color-bg-deep); --fg: var(--color-text); align-self: start; }
.locate__cta .btn::after { background: oklch(24% 0.025 80); }

.rows { display: grid; gap: var(--space-4); margin-top: var(--space-6); }
.row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-6);
  padding-block: var(--space-3);
  border-top: 1px solid var(--color-line);
  font-size: var(--text-base);
}
.row dt { color: var(--color-text-mute); }
.row dd { color: var(--color-text); font-weight: 500; text-align: right; }
.row dd em { color: var(--color-accent-bright); font-style: normal; }

.phone-xl {
  font-family: var(--font-sans);
  font-size: clamp(2.2rem, 1.4rem + 3vw, 4rem);
  letter-spacing: -0.03em;
  font-weight: 800;
  line-height: 1;
}

/* ---- Footer ---- */
.footer {
  position: relative;
  z-index: 10;
  background: var(--color-bg-deep);
  border-top: 1px solid var(--color-line);
  padding-block: var(--space-16) var(--space-8);
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: var(--space-8) var(--space-12);
  align-items: start;
  padding-bottom: var(--space-12);
}
.footer__brand { max-width: 36ch; }
.footer__logo {
  height: clamp(48px, 4.5vw, 68px);
  width: auto;
  opacity: 0.92;
  margin-bottom: var(--space-4);
  display: block;
}
.footer small { color: var(--color-text-mute); font-size: var(--text-sm); }

.footer__col { display: grid; gap: var(--space-3); align-content: start; }
.footer__heading {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-weight: 600;
  color: var(--color-text-mute);
  margin-bottom: var(--space-2);
}
.footer__heading::before {
  content: "";
  display: inline-block;
  width: 1.4em; height: 1px;
  margin-right: 0.7em;
  vertical-align: middle;
  background: var(--color-red);
}
.footer__col a, .footer__col span {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  width: max-content;
  transition: color var(--dur-fast) var(--ease-soft);
}
.footer__col a:hover { color: var(--color-text); }

.footer__bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-3) var(--space-6);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-line);
}
.footer__powered a {
  color: var(--color-text-soft);
  border-bottom: 1px solid var(--color-line);
  transition: color var(--dur-fast) var(--ease-soft), border-color var(--dur-fast) var(--ease-soft);
}
.footer__powered a:hover { color: var(--color-text); border-color: var(--color-text-mute); }

@media (max-width: 680px) {
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
}
