/* =====================================================================
   TIDY BEAR — Foundation Design System
   Mobile-first, responsive, coastal. Fonts are loaded in the HTML head
   (Fontshare) — do NOT @import here.
   ===================================================================== */

/* ---------------------------------------------------------------------
   1. Design Tokens
   --------------------------------------------------------------------- */
:root {
  /* Palette */
  --beige: #F3ECE0;
  --seafoam: #BFE9D7;
  --mint: #9FE0C4;
  --coral: #FF8E7C;
  --teal: #2FA98F;
  --teddy: #A9744F;
  --ink: #2A2018;
  --muted: #6E5E50;
  --white: #FFFFFF;

  /* Effects */
  --shadow: 0 10px 30px rgba(42, 32, 24, .08);
  --shadow-hover: 0 18px 44px rgba(42, 32, 24, .14);
  --radius: 16px;
  --radius-sm: 12px;

  /* Layout */
  --maxw: 1200px;

  /* Type */
  --font-display: 'Cabinet Grotesk', system-ui, sans-serif;
  --font-body: 'Satoshi', system-ui, sans-serif;

  /* Motion */
  --ease: cubic-bezier(.22, .61, .36, 1);
  --speed: .25s;

  /* Header height (used for scroll-padding + spacing) */
  --header-h: 72px;
}

/* ---------------------------------------------------------------------
   2. Reset / Normalize
   --------------------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-h) + 16px);
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}

body {
  font: 400 17px/1.6 var(--font-body);
  color: var(--ink);
  background: var(--beige);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  overflow-x: hidden;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
}

button {
  background: none;
  border: 0;
  cursor: pointer;
}

a {
  color: var(--teal);
  text-decoration: none;
}

ul[role="list"],
ol[role="list"] {
  list-style: none;
  padding: 0;
}

/* ---------------------------------------------------------------------
   3. Typography
   --------------------------------------------------------------------- */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-display);
  font-weight: 800;
  color: var(--ink);
  line-height: 1.1;
}

p {
  max-width: 68ch;
}

strong,
b {
  font-weight: 700;
}

/* ---------------------------------------------------------------------
   4. Accessibility helpers
   --------------------------------------------------------------------- */
:focus-visible {
  outline: 3px solid var(--teal);
  outline-offset: 3px;
  border-radius: 6px;
}

/* Remove default outline only where focus-visible is supported */
:focus:not(:focus-visible) {
  outline: none;
}

.sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.skip-link {
  position: absolute;
  top: -100%;
  left: 16px;
  z-index: 1000;
  padding: 12px 18px;
  background: var(--ink);
  color: var(--white);
  border-radius: var(--radius-sm);
  font: 700 15px var(--font-body);
}

.skip-link:focus {
  top: 16px;
}

/* ---------------------------------------------------------------------
   5. Layout primitives
   --------------------------------------------------------------------- */
.container {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
}

.section {
  padding: 88px 0;
}

.section--beige {
  background: var(--beige);
}

.section--white {
  background: var(--white);
}

.section--seafoam {
  background: var(--seafoam);
}

.section--mint {
  background: var(--mint);
}

/* Spacing utilities */
.stack > * + * {
  margin-top: 16px;
}

.center {
  text-align: center;
}

.center .lead,
.center p {
  margin-left: auto;
  margin-right: auto;
}

/* ---------------------------------------------------------------------
   6. Typographic components
   --------------------------------------------------------------------- */
.eyebrow {
  font: 700 14px/1 var(--font-body);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--teal);
  display: inline-block;
}

.display {
  font: 800 clamp(34px, 5vw, 56px)/1.05 var(--font-display);
  color: var(--ink);
}

.h2 {
  font: 800 clamp(28px, 3.5vw, 42px)/1.1 var(--font-display);
  color: var(--ink);
}

.h3 {
  font: 800 clamp(20px, 2vw, 24px)/1.2 var(--font-display);
  color: var(--ink);
}

.lead {
  font: 400 19px/1.6 var(--font-body);
  color: var(--muted);
  max-width: 60ch;
}

.tag {
  font: 700 12px var(--font-body);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--teal);
  display: inline-block;
}

.trust-strip {
  color: var(--muted);
  font: 500 14px var(--font-body);
}

