/* =====================================================
   FamilyTracking — design system
   Palette: map-paper / evergreen ink / signal coral / route teal
   ===================================================== */
:root{
  --paper:#F5F8F6;        /* page background — cool map paper */
  --card:#FFFFFF;
  --ink:#122E2B;          /* evergreen ink — headings, text */
  --ink-soft:#3D5550;     /* body text */
  --mint:#E3EFE9;         /* soft section wash */
  --coral:#FF5A4E;        /* signal coral — pins & primary CTA */
  --coral-dark:#E6483D;
  --teal:#1F8A70;         /* route teal — links, secondary */
  --amber:#FFB547;        /* rating stars */
  --line:#D7E4DE;
  --radius:14px;
  --shadow:0 10px 30px rgba(18,46,43,.08);
  --display:"Bricolage Grotesque",ui-sans-serif,system-ui,sans-serif;
  --body:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{margin:0;font-family:var(--body);color:var(--ink-soft);background:var(--paper);
  font-size:1.05rem;line-height:1.7;-webkit-font-smoothing:antialiased}
img,svg{max-width:100%;height:auto}
a{color:var(--teal)}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:3px solid var(--coral);outline-offset:2px;border-radius:4px}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,4.5vw,3.4rem);font-weight:800}
h2{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:700}
h3{font-size:1.25rem;font-weight:700}
p{margin:0 0 1.1em}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
.narrow{max-width:780px}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(245,248,246,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:26px;height:68px}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;
  font-size:1.22rem;color:var(--ink);text-decoration:none}
.brand svg{flex:none}
.nav-links{display:flex;gap:22px;margin-left:auto;align-items:center;flex-wrap:wrap}
.nav-links a{color:var(--ink);text-decoration:none;font-weight:600;font-size:.96rem}
.nav-links a:hover{color:var(--teal)}
.nav-toggle{display:none}

/* ---------- buttons ---------- */
.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:999px;font-weight:700;
  text-decoration:none;font-size:1rem;border:2px solid transparent;transition:transform .15s,box-shadow .15s}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 6px 18px rgba(255,90,78,.35)}
.btn-primary:hover{background:var(--coral-dark);transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ---------- hero ---------- */
.hero{padding:64px 0 56px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--mint);color:var(--ink);
  font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.4rem .9rem;border-radius:999px;margin-bottom:1rem}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--coral);position:relative}
.eyebrow .dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid var(--coral);opacity:.5;animation:pulse 1.8s infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.5);opacity:0}}
.hero p.lead{font-size:1.18rem}
.hero-art{filter:drop-shadow(0 18px 40px rgba(18,46,43,.14))}

/* ---------- route divider (signature) ---------- */
.route-divider{display:block;width:100%;height:46px;margin:0}

/* ---------- sections ---------- */
.section{padding:64px 0}
.section.alt{background:var(--mint)}
.section-head{max-width:720px;margin-bottom:2.2rem}
.kicker{color:var(--teal);font-weight:800;text-transform:uppercase;letter-spacing:.09em;font-size:.82rem;margin-bottom:.4rem}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow)}
.card h3{margin-top:.8rem}
.card .icon{width:46px;height:46px;display:grid;place-items:center;border-radius:12px;background:var(--mint)}
.card a.more{font-weight:700;text-decoration:none}
.card a.more::after{content:" →"}

/* ---------- stats / trust bar ---------- */
.trust{display:flex;gap:34px;flex-wrap:wrap;justify-content:space-between;
  background:var(--ink);color:#fff;border-radius:var(--radius);padding:28px 34px}
.trust b{display:block;font-family:var(--display);font-size:1.7rem;color:#fff}
.trust span{font-size:.92rem;color:#BBD2CA}

/* ---------- steps ---------- */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;position:relative}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:relative}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-18px;left:22px;
  width:36px;height:36px;border-radius:50%;background:var(--coral);color:#fff;font-weight:800;
  display:grid;place-items:center;font-family:var(--display);box-shadow:0 4px 12px rgba(255,90,78,.4)}

/* ---------- download / how-to box ---------- */
.howto-box{background:var(--ink);color:#E7F1EC;border-radius:var(--radius);padding:34px;
  display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center}
