/* ============================================================
   SHOT BY SHELDON — MASTER CSS
   Liquid Glass · Rose-Tinted Grey Palette
   Consolidated styles for all pages
   ============================================================ */

/* ---------- CSS VARIABLES (Rose-Tinted Palette) ---------- */
:root {
  /* Core brand — rose-tinted greyscale */
  --color-ink: #1a1618;
  --color-ink-soft: #3a3236;
  --color-mist: #6b6066;
  --color-rose-mist: #b8aeb4;
  --color-rose-petal: #d6cdd3;
  --color-cream: #faf8f6;
  
  /* NEW: Medium grey with rose tint for background */
  --color-bg-start: #e8e4e6;
  --color-bg-end: #d4cdd1;
  
  /* Glass surfaces — rose undertone (more opaque for visibility) */
  --glass-light: rgba(255, 255, 255, 0.92);
  --glass-solid: rgba(255, 255, 255, 0.98);
  --glass-dark: rgba(26, 22, 24, 0.82);
  --glass-border-light: rgba(255, 255, 255, 0.8);
  --glass-border-dark: rgba(255, 255, 255, 0.25);
  
  /* Specular highlights */
  --glass-specular: inset 0 1px 0 rgba(255, 255, 255, 0.95),
                    inset 0 0 0 1px rgba(255, 255, 255, 0.6);
  --glass-specular-dark: inset 0 1px 0 rgba(255, 255, 255, 0.3),
                         inset 0 0 0 1px rgba(255, 255, 255, 0.15);
  
  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 8px 24px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 16px 40px rgba(0, 0, 0, 0.12);
  --shadow-hover: 0 24px 48px rgba(0, 0, 0, 0.16);
  
  /* Blur levels */
  --blur-strong: blur(16px);
  --blur-mid: blur(12px);
  --blur-light: blur(6px);
  
  /* Glass gradient shine */
  --glass-gloss: linear-gradient(135deg,
                  rgba(255, 255, 255, 0.6) 0%,
                  rgba(255, 255, 255, 0.15) 30%,
                  transparent 50%,
                  rgba(255, 255, 255, 0.1) 70%,
                  rgba(255, 255, 255, 0.3) 100%);
  
  --ease-ios: cubic-bezier(0.25, 0.1, 0.1, 1);
}

/* ---------- BASE RESET ---------- */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body {
  background: linear-gradient(135deg, var(--color-bg-start) 0%, var(--color-bg-end) 100%);
  color: var(--color-ink);
  font-family: 'Sora', sans-serif;
  -webkit-font-smoothing: antialiased;
  font-size: 16px;
  line-height: 1.6;
  min-height: 100vh;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: var(--color-ink-soft);
  text-decoration: none;
  transition: 0.2s ease;
}

a:hover {
  color: var(--color-mist);
}

/* ---------- TYPOGRAPHY ---------- */
h1, h2, h3, h4 {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.05;
  color: var(--color-ink);
}

h1 em, h2 em, h3 em, h4 em {
  font-style: italic;
  font-weight: 300;
  color: var(--color-mist);
}

.eyebrow, .eb {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-rose-mist);
  font-weight: 600;
}

/* ---------- CONTAINER ---------- */
.container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 40px;
}

@media (max-width: 880px) {
  .container {
    padding: 0 24px;
  }
}

/* ---------- APPLE-LIKE LIQUID GLASS NAVIGATION BAR ---------- */
.nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  /* Full-width sticky bar, but its inner content is capped at 1320px on wide
     screens so the logo and CTA don't sit at opposite ends of a 4K display. */
  padding: 14px max(32px, calc((100vw - 1600px) / 2));
  flex-wrap: wrap;
  gap: 24px;
  position: sticky;
  top: 0;
  z-index: 1000;
  width: 100%;
  background: var(--glass-solid);
  backdrop-filter: var(--blur-strong);
  -webkit-backdrop-filter: var(--blur-strong);
  border-bottom: 0.5px solid var(--glass-border-light);
  box-shadow: var(--shadow-sm);
}

.nav .logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Fahkwang', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink);
  text-decoration: none;
}

.nav .logo::before {
  content: '';
  width: 28px;
  height: 28px;
  background: url('../images/sbs-glass.svg') center / contain no-repeat;
  flex: none;
  transition: transform 0.45s var(--ease-ios);
}

.nav .logo:hover::before {
  transform: scale(1.05) translateY(-1px);
}

.nav-toggle {
  display: none;
}

.nav-toggle-btn {
  display: none;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 8px 14px;
  background: var(--glass-light);
  backdrop-filter: var(--blur-light);
  border-radius: 30px;
  border: 0.5px solid var(--glass-border-light);
}

.nav-links {
  display: flex;
  gap: 4px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  list-style: none;
  align-items: center;
  /* Pull the nav links closer to the centre on wide screens so the logo
     and CTA don't feel marooned at the edges. */
  margin: 0 auto;
}

.nav-links a {
  color: var(--color-mist);
  text-decoration: none;
  padding: 8px 16px;
  transition: 0.15s;
  border-radius: 30px;
  font-weight: 500;
  /* Uniform tab width — every link renders at the same size as the widest
     label (Locations / Dashboard) so the menu reads as evenly-spaced tabs
     instead of clustering tightly around the short links. */
  min-width: 104px;
  text-align: center;
  white-space: nowrap;
  box-sizing: border-box;
}