/* ---------------------------------------------------------------------
   7. Buttons
   --------------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 15px 26px;
  border-radius: 999px;
  font: 700 16px var(--font-body);
  cursor: pointer;
  border: 0;
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
  transition: transform var(--dur-press) var(--ease-crisp),
              box-shadow var(--dur-quick) var(--ease-crisp),
              background-color var(--dur-quick) var(--ease-crisp),
              color var(--dur-quick) var(--ease-crisp);
  will-change: transform;
}

.btn--primary {
  background: var(--coral);
  color: var(--ink); /* dark text on coral for legibility */
  box-shadow: 0 8px 20px rgba(255, 142, 124, .35);
}

.btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(255, 142, 124, .45);
  background: #ff9d8d;
}

.btn--primary:active {
  transform: translateY(0);
  box-shadow: 0 6px 16px rgba(255, 142, 124, .35);
}

.btn--ghost {
  background: transparent;
  color: var(--teal);
  box-shadow: inset 0 0 0 2px rgba(47, 169, 143, .35);
}

.btn--ghost:hover {
  transform: translateY(-2px);
  background: rgba(47, 169, 143, .08);
  box-shadow: inset 0 0 0 2px var(--teal);
}

.btn--ghost:active {
  transform: translateY(0);
}

.btn--block {
  width: 100%;
}

.btn:focus-visible {
  outline: 3px solid var(--ink);
  outline-offset: 3px;
}

/* ---------------------------------------------------------------------
   8. Cards & badges
   --------------------------------------------------------------------- */
.card {
  background: var(--white);
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: var(--shadow);
  transition: transform var(--dur-quick) var(--ease-crisp),
              box-shadow var(--dur-quick) var(--ease-crisp);
}

.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
}

.card--flat {
  box-shadow: none;
  border: 1px solid rgba(42, 32, 24, .08);
}

.card--flat:hover {
  transform: none;
  box-shadow: var(--shadow);
}

.badge {
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: var(--coral);
  color: var(--ink);
  display: grid;
  place-items: center;
  font: 800 22px var(--font-display);
  flex-shrink: 0;
}

.badge--teal {
  background: var(--teal);
  color: var(--white);
}

.badge--mint {
  background: var(--mint);
  color: var(--ink);
}

/* Decorative pill chip */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 999px;
  background: var(--white);
  color: var(--ink);
  font: 600 14px var(--font-body);
  box-shadow: var(--shadow);
}

/* ---------------------------------------------------------------------
   9. Grid helpers
   --------------------------------------------------------------------- */
.grid {
  display: grid;
  gap: 24px;
}

.grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

.grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

.grid-4 {
  grid-template-columns: repeat(4, 1fr);
}

/* ---------------------------------------------------------------------
   10. Site header (sticky, translucent)
   --------------------------------------------------------------------- */
#site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  width: 100%;
  background: rgba(243, 236, 224, .72);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: background-color var(--speed) var(--ease),
              box-shadow var(--speed) var(--ease),
              border-color var(--speed) var(--ease);
}

#site-header.scrolled {
  background: rgba(255, 255, 255, .82);
  box-shadow: 0 6px 24px rgba(42, 32, 24, .07);
  border-bottom-color: rgba(42, 32, 24, .06);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: var(--header-h);
}

/* Brand / logo */
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: 800 20px var(--font-display);
  color: var(--ink);
  text-decoration: none;
  flex-shrink: 0;
}

.brand:hover {
  color: var(--teal);
}

.brand__mark {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: var(--coral);
  display: grid;
  place-items: center;
  font: 800 18px var(--font-display);
  color: var(--ink);
}

/* Primary navigation */
.main-nav {
  display: flex;
  align-items: center;
  gap: 28px;
}

.main-nav ul {
  display: flex;
  align-items: center;
  gap: 28px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.main-nav a {
  font: 600 16px var(--font-body);
  color: var(--ink);
  text-decoration: none;
  position: relative;
  padding: 6px 0;
  transition: color var(--speed) var(--ease);
}

.main-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 0;
  height: 2px;
  background: var(--teal);
  border-radius: 2px;
  transition: width var(--speed) var(--ease);
}

.main-nav a:hover,
.main-nav a[aria-current="page"] {
  color: var(--teal);
}

.main-nav a:hover::after,
.main-nav a[aria-current="page"]::after {
  width: 100%;
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: 14px;
}

/* Hamburger toggle (hidden on desktop) */
.nav-toggle {
  display: none;
  width: 46px;
  height: 46px;
  border-radius: var(--radius-sm);
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--ink);
  flex-shrink: 0;
  transition: background-color var(--speed) var(--ease);
}

