/* ============================================================
   FamilyCarer website — shared styles
   Identity: navy #21295C + teal #02C39A, warmed with soft paper.
   Audience skews older → large, legible type and generous space.
   ============================================================ */

:root{
  --navy:#21295C;
  --navy-deep:#1A2049;
  --teal:#02C39A;
  --teal-deep:#019C7B;
  --gold:#F4A832;
  --coral:#F08A6B;
  --paper:#FBF6EE;          /* warm ivory base, no more cold white */
  --paper-warm:#F3EADB;     /* deeper warm sand */
  --tint-teal:#E7F6F1;      /* soft teal wash */
  --tint-gold:#FCF3E2;      /* soft warm wash */
  --tint-navy:#EDEFF7;      /* gentle navy tint */
  --ink:#2A2E3F;
  --ink-soft:#5A5F70;
  --line:#E7E0D2;
  --card:#FFFFFF;
  --radius:18px;
  --shadow:0 10px 30px rgba(33,41,92,.08);
  --shadow-lg:0 24px 60px rgba(33,41,92,.16);
  --maxw:1140px;
  --font-display:"Fraunces","Georgia",serif;
  --font-body:"Inter","Segoe UI",system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.12;color:var(--navy);letter-spacing:-.01em}
a{color:var(--teal-deep);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- header / nav ---------- */
.site-head{
  position:sticky;top:0;z-index:50;
  background:rgba(251,250,247,.86);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-head .wrap{display:flex;align-items:center;gap:24px;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:600;font-size:1.35rem;color:var(--navy)}
.brand .mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--navy),var(--teal));display:grid;place-items:center;color:#fff;font-size:1.1rem}
.brand small{font-family:var(--font-body);font-weight:600;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-deep);display:block;margin-top:-4px}
.nav{margin-left:auto;display:flex;align-items:center;gap:28px}
.nav a{color:var(--ink-soft);font-weight:500;font-size:1rem}
.nav a:hover{color:var(--navy);text-decoration:none}
.lang{display:flex;gap:2px;border:1px solid var(--line);border-radius:999px;padding:3px;background:#fff}
.lang a{padding:4px 11px;border-radius:999px;font-size:.82rem;font-weight:600;color:var(--ink-soft)}
.lang a.on{background:var(--navy);color:#fff}
.btn{display:inline-flex;align-items:center;gap:9px;background:var(--teal);color:#06281f;font-weight:700;
  padding:13px 22px;border-radius:999px;border:none;cursor:pointer;font-size:1rem;transition:transform .15s,box-shadow .15s;box-shadow:0 8px 20px rgba(2,195,154,.3)}
.btn:hover{transform:translateY(-2px);text-decoration:none;box-shadow:0 12px 26px rgba(2,195,154,.42)}
.btn.ghost{background:transparent;color:var(--navy);box-shadow:none;border:1.5px solid var(--navy)}
.btn.ghost:hover{background:var(--navy);color:#fff}
.btn.navy{background:var(--navy);color:#fff;box-shadow:0 8px 20px rgba(33,41,92,.28)}

.menu-toggle{display:none;margin-left:auto;background:none;border:none;font-size:1.6rem;color:var(--navy);cursor:pointer}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1200px 520px at 82% -8%,rgba(2,195,154,.20),transparent 60%),
  radial-gradient(900px 520px at -5% 108%,rgba(244,168,50,.16),transparent 60%),
  linear-gradient(180deg,var(--tint-teal),var(--paper) 70%)}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding-top:72px;padding-bottom:80px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-deep);background:rgba(2,195,154,.1);padding:7px 14px;border-radius:999px;margin-bottom:22px}
.hero h1{font-size:clamp(2.6rem,5.2vw,4.1rem);margin:0 0 20px}
.hero h1 em{font-style:italic;color:var(--teal-deep)}
.hero p.lead{font-size:1.25rem;color:var(--ink-soft);margin:0 0 32px;max-width:34ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-note{margin-top:18px;font-size:.95rem;color:var(--ink-soft)}

/* phone mock in hero */
.phone{position:relative;justify-self:center;width:300px;height:600px;border-radius:42px;background:linear-gradient(160deg,#222a55,#151a38);
  padding:14px;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.08)}
.phone .screen{width:100%;height:100%;border-radius:30px;background:var(--paper);overflow:hidden;position:relative}
.phone .sbar{height:46px;background:var(--navy);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.78rem;letter-spacing:.04em}
.phone .card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 13px;margin:11px;box-shadow:0 4px 12px rgba(33,41,92,.06)}
.phone .card .bar{width:7px;border-radius:5px;position:absolute;left:0;top:10px;bottom:10px}
.phone .card{position:relative;overflow:hidden}
.phone .t{font-weight:700;color:var(--navy);font-size:.92rem}
.phone .s{color:var(--ink-soft);font-size:.76rem;margin-top:3px}
.pill{display:inline-block;font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:999px}