.nav-links a:hover {
  background: rgba(107, 96, 102, 0.12);
  color: var(--color-ink);
}

.nav-links a.active {
  color: var(--color-ink);
  font-weight: 600;
  background: rgba(107, 96, 102, 0.08);
}

.nav-cta {
  color: white;
  padding: 8px 20px;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  text-decoration: none;
  background: var(--color-ink);
  border-radius: 30px;
  transition: 0.2s;
}

.nav-cta:hover {
  background: var(--color-ink-soft);
  color: white;
  transform: translateY(-1px);
}

@media (max-width: 880px) {
  .nav {
    padding: 12px 20px;
    gap: 12px;
  }

  .nav-toggle-btn {
    display: inline-block;
  }

  .nav-links, .nav-cta {
    display: none;
    width: 100%;
  }

  .nav-links { margin: 0; }

  .nav-toggle:checked ~ .nav-links {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding-top: 16px;
    margin-top: 12px;
    border-top: 0.5px solid var(--color-rose-petal);
  }

  .nav-toggle:checked ~ .nav-links li {
    padding: 10px 0;
  }

  /* On mobile, reset the uniform tab width so links flow full-bleed */
  .nav-toggle:checked ~ .nav-links a {
    min-width: 0;
    text-align: left;
    padding: 8px 0;
  }

  .nav-toggle:checked ~ .nav-cta {
    display: inline-block;
    margin-top: 12px;
    text-align: center;
  }
}

/* ---------- BUTTONS ---------- */
.btn-primary {
  background: var(--color-ink);
  color: white;
  padding: 14px 28px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 500;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 40px;
  transition: all 0.25s var(--ease-ios);
  border: none;
  cursor: pointer;
}

.btn-primary:hover {
  background: var(--color-ink-soft);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn-ghost {
  background: transparent;
  color: var(--color-ink);
  padding: 14px 4px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 500;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--color-rose-mist);
  transition: 0.2s;
}

.btn-ghost:hover {
  color: var(--color-mist);
  border-bottom-color: var(--color-mist);
  gap: 12px;
}

/* ---------- DARK TICKER (Medium-sized, full-width, darker) ---------- */
.dark-ticker {
  background: rgba(26, 22, 24, 0.94);
  backdrop-filter: var(--blur-mid);
  color: var(--color-rose-mist);
  padding: 18px 0;
  overflow: hidden;
  white-space: nowrap;
  border-block: 0.5px solid rgba(255, 255, 255, 0.1);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 15px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 500;
}

.ticker-track {
  display: inline-flex;
  gap: 60px;
  animation: scrollTicker 30s linear infinite;
}

@keyframes scrollTicker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ---------- LIQUID GLASS CARD SYSTEM ---------- */
.glass-card-light,
.glass-card-dark {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  transition: transform 0.25s var(--ease-ios), box-shadow 0.25s var(--ease-ios);
}

/* Light glass — visible on rose-grey background */
.glass-card-light {
  background: var(--glass-light);
  backdrop-filter: var(--blur-mid);
  border: 1px solid var(--glass-border-light);
  box-shadow: var(--shadow-md), var(--glass-specular);
}

.glass-card-light:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover), var(--glass-specular);
  background: rgba(255, 255, 255, 0.97);
}

/* Dark glass — for dark overlay sections */
.glass-card-dark {
  background: var(--glass-dark);
  backdrop-filter: var(--blur-mid);
  border: 0.5px solid var(--glass-border-dark);
  box-shadow: var(--shadow-md), var(--glass-specular-dark);
}

.glass-card-dark:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
  background: rgba(26, 22, 24, 0.9);
}

/* Glass shine overlay */
.glass-card-light::before,
.glass-card-dark::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--glass-gloss);
  pointer-events: none;
  z-index: 1;
}

.glass-card-light > *,
.glass-card-dark > * {
  position: relative;
  z-index: 2;
}

/* Dark glass text overrides */
.glass-card-dark h1,
.glass-card-dark h2,
.glass-card-dark h3,
.glass-card-dark h4 {
  color: white;
}

.glass-card-dark p,
.glass-card-dark .text-muted {
  color: var(--color-rose-mist);
}

.card-padding {
  padding: 28px 24px;
}

/* ---------- CIRCULAR BOKEH CHIPS (Visible, shiny but flat) ---------- */
.bokeh-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%,
    rgba(255, 255, 255, 0.96) 0%,
    rgba(255, 255, 255, 0.75) 40%,
    rgba(184, 174, 180, 0.55) 70%,
    rgba(107, 96, 102, 0.25) 100%);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06),
              inset 0 1px 0 rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(2px);
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 500;
  transition: all 0.2s ease;
  color: var(--color-ink);
}

.bokeh-chip-sm {
  width: 36px;
  height: 36px;
  font-size: 13px;
}

.bokeh-chip-md {
  width: 52px;
  height: 52px;
  font-size: 18px;
}