.nav-toggle:hover {
  background: rgba(42, 32, 24, .06);
}

.nav-toggle__bars {
  position: relative;
  display: block;
  width: 22px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  transition: background-color var(--speed) var(--ease);
}

.nav-toggle__bars::before,
.nav-toggle__bars::after {
  content: "";
  position: absolute;
  left: 0;
  width: 22px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  transition: transform var(--speed) var(--ease),
              top var(--speed) var(--ease);
}

.nav-toggle__bars::before {
  top: -7px;
}

.nav-toggle__bars::after {
  top: 7px;
}

/* Animate hamburger into an X when menu is open */
#site-header.nav-open .nav-toggle__bars {
  background: transparent;
}

#site-header.nav-open .nav-toggle__bars::before {
  top: 0;
  transform: rotate(45deg);
}

#site-header.nav-open .nav-toggle__bars::after {
  top: 0;
  transform: rotate(-45deg);
}

/* ---------------------------------------------------------------------
   11. Hero
   --------------------------------------------------------------------- */
.hero {
  position: relative;
  overflow: hidden;
  padding: clamp(56px, 9vw, 112px) 0;
}

.hero__grid {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}

.hero__content > * + * {
  margin-top: 22px;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  margin-top: 32px;
}

.hero__media {
  position: relative;
}

.hero__media img {
  width: 100%;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

/* Soft coastal blobs for atmosphere */
.hero::before,
.hero::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(8px);
  opacity: .55;
  z-index: 0;
  pointer-events: none;
}

.hero::before {
  width: 320px;
  height: 320px;
  background: radial-gradient(circle at 30% 30%, var(--mint), transparent 70%);
  top: -80px;
  right: -60px;
}

.hero::after {
  width: 260px;
  height: 260px;
  background: radial-gradient(circle at 30% 30%, var(--seafoam), transparent 70%);
  bottom: -90px;
  left: -70px;
}

.hero .container {
  position: relative;
  z-index: 1;
}

/* ---------------------------------------------------------------------
   12. Section header block
   --------------------------------------------------------------------- */
.section-head {
  max-width: 720px;
  margin-bottom: 48px;
}

.section-head > * + * {
  margin-top: 14px;
}

.section-head.center {
  margin-left: auto;
  margin-right: auto;
}

/* ---------------------------------------------------------------------
   13. Feature / step cards content
   --------------------------------------------------------------------- */
.feature {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.feature__icon {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-sm);
  display: grid;
  place-items: center;
  background: var(--seafoam);
  color: var(--teal);
  font-size: 26px;
}

.feature h3 {
  font: 800 20px/1.25 var(--font-display);
  color: var(--ink);
}

.feature p {
  color: var(--muted);
  font: 400 16px/1.6 var(--font-body);
}

/* ---------------------------------------------------------------------
   14. Footer
   --------------------------------------------------------------------- */
.site-footer {
  background: var(--ink);
  color: rgba(255, 255, 255, .82);
  padding: 64px 0 32px;
}

.site-footer a {
  color: rgba(255, 255, 255, .82);
  text-decoration: none;
  transition: color var(--speed) var(--ease);
}

.site-footer a:hover {
  color: var(--mint);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
}

.footer-col h4 {
  font: 800 16px var(--font-display);
  color: var(--white);
  margin-bottom: 16px;
}

.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
}

.footer-bottom {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: space-between;
  align-items: center;
  padding-top: 28px;
  border-top: 1px solid rgba(255, 255, 255, .12);
  font: 500 14px var(--font-body);
  color: rgba(255, 255, 255, .6);
}

/* ---------------------------------------------------------------------
   15. Responsive — mobile-first breakpoints
   --------------------------------------------------------------------- */

/* Tablet: ease 4-col down to 2-col */
@media (max-width: 1024px) {
  .grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }
}