.howto-box h2,.howto-box h3{color:#fff}
.howto-box ol{margin:0 0 1.2em;padding-left:1.3em}
.howto-box li{margin-bottom:.5em}
.howto-box a:not(.btn){color:#9FE0CB}
.store-badges{display:flex;gap:12px;flex-wrap:wrap}
.store-badges a{display:inline-flex;align-items:center;gap:10px;background:#0B201E;border:1px solid #2C4A45;
  color:#fff;text-decoration:none;padding:.65rem 1.1rem;border-radius:12px;font-weight:600;font-size:.95rem}
.store-badges a:hover{border-color:var(--coral)}

/* ---------- reviews ---------- */
.review{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.stars{color:var(--amber);letter-spacing:2px;font-size:1.05rem}
.review p{margin:.7em 0}
.review footer{font-size:.9rem;color:var(--ink);font-weight:700}
.review footer span{display:block;font-weight:400;color:var(--ink-soft)}

/* ---------- FAQ ---------- */
.faq details{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:0;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;font-weight:700;color:var(--ink);padding:18px 22px;list-style:none;
  display:flex;justify-content:space-between;gap:16px;font-size:1.02rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--display);font-size:1.3rem;color:var(--coral);flex:none}
.faq details[open] summary::after{content:"–"}
.faq .faq-a{padding:0 22px 18px}

/* ---------- pricing teaser ---------- */
.price-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.price-cards .card.featured{border:2px solid var(--coral);position:relative}
.price-cards .tag{position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--coral);color:#fff;font-size:.78rem;font-weight:800;letter-spacing:.05em;
  padding:.25rem .9rem;border-radius:999px;text-transform:uppercase}
.price{font-family:var(--display);font-size:2.2rem;color:var(--ink);font-weight:800}
.price small{font-size:1rem;color:var(--ink-soft);font-weight:400}
.check-list{list-style:none;padding:0;margin:0 0 1.4em}
.check-list li{padding-left:1.7em;position:relative;margin-bottom:.55em}
.check-list li::before{content:"";position:absolute;left:0;top:.42em;width:1em;height:1em;
  background:var(--teal);border-radius:50%;
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path fill="black" d="M6.5 11.2 3.3 8l-1 1 4.2 4.2 7.2-7.2-1-1z"/></svg>') center/contain no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path fill="black" d="M6.5 11.2 3.3 8l-1 1 4.2 4.2 7.2-7.2-1-1z"/></svg>') center/contain no-repeat}

/* ---------- prose (long-form sections) ---------- */
.prose h2{margin-top:2.2em}
.prose h3{margin-top:1.6em}
.prose ul{padding-left:1.3em}
.prose li{margin-bottom:.5em}
.inline-art{margin:2rem 0;text-align:center}
.inline-art figcaption{font-size:.88rem;color:var(--ink-soft);margin-top:.5rem}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg,var(--ink) 0%,#1C4A40 100%);color:#E7F1EC;
  border-radius:var(--radius);padding:48px;text-align:center}
.cta-band h2{color:#fff}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#A9C6BC;margin-top:70px;padding:54px 0 30px;font-size:.95rem}
.site-footer a{color:#D7EAE1;text-decoration:none}
.site-footer a:hover{color:#fff;text-decoration:underline}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px;margin-bottom:34px}
.footer-grid h4{color:#fff;font-size:1rem;margin-bottom:.8em}
.footer-grid ul{list-style:none;margin:0;padding:0}
.footer-grid li{margin-bottom:.5em}
.footer-bottom{border-top:1px solid #2C4A45;padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.88rem}

/* ---------- breadcrumbs ---------- */
.crumbs{font-size:.88rem;margin:18px 0 0}
.crumbs a{text-decoration:none}
.crumbs span{color:var(--ink-soft)}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .hero-grid,.grid-3,.grid-4,.price-cards,.steps,.howto-box{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .hero{padding:40px 0}
  .hero-grid,.grid-2,.grid-3,.grid-4,.price-cards,.steps,.howto-box{grid-template-columns:1fr}
  .nav-links{display:none}
  .nav-toggle{display:block;margin-left:auto;background:none;border:1px solid var(--line);
    border-radius:10px;padding:.5rem .7rem;font-size:1.1rem;color:var(--ink);cursor:pointer}
  .nav-links.open{display:flex;position:absolute;top:68px;left:0;right:0;background:var(--paper);
    flex-direction:column;padding:18px 22px;border-bottom:1px solid var(--line);gap:14px}
  .trust{gap:18px}
  .cta-band{padding:32px 22px}
}