.bokeh-chip-lg {
  width: 80px;
  height: 80px;
  font-size: 24px;
}

.bokeh-chip-rose {
  background: radial-gradient(circle at 30% 30%,
    rgba(214, 205, 211, 0.96) 0%,
    rgba(184, 174, 180, 0.85) 50%,
    rgba(107, 96, 102, 0.45) 100%);
}

.bokeh-chip-ink {
  background: radial-gradient(circle at 30% 30%,
    rgba(26, 22, 24, 0.95) 0%,
    rgba(58, 50, 54, 0.85) 50%,
    rgba(107, 96, 102, 0.45) 100%);
  color: white;
}

/* ---------- STAT BUBBLES ---------- */
.stat-bubble {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 12px 20px;
  border-radius: 60px;
  background: var(--glass-light);
  backdrop-filter: var(--blur-mid);
  border: 0.5px solid var(--glass-border-light);
}

.stat-bubble .num {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 300;
  font-size: 28px;
  color: var(--color-ink);
  line-height: 1;
}

.stat-bubble .num span {
  font-size: 16px;
  color: var(--color-mist);
}

.stat-bubble .lbl {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mist);
  margin-top: 4px;
}

/* Dark variant */
.stat-bubble-dark {
  background: var(--glass-dark);
  border-color: var(--glass-border-dark);
}

.stat-bubble-dark .num {
  color: white;
}

.stat-bubble-dark .lbl {
  color: var(--color-rose-mist);
}

/* ---------- IMAGE FRAME ---------- */
.image-frame {
  border-radius: 24px;
  overflow: hidden;
  background: var(--color-rose-petal);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.03);
}

.image-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ---------- DARK CLOSING CTA ---------- */
.closing-cta-dark {
  background: rgba(26, 22, 24, 0.96);
  backdrop-filter: var(--blur-strong);
  text-align: center;
  padding: 80px 24px;
  margin-top: 80px;
  border-top: 0.5px solid rgba(255, 255, 255, 0.08);
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.08);
}

.closing-cta-dark .container {
  max-width: 760px;
  margin: 0 auto;
}

.closing-cta-dark .eyebrow {
  color: var(--color-rose-mist);
  margin-bottom: 20px;
}

.closing-cta-dark h2 {
  color: white;
  font-size: clamp(36px, 5vw, 64px);
  letter-spacing: -0.03em;
  margin-bottom: 22px;
  font-weight: 300;
}

.closing-cta-dark h2 em {
  color: var(--color-rose-mist);
  font-weight: 400;
}

.closing-cta-dark p {
  color: var(--color-rose-mist);
  font-size: 17px;
  max-width: 520px;
  margin: 0 auto 32px;
}

.closing-cta-dark .cta-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

.btn-primary-light {
  background: white;
  color: var(--color-ink);
  padding: 14px 28px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 500;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 40px;
  transition: all 0.25s var(--ease-ios);
}

.btn-primary-light:hover {
  transform: translateY(-2px);
  background: var(--color-rose-petal);
  box-shadow: var(--shadow-md);
}

.btn-ghost-light {
  background: transparent;
  color: white;
  padding: 14px 28px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 500;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 0.5px solid rgba(255, 255, 255, 0.3);
  border-radius: 40px;
  transition: all 0.25s var(--ease-ios);
}

.btn-ghost-light:hover {
  border-color: white;
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.05);
  gap: 12px;
}

/* ---------- WORK / SERVICE CARDS GRID ---------- */
.section {
  padding: 80px 0;
}

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin: 0 auto 36px;
  max-width: 1240px;
  padding: 0 40px 20px;
  gap: 16px;
  flex-wrap: wrap;
  border-bottom: 0.5px solid var(--color-rose-petal);
}

.section-head h2 {
  font-size: clamp(32px, 4vw, 48px);
}

.section-head .count {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-mist);
}

@media (max-width: 880px) {
  .section {
    padding: 56px 0;
  }
  .section-head {
    padding: 0 24px 16px;
  }
}

.work-grid,
.services-grid {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 40px;
}

.work-cards,
.services-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

@media (max-width: 980px) {
  .work-cards,
  .services-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .work-cards,
  .services-cards {
    grid-template-columns: 1fr;
  }
}

.work-card,
.service-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  text-decoration: none;
  color: var(--color-ink);
  transition: 0.2s;
}

.work-card:hover,
.service-card:hover {
  transform: translateY(-2px);
}

.work-card .num,
.service-card .num {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  color: var(--color-rose-mist);
  letter-spacing: 0.18em;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-transform: uppercase;
}

/* Icon pill nested inside a .num label (e.g. services.html cards) */
.work-card .num .icon-bubble,
.service-card .num .icon-bubble {
  flex: none;
  margin: 0;
  font-size: 13px;
  line-height: 1;
}

/* Contact-page direct-line rows and About-page channel rows host an
   icon-bubble next to a small uppercase label — give the wrapper a
   flex layout with gap so the pill stays vertically centered next to
   text on every page, without inline width/margin hacks. */