/* Mobile: < 820px — collapse grids, stack hero, show hamburger */
@media (max-width: 819px) {
  .section {
    padding: 64px 0;
  }

  .container {
    padding: 0 20px;
  }

  /* Collapse multi-column grids to a single column */
  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr;
  }

  /* Hero becomes single column */
  .hero__grid {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .hero__content > * {
    margin-left: auto;
    margin-right: auto;
  }

  .hero__actions {
    justify-content: center;
  }

  .hero__media {
    order: -1;
  }

  /* Show hamburger, hide inline desktop nav by default */
  .nav-toggle {
    display: inline-flex;
  }

  .main-nav {
    position: fixed;
    inset: var(--header-h) 0 auto 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 16px 20px 24px;
    background: var(--white);
    box-shadow: 0 18px 40px rgba(42, 32, 24, .14);
    border-bottom: 1px solid rgba(42, 32, 24, .06);

    /* Hidden state: slide/fade out, not interactive */
    transform: translateY(-12px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--speed) var(--ease),
                transform var(--speed) var(--ease),
                visibility var(--speed) var(--ease);
  }

  .main-nav ul {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100%;
  }

  .main-nav li {
    border-bottom: 1px solid rgba(42, 32, 24, .06);
  }

  .main-nav a {
    display: block;
    padding: 16px 4px;
    font-size: 18px;
  }

  .main-nav a::after {
    display: none;
  }

  .nav-actions {
    margin-top: 18px;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .nav-actions .btn {
    width: 100%;
  }

  /* Open state — toggled by JS adding .nav-open to #site-header */
  #site-header.nav-open .main-nav {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  /* Footer stacks fully */
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Small phones */
@media (max-width: 420px) {
  .container {
    padding: 0 16px;
  }

  .btn {
    width: 100%;
  }

  .hero__actions {
    flex-direction: column;
    align-items: stretch;
  }
}

/* ---------------------------------------------------------------------
   16. Print
   --------------------------------------------------------------------- */
@media print {
  #site-header,
  .nav-toggle,
  .hero::before,
  .hero::after {
    display: none !important;
  }

  body {
    background: var(--white);
    color: #000;
  }
}
/* ===== Tidy Bear — Site header / nav (scoped to .s-nav) ===== */

.s-nav {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--white);
  border-bottom: 1px solid rgba(42, 32, 24, .06);
}

.s-nav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: 72px;
}

/* Brand wordmark */
.s-nav__brand {
  font: 800 24px/1 var(--font-display);
  color: var(--teddy);
  text-decoration: none;
  letter-spacing: -.01em;
  white-space: nowrap;
}

/* Nav cluster (links + actions) */
.s-nav__nav {
  display: flex;
  align-items: center;
  gap: 32px;
  flex: 1;
  justify-content: flex-end;
}

.s-nav__links {
  display: flex;
  align-items: center;
  gap: 28px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.s-nav__links a {
  font: 600 16px var(--font-body);
  color: var(--ink);
  text-decoration: none;
  position: relative;
}

/* underline-grow on hover/focus — pure transform, reuses --teal (no new color) */
.s-nav__links a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -4px;
  height: 2px;
  background: var(--teal);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 200ms var(--ease);
}

.s-nav__links a:hover {
  color: var(--teal);
}

.s-nav__links a:hover::after,
.s-nav__links a:focus-visible::after {
  transform: scaleX(1);
}

/* Actions: phone + CTA */
.s-nav__actions {
  display: flex;
  align-items: center;
  gap: 18px;
}

.s-nav__phone {
  font: 700 16px var(--font-body);
  color: var(--teal);
  text-decoration: none;
  white-space: nowrap;
}

.s-nav__phone:hover {
  color: var(--ink);
}

/* Small CTA variant of .btn--primary */
.s-nav__cta {
  padding: 11px 20px;
  font-size: 15px;
}

/* Hamburger toggle (hidden on desktop) */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 10px;
  background: transparent;
  border: 0;
  border-radius: var(--radius-sm);
  cursor: pointer;
}

.nav-toggle__bar {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 2px;
  background: var(--ink);
}

/* Visible focus states */
.s-nav a:focus-visible,
.s-nav button:focus-visible {
  outline: 3px solid var(--teal);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ===== Mobile ===== */
@media (max-width: 820px) {
  .nav-toggle {
    display: flex;
  }

  .s-nav__nav {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 8px 24px 24px;
    background: var(--white);
    border-bottom: 1px solid rgba(42, 32, 24, .06);
    box-shadow: var(--shadow);

    /* collapsed by default */
    display: none;
  }

  .s-nav.nav-open .s-nav__nav {
    display: flex;
  }

  .s-nav__links {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100%;
  }

  .s-nav__links li {
    border-bottom: 1px solid rgba(42, 32, 24, .06);
  }

  .s-nav__links a {
    display: block;
    padding: 16px 0;
    font-size: 18px;
  }

  .s-nav__actions {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
    width: 100%;
    margin-top: 20px;
  }

  .s-nav__phone {
    text-align: center;
    font-size: 18px;
    padding: 6px 0;
  }

  .s-nav__cta {
    justify-content: center;
    padding: 15px 26px;
    font-size: 16px;
  }
}
/* HERO — scoped styles beyond the design-system contract. Uses contract CSS vars only. */

.s-hero__inner {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 56px;
  align-items: center;
}

.s-hero__text > * + * { margin-top: 18px; }

.s-hero__warning {
  font: 700 19px/1.5 var(--font-body);
  color: var(--teddy);
  margin-top: 20px;
}

.s-hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}

