/* ===================================================
   Unique Ride Services — Shared Stylesheet
   =================================================== */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --sky: #1a3a5c; --sky-mid: #2a5280; --sky-light: #e8f0f8;
  --warm: #e8793a; --warm-dark: #c95e22; --warm-light: #fdf0e8;
  --green: #2d7a4f; --green-light: #e8f5ee;
  --white: #ffffff; --off-white: #fafaf8;
  --text: #1c2b3a; --text-mid: #3e5263; --text-light: #5a6f80;
  --border: rgba(26,58,92,0.1);
  --focus-ring: 0 0 0 3px rgba(232,121,58,.55);
}

html { scroll-behavior: smooth; font-size: 18px; }
@media (min-width: 641px)  { html { font-size: 21px; } }
@media (min-width: 1025px) { html { font-size: 24px; } }
body { font-family: 'Nunito', sans-serif; background: var(--off-white); color: var(--text); overflow-x: hidden; line-height: 1.6; }

*:focus { outline: none; }
*:focus-visible { outline: 3px solid var(--warm); outline-offset: 2px; border-radius: 4px; }
.pill-group input:focus-visible + label { outline: 3px solid var(--warm); outline-offset: 2px; }

/* ── NAV ── */
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; display: flex; align-items: center; justify-content: space-between; padding: 14px 32px; background: var(--sky); box-shadow: 0 2px 20px rgba(0,0,0,0.15); }
.nav-brand { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.nav-logo-mark { width: 40px; height: 40px; border-radius: 50%; background: var(--warm); display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; color: #fff; flex-shrink: 0; }
.nav-brand-text { color: #fff; }
.nav-brand-text .line1 { font-family: 'Lora', serif; font-size: 18px; font-weight: 700; line-height: 1.1; }
.nav-brand-text .line2 { font-size: 14px; font-weight: 500; opacity: .9; letter-spacing: .08em; text-transform: uppercase; }
.nav-links { display: flex; gap: 28px; list-style: none; align-items: center; }
.nav-links a, .nav-links button { color: rgba(255,255,255,.9); font-size: 15px; font-weight: 600; text-decoration: none; transition: color .2s; background: none; border: none; cursor: pointer; font-family: inherit; padding: 0; }
.nav-links a:hover, .nav-links button:hover { color: #fff; }
.nav-cta { display: flex; align-items: center; gap: .5rem; color: #fff; font-size: 15px; font-weight: 700; background: var(--warm); padding: 10px 22px; border-radius: 50px; text-decoration: none; transition: background .2s; cursor: pointer; border: none; font-family: inherit; }
.nav-cta:hover { background: var(--warm-dark); }

/* Dropdown */
.nav-dropdown { position: relative; }
.nav-dropdown-toggle { display: flex; align-items: center; gap: 4px; }
.nav-dropdown-toggle::after { content: '▾'; font-size: .7rem; margin-left: 2px; }
.nav-dropdown-menu {
  position: absolute; top: calc(100% + 16px); left: 50%; transform: translateX(-50%);
  background: #fff; border-radius: 12px; padding: .5rem 0; min-width: 260px;
  box-shadow: 0 8px 32px rgba(0,0,0,.18); list-style: none;
  border: 1px solid var(--border); z-index: 200;
  opacity: 0; pointer-events: none; transform: translateX(-50%) translateY(-6px);
  transition: opacity .18s, transform .18s;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu {
  opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0);
}
.nav-dropdown-menu li a {
  display: block; padding: .6rem 1.25rem; color: var(--sky); font-size: 14px;
  font-weight: 600; text-decoration: none; transition: background .15s; white-space: nowrap;
}
.nav-dropdown-menu li a:hover { background: var(--sky-light); }

/* ── HERO ── */
.hero { min-height: 100vh; background: var(--sky); display: flex; align-items: center; padding-top: 70px; position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 40%, rgba(42,82,128,.8) 0%, transparent 60%), radial-gradient(ellipse at 20% 80%, rgba(232,121,58,.15) 0%, transparent 50%); }
.hero-circle-1 { position: absolute; right: -100px; top: 50%; transform: translateY(-50%); width: 600px; height: 600px; border-radius: 50%; border: 1px solid rgba(255,255,255,.06); }
.hero-circle-2 { position: absolute; right: -60px; top: 50%; transform: translateY(-50%); width: 480px; height: 480px; border-radius: 50%; border: 1px solid rgba(255,255,255,.08); }
.hero-inner { position: relative; z-index: 2; max-width: 1280px; margin: 0 auto; padding: 5rem 2rem; display: grid; grid-template-columns: 1fr 460px; gap: 3rem; align-items: center; }
.hero-badge { display: inline-flex; align-items: center; gap: .5rem; background: rgba(232,121,58,.18); border: 1px solid rgba(232,121,58,.45); color: #ffb38a; padding: .45rem 1rem; border-radius: 50px; font-size: 13px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 1.5rem; max-width: 100%; }
.hero-badge::before { content: '●'; font-size: .5rem; }
.hero h1 { font-family: 'Nunito', sans-serif; font-size: clamp(1.1rem, 2vw, 1.35rem); font-weight: 700; letter-spacing: 0.02em; text-transform: uppercase; color: #ffb38a; margin: 0 0 0.5rem; }
.hero-promise { font-family: 'Lora', serif; font-size: clamp(36px, 5.5vw, 64px); font-weight: 700; line-height: 1.15; color: #fff; margin: 0 0 1.25rem; }
.hero-promise span { color: #ffb38a; }
.hero-sub { font-size: 1.05rem; color: rgba(255,255,255,.92); line-height: 1.65; margin-bottom: 2rem; font-weight: 400; max-width: 540px; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.btn-hero-primary { background: var(--warm); color: #fff; padding: .9rem 2rem; border-radius: 50px; font-size: 1rem; font-weight: 700; text-decoration: none; transition: background .2s, transform .15s; box-shadow: 0 4px 20px rgba(232,121,58,.4); cursor: pointer; border: none; font-family: inherit; min-height: 44px; display: inline-flex; align-items: center; }
.btn-hero-primary:hover { background: var(--warm-dark); transform: translateY(-2px); }
.btn-hero-secondary { background: rgba(255,255,255,.12); color: #fff; padding: .9rem 1.75rem; border-radius: 50px; font-size: 1rem; font-weight: 600; text-decoration: none; border: 1px solid rgba(255,255,255,.35); transition: background .2s; min-height: 44px; display: inline-flex; align-items: center; }
.btn-hero-secondary:hover { background: rgba(255,255,255,.22); }
.hero-trust { display: flex; gap: 1.25rem; margin-top: 2.25rem; flex-wrap: wrap; }
.trust-item { display: flex; align-items: center; gap: .5rem; color: rgba(255,255,255,.85); font-size: .9rem; font-weight: 500; }
.trust-item::before { content: '✓'; color: #8fd9a8; font-weight: 700; font-size: .9rem; }

/* Hero card */
.hero-card { background: #fff; border-radius: 16px; padding: 2.5rem 2rem; box-shadow: 0 20px 60px rgba(0,0,0,.25); }
.hero-card-title { font-family: 'Lora', serif; font-size: 1.2rem; font-weight: 700; color: var(--sky); margin-bottom: 1.5rem; text-align: center; }
.routes-list { display: flex; flex-direction: column; gap: .85rem; }
.route-item { display: flex; align-items: center; justify-content: space-between; padding: .85rem 1rem; background: var(--sky-light); border-radius: 8px; gap: 1rem; }
.route-item .r-left { display: flex; align-items: center; gap: .75rem; }
.route-item .r-icon { width: 34px; height: 34px; border-radius: 50%; background: var(--sky); color: #fff; display: flex; align-items: center; justify-content: center; font-size: .9rem; flex-shrink: 0; }
.route-item .r-dest { font-weight: 700; font-size: .88rem; color: var(--sky); }
.route-item .r-sub { font-size: .75rem; color: var(--text-light); margin-top: 1px; }
.route-item .r-dist { font-size: .78rem; font-weight: 700; color: var(--warm); white-space: nowrap; }
.hero-card-note { margin-top: 1.25rem; text-align: center; font-size: .8rem; color: var(--text-light); line-height: 1.5; }
.hero-card-cta { display: block; margin-top: 1.25rem; background: var(--warm); color: #fff; text-align: center; padding: .9rem; border-radius: 8px; font-weight: 700; font-size: .95rem; text-decoration: none; transition: background .2s; cursor: pointer; border: none; width: 100%; font-family: inherit; }
.hero-card-cta:hover { background: var(--warm-dark); }

/* ── TRUST BAND ── */
.trust-band { background: var(--sky-light); padding: 2rem 2rem; display: flex; gap: 2.5rem; justify-content: center; align-items: center; flex-wrap: wrap; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.tb-item { display: flex; align-items: center; gap: .75rem; }
.tb-icon { width: 44px; height: 44px; border-radius: 50%; background: var(--sky); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; }
.tb-text .tb-num { font-family: 'Lora', serif; font-size: 1.3rem; font-weight: 700; color: var(--sky); }
.tb-text .tb-label { font-size: .9rem; color: var(--text-mid); font-weight: 600; }

/* ── SECTIONS ── */
.section { padding: 5rem 2rem; max-width: 1280px; margin: 0 auto; }
.full-section { padding: 5rem 2rem; }
.full-section .inner { max-width: 1280px; margin: 0 auto; }
.section-tag { display: inline-flex; align-items: center; gap: .5rem; background: var(--warm-light); color: #7a3608; padding: .45rem 1.1rem; border-radius: 50px; font-size: .88rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 1rem; }
.section-tag.blue { background: var(--sky-light); color: var(--sky-mid); }
.section-tag.green { background: var(--green-light); color: var(--green); }
h2.section-title { font-family: 'Lora', serif; font-size: clamp(28px, 3.5vw, 44px); font-weight: 700; line-height: 1.2; color: var(--sky); margin-bottom: 1rem; }
.section-desc { font-size: 1.05rem; color: var(--text-mid); line-height: 1.7; font-weight: 400; max-width: 640px; }

/* ── HOW IT WORKS ── */
.how-bg { background: var(--sky-light); }
.steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; margin-top: 3.5rem; position: relative; }
.steps-grid::before { content: ''; position: absolute; top: 36px; left: 10%; right: 10%; height: 2px; background: repeating-linear-gradient(90deg,var(--sky) 0,var(--sky) 8px,transparent 8px,transparent 16px); opacity: .2; z-index: 0; }
.step-card { background: #fff; border-radius: 16px; padding: 2.5rem 1.75rem; text-align: center; position: relative; z-index: 1; box-shadow: 0 4px 24px rgba(26,58,92,.07); transition: transform .2s, box-shadow .2s; }
.step-card:hover { transform: translateY(-4px); box-shadow: 0 10px 40px rgba(26,58,92,.12); }
.step-num { width: 56px; height: 56px; border-radius: 50%; background: var(--sky); color: #fff; display: flex; align-items: center; justify-content: center; font-family: 'Lora', serif; font-size: 1.4rem; font-weight: 700; margin: 0 auto 1.25rem; }
.step-card:nth-child(2) .step-num { background: var(--warm); }
.step-card:nth-child(3) .step-num { background: var(--sky-mid); }
.step-card:nth-child(4) .step-num { background: var(--green); }
.step-title { font-family: 'Lora', serif; font-size: 1.05rem; font-weight: 700; color: var(--sky); margin-bottom: .6rem; }
.step-desc { font-size: .88rem; color: var(--text-mid); line-height: 1.65; }

/* ── SERVICES ── */
.services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-top: 3rem; }
.service-card { background: #fff; border-radius: 16px; padding: 2.5rem 2rem; border: 2px solid transparent; transition: border-color .2s, box-shadow .2s, transform .2s; box-shadow: 0 2px 16px rgba(26,58,92,.06); }
.service-card:hover { border-color: var(--warm); transform: translateY(-3px); box-shadow: 0 8px 32px rgba(232,121,58,.15); }
.service-card a { text-decoration: none; display: block; }
.service-icon { font-size: 2.5rem; margin-bottom: 1.25rem; display: block; }
.service-title { font-family: 'Lora', serif; font-size: 1.1rem; font-weight: 700; color: var(--sky); margin-bottom: .6rem; }
.service-desc { font-size: .88rem; color: var(--text-mid); line-height: 1.65; margin-bottom: 1rem; }
.service-tag { display: inline-block; background: var(--sky-light); color: var(--sky-mid); padding: .3rem .85rem; border-radius: 50px; font-size: .85rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }

/* ── EXPERIENCE ── */
.exp-bg { background: var(--sky); }
.exp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.exp-text h2 { color: #fff; }
.exp-text .section-desc { color: rgba(255,255,255,.92); max-width: none; }
.exp-features { margin-top: 2.5rem; display: flex; flex-direction: column; gap: 1.25rem; }
.exp-feature { display: flex; gap: 1rem; align-items: flex-start; }
.exp-feature-icon { width: 42px; height: 42px; border-radius: 10px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; }
.exp-feature-text h4 { font-size: 1rem; font-weight: 700; color: #fff; margin-bottom: .25rem; }
.exp-feature-text p { font-size: .92rem; color: rgba(255,255,255,.85); line-height: 1.55; }
.comfort-cards { display: flex; flex-direction: column; gap: 1rem; }
.comfort-card { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); border-radius: 12px; padding: 1.25rem 1.5rem; display: flex; align-items: center; gap: 1rem; transition: background .2s; }
.comfort-card:hover { background: rgba(255,255,255,.14); }
.comfort-card .cc-icon { font-size: 1.4rem; }
.comfort-card .cc-text { font-size: .95rem; color: rgba(255,255,255,.92); font-weight: 500; line-height: 1.45; }
.comfort-card .cc-text strong { color: #fff; display: block; }

/* ── WHO WE SERVE ── */
.audience-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-top: 3rem; }
.audience-card { border-radius: 16px; padding: 2.5rem 2rem; text-align: center; transition: transform .2s; }
.audience-card:hover { transform: translateY(-3px); }
.audience-card.seniors { background: var(--sky-light); }
.audience-card.families { background: var(--warm-light); }
.audience-card.providers { background: var(--green-light); }
.audience-emoji { font-size: 3rem; margin-bottom: 1rem; display: block; }
.audience-title { font-family: 'Lora', serif; font-size: 1.15rem; font-weight: 700; margin-bottom: .6rem; }
.audience-card.seniors .audience-title { color: var(--sky); }
.audience-card.families .audience-title { color: var(--warm-dark); }
.audience-card.providers .audience-title { color: var(--green); }
.audience-desc { font-size: .88rem; color: var(--text-mid); line-height: 1.65; }
.audience-cta { display: inline-block; margin-top: 1.25rem; padding: .55rem 1.25rem; border-radius: 50px; font-size: .8rem; font-weight: 700; text-decoration: none; transition: opacity .2s; cursor: pointer; border: none; font-family: inherit; }
.audience-card.seniors .audience-cta { background: var(--sky); color: #fff; }
.audience-card.families .audience-cta { background: var(--warm); color: #fff; }
.audience-card.providers .audience-cta { background: var(--green); color: #fff; }
.audience-cta:hover { opacity: .85; }

/* ── COMMUNITY ── */
.community-bg { background: var(--warm-light); }
.community-inner { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.big-quote { font-family: 'Lora', serif; font-size: clamp(22px, 2.8vw, 32px); font-weight: 700; line-height: 1.4; color: var(--sky); padding-left: 1.5rem; border-left: 4px solid var(--warm); margin-bottom: 1.5rem; }
.big-quote em { color: var(--warm-dark); font-style: normal; }
.quote-attr { font-size: .95rem; color: var(--text-mid); }
.quote-attr strong { color: var(--text); display: block; }
.community-facts { display: flex; flex-direction: column; gap: 1.25rem; }
.fact-item { background: #fff; border-radius: 12px; padding: 1.5rem; display: flex; gap: 1rem; align-items: flex-start; box-shadow: 0 2px 12px rgba(26,58,92,.06); }
.fact-icon { font-size: 1.4rem; width: 44px; height: 44px; background: var(--sky-light); border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.fact-text h4 { font-size: .95rem; font-weight: 700; color: var(--sky); margin-bottom: .2rem; }
.fact-text p { font-size: .85rem; color: var(--text-mid); line-height: 1.5; }

/* ── COVERAGE ── */
.coverage-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-top: 3rem; }
.coverage-card { background: #fff; border-radius: 16px; padding: 2rem 1.75rem; border-top: 4px solid var(--sky); box-shadow: 0 2px 16px rgba(26,58,92,.07); transition: box-shadow .2s, transform .2s; }
.coverage-card:hover { box-shadow: 0 8px 32px rgba(26,58,92,.12); transform: translateY(-2px); }
.coverage-card:nth-child(2) { border-top-color: var(--warm); }
.coverage-card:nth-child(3) { border-top-color: var(--green); }
.cov-city { font-family: 'Lora', serif; font-size: 1.15rem; font-weight: 700; color: var(--sky); margin-bottom: .3rem; }
.cov-dist { font-size: .82rem; color: var(--warm); font-weight: 700; margin-bottom: .75rem; }
.cov-facilities { list-style: none; }
.cov-facilities li { font-size: .85rem; color: var(--text-mid); padding: .35rem 0; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: .5rem; }
.cov-facilities li:last-child { border-bottom: none; }
.cov-facilities li::before { content: '→'; color: var(--warm); font-weight: 700; font-size: .8rem; }

/* ── FAQ ── */
.faq-list { margin-top: 3rem; display: flex; flex-direction: column; gap: 1rem; max-width: 720px; }
.faq-item { background: #fff; border-radius: 12px; border: 1px solid var(--border); overflow: hidden; }
.faq-q { padding: 1.25rem 1.5rem; font-weight: 700; font-size: .95rem; color: var(--sky); cursor: pointer; display: flex; justify-content: space-between; align-items: center; user-select: none; width: 100%; background: transparent; border: none; text-align: left; font-family: inherit; }
.faq-q::after { content: '+'; font-size: 1.2rem; color: var(--warm); font-weight: 700; transition: transform .2s; }
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a { padding: 0 1.5rem; font-size: .9rem; color: var(--text-mid); line-height: 1.7; max-height: 0; overflow: hidden; transition: max-height .3s ease, padding .3s; }
.faq-item.open .faq-a { max-height: 300px; padding: 0 1.5rem 1.25rem; }

/* ── CTA SECTION ── */
.cta-section { background: var(--sky); text-align: center; padding: 5rem 2rem; position: relative; overflow: hidden; }
.cta-section::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 120%, rgba(232,121,58,.2) 0%, transparent 60%); }
.cta-section .inner { position: relative; z-index: 1; max-width: 800px; margin: 0 auto; }
.cta-section h2 { font-family: 'Lora', serif; font-size: clamp(28px, 4vw, 48px); color: #fff; font-weight: 700; margin-bottom: 1rem; }
.cta-section p { font-size: 1.1rem; color: rgba(255,255,255,.92); margin-bottom: 2.5rem; font-weight: 400; line-height: 1.7; }
.cta-buttons { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.btn-cta-main { background: var(--warm); color: #fff; padding: 1rem 2.4rem; border-radius: 50px; font-size: 1.05rem; font-weight: 700; text-decoration: none; box-shadow: 0 4px 24px rgba(232,121,58,.4); transition: background .2s, transform .15s; cursor: pointer; border: none; font-family: inherit; min-height: 44px; display: inline-flex; align-items: center; }
.btn-cta-main:hover { background: var(--warm-dark); transform: translateY(-2px); }
.btn-cta-ghost { background: transparent; color: #fff; padding: 1rem 2rem; border-radius: 50px; font-size: 1.05rem; font-weight: 600; text-decoration: none; border: 2px solid rgba(255,255,255,.45); transition: border-color .2s, background .2s; cursor: pointer; font-family: inherit; min-height: 44px; display: inline-flex; align-items: center; }
.btn-cta-ghost:hover { border-color: rgba(255,255,255,.75); background: rgba(255,255,255,.1); }
.cta-reassurance { margin-top: 2rem; font-size: .9rem; color: rgba(255,255,255,.85); display: flex; gap: 2rem; justify-content: center; flex-wrap: wrap; }
.cta-reassurance span::before { content: '✓ '; color: #8fd9a8; }

/* ── FOOTER ── */
footer { background: #0f1f30; padding: 3.5rem 2rem 2rem; color: rgba(255,255,255,.8); }
.footer-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 2.5rem; margin-bottom: 3rem; }
.footer-brand-col .fb-logo { display: flex; align-items: center; gap: .75rem; margin-bottom: 1rem; }
.footer-brand-col .fb-logo-mark { width: 38px; height: 38px; border-radius: 50%; background: var(--warm); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1rem; }
.footer-brand-col .fb-name { font-family: 'Lora', serif; font-size: 1.05rem; font-weight: 700; color: #fff; }
.footer-brand-col p { font-size: .92rem; line-height: 1.65; max-width: 320px; color: rgba(255,255,255,.85); margin-bottom: 1rem; }
.footer-brand-col .medicaid-badge { display: inline-flex; align-items: center; gap: .4rem; background: rgba(108,192,138,.18); border: 1px solid rgba(108,192,138,.4); color: #9fe0b8; padding: .4rem .9rem; border-radius: 50px; font-size: .78rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.footer-nap { margin-top: 1.25rem; font-size: .85rem; color: rgba(255,255,255,.7); line-height: 1.8; }
.footer-nap a { color: rgba(255,255,255,.85); text-decoration: none; }
.footer-nap a:hover { color: #fff; }
.footer-col h4 { font-size: .82rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.7); margin-bottom: 1rem; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .6rem; }
.footer-col ul li a { color: rgba(255,255,255,.85); font-size: .9rem; text-decoration: none; transition: color .2s; }
.footer-col ul li a:hover { color: #fff; }
.footer-bottom { max-width: 1280px; margin: 0 auto; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.15); display: flex; justify-content: space-between; align-items: center; font-size: .85rem; flex-wrap: wrap; gap: 1rem; color: rgba(255,255,255,.75); }
.footer-bottom a { color: rgba(255,255,255,.75); text-decoration: none; }
.footer-bottom a:hover { color: #fff; }

/* ── STICKY BAR ── */
.sticky-bar { position: fixed; bottom: 0; left: 0; right: 0; background: var(--sky); color: #fff; padding: .85rem 1.5rem; display: flex; align-items: center; justify-content: space-between; z-index: 90; box-shadow: 0 -4px 20px rgba(0,0,0,.2); transform: translateY(100%); transition: transform .3s; gap: 1rem; }
.sticky-bar.show { transform: translateY(0); }
.sticky-bar-text { font-size: 1rem; font-weight: 600; }
.sticky-bar-text span { color: rgba(255,255,255,.92); font-weight: 400; font-size: .9rem; }
.sticky-btn { background: var(--warm); color: #fff; padding: .7rem 1.75rem; border-radius: 50px; font-weight: 700; font-size: .95rem; text-decoration: none; white-space: nowrap; cursor: pointer; border: none; font-family: inherit; min-height: 44px; }

/* ── FADE IN ── */
.fade-in { opacity: 0; transform: translateY(20px); transition: opacity .65s ease, transform .65s ease; }
.fade-in.visible { opacity: 1; transform: translateY(0); }

/* ── SURVEY PAGE ── */
.survey-page { position: fixed; inset: 0; z-index: 200; background: var(--off-white); display: none; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.survey-page.open { display: block; animation: surveyIn .25s ease; }
@keyframes surveyIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
body.survey-open { overflow: hidden; }
.survey-header { background: var(--sky); color: #fff; padding: 1rem 3rem; display: flex; align-items: center; justify-content: space-between; box-shadow: 0 2px 20px rgba(0,0,0,.15); position: sticky; top: 0; z-index: 5; }
.survey-back { background: transparent; border: 1px solid rgba(255,255,255,.3); color: #fff; padding: .5rem 1.25rem; border-radius: 50px; font-size: .88rem; font-weight: 600; cursor: pointer; font-family: inherit; display: inline-flex; align-items: center; gap: .4rem; transition: background .2s, border-color .2s; }
.survey-back:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.55); }
.survey-page-content { max-width: 720px; margin: 0 auto; padding: 3.5rem 2rem 6rem; }
.survey-page-content .form-content { padding: 0; }
.survey-page-content .form-intro { margin-bottom: 2rem; text-align: center; }
.survey-page-content .form-intro h3 { font-size: clamp(1.7rem, 3vw, 2.2rem); }
.survey-page-content .form-intro p.sub { font-size: 1rem; max-width: 540px; margin: 0 auto; }
.survey-page-content .optional-contact { background: var(--sky-light); margin-left: -2rem; margin-right: -2rem; padding: 2rem; border-radius: 14px; }
.progress-wrap { padding: 2rem 2.5rem 0; }
.progress-label { display: flex; justify-content: space-between; font-size: .85rem; color: var(--text-mid); font-weight: 600; margin-bottom: .5rem; }
.progress-track { height: 6px; background: var(--sky-light); border-radius: 10px; overflow: hidden; }
.progress-fill { height: 100%; background: linear-gradient(90deg, var(--sky), var(--warm)); border-radius: 10px; transition: width .4s ease; }
.step-panel { display: none; padding: 2rem 2.5rem 2.5rem; }
.step-panel.active { display: block; }
.step-header { margin-bottom: 1.75rem; }
.step-eyebrow { font-size: .85rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--warm-dark); margin-bottom: .4rem; }
.step-panel h3 { font-family: 'Lora', serif; font-size: 1.45rem; font-weight: 700; color: var(--sky); line-height: 1.25; margin-bottom: .5rem; }
.step-panel p.sub { font-size: .88rem; color: var(--text-light); line-height: 1.55; }
.field { margin-bottom: 1.25rem; }
.field label { display: block; font-size: .82rem; font-weight: 700; color: var(--text); margin-bottom: .45rem; }
.field input[type=text], .field input[type=tel], .field input[type=email], .field select, .field textarea { width: 100%; padding: .8rem 1rem; border: 2px solid var(--border); border-radius: 10px; font-family: inherit; font-size: .95rem; color: var(--text); background: #fff; transition: border-color .2s; appearance: none; -webkit-appearance: none; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--sky); }
.field textarea { resize: vertical; min-height: 90px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.pill-group { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: .2rem; }
.pill-group input[type=radio], .pill-group input[type=checkbox] { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.pill-group label { padding: .5rem 1.1rem; border-radius: 50px; border: 2px solid var(--border); font-size: .85rem; font-weight: 600; color: var(--text-mid); cursor: pointer; transition: all .15s; user-select: none; }
.pill-group input:checked + label { background: var(--sky); border-color: var(--sky); color: #fff; }
.pill-group label:hover { border-color: var(--sky-mid); color: var(--sky); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.other-reveal { overflow: hidden; max-height: 0; opacity: 0; transition: max-height .25s ease, opacity .2s ease, margin-top .25s ease; margin-top: 0; }
.other-reveal.visible { max-height: 120px; opacity: 1; margin-top: .75rem; }
.other-reveal input[type=text] { width: 100%; padding: .8rem 1rem; border: 2px solid var(--border); border-radius: 10px; font-family: inherit; font-size: .95rem; color: var(--text); background: #fff; transition: border-color .2s; }
.other-reveal input[type=text]:focus { outline: none; border-color: var(--sky); }
.other-reveal input[type=text].other-invalid { border-color: #c0392b; }
.other-error { display: none; color: #c0392b; font-size: .85rem; font-weight: 600; margin-top: .4rem; }
.other-error.visible { display: block; }
.step-nav { display: flex; justify-content: space-between; align-items: center; margin-top: 2rem; gap: 1rem; }
.btn-back { background: none; border: 2px solid var(--border); color: var(--text-mid); padding: .75rem 1.75rem; border-radius: 50px; font-size: .9rem; font-weight: 700; cursor: pointer; transition: border-color .2s, color .2s; font-family: inherit; }
.btn-back:hover { border-color: var(--sky); color: var(--sky); }
.btn-next { background: var(--sky); color: #fff; padding: .75rem 2rem; border-radius: 50px; font-size: .9rem; font-weight: 700; cursor: pointer; border: none; transition: background .2s, transform .15s; font-family: inherit; flex: 1; }
.btn-next:hover { background: var(--sky-mid); transform: translateY(-1px); }
.btn-submit { background: var(--warm); color: #fff; padding: .85rem 2rem; border-radius: 50px; font-size: 1rem; font-weight: 700; cursor: pointer; border: none; transition: background .2s, transform .15s; font-family: inherit; flex: 1; box-shadow: 0 4px 16px rgba(232,121,58,.35); }
.btn-submit:hover { background: var(--warm-dark); transform: translateY(-1px); }
.thankyou { display: none; padding: 4rem 2rem; text-align: center; }
.thankyou.show { display: block; }
.ty-icon { font-size: 4rem; margin-bottom: 1rem; }
.thankyou h3 { font-family: 'Lora', serif; font-size: 2rem; font-weight: 700; color: var(--sky); margin-bottom: .75rem; }
.thankyou p { font-size: 1rem; color: var(--text-mid); line-height: 1.7; max-width: 460px; margin: 0 auto 1.75rem; }
.ty-phone { display: inline-flex; align-items: center; gap: .5rem; background: var(--sky); color: #fff; padding: .85rem 2rem; border-radius: 50px; font-weight: 700; font-size: 1rem; text-decoration: none; }
.ty-note { margin-top: 1rem; font-size: .8rem; color: var(--text-light); }
.ty-actions { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; margin-top: .5rem; }
.ty-back-home { display: inline-flex; align-items: center; gap: .4rem; background: var(--warm); color: #fff; padding: .85rem 2rem; border-radius: 50px; font-weight: 700; font-size: 1rem; border: none; cursor: pointer; font-family: inherit; transition: background .2s; }
.ty-back-home:hover { background: var(--warm-dark); }
.form-content { padding: 2rem 2.5rem 1rem; }
.form-intro { margin-bottom: 1.5rem; }
.form-intro h3 { font-family: 'Lora', serif; font-size: 1.45rem; font-weight: 700; color: var(--sky); line-height: 1.25; margin-bottom: .5rem; }
.form-intro p.sub { font-size: .88rem; color: var(--text-light); line-height: 1.55; }
.form-body { display: block; }
.form-section { padding-top: 1.5rem; margin-top: 1.5rem; border-top: 1px solid var(--border); }
.form-section:first-child { padding-top: 0; margin-top: 0; border-top: none; }
.section-eyebrow { font-size: .85rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--warm-dark); margin-bottom: 1rem; }
.optional-contact { background: var(--sky-light); margin-left: -2.5rem; margin-right: -2.5rem; padding: 1.75rem 2.5rem; border-radius: 0; }
.optional-contact .section-eyebrow { color: var(--sky); font-size: .8rem; }
.optional-intro { font-size: .88rem; color: var(--text-mid); line-height: 1.55; margin-bottom: 1.25rem; }
.form-submit-wrap { margin-top: 1.75rem; padding: 0 0 .5rem; }
.form-submit-wrap .btn-submit { width: 100%; }
.form-body [data-show] { display: none; }
.form-body.path-rider [data-show="rider"], .form-body.path-partner [data-show="partner"] { display: block; }
.form-body.path-rider .pill-group[data-show="rider"], .form-body.path-partner .pill-group[data-show="partner"] { display: flex; }

/* ── CHOOSER POPUP ── */
.chooser-overlay { position: fixed; inset: 0; background: rgba(15,30,50,.65); backdrop-filter: blur(4px); display: none; align-items: center; justify-content: center; z-index: 1100; padding: 1.5rem; }
.chooser-overlay.open { display: flex; }
.chooser-box { background: #fff; border-radius: 16px; max-width: 460px; width: 100%; padding: 2rem 1.75rem; box-shadow: 0 30px 80px rgba(0,0,0,.35); position: relative; animation: chooserIn .25s ease; }
@keyframes chooserIn { from { opacity: 0; transform: translateY(8px) scale(.98); } to { opacity: 1; transform: none; } }
.chooser-close { position: absolute; top: .75rem; right: .75rem; background: transparent; border: none; width: 36px; height: 36px; border-radius: 50%; font-size: 1.4rem; color: var(--text-light); cursor: pointer; line-height: 1; }
.chooser-close:hover { background: var(--sky-light); color: var(--sky); }
.chooser-title { font-family: 'Lora', serif; font-size: 1.35rem; font-weight: 700; color: var(--sky); text-align: center; margin-bottom: .35rem; }
.chooser-sub { text-align: center; color: var(--text-mid); font-size: .92rem; margin-bottom: 1.4rem; }
.chooser-options { display: flex; flex-direction: column; gap: .85rem; }
.chooser-option { display: flex; align-items: center; gap: 1rem; padding: 1.1rem 1.25rem; background: var(--off-white); border: 2px solid var(--border); border-radius: 12px; cursor: pointer; font-family: inherit; text-align: left; transition: border-color .2s, background .2s, transform .15s; width: 100%; }
.chooser-option:hover { border-color: var(--warm); background: var(--warm-light); transform: translateY(-1px); }
.chooser-option .co-icon { width: 44px; height: 44px; border-radius: 50%; background: var(--sky); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.chooser-option.partner .co-icon { background: var(--green); }
.chooser-option .co-text { flex: 1; }
.chooser-option .co-title { font-size: 1rem; font-weight: 700; color: var(--sky); margin-bottom: .15rem; }
.chooser-option .co-desc { font-size: .8rem; color: var(--text-light); line-height: 1.4; }
.chooser-option .co-arrow { color: var(--text-light); font-size: 1.2rem; flex-shrink: 0; }

/* ── INNER PAGE LAYOUT ── */
.page-header { background: var(--sky); padding: 7rem 2rem 4rem; position: relative; overflow: hidden; }
.page-header::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 50%, rgba(42,82,128,.6) 0%, transparent 60%); }
.page-header .inner { position: relative; z-index: 1; max-width: 860px; margin: 0 auto; }
.page-header h1 { font-family: 'Lora', serif; font-size: clamp(28px, 4vw, 48px); font-weight: 700; color: #fff; line-height: 1.2; margin-bottom: 1rem; }
.page-header p { font-size: 1.05rem; color: rgba(255,255,255,.9); line-height: 1.65; max-width: 600px; }
.breadcrumb { display: flex; align-items: center; gap: .5rem; font-size: .82rem; color: rgba(255,255,255,.65); margin-bottom: 1.25rem; flex-wrap: wrap; }
.breadcrumb a { color: rgba(255,255,255,.8); text-decoration: none; }
.breadcrumb a:hover { color: #fff; }
.breadcrumb span { color: rgba(255,255,255,.45); }

.page-body { max-width: 860px; margin: 0 auto; padding: 4rem 2rem 2rem; }
.page-body h2 { font-family: 'Lora', serif; font-size: clamp(22px, 2.8vw, 34px); font-weight: 700; color: var(--sky); margin-bottom: 1rem; margin-top: 3rem; }
.page-body h2:first-child { margin-top: 0; }
.page-body p { font-size: 1rem; color: var(--text-mid); line-height: 1.75; margin-bottom: 1rem; }
.page-body ul { list-style: none; margin-bottom: 1.25rem; display: flex; flex-direction: column; gap: .5rem; }
.page-body ul li { font-size: 1rem; color: var(--text-mid); line-height: 1.65; padding-left: 1.5rem; position: relative; }
.page-body ul li::before { content: '→'; position: absolute; left: 0; color: var(--warm); font-weight: 700; }

/* Link grids on inner pages */
.link-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; margin-top: 1.5rem; margin-bottom: 2rem; }
.link-card { background: #fff; border: 2px solid var(--border); border-radius: 12px; padding: 1.25rem 1.5rem; text-decoration: none; transition: border-color .2s, transform .15s, box-shadow .2s; display: block; }
.link-card:hover { border-color: var(--warm); transform: translateY(-2px); box-shadow: 0 6px 24px rgba(232,121,58,.12); }
.link-card-label { font-size: .75rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--warm-dark); margin-bottom: .3rem; }
.link-card-title { font-family: 'Lora', serif; font-size: 1rem; font-weight: 700; color: var(--sky); }
.link-card-sub { font-size: .82rem; color: var(--text-light); margin-top: .2rem; }

/* Scenario cards */
.scenario-list { display: flex; flex-direction: column; gap: .85rem; margin-top: 1.25rem; margin-bottom: 1.5rem; }
.scenario-item { background: var(--sky-light); border-radius: 10px; padding: 1rem 1.25rem; font-size: .95rem; color: var(--sky); font-weight: 500; line-height: 1.5; }
.scenario-item::before { content: '"'; color: var(--warm); font-weight: 700; }
.scenario-item::after { content: '"'; color: var(--warm); font-weight: 700; }

/* Included list */
.included-list { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; margin-top: 1.25rem; margin-bottom: 1.5rem; }
.included-item { background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 1rem 1.1rem; display: flex; align-items: flex-start; gap: .75rem; }
.included-icon { font-size: 1.3rem; flex-shrink: 0; }
.included-text { font-size: .88rem; color: var(--text-mid); line-height: 1.5; }
.included-text strong { color: var(--text); display: block; font-size: .9rem; }

/* Contact page */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: start; margin-top: 2rem; }
.contact-info-block { display: flex; flex-direction: column; gap: 1.5rem; }
.contact-item { background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 1.5rem; }
.contact-item h3 { font-family: 'Lora', serif; font-size: 1rem; font-weight: 700; color: var(--sky); margin-bottom: .5rem; }
.contact-item p, .contact-item a { font-size: .95rem; color: var(--text-mid); line-height: 1.6; text-decoration: none; }
.contact-item a { color: var(--warm-dark); font-weight: 700; }
.contact-item a:hover { color: var(--warm); }

/* Privacy */
.prose h2 { font-family: 'Lora', serif; font-size: 1.3rem; font-weight: 700; color: var(--sky); margin: 2.5rem 0 .75rem; }
.prose p, .prose li { font-size: .95rem; color: var(--text-mid); line-height: 1.75; margin-bottom: .75rem; }
.prose ul { padding-left: 1.5rem; list-style: disc; }
.prose ul li::before { display: none; }

/* 404 */
.not-found { min-height: 70vh; display: flex; align-items: center; justify-content: center; text-align: center; padding: 4rem 2rem; }
.not-found h1 { font-family: 'Lora', serif; font-size: clamp(48px, 8vw, 96px); font-weight: 700; color: var(--sky); opacity: .15; line-height: 1; margin-bottom: .5rem; }
.not-found h2 { font-family: 'Lora', serif; font-size: clamp(22px, 3vw, 32px); font-weight: 700; color: var(--sky); margin-bottom: 1rem; }
.not-found p { font-size: 1rem; color: var(--text-mid); margin-bottom: 2rem; }
.not-found-links { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ── LANGUAGE TOGGLE ── */
.lang-toggle {
  display: inline-flex;
  align-items: stretch;
  gap: 0;
  border: 2px solid #fff;
  border-radius: 10px;
  padding: 0;
  background: #fff;
  margin-right: .65rem;
  flex-shrink: 0;
  box-shadow: 0 2px 6px rgba(0,0,0,.18), 0 0 0 1px rgba(0,0,0,.04);
  overflow: hidden;
  position: relative;
}
.lang-toggle::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 6px;
  bottom: 6px;
  width: 1px;
  background: rgba(31, 71, 99, 0.18);
  pointer-events: none;
  z-index: 1;
}
.lang-toggle-btn {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--sky);
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: 0.9375rem;
  letter-spacing: .04em;
  min-width: 44px;
  height: 36px;
  padding: 0 .85rem;
  cursor: pointer;
  line-height: 1;
  transition: background .15s, color .15s;
  position: relative;
  z-index: 2;
}
.lang-toggle-btn:hover { background: rgba(31, 71, 99, 0.08); }
.lang-toggle-btn.is-active {
  background: var(--warm);
  color: #fff;
}
.lang-toggle-btn.is-active:hover { background: var(--warm); }
@media (max-width: 1024px) {
  .lang-toggle { margin-right: .4rem; }
  .lang-toggle-btn { min-width: 46px; height: 40px; font-size: 0.9375rem; padding: 0 .85rem; }
}
@media (max-width: 480px) {
  .lang-toggle-btn { min-width: 42px; padding: 0 .65rem; font-size: 0.875rem; }
}
@media (pointer: coarse) {
  .lang-toggle-btn { min-width: 48px; min-height: 44px; }
}
/* Mobile-panel lang toggle: labeled, prominent */
.mobile-nav-lang {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 0 1rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 0.5rem;
}
.mobile-nav-lang::before {
  content: "Language / Idioma";
  font-family: 'Nunito', sans-serif;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--text-mid);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.mobile-nav-lang .lang-toggle {
  margin: 0;
  border-color: var(--sky);
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.12), 0 0 0 1px rgba(31, 71, 99, 0.08);
}
.mobile-nav-lang .lang-toggle::before {
  background: rgba(31, 71, 99, 0.18);
}
.mobile-nav-lang .lang-toggle-btn {
  color: var(--sky);
  min-width: 72px;
  min-height: 48px;
  font-size: 1.0625rem;
}
.mobile-nav-lang .lang-toggle-btn:hover { background: rgba(31, 71, 99, 0.08); }
.mobile-nav-lang .lang-toggle-btn.is-active {
  background: var(--warm);
  color: #fff;
}
.mobile-nav-lang .lang-toggle-btn.is-active:hover { background: var(--warm); }

/* ── MOBILE NAV (hamburger + slide-out panel) ── */
.nav-hamburger {
  display: none;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  width: 48px;
  height: 48px;
  margin-right: .5rem;
  padding: 0;
  background: transparent;
  border: 2px solid rgba(255,255,255,.55);
  border-radius: 10px;
  cursor: pointer;
  color: #fff;
  -webkit-tap-highlight-color: transparent;
}
.nav-hamburger:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.85); }
.nav-hamburger-bar {
  display: block;
  width: 22px;
  height: 2.5px;
  background: currentColor;
  border-radius: 2px;
}
body.mobile-nav-open { overflow: hidden; }
.mobile-nav-backdrop {
  position: fixed; inset: 0;
  background: rgba(10, 30, 50, .55);
  z-index: 998;
  opacity: 0;
  transition: opacity .2s ease;
}
.mobile-nav-backdrop.is-open { opacity: 1; }
.mobile-nav-panel {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(360px, 88vw);
  background: #fff;
  z-index: 999;
  box-shadow: -8px 0 32px rgba(0,0,0,.18);
  transform: translateX(100%);
  transition: transform .22s ease;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.mobile-nav-panel.is-open { transform: translateX(0); }
.mobile-nav-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid #e5ecf2;
  background: var(--sky);
  color: #fff;
}
.mobile-nav-title {
  font-family: 'Lora', serif;
  font-size: 20px;
  font-weight: 700;
}
.mobile-nav-close {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.55);
  border-radius: 8px;
  font-size: 28px; line-height: 1;
  cursor: pointer;
  padding: 0;
}
.mobile-nav-close:hover { background: rgba(255,255,255,.12); border-color: #fff; }
.mobile-nav-list, .mobile-nav-sublist {
  list-style: none;
  margin: 0;
  padding: 0;
}
.mobile-nav-list > li { border-bottom: 1px solid #eef2f6; }
.mobile-nav-list a,
.mobile-nav-group-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-height: 56px;
  padding: 1rem 1.25rem;
  font-family: 'Nunito', sans-serif;
  font-size: 1.0625rem;
  font-weight: 600;
  color: #1f3a4d;
  text-decoration: none;
  background: transparent;
  border: 0;
  text-align: left;
  cursor: pointer;
}
.mobile-nav-list a:hover,
.mobile-nav-group-toggle:hover { background: #f4f8fb; color: var(--sky); }
.mobile-nav-list a[aria-current="page"] {
  color: var(--warm-dark);
  background: #fff4ec;
}
.mobile-nav-chev {
  font-size: 14px;
  color: #5a6f80;
  transition: transform .2s ease;
}
.mobile-nav-group.is-open .mobile-nav-chev { transform: rotate(180deg); }
.mobile-nav-sublist { background: #f6f9fc; border-top: 1px solid #eef2f6; }
.mobile-nav-sublist a {
  min-height: 52px;
  padding-left: 2.25rem;
  font-size: 1rem;
  font-weight: 500;
  border-bottom: 1px solid #eef2f6;
}
.mobile-nav-sublist li:last-child a { border-bottom: 0; }

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  nav { padding: 1rem 1.5rem; }
  .nav-links { display: none; }
  .nav-hamburger { display: inline-flex; }
  .hero-inner { grid-template-columns: 1fr; padding: 4rem 1.5rem; }
  .hero-card { display: none; }
  .steps-grid { grid-template-columns: repeat(2,1fr); }
  .steps-grid::before { display: none; }
  .services-grid { grid-template-columns: repeat(2,1fr); }
  .exp-grid { grid-template-columns: 1fr; gap: 3rem; }
  .audience-grid { grid-template-columns: 1fr; }
  .community-inner { grid-template-columns: 1fr; }
  .coverage-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .section, .full-section { padding: 4rem 1.5rem; }
  .trust-band { padding: 1.5rem; gap: 1.5rem; }
  .link-grid { grid-template-columns: 1fr; }
  .included-list { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
}
@media (max-width:640px) {
  .steps-grid, .services-grid { grid-template-columns: 1fr; }
  .footer-bottom, .cta-buttons, .hero-actions { flex-direction: column; align-items: center; }
  .footer-grid { grid-template-columns: 1fr; }
  .sticky-bar { flex-direction: column; gap: .5rem; text-align: center; padding: .75rem 1rem; }
  .step-panel { padding: 1.5rem 1.25rem 2rem; }
  .progress-wrap { padding: 1.5rem 1.25rem 0; }
  .field-row { grid-template-columns: 1fr; }
  .form-content { padding: 1.5rem 1.25rem 1rem; }
  .optional-contact { margin-left: -1.25rem; margin-right: -1.25rem; padding: 1.5rem 1.25rem; }
  .survey-header { padding: .85rem 1.25rem; }
  .survey-page-content { padding: 2rem 1.25rem 4rem; }
  .survey-page-content .optional-contact { margin-left: -1.25rem; margin-right: -1.25rem; padding: 1.5rem 1.25rem; border-radius: 0; }
  .survey-header .nav-brand-text .line2 { display: none; }
  .page-body { padding: 2.5rem 1.25rem 2rem; }
  .link-grid { grid-template-columns: 1fr; }
}