.line .num,
.contact-grid .line .num {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.channel .top {
  gap: 10px;
}

.channel .top .icon-bubble {
  margin: 0;
}

.work-card h3,
.service-card h3 {
  font-size: 24px;
  letter-spacing: -0.01em;
  line-height: 1.15;
}

.work-card p,
.service-card p {
  font-size: 14px;
  color: var(--color-mist);
  line-height: 1.55;
}

.work-card .arrow,
.service-card .arrow {
  margin-top: auto;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mist);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 4px;
}

.work-card .arrow::after,
.service-card .arrow::after {
  content: '→';
  font-family: 'Sora', sans-serif;
  font-size: 18px;
  color: var(--color-ink);
  transition: transform 0.2s;
}

.work-card:hover .arrow::after,
.service-card:hover .arrow::after {
  transform: translateX(4px);
}

/* ---------- REVIEWS GRID ---------- */
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 40px;
}

@media (max-width: 880px) {
  .reviews-grid {
    grid-template-columns: 1fr;
  }
}

.review-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: var(--glass-light);
  backdrop-filter: var(--blur-mid);
  border-radius: 28px;
  padding: 28px 24px;
  border: 1px solid var(--glass-border-light);
}

.review-card .stars {
  color: var(--color-rose-mist);
  letter-spacing: 0.12em;
  font-size: 14px;
}

.review-card p {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-style: italic;
  font-size: 17px;
  line-height: 1.5;
  color: var(--color-ink);
  letter-spacing: -0.005em;
  flex: 1;
}

.review-card .author {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mist);
  display: flex;
  justify-content: space-between;
  padding-top: 12px;
}

/* ---------- LOCATIONS LIST ---------- */
.locations-grid {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 40px;
}

.loc-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

.loc-row {
  display: grid;
  grid-template-columns: 60px 1.6fr 1.4fr 1fr 60px;
  gap: 24px;
  align-items: center;
  padding: 22px 8px;
  text-decoration: none;
  color: var(--color-ink);
  transition: 0.15s;
  border-bottom: 0.5px solid var(--color-rose-petal);
  background: var(--glass-light);
  backdrop-filter: var(--blur-light);
  border-radius: 20px;
  margin-bottom: 8px;
}

.loc-row:last-child {
  border-bottom: none;
}

.loc-row .num {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--color-rose-mist);
  font-weight: 600;
}

.loc-row .name {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 24px;
  color: var(--color-ink);
  letter-spacing: -0.01em;
}

.loc-row .name em {
  font-style: italic;
  color: var(--color-mist);
}

.loc-row .desc {
  font-size: 14px;
  color: var(--color-ink-soft);
}

.loc-row .tag {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mist);
}

.loc-row .arr {
  font-family: 'Sora', sans-serif;
  font-size: 22px;
  color: var(--color-ink);
  text-align: right;
  transition: 0.2s;
}

.loc-row:hover .arr {
  transform: translateX(4px);
}

@media (max-width: 880px) {
  .loc-row {
    grid-template-columns: 40px 1fr 40px;
  }
  .loc-row .desc,
  .loc-row .tag {
    display: none;
  }
}

/* ---------- FOOTER ---------- */
footer {
  color: var(--color-ink-soft);
  padding: 64px 40px 32px;
  position: relative;
  z-index: 2;
  background: transparent;
}

.footer-inner {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 56px;
  align-items: start;
}

@media (max-width: 880px) {
  .footer-inner {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
  }
}

@media (max-width: 600px) {
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

footer .brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-style: italic;
  font-size: 28px;
  color: var(--color-ink);
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}

footer .brand::before {
  content: '';
  width: 30px;
  height: 30px;
  background: url('../images/sbs-glass.svg') center / contain no-repeat;
  flex: none;
}

footer .brand em {
  color: var(--color-mist);
}

footer .brand-sub {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-rose-mist);
  margin-bottom: 24px;
}

footer .blurb {
  font-size: 13px;
  color: var(--color-ink-soft);
  line-height: 1.6;
  max-width: 320px;
  margin-bottom: 18px;
}

footer h4 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-rose-mist);
  font-weight: 600;
  margin-bottom: 16px;
}

footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

footer ul a {
  color: var(--color-ink-soft);
  text-decoration: none;
  font-size: 13px;
  font-family: 'Sora', sans-serif;
  transition: 0.15s;
}

footer ul a:hover {
  color: var(--color-ink);
}

.footer-bottom {
  margin-top: 56px;
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--color-rose-mist);
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  flex-wrap: wrap;
  gap: 16px;
  border-top: 0.5px solid var(--color-rose-petal);
}

.footer-bottom a {
  color: var(--color-rose-mist);
  text-decoration: none;
}

.footer-bottom a:hover {
  color: var(--color-ink);
}

.footer-bottom .legal {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}

/* ---------- LAND ACKNOWLEDGEMENT ---------- */
.land-ack {
  font-size: 10px;
  line-height: 1.5;
  max-width: 600px;
  color: var(--color-mist);
}

/* ---------- PAGE HEAD (Interior pages) ---------- */
.page-head {
  max-width: 1240px;
  margin: 0 auto;
  padding: 80px 40px 56px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: end;
}

.page-head .eb {
  display: inline-block;
  margin-bottom: 18px;
}