.s-hero__cta .btn:focus-visible,
.s-hero a:focus-visible {
  outline: 3px solid var(--teal);
  outline-offset: 3px;
}

.s-hero .trust-strip { margin-top: 24px; }

/* ---- Photo report card ---- */
.s-hero__report { max-width: 480px; margin-left: auto; }

.s-hero__report-eyebrow { margin: 0 0 14px; }

.s-hero__report-title {
  font: 800 20px/1.2 var(--font-display);
  color: var(--ink);
  margin: 0 0 6px;
}

.s-hero__report-status {
  font: 600 14px var(--font-body);
  color: var(--teal);
  margin: 0 0 20px;
}

.s-hero__photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
}

.s-hero__tile {
  position: relative;
  border-radius: var(--radius-sm);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--seafoam);
}

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

.s-hero__caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 8px 10px;
  background: rgba(42, 32, 24, .62);
  color: var(--white);
  font: 700 13px var(--font-body);
}

.s-hero__caption--coral { color: var(--coral); }

.s-hero__report-foot {
  font: 400 14px/1.5 var(--font-body);
  color: var(--muted);
  margin: 0;
}

.s-hero__report-foot--byline {
  margin-top: 8px;
  font-weight: 600;
}

/* ---- Mobile: stack to single column ---- */
@media (max-width: 820px) {
  .s-hero__inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .s-hero__report { margin-left: 0; max-width: none; }
}
/* THE PROMISE — scoped styles (contract classes used everywhere else) */

.s-promise__head {
  max-width: 720px;
  margin-bottom: 48px;
}

/* eyebrow recoloured teddy-brown for this section per brief */
.s-promise__eyebrow {
  color: var(--teddy);
}

.s-promise__head .h2 {
  margin: 12px 0 16px;
}

/* reset list semantics so .card items read as a plain grid */
.s-promise__grid {
  list-style: none;
  margin: 0;
  padding: 0;
}