/* ---------- sections ---------- */
section{padding:84px 0}
.section-head{max-width:620px;margin:0 auto 54px;text-align:center}
.section-head .eyebrow{margin-bottom:16px}
.section-head h2{font-size:clamp(2rem,3.6vw,2.8rem);margin:0 0 14px}
.section-head p{font-size:1.15rem;color:var(--ink-soft);margin:0}

.alt{background:linear-gradient(180deg,var(--tint-gold),var(--paper-warm))}
.tint-teal{background:linear-gradient(180deg,var(--tint-teal),var(--paper))}
.tint-navy{background:var(--tint-navy)}

/* feature grid — each card its own warm accent */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s;border-top:4px solid var(--teal)}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feature .ic{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:1.5rem;margin-bottom:18px;background:var(--tint-teal)}
.feature h3{font-size:1.3rem;margin:0 0 10px}
.feature p{margin:0;color:var(--ink-soft);font-size:1.02rem}
/* rotate accent colours across the six cards */
.feature:nth-child(1){border-top-color:var(--teal)}      .feature:nth-child(1) .ic{background:var(--tint-teal)}
.feature:nth-child(2){border-top-color:var(--gold)}      .feature:nth-child(2) .ic{background:var(--tint-gold)}
.feature:nth-child(3){border-top-color:#1976D2}          .feature:nth-child(3) .ic{background:#E3F0FB}
.feature:nth-child(4){border-top-color:var(--coral)}     .feature:nth-child(4) .ic{background:#FCEAE3}
.feature:nth-child(5){border-top-color:var(--navy)}      .feature:nth-child(5) .ic{background:var(--tint-navy)}
.feature:nth-child(6){border-top-color:var(--teal-deep)} .feature:nth-child(6) .ic{background:var(--tint-teal)}

/* split rows */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split + .split{margin-top:80px}
.split.flip .copy{order:2}
.split .copy h3{font-size:2rem;margin:0 0 16px}
.split .copy p{color:var(--ink-soft);font-size:1.12rem;margin:0 0 14px}
.split ul{margin:0;padding:0;list-style:none}
.split ul li{padding:9px 0 9px 32px;position:relative;color:var(--ink)}
.split ul li::before{content:"✓";position:absolute;left:0;top:9px;color:var(--teal-deep);font-weight:800}
.visual{background:linear-gradient(150deg,var(--navy),var(--navy-deep));border-radius:24px;padding:34px;box-shadow:var(--shadow-lg);min-height:320px;display:flex;flex-direction:column;justify-content:center;gap:14px}
.visual .vc{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:16px 18px;color:#fff}
.visual .vc .t{font-weight:700}
.visual .vc .s{color:#CADCFC;font-size:.92rem;margin-top:4px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;position:relative;box-shadow:var(--shadow)}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-16px;left:24px;width:38px;height:38px;border-radius:11px;background:var(--teal);color:#06281f;font-weight:800;display:grid;place-items:center;font-family:var(--font-display)}
.step:nth-child(2)::before{background:var(--gold);color:#5a3c06}
.step:nth-child(3)::before{background:var(--coral);color:#5e2415}
.step:nth-child(4)::before{background:var(--navy);color:#fff}
.step h3{font-size:1.15rem;margin:14px 0 8px}
.step p{margin:0;color:var(--ink-soft);font-size:.98rem}

/* CTA band */
.band{background:linear-gradient(150deg,var(--navy),var(--navy-deep));color:#fff;border-radius:28px;padding:56px;text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.band::after{content:"";position:absolute;inset:auto -10% -60% auto;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(2,195,154,.3),transparent 65%)}
.band h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.6rem);margin:0 0 14px;position:relative}
.band p{color:#CADCFC;font-size:1.15rem;margin:0 0 28px;position:relative}
.band .hero-cta{justify-content:center;position:relative}

/* download badges */
.stores{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin-top:8px}
.store{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px 22px;min-width:230px;box-shadow:var(--shadow);transition:transform .16s,box-shadow .16s}
.store:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);text-decoration:none}
.store.primary{border-color:var(--teal);box-shadow:0 12px 30px rgba(2,195,154,.22)}
.store .si{font-size:2rem}
.store .meta small{display:block;color:var(--ink-soft);font-size:.74rem;letter-spacing:.04em;text-transform:uppercase}
.store .meta b{font-family:var(--font-display);color:var(--navy);font-size:1.18rem;font-weight:600}
.store .tag{margin-left:auto;font-size:.68rem;font-weight:700;color:var(--gold);background:rgba(244,168,50,.13);padding:3px 9px;border-radius:999px}

/* ---------- footer ---------- */
.site-foot{background:var(--navy);color:#cfd4ea;padding:54px 0 30px;margin-top:0}
.site-foot .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.site-foot h4{color:#fff;font-family:var(--font-body);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 16px}
.site-foot a{color:#cfd4ea;display:block;padding:5px 0}
.site-foot a:hover{color:#fff}
.site-foot .brand{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:22px;font-size:.88rem;color:#9aa0c0;text-align:center}

/* ---------- docs ---------- */
.docs{display:grid;grid-template-columns:280px 1fr;gap:0;min-height:calc(100vh - 74px)}
.docs-nav{border-right:1px solid var(--line);background:var(--paper-warm);padding:32px 20px;position:sticky;top:74px;height:calc(100vh - 74px);overflow-y:auto}
.docs-nav .group{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin:22px 8px 8px}
.nav-row{display:flex;align-items:center;gap:4px}
.docs-nav a{display:block;flex:1;padding:9px 14px;border-radius:10px;color:var(--ink);font-weight:500;font-size:.98rem}
.docs-nav a:hover{background:#fff;text-decoration:none}
.docs-nav a.on{background:var(--navy);color:#fff}
.docs-body{padding:46px 56px;max-width:860px}
.docs-body h1{font-size:2.2rem;border-bottom:2px solid var(--line);padding-bottom:14px;margin:0 0 22px}
.docs-body h2{font-size:1.4rem;margin:32px 0 10px}
.docs-body p,.docs-body li{font-size:1.05rem;color:var(--ink)}
.docs-body .tip,.docs-body .note{padding:14px 18px;border-radius:12px;margin:18px 0}
.docs-body .tip{background:rgba(2,195,154,.1);border-left:4px solid var(--teal-deep)}
.docs-body .note{background:rgba(28,114,147,.1);border-left:4px solid #1C7293}
.docs-body .warn{background:rgba(244,168,50,.13);border-left:4px solid var(--gold);padding:14px 18px;border-radius:12px;margin:18px 0}

/* coming soon */
.soon{min-height:70vh;display:grid;place-items:center;text-align:center}
.soon .inner{max-width:560px;padding:40px}
.soon .big{font-size:4rem;margin-bottom:10px}
.soon h1{font-size:2.6rem;margin:0 0 16px}
.soon p{font-size:1.2rem;color:var(--ink-soft);margin:0 0 28px}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;text-align:center;padding-top:48px}
  .hero p.lead{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  .phone{margin-top:20px}
  .features{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:30px}
  .split.flip .copy{order:0}
  .site-foot .wrap{grid-template-columns:1fr 1fr}
  .docs{grid-template-columns:1fr}
  .docs-nav{position:static;height:auto;border-right:none;border-bottom:1px solid var(--line)}
  .docs-body{padding:32px 24px}
}
@media(max-width:620px){
  .site-head .wrap{flex-wrap:wrap}
  .nav{
    display:none;
    position:absolute;
    top:74px;left:0;right:0;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    background:var(--paper);
    border-bottom:1px solid var(--line);
    box-shadow:0 16px 30px rgba(33,41,92,.12);
    padding:8px 0;
    margin-left:0;
  }
  .nav.open{display:flex}
  .nav a{padding:14px 24px;font-size:1.08rem;border-bottom:1px solid var(--line)}
  .nav a:last-of-type{border-bottom:none}
  .nav .lang{margin:12px 24px;justify-content:center}
  .nav .btn.navy{margin:8px 24px 12px;justify-content:center}
  .menu-toggle{display:block}
  .features,.steps{grid-template-columns:1fr}
  .site-foot .wrap{grid-template-columns:1fr}
  .band{padding:36px 24px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}

/* ---------- hero screenshot (replaces CSS phone mock) ---------- */
.hero-screenshot {
  position: relative;
  justify-self: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-screenshot img.phone-img {
  width: 300px;
  height: auto;
  border-radius: 28px;
  box-shadow: 0 24px 60px rgba(0,0,40,.28), 0 4px 16px rgba(0,0,40,.14);
  display: block;
}
.hero-screenshot img.desktop-img {
  width: 560px;
  max-width: 100%;
  height: auto;
  border-radius: 14px;
  box-shadow: 0 24px 60px rgba(0,0,40,.22), 0 4px 16px rgba(0,0,40,.10);
  display: none;
}
/* phone shown by default; JS toggle switches between phone and desktop */


/* ---------- doc page screenshot toggle ---------- */
.doc-screenshot {
  margin: 24px 0 32px;
  text-align: center;
}
.doc-screenshot .screen-toggle {
  margin-bottom: 14px;
}

/* ---------- sidebar screen button ---------- */
.scr-btn{border:none;background:none;cursor:pointer;font-size:.9rem;padding:4px 6px;opacity:.4;flex-shrink:0;line-height:1;border-radius:6px}
.scr-btn:hover{opacity:1;background:rgba(0,0,139,.08)}

/* ---------- platform icon toggle ---------- */
.hero-screenshot {
  display: flex;
  align-items: center;
  gap: 32px;
  justify-self: center;
}
.screen-toggle {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
}
.stbtn {
  border: 2px solid transparent;
  background: none;
  border-radius: 10px;
  padding: 4px;
  cursor: pointer;
  opacity: .6;
  transition: opacity .18s, border-color .18s;
  line-height: 0;
  display: block;
}
.stbtn svg { display: block; }
.stbtn.active {
  opacity: 1;
  border-color: rgba(255,255,255,.75);
  background: rgba(255,255,255,.1);
}
.stbtn:hover:not(.active):not(.disabled) {
  opacity: .9;
}
.stbtn.disabled {
  opacity: .45;
  cursor: not-allowed;
}