.page-head h1 {
  font-size: clamp(48px, 6vw, 88px);
  letter-spacing: -0.025em;
  line-height: 1;
  margin-bottom: 18px;
}

.page-head .lede {
  color: var(--color-ink-soft);
  font-size: 17px;
  max-width: 480px;
  line-height: 1.55;
}

.page-head .meta-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mist);
}

.page-head .meta-list .row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 14px;
  border-bottom: 0.5px solid var(--color-rose-petal);
}

.page-head .meta-list .row strong {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 400;
  font-size: 18px;
  letter-spacing: -0.01em;
  color: var(--color-ink);
  text-transform: none;
}

@media (max-width: 880px) {
  .page-head {
    grid-template-columns: 1fr;
    padding: 56px 24px 40px;
    gap: 28px;
  }
}

/* ---------- ARTICLE BODY ---------- */
.article {
  max-width: 760px;
  margin: 80px auto;
  padding: 0 40px;
}

.article p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--color-ink-soft);
  margin-bottom: 18px;
}

.article p strong {
  color: var(--color-ink);
}

.article h2 {
  font-size: clamp(28px, 3.4vw, 40px);
  letter-spacing: -0.02em;
  margin: 56px 0 18px;
  padding-top: 36px;
  border-top: 0.5px solid var(--color-rose-petal);
}

.article h2:first-child {
  padding-top: 0;
  border-top: none;
  margin-top: 0;
}

.article h3 {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 22px;
  letter-spacing: -0.01em;
  margin: 28px 0 10px;
  color: var(--color-ink);
}

.article ul,
.article ol {
  margin: 8px 0 22px 22px;
}

.article li {
  font-size: 16px;
  line-height: 1.7;
  color: var(--color-ink-soft);
  margin-bottom: 8px;
}

.article a {
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-rose-mist);
}

.article blockquote {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 300;
  font-size: 22px;
  line-height: 1.4;
  color: var(--color-ink);
  padding: 8px 0 8px 22px;
  margin: 28px 0;
  border-left: 2px solid var(--color-rose-mist);
}

.article table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
}

.article th,
.article td {
  padding: 12px 14px;
  border-bottom: 0.5px solid var(--color-rose-petal);
  text-align: left;
  font-size: 14px;
}

/* ---------- UTILITY CLASSES ---------- */
.text-center {
  text-align: center;
}

.text-rose {
  color: var(--color-rose-mist);
}

.text-ink-soft {
  color: var(--color-ink-soft);
}

.mt-0 { margin-top: 0; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-3 { margin-top: 24px; }
.mt-4 { margin-top: 32px; }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 16px; }
.mb-3 { margin-bottom: 24px; }
.mb-4 { margin-bottom: 32px; }

/* ============================================================
   INTERIOR-PAGE COMPONENTS
   Everything below was previously duplicated in each interior
   page's inline <style> block. Now consolidated here so every
   page shares the same rose / two-tier-glass system.
   ============================================================ */

/* ---------- TOP ANNOUNCEMENT BAR (legacy markup, kept low-key) ---------- */
.top-bar {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  padding: 9px 24px;
  background: var(--glass-dark);
  -webkit-backdrop-filter: var(--blur-mid);
          backdrop-filter: var(--blur-mid);
  color: var(--color-rose-mist);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
}
.top-bar a { color: #fff; text-decoration: none; }
.top-bar a:hover { color: var(--color-rose-mist); }
.top-bar .pulse { color: var(--color-rose-mist); }
@media (max-width: 720px) {
  .top-bar { font-size: 10px; letter-spacing: 0.14em; padding: 8px 16px; }
}

/* ---------- INTERIOR HERO (used on service / location subpages) ---------- */
.hero {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 64px;
  padding: 60px 40px 40px;
  max-width: 1240px;
  margin: 0 auto;
  align-items: center;
}
.hero-left .meta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mist);
}
.hero-left .meta .pipe { color: var(--color-rose-mist); }
.hero-left h1 {
  font-size: clamp(46px, 6vw, 88px);
  line-height: 0.98;
  margin-bottom: 24px;
}
.hero-left .lede {
  max-width: 460px;
  font-size: 17px;
  color: var(--color-ink-soft);
  margin-bottom: 32px;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.hero-right { position: relative; }
.hero-image {
  width: 100%;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  background: var(--glass-light);
  aspect-ratio: 4/5;
}
.hero-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-tag {
  display: inline-block;
  background: var(--glass-light);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  border: 0.5px solid var(--glass-border-light);
  color: var(--color-ink);
  padding: 8px 16px;
  border-radius: 40px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
}
@media (max-width: 880px) {
  .hero { grid-template-columns: 1fr; padding: 40px 24px; gap: 40px; }
}

/* ---------- LIGHT CARD (Golden-hour 3-up panel) ---------- */
.light-card {
  max-width: 900px;
  margin: 40px auto;
  background: var(--glass-light);
  -webkit-backdrop-filter: var(--blur-mid);
          backdrop-filter: var(--blur-mid);
  border-radius: 28px;
  border: 1px solid var(--glass-border-light);
  box-shadow: var(--shadow-md), var(--glass-specular);
  padding: 28px 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
}
.lc-eyebrow {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-rose-mist);
  margin-bottom: 4px;
}
.lc-time {
  font-family: 'Fraunces', serif;
  font-size: 28px;
  color: var(--color-ink);
  letter-spacing: -0.02em;
}
.lc-time em { font-style: italic; color: var(--color-mist); font-weight: 300; }
.lc-sub {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  color: var(--color-mist);
  margin-top: 2px;
}
@media (max-width: 720px) {
  .light-card { flex-direction: column; text-align: center; margin: 32px 24px; padding: 24px; }
}