.s-promise__item {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.s-promise__item .badge {
  margin-bottom: 2px;
}

.s-promise__title {
  font: 800 20px/1.25 var(--font-display);
  color: var(--ink);
  margin: 0;
}

/* item 2 title in coral per brief */
.s-promise__title--coral {
  color: var(--coral);
}

.s-promise__desc {
  font: 400 16px/1.6 var(--font-body);
  color: var(--muted);
  margin: 0;
}
/* Tidy Bear — Services section (scoped) */
.s-services__head {
  max-width: 640px;
  margin: 0 0 40px;
}
.s-services__head .eyebrow {
  display: block;
  margin: 0 0 12px;
}
.s-services__head .h2 {
  margin: 0 0 14px;
}
.s-services__head .lead {
  margin: 0;
}

.s-services__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.s-services__card {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.s-services__card .tag {
  margin: 0;
}
.s-services__title {
  font: 800 22px/1.2 var(--font-display);
  color: var(--ink);
  margin: 2px 0 0;
}
.s-services__desc {
  font: 400 16px/1.6 var(--font-body);
  color: var(--muted);
  margin: 0;
}
/* Tidy Bear — Pricing section (06-pricing)
   Scoped under .s-pricing, using design-system CSS variables only. */

.s-pricing__head {
  max-width: 720px;
  margin: 0 auto 48px;
  text-align: center;
}
.s-pricing__head .eyebrow { display: block; margin-bottom: 14px; }
.s-pricing__head .h2 { margin: 0 0 16px; }
.s-pricing__head .lead { margin: 0; }

/* Tier cards */
.s-pricing__tier {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
}
.s-pricing__tier .tag { margin: 0 0 10px; }

.s-pricing__tier-name {
  font: 800 24px/1.15 var(--font-display);
  color: var(--ink);
  margin: 0 0 14px;
}
.s-pricing__beds {
  font: 700 15px/1.2 var(--font-body);
  color: var(--muted);
  white-space: nowrap;
}

.s-pricing__price {
  margin: 0 0 14px;
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 6px;
}
.s-pricing__amount {
  font: 800 clamp(28px, 3vw, 34px)/1 var(--font-display);
  color: var(--teal);
}
.s-pricing__per {
  font: 500 15px/1 var(--font-body);
  color: var(--muted);
}

.s-pricing__desc {
  font: 400 16px/1.55 var(--font-body);
  color: var(--muted);
  margin: 0 0 24px;
}

/* Push CTA to the bottom so cards align */
.s-pricing__cta {
  margin-top: auto;
  align-self: stretch;
  justify-content: center;
}

/* Ghost CTAs sit on beige cards — give a subtle outline for affordance */
.s-pricing__tier .btn--ghost {
  border: 2px solid var(--mint);
}

/* Featured / "Most Booked" tier */
.s-pricing__tier--featured {
  border: 2px solid var(--coral);
  box-shadow: 0 18px 44px rgba(255, 142, 124, .28);
}
@media (min-width: 821px) {
  .s-pricing__tier--featured { transform: translateY(-12px); }
}

.s-pricing__ribbon {
  position: absolute;
  top: 0;
  right: 24px;
  transform: translateY(-50%);
  background: var(--coral);
  color: var(--ink);
  font: 800 12px/1 var(--font-display);
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 9px 16px;
  border-radius: 999px;
  box-shadow: var(--shadow);
}

/* Footer copy */
.s-pricing__foot {
  margin-top: 44px;
  text-align: center;
}
.s-pricing__plan {
  font: 700 18px/1.5 var(--font-body);
  color: var(--ink);
  margin: 0 0 12px;
}
.s-pricing__plan-link {
  padding: 0;
  font-weight: 700;
  text-decoration: underline;
}
.s-pricing__fine {
  font-size: 15px;
  margin: 0 auto;
  max-width: 620px;
}

/* Mobile: grid-3 already collapses to 1 col in foundation;
   reset the featured lift so it doesn't overlap on small screens. */
@media (max-width: 820px) {
  .s-pricing__tier--featured { transform: none; }
  .s-pricing__ribbon { right: 20px; }
}
/* PROOF section (#reviews) — scoped under .s-proof, uses design-system variables only */

.s-proof__head {
  max-width: 760px;
  margin: 0 0 40px;
}
.s-proof__head .eyebrow { margin: 0 0 14px; }
.s-proof__head .h2 { margin: 0 0 16px; }
.s-proof__head .lead { margin: 0; }

/* Highlighted founding-cohort card */
.s-proof__founding {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  background: var(--seafoam);
  border: 2px solid var(--mint);
  margin-bottom: 40px;
}
.s-proof__founding-icon { flex: 0 0 auto; }
.s-proof__founding-text { flex: 1 1 auto; }
.s-proof__founding-text .tag { display: inline-block; margin: 0 0 10px; }
.s-proof__founding-title {
  font: 800 clamp(22px, 2.6vw, 30px)/1.15 var(--font-display);
  color: var(--ink);
  margin: 0 0 12px;
}
.s-proof__founding-body {
  font: 400 17px/1.6 var(--font-body);
  color: var(--ink);
  margin: 0 0 22px;
}
.s-proof__founding-body strong { color: var(--teal); }

/* Sample review cards */
.s-proof__reviews {
  list-style: none;
  margin: 0 0 40px;
  padding: 0;
}
.s-proof__review {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.s-proof__stars {
  margin: 0;
  font-size: 22px;
  letter-spacing: 2px;
  color: #F5B301; /* gold stars */
  line-height: 1;
}
.s-proof__quote { margin: 0; }
.s-proof__quote p {
  font: 500 17px/1.55 var(--font-body);
  color: var(--ink);
  margin: 0;
}
.s-proof__byline {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: auto;
}
.s-proof__name {
  font: 700 15px var(--font-body);
  color: var(--ink);
}
.s-proof__meta {
  font: 500 13px var(--font-body);
  color: var(--muted);
}

/* Honest stat strip */
.s-proof__stats {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
  margin: 0;
  padding: 16px 22px;
  background: var(--beige);
  border-radius: var(--radius-sm);
}
.s-proof__stat {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.s-proof__stat-star { color: #F5B301; }
.s-proof__divider { color: var(--teddy); }

/* Mobile-first responsive: stack founding card under 820px */
@media (max-width: 820px) {
  .s-proof__founding {
    flex-direction: column;
    gap: 16px;
  }
  .s-proof__stats { justify-content: flex-start; }
}
/* =====================================================================
   TIDY BEAR — Closing CTA (#quote)
   Scoped under .s-closing. Tokens only; foundation provides base classes.
   ===================================================================== */

.s-closing__inner {
  max-width: 720px;
  margin-inline: auto;
}

/* Even vertical rhythm between eyebrow, heading, lead, actions, note */
.s-closing__inner > * + * {
  margin-top: 18px;
}

.s-closing__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  margin-top: 32px;
}

.s-closing__note {
  margin-top: 22px;
  color: var(--muted);
}

/* Stack actions full-width on small phones for easy tapping */
@media (max-width: 420px) {
  .s-closing__actions {
    flex-direction: column;
    align-items: stretch;
  }
}
/* =====================================================================
   TIDY BEAR — Footer (section 09)
   Scoped under .s-footer. Dark teddy-brown background with light text.
   Uses design-system tokens; light text is intentionally NOT --ink.
   ===================================================================== */

.s-footer {
  background: #3A2A1E; /* dark teddy-brown, not global --ink */
  color: rgba(255, 255, 255, .82);
  padding: 72px 0 36px;
  font: 400 16px/1.6 var(--font-body);
}

/* Light links on the dark footer (overrides global teal link color) */
.s-footer a {
  color: rgba(255, 255, 255, .82);
  text-decoration: none;
  transition: color var(--speed, .25s) var(--ease, ease);
}

.s-footer a:hover {
  color: var(--mint);
}

.s-footer a:focus-visible {
  outline: 3px solid var(--mint);
  outline-offset: 3px;
  border-radius: 6px;
}

/* ---- Column layout ---- */
.s-footer__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 44px;
  border-bottom: 1px solid rgba(255, 255, 255, .14);
}

/* ---- Brand column ---- */
.s-footer__brand {
  max-width: 36ch;
}

.s-footer__logo {
  display: inline-block;
  font: 800 24px/1 var(--font-display);
  color: var(--white);
}

.s-footer__logo:hover {
  color: var(--mint);
}

.s-footer__tagline {
  margin-top: 14px;
  max-width: 32ch;
  color: rgba(255, 255, 255, .72);
}

.s-footer__badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 22px;
}

.s-footer__badge {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .16);
  font: 700 12px var(--font-body);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--mint);
}