/* ---------- TWO-TIER GLASS CARD (alias for legacy class names) ---------- */
.review,
.support-link,
.work-card,
.service-card,
.stat-bubble,
.contact-wrap, .contact-grid .cell,
.hours-inner, .travel-list,
.channel, .specs, .stats-inner,
.about-portrait, .portrait-tile, .frame, .visual,
.shop-grid .product, .callout,
.product-card,
.login-card, .card, .stat-card, .lead-card,
.machine-card, .quick-link, .funnel, .mini-chart,
.cal-modal-card, .table-wrap {
  background: var(--glass-light);
  -webkit-backdrop-filter: var(--blur-mid);
          backdrop-filter: var(--blur-mid);
  border: 1px solid var(--glass-border-light);
  border-radius: 24px;
  box-shadow: var(--shadow-md), var(--glass-specular);
  transition: transform 0.25s var(--ease-ios), box-shadow 0.25s var(--ease-ios);
}

/* dark tier (feature / CTA blocks) */
.guarantee-inner,
.support-callout,
.shop-callout,
.dark-tile-deep,
.machines-banner,
.icon-bubble--dark {
  background: rgba(26, 22, 24, 0.92);
  -webkit-backdrop-filter: var(--blur-strong);
          backdrop-filter: var(--blur-strong);
  border: 0.5px solid var(--glass-border-dark);
  border-radius: 28px;
  box-shadow: var(--shadow-lg), var(--glass-specular-dark);
  color: #ece7ea;
}
.guarantee-inner h2, .guarantee-inner h3,
.support-callout h2, .support-callout h3,
.shop-callout h2, .shop-callout h3,
.dark-tile-deep h2, .dark-tile-deep h3 { color: #fff; }
.guarantee-inner p, .support-callout p, .shop-callout p,
.dark-tile-deep p { color: var(--color-rose-mist); }

/* ---------- VISION GUARANTEE ---------- */
.guarantee { margin: 60px auto; max-width: 1240px; padding: 0 40px; }
.guarantee-inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 56px;
  padding: 56px 48px;
  position: relative;
}
.guarantee-inner .stamp {
  position: absolute;
  top: 28px; right: 32px;
  width: 92px; height: 92px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  text-align: center;
  color: var(--color-rose-mist);
  font-weight: 600;
  line-height: 1.4;
}
.guarantee-inner .stamp em {
  display: block;
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 22px;
  color: #fff;
  font-weight: 300;
}
.guarantee-inner .eyebrow-light {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-rose-mist);
  margin-bottom: 18px;
  font-weight: 600;
}
.guarantee-inner h2 {
  font-size: clamp(32px, 4vw, 52px);
  letter-spacing: -0.025em;
  line-height: 1;
  margin-bottom: 22px;
  font-weight: 300;
}
.guarantee-inner h2 em { color: var(--color-rose-mist); font-weight: 400; }
.pills { display: flex; gap: 8px; flex-wrap: wrap; }
.pill {
  padding: 7px 14px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 40px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-rose-mist);
}
.pill.gold { background: #fff; color: var(--color-ink); }
.guarantee-quote { padding: 24px; }
.guarantee-quote .qm {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 72px;
  line-height: 0.4;
  color: var(--color-rose-mist);
  display: block;
  margin-bottom: 14px;
}
.guarantee-quote blockquote {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-size: 19px;
  line-height: 1.45;
  color: #fff;
  margin-bottom: 18px;
}
.guarantee-quote cite {
  font-style: normal;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-rose-mist);
}
@media (max-width: 880px) {
  .guarantee-inner { grid-template-columns: 1fr; padding: 40px 28px; gap: 32px; }
  .guarantee-inner .stamp { display: none; }
}

/* ---------- REVIEWS BLOCK (alias: legacy .review === .review-card) ---------- */
.reviews, .reviews-section { padding: 60px 40px; max-width: 1240px; margin: 0 auto; }
.reviews-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 32px;
  padding-bottom: 16px;
  border-bottom: 0.5px solid var(--color-rose-petal);
  gap: 16px;
  flex-wrap: wrap;
}
.reviews-head h2 { font-size: clamp(28px, 4vw, 44px); }
.reviews-head .meta {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mist);
  text-align: right;
}
.reviews-head .meta strong {
  display: block;
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 26px;
  color: var(--color-ink);
  letter-spacing: -0.02em;
  text-transform: none;
  margin-top: 4px;
}
.review {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 28px 24px;
}
.review .stars {
  color: var(--color-rose-mist);
  letter-spacing: 0.12em;
  font-size: 14px;
}
.review p {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-style: italic;
  font-size: 17px;
  line-height: 1.5;
  color: var(--color-ink);
  flex: 1;
}
.review .author {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mist);
  display: flex;
  justify-content: space-between;
  padding-top: 8px;
}
.reviews-cta { text-align: center; margin-top: 24px; }