.s-footer__dot {
  color: rgba(255, 255, 255, .4);
}

/* ---- Link columns ---- */
.s-footer__heading {
  font: 800 16px var(--font-display);
  color: var(--white);
  margin-bottom: 16px;
}

.s-footer__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.s-footer__contact {
  font-weight: 600;
}

/* ---- Bottom line ---- */
.s-footer__bottom {
  margin-top: 28px;
  max-width: none;
  font: 500 14px/1.6 var(--font-body);
  color: rgba(255, 255, 255, .6);
}

.s-footer__copy {
  display: inline-block;
  color: rgba(255, 255, 255, .5);
}

/* ---------------------------------------------------------------------
   Responsive
   --------------------------------------------------------------------- */

/* Tablet: brand spans full width, link cols sit beside each other */
@media (max-width: 1024px) {
  .s-footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: 40px 32px;
  }

  .s-footer__brand {
    grid-column: 1 / -1;
    max-width: 48ch;
  }
}

/* Mobile: < 820px — single column, no horizontal scroll */
@media (max-width: 819px) {
  .s-footer {
    padding: 56px 0 32px;
  }

  .s-footer__grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .s-footer__brand {
    grid-column: auto;
  }
}

/* ====== Services — coral accent scheme (requested) ====== */
.s-services .tag{display:inline-block;background:var(--coral);color:var(--ink);padding:4px 11px;border-radius:999px;font-weight:700;}
.s-services .card{border-top:3px solid var(--coral);}
.s-services .card:hover{border-top-color:var(--coral);}

/* ===== Fuller layout (requested: less "windowed", stretch out) ===== */
:root { --maxw: 1320px; }
.s-hero { min-height: min(86vh, 840px); display: grid; align-items: center; }
@media (max-width: 820px){ .s-hero { min-height: 0; } }

/* ===== Wider content for large/ultrawide screens ===== */
:root { --maxw: 1600px; }

/* ===== Services card definition (contrast fix) ===== */
.s-services .card { border: 1px solid rgba(42,32,24,.08); border-top: 3px solid var(--coral); }