/* ---------- LOCATIONS WRAPPER ---------- */
.locations {
  max-width: 1240px;
  margin: 60px auto;
  padding: 0 40px;
}
.locations h2 { font-size: clamp(28px, 4vw, 48px); margin-bottom: 24px; }
.locations h2 em { color: var(--color-mist); font-style: italic; font-weight: 300; }

/* ---------- SUPPORT / RESOURCES BLOCK ---------- */
.support, .support-section {
  max-width: 1240px;
  margin: 60px auto;
  padding: 0 40px;
}
.support-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  max-width: 920px;
  margin: 0 auto 40px;
}
@media (max-width: 720px) { .support-grid { grid-template-columns: repeat(2, 1fr); } }
.support-link {
  padding: 14px 18px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-ink);
  text-decoration: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  border-radius: 60px;
  font-weight: 500;
}
.support-link:hover {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.95);
}
.support-link .arr { color: var(--color-rose-mist); font-size: 16px; }
.support-callout {
  max-width: 600px;
  margin: 0 auto;
  padding: 44px 36px;
  text-align: center;
}
.support-callout .ribbon, .shop-callout .ribbon {
  display: inline-block;
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  border-radius: 40px;
  padding: 5px 14px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 18px;
}

/* ---------- IMAGE PLACEHOLDER SLOTS ---------- */
.img-slot {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--glass-light);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
  border: 1px dashed var(--color-rose-mist);
  border-radius: 20px;
  color: var(--color-mist);
}
.img-slot::before {
  content: '';
  position: absolute; inset: 12px;
  background: repeating-linear-gradient(45deg, transparent 0 22px, rgba(184, 174, 180, 0.16) 22px 23px);
  pointer-events: none;
  border-radius: inherit;
}
.img-slot .label {
  position: relative;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-mist);
  padding: 8px 12px;
  max-width: 78%;
  text-align: center;
}

/* ---------- BUBBLE ROW (group of bokeh-chip-style stats) ---------- */
.bubble-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.bubble-row--center { justify-content: center; }