/* ===== "Typical cleaner vs Tidy Bear" comparison ===== */
.s-compare__grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:36px; }
.s-compare__col { border-radius:var(--radius); padding:28px 30px; }
.s-compare__col--old { background:var(--white); border:1px solid rgba(42,32,24,.10); }
.s-compare__col--new { background:var(--seafoam); }
.s-compare__col-head { font:800 20px var(--font-display); margin:0 0 14px; color:var(--ink); }
.s-compare__col--new .s-compare__col-head { color:var(--teal); }
.s-compare__col ul { list-style:none; margin:0; padding:0; }
.s-compare__col li { position:relative; padding:12px 0 12px 30px; color:var(--muted); border-top:1px solid rgba(42,32,24,.07); font:500 16px var(--font-body); }
.s-compare__col li:first-child { border-top:0; }
.s-compare__col--new li { color:var(--ink); }
.s-compare__col--old li::before { content:"\00d7"; position:absolute; left:0; top:11px; color:#B98; font-weight:700; }
.s-compare__col--new li::before { content:"\2713"; position:absolute; left:0; top:11px; color:var(--teal); font-weight:800; }
@media (max-width:820px){ .s-compare__grid { grid-template-columns:1fr; } }

/* ===== Section-level CTA (services, comparison, service-area) ===== */
.section-cta { text-align:center; margin:36px 0 0; }

/* ===== Where we clean (service area) ===== */
.s-area__head { max-width:720px; margin:0 auto 36px; text-align:center; }
.s-area__grid { margin-top:0; }
.s-area__town { scroll-margin-top:90px; }
.s-area__name { font:800 20px var(--font-display); color:var(--ink); margin:0 0 8px; }
.s-area__town:nth-child(2) .s-area__name { color:var(--teal); }
.s-area__note { font:500 15px/1.55 var(--font-body); color:var(--muted); margin:0; }

/* ===== Pricing + closing guarantee ===== */
.s-pricing__guarantee {
  margin:16px auto 0; max-width:680px; text-align:center;
  font:500 15px/1.55 var(--font-body); color:var(--ink);
  background:var(--seafoam); border-radius:var(--radius-sm); padding:14px 20px;
}
.s-pricing__guarantee strong { color:var(--teal); }
.s-closing__guarantee { margin:14px 0 0; font:700 16px var(--font-body); color:var(--teal); }

/* ===== Coastal top wave (very top of the page) =====
   A repeating SVG wave tile (240px wide). repeat-x means it spans any width
   edge-to-edge with no cut, and the drift animation shifts by exactly one tile
   (240px) so the loop is seamless. */
.topwave {
  width:100%; height:34px;
  background-color:var(--beige);
  background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 34' preserveAspectRatio='none'><path fill='none' stroke='%23BFE9D7' stroke-width='3' stroke-linecap='round' d='M0 24 q60 7 120 0 q60 -7 120 0'/><path fill='none' stroke='%232FA98F' stroke-width='3' stroke-linecap='round' d='M0 13 q60 -8 120 0 q60 8 120 0'/></svg>");
  background-repeat:repeat-x;
  background-position:0 center;
  background-size:240px 34px;
}
@media (prefers-reduced-motion: no-preference){
  .topwave { animation: topwaveDrift 16s linear infinite; }
}
@keyframes topwaveDrift { from { background-position:0 center; } to { background-position:-240px center; } }
@media (max-width:560px){ .topwave { height:24px; background-size:240px 24px; } }

/* ===== Sticky mobile call / text bar ===== */
.mobile-bar { display:none; }
@media (max-width:720px){
  .mobile-bar {
    display:flex; gap:8px; position:fixed; left:0; right:0; bottom:0; z-index:60;
    padding:10px 12px calc(10px + env(safe-area-inset-bottom));
    background:color-mix(in srgb, var(--white) 94%, transparent);
    backdrop-filter:blur(8px); border-top:1px solid rgba(42,32,24,.10);
    box-shadow:0 -6px 20px rgba(42,32,24,.10);
  }
  .mobile-bar__btn {
    flex:1 1 0; text-align:center; text-decoration:none;
    min-height:48px; display:flex; align-items:center; justify-content:center;
    border-radius:12px; font:800 15px var(--font-body);
  }
  .mobile-bar__btn--call { background:var(--teal); color:var(--white); }
  .mobile-bar__btn--text { background:var(--mint); color:var(--ink); }
  .mobile-bar__btn--quote { background:var(--coral); color:var(--ink); }
  /* keep the footer clear of the fixed bar */
  body { padding-bottom:76px; }
}