/* ---------- DARK CLOSING CTA — legacy .closing markup === .closing-cta-dark ---------- */
.closing,
.closing-cta-dark {
  background: rgba(26, 22, 24, 0.96);
  -webkit-backdrop-filter: var(--blur-strong);
          backdrop-filter: var(--blur-strong);
  text-align: center;
  padding: clamp(64px, 9vw, 96px) 24px;
  margin: 80px 0 0;
  border-top: 0.5px solid rgba(255, 255, 255, 0.08);
  border-bottom: 0.5px solid rgba(255, 255, 255, 0.08);
  position: relative;
  z-index: 2;
}
.closing .closing-inner,
.closing-cta-dark .container {
  max-width: 760px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.closing .eb,
.closing .eyebrow,
.closing-cta-dark .eyebrow {
  color: var(--color-rose-mist);
  margin-bottom: 20px;
}
.closing h2,
.closing-cta-dark h2 {
  color: #fff;
  font-size: clamp(36px, 5vw, 64px);
  letter-spacing: -0.03em;
  margin-bottom: 22px;
  font-weight: 300;
}
.closing h2 em,
.closing-cta-dark h2 em { color: var(--color-rose-mist); font-weight: 400; }
.closing p,
.closing-cta-dark p {
  color: var(--color-rose-mist);
  font-size: 17px;
  max-width: 520px;
  margin: 0 auto 28px;
}
.closing-actions,
.closing-cta-dark .cta-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
/* primary button inverts inside the dark band */
.closing .btn-primary,
.closing-cta-dark .btn-primary {
  background: #fff;
  color: var(--color-ink);
}
.closing .btn-primary:hover,
.closing-cta-dark .btn-primary:hover {
  background: var(--color-rose-petal);
  color: var(--color-ink);
}
.closing .btn-ghost,
.closing-cta-dark .btn-ghost {
  color: #fff;
  border: 0.5px solid rgba(255, 255, 255, 0.4);
  border-radius: 40px;
  padding: 14px 24px;
  border-bottom-width: 0.5px;
}
.closing .btn-ghost:hover,
.closing-cta-dark .btn-ghost:hover {
  border-color: #fff;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

/* ---------- DARK TICKER — sits at the TOP of every page, right after nav ---------- */
.dark-ticker {
  position: relative;
  z-index: 2;
  margin: 0;
}

/* ---------- BOKEH LAYERING SAFETY ---------- */
.top-bar, .nav, main, footer,
.login-container, .page, .header,
.closing, .closing-cta-dark, .dark-ticker {
  position: relative;
  z-index: 2;
}

/* ---------- LEGACY .article BG -> glass card ---------- */
.article {
  background: var(--glass-light);
  -webkit-backdrop-filter: var(--blur-mid);
          backdrop-filter: var(--blur-mid);
  border: 1px solid var(--glass-border-light);
  border-radius: 28px;
  box-shadow: var(--shadow-md), var(--glass-specular);
  max-width: 820px;
  margin: 56px auto;
  padding: 48px clamp(24px, 5vw, 56px);
}
.article a { color: var(--color-ink); border-bottom: 1px solid var(--color-rose-mist); }

/* ---------- LEGACY palette-var alias (catches any leftover --color-* refs) ---------- */
:root:root {
  --color-bg: #e8e4e6;
  --color-text: var(--color-ink);
  --color-text-soft: var(--color-ink-soft);
  --color-muted: var(--color-mist);
  --color-olive: var(--color-ink-soft);
  --color-olive-dark: var(--color-ink);
  --color-olive-soft: var(--color-mist);
  --color-wheat: var(--color-rose-mist);
  --color-wheat-light: var(--color-rose-petal);
  --color-line: var(--color-rose-petal);
  --color-line-soft: var(--color-rose-petal);
  --color-card: var(--glass-light);
  --color-cream-soft: #faf8f6;
}

/* ============================================================
   MOBILE — small phones (≤ 480px)
   ============================================================ */
@media (max-width: 480px) {

  /* --- Global spacing --- */
  .section { padding: 40px 0; }
  .section-head { padding: 0 16px 12px; }

  .work-grid,
  .services-grid { padding: 0 16px; }

  /* --- Nav --- */
  .nav { padding: 0 16px; }
  .nav-cta { padding: 10px 16px; font-size: 12px; }

  /* --- Page header --- */
  .page-head {
    padding: 44px 16px 32px;
  }
  .page-head h1 {
    font-size: clamp(34px, 9vw, 48px);
  }
  .page-head .lede { font-size: 13px; }

  /* --- Stat bubbles row on service pages --- */
  .bubble-row {
    gap: 8px;
  }
  .stat-bubble--sm {
    padding: 12px 14px;
    min-width: 72px;
  }
  .stat-bubble--sm .num { font-size: 22px; }

  /* --- Article body (service detail pages) --- */
  .article {
    padding: 32px 20px;
    margin: 32px 16px;
    border-radius: 20px;
  }

  /* --- Hero (homepage) --- */
  .hero { padding: 32px 16px; gap: 28px; }
  .hero h1 { font-size: clamp(34px, 9.5vw, 48px); }

  /* --- Reviews grid --- */
  .reviews-grid { padding: 0 16px; gap: 12px; }

  /* --- Guarantee section --- */
  .guarantee-inner { padding: 32px 16px; gap: 24px; }

  /* --- Closing CTA --- */
  .closing,
  .closing-cta-dark {
    padding: 56px 16px;
  }
  .closing h2,
  .closing-cta-dark h2 { font-size: clamp(28px, 7.5vw, 40px); }
  .closing p,
  .closing-cta-dark p { font-size: 15px; }
  .closing-actions,
  .closing-cta-dark .cta-actions { flex-direction: column; align-items: center; gap: 12px; }
  .closing .btn-primary,
  .closing-cta-dark .btn-primary,
  .closing .btn-ghost,
  .closing-cta-dark .btn-ghost {
    width: 100%;
    max-width: 320px;
    text-align: center;
    justify-content: center;
  }

  /* --- Locations --- */
  .loc-row { padding: 0 16px; gap: 16px; }

  /* --- Light card (availability panel) --- */
  .light-card { margin: 24px 16px; padding: 20px 16px; }

  /* --- Support grid --- */
  .support-grid { grid-template-columns: 1fr !important; padding: 0 16px; }

  /* --- Footer --- */
  .footer-inner { padding: 40px 16px 24px; gap: 28px; }
  .footer-bottom { padding: 16px 16px; flex-direction: column; gap: 8px; text-align: center; }

  /* --- Top bar ticker --- */
  .top-bar { font-size: 9px; letter-spacing: 0.1em; padding: 6px 12px; }

  /* --- Touch targets: buttons and nav links --- */
  .btn-primary,
  .btn-ghost,
  .btn-outline {
    padding: 14px 20px;
    font-size: 13px;
  }

  /* --- Guarantee quote --- */
  .guarantee-quote { padding: 20px 16px; }
  .guarantee-quote blockquote { font-size: 15px; }

  /* --- Pills row --- */
  .pills { gap: 6px; }
  .pill { font-size: 10px; padding: 5px 10px; }

  /* --- Eyebrow label --- */
  .eyebrow, .eb { font-size: 9px; letter-spacing: 0.18em; }

  /* --- Tables inside .article (pricing tables) --- */
  .article table { font-size: 13px; }
  .article table th,
  .article table td { padding: 8px 6px; }
}

/* ============================================================
   MOBILE — very small phones (≤ 390px)
   ============================================================ */
@media (max-width: 390px) {
  .page-head h1 { font-size: clamp(30px, 8.5vw, 38px); }
  .hero h1 { font-size: clamp(30px, 9vw, 38px); }
  .closing h2,
  .closing-cta-dark h2 { font-size: clamp(26px, 7vw, 34px); }
  .article { margin: 24px 12px; padding: 28px 16px; }
  .bubble-row { gap: 6px; }
  .stat-bubble--sm { min-width: 64px; padding: 10px 10px; }
  .stat-bubble--sm .num { font-size: 19px; }
}