/* Selbst-gehostete Schriften (DSGVO) — Hanken Grotesk + Inter, Subsets: latin, latin-ext */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/hanken-grotesk-400-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/hanken-grotesk-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/hanken-grotesk-500-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/hanken-grotesk-500-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/hanken-grotesk-600-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/hanken-grotesk-600-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/hanken-grotesk-700-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/hanken-grotesk-700-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(fonts/hanken-grotesk-800-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(fonts/hanken-grotesk-800-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/inter-700-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/inter-700-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(fonts/inter-800-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(fonts/inter-800-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* ===========================================================
   Yua — Info-Website  ·  Brand stylesheet
   Farbwelt: Cyan · Blau · Teal (App-Design-System)
   Danger (Rot/Orange) ausschließlich für Notfall-Kontext.
   =========================================================== */

:root {
  /* Brand scale */
  --cyan-50:#ecfeff;  --cyan-100:#cffafe; --cyan-200:#a5f3fc; --cyan-300:#67e8f9;
  --cyan-400:#22d3ee; --cyan-500:#06b6d4; --cyan-600:#0891b2; --cyan-700:#0e7490; --cyan-800:#155e75;
  --blue-400:#60a5fa; --blue-500:#3b82f6; --blue-600:#2563eb; --blue-700:#1d4ed8;
  --teal-400:#2dd4bf; --teal-500:#14b8a6; --teal-600:#0d9488; --teal-700:#0f766e;

  /* Neutrals — slightly warm slate */
  --ink:#0d1b2a; --ink-2:#1e2f40;
  --gray-900:#0f172a; --gray-700:#334155; --gray-600:#475569; --gray-500:#64748b;
  --gray-400:#94a3b8; --gray-300:#cbd5e1; --gray-200:#e2e8f0; --gray-100:#eef2f6; --gray-50:#f6f9fb;
  --paper:#ffffff;
  --mist:#f1f9fb;       /* soft cyan tint section bg */
  --mist-2:#eaf4f9;

  /* Roles */
  --primary:var(--cyan-700);
  --primary-strong:var(--cyan-800);
  --accent:var(--blue-600);
  --brand-grad:linear-gradient(135deg,#18c5e6 0%, #2e72f0 54%, #0fa389 100%);
  --brand-grad-soft:linear-gradient(135deg,#e3fbff 0%, #eaf1ff 50%, #e6fbf4 100%);

  /* Danger — emergency only */
  --danger:#e23744; --danger-strong:#c01f2c; --danger-soft:#fff1f1; --danger-line:#fbd5d7;

  /* Type */
  --font:"Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --font-brand:"Inter", system-ui, sans-serif;

  /* Shape */
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:34px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(13,27,42,.06), 0 2px 6px rgba(13,27,42,.05);
  --shadow-md:0 8px 24px -8px rgba(13,27,42,.16), 0 2px 8px rgba(13,27,42,.06);
  --shadow-lg:0 30px 60px -22px rgba(20,60,110,.30), 0 8px 22px -12px rgba(13,27,42,.18);
  --shadow-brand:0 26px 50px -20px rgba(37,99,235,.45);

  --maxw:1180px;
  --gutter:clamp(20px,5vw,56px);
}

* { box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  margin:0; font-family:var(--font); color:var(--ink);
  background:var(--paper); line-height:1.6; font-size:18px;
  -webkit-font-smoothing:antialiased; letter-spacing:.005em;
}
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
h1,h2,h3,h4 { margin:0; line-height:1.1; letter-spacing:-.02em; font-weight:700; color:var(--gray-900); text-wrap:balance; }
p { margin:0; text-wrap:pretty; }
ul { margin:0; padding:0; list-style:none; }

/* ---------- Layout ---------- */
.wrap { max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.section { padding-block:clamp(64px,9vw,120px); }
.section--mist { background:var(--mist); }
.eyebrow {
  display:inline-flex; align-items:center; gap:9px;
  font-size:14px; font-weight:700; letter-spacing:.10em; text-transform:uppercase;
  color:var(--cyan-700);
}
.eyebrow::before { content:""; width:22px; height:2px; border-radius:2px; background:var(--cyan-500); }
.section__head { max-width:680px; margin-bottom:clamp(36px,5vw,60px); }
.section__head h2 { font-size:clamp(30px,4.2vw,46px); margin-top:16px; }
.section__head p { font-size:clamp(18px,2vw,21px); color:var(--gray-600); margin-top:18px; }

/* ---------- Buttons ---------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font); font-size:17px; font-weight:700; letter-spacing:.005em;
  padding:15px 26px; border-radius:var(--r-pill); border:1.5px solid transparent;
  cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  min-height:54px;
}
.btn--primary { color:#fff; background:var(--brand-grad); box-shadow:var(--shadow-brand); }
.btn--primary:hover { transform:translateY(-2px); box-shadow:0 32px 56px -20px rgba(37,99,235,.55); }
.btn--ghost { color:var(--cyan-800); background:#fff; border-color:var(--gray-200); box-shadow:var(--shadow-sm); }
.btn--ghost:hover { border-color:var(--cyan-300); transform:translateY(-2px); }
.btn--light { color:var(--cyan-800); background:#fff; }
.btn--light:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn svg { width:19px; height:19px; }

/* ---------- Logo ---------- */
.logo { display:inline-flex; align-items:center; gap:11px; }
.logo__mark {
  width:40px; height:40px; border-radius:11px; background:var(--brand-grad);
  display:grid; place-items:center; color:#fff; box-shadow:0 6px 14px -6px rgba(37,99,235,.5);
  position:relative; overflow:hidden; flex:none;
}
.logo__mark::after { content:""; position:absolute; inset:0; background:linear-gradient(160deg,rgba(255,255,255,.28),transparent 46%); }
.logo__mark svg { width:62%; height:62%; position:relative; z-index:1; }
.logo__word { font-family:var(--font-brand); font-weight:800; font-size:27px; letter-spacing:-.035em; color:var(--gray-900); }
.logo--lg .logo__mark { width:54px; height:54px; border-radius:15px; }
.logo--lg .logo__word { font-size:36px; }
.logo--inv .logo__word { color:#fff; }

/* ---------- Header ---------- */
.site-header {
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.82); backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--gray-100);
}
.site-header__inner { display:flex; align-items:center; justify-content:space-between; height:74px; gap:24px; }
.nav { display:flex; align-items:center; gap:32px; }
.nav a { font-size:16px; font-weight:600; color:var(--gray-600); transition:color .15s; }
.nav a:hover { color:var(--cyan-800); }
.header-cta { display:flex; align-items:center; gap:14px; }
.header-cta .btn { padding:11px 20px; min-height:46px; font-size:15px; }
@media (max-width:880px){ .nav { display:none; } }

/* ---------- Hero ---------- */
.hero { position:relative; overflow:hidden; background:var(--brand-grad-soft); }
.hero::before {
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(54% 60% at 88% 8%, rgba(34,211,238,.22), transparent 60%),
    radial-gradient(50% 55% at 8% 92%, rgba(20,184,166,.18), transparent 60%);
}
.hero__inner { position:relative; display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:center; padding-block:clamp(56px,7vw,96px); }
.hero__copy { max-width:600px; }
.hero h1 { font-size:clamp(38px,5.4vw,62px); line-height:1.04; }
.hero h1 .grad { background:var(--brand-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero__sub { font-size:clamp(18px,2.1vw,22px); color:var(--gray-600); margin-top:24px; max-width:540px; }
.hero__cta { display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero__trust { display:flex; flex-wrap:wrap; gap:18px 26px; margin-top:34px; }
.hero__trust span { display:inline-flex; align-items:center; gap:9px; font-size:15px; font-weight:600; color:var(--gray-700); }
.hero__trust svg { width:19px; height:19px; color:var(--teal-600); flex:none; }
.hero__art { position:relative; display:flex; justify-content:center; align-items:center; min-height:520px; }
@media (max-width:920px){
  .hero__inner { grid-template-columns:1fr; }
  .hero__art { min-height:0; margin-top:18px; }
}

/* ---------- Phone mockups ---------- */
.phone {
  width:300px; border-radius:42px; background:#0c1622; padding:12px;
  box-shadow:var(--shadow-lg); position:relative; flex:none;
}
.phone__screen { border-radius:31px; overflow:hidden; background:#fff; position:relative; aspect-ratio:9/19.3; }
.phone__notch { position:absolute; top:12px; left:50%; transform:translateX(-50%); width:104px; height:26px; background:#0c1622; border-radius:0 0 16px 16px; z-index:6; }
.phone--float-1 { transform:rotate(-4deg); }
.phone--float-2 { position:absolute; right:-8%; bottom:-6%; width:208px; transform:rotate(6deg); z-index:3; }
@media (max-width:920px){ .phone--float-2 { display:none; } }

.hero__art .phone-stack { position:relative; }

/* App screen scaffolding */
.scr { position:absolute; inset:0; display:flex; flex-direction:column; font-size:13px; color:var(--gray-900); }
.scr__status { display:flex; justify-content:space-between; align-items:center; padding:14px 20px 6px; font-size:12px; font-weight:700; color:var(--gray-700); }
.scr__bar { display:flex; align-items:center; gap:5px; }
.scr__bar i { width:4px; height:9px; background:var(--gray-400); border-radius:1px; display:inline-block; }
.scr__hd { padding:6px 18px 12px; }
.scr__hd .sml { font-size:12px; color:var(--gray-500); font-weight:600; }
.scr__hd .big { font-size:20px; font-weight:700; letter-spacing:-.02em; margin-top:2px; }
.scr__body { flex:1; overflow:hidden; padding:4px 16px 16px; display:flex; flex-direction:column; gap:10px; }

.med {
  display:flex; align-items:center; gap:12px; background:#fff; border:1px solid var(--gray-100);
  border-radius:16px; padding:12px; box-shadow:var(--shadow-sm);
}
.med__ic { width:42px; height:42px; border-radius:12px; flex:none; display:grid; place-items:center; color:#fff; font-size:18px; }
.med__t { font-weight:700; font-size:14px; }
.med__s { font-size:12px; color:var(--gray-500); margin-top:2px; }
.med__pill { margin-left:auto; font-size:11px; font-weight:700; color:var(--cyan-800); background:var(--cyan-50); border:1px solid var(--cyan-100); padding:5px 9px; border-radius:999px; white-space:nowrap; }

.scr__tab { margin-top:auto; display:flex; justify-content:space-around; padding:12px 8px calc(12px + env(safe-area-inset-bottom)); border-top:1px solid var(--gray-100); background:#fff; }
.scr__tab i { width:24px; height:24px; border-radius:7px; background:var(--gray-200); }
.scr__tab i.on { background:var(--cyan-600); }

/* Notfall screen */
.scr--sos { background:linear-gradient(180deg,#fff,#fff7f7); }
.sos-card { border:1.5px solid var(--danger-line); background:var(--danger-soft); border-radius:18px; padding:14px; }
.sos-head { display:flex; align-items:center; gap:9px; color:var(--danger-strong); font-weight:800; font-size:14px; }
.sos-head .dot { width:30px; height:30px; border-radius:9px; background:var(--danger); color:#fff; display:grid; place-items:center; font-size:15px; }
.sos-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:12px; }
.sos-grid .k { font-size:10px; text-transform:uppercase; letter-spacing:.06em; color:var(--gray-500); font-weight:700; }
.sos-grid .v { font-size:15px; font-weight:700; color:var(--gray-900); margin-top:1px; }
.sos-grid .blood { color:var(--danger-strong); }
.sos-contact { display:flex; align-items:center; gap:10px; background:#fff; border:1px solid var(--gray-100); border-radius:14px; padding:10px 12px; margin-top:8px; }
.sos-contact .av { width:34px; height:34px; border-radius:50%; background:var(--brand-grad); color:#fff; display:grid; place-items:center; font-weight:700; font-size:13px; flex:none; }

/* Scan screen */
.scr--scan { background:#0c1622; color:#fff; }
.scan-view { flex:1; position:relative; margin:0; background:
  linear-gradient(135deg,#16273a,#0c1622); display:grid; place-items:center; }
.scan-box { width:78%; aspect-ratio:1.4; border:none; border-radius:14px; position:relative; }
.scan-box::before,.scan-box::after { content:""; position:absolute; width:30px; height:30px; border:3px solid var(--cyan-400); }
.scan-box::before { top:0; left:0; border-right:0; border-bottom:0; border-radius:8px 0 0 0; }
.scan-box::after { bottom:0; right:0; border-left:0; border-top:0; border-radius:0 0 8px 0; }
.scan-corner-tr,.scan-corner-bl { position:absolute; width:30px; height:30px; border:3px solid var(--cyan-400); }
.scan-corner-tr { top:0; right:0; border-left:0; border-bottom:0; border-radius:0 8px 0 0; }
.scan-corner-bl { bottom:0; left:0; border-right:0; border-top:0; border-radius:0 0 0 8px; }
.scan-laser { position:absolute; left:0; right:0; top:50%; height:2px; background:var(--cyan-300); box-shadow:0 0 16px 2px var(--cyan-400); }
.scan-chip { position:absolute; left:50%; bottom:8%; transform:translateX(-50%); background:rgba(255,255,255,.96); color:var(--gray-900); border-radius:12px; padding:10px 14px; display:flex; align-items:center; gap:10px; box-shadow:var(--shadow-md); white-space:nowrap; }
.scan-chip .pzn { font-size:11px; color:var(--gray-500); font-weight:700; }
.scan-chip .nm { font-size:13px; font-weight:700; }
.scan-chip .ok { width:24px; height:24px; border-radius:50%; background:var(--teal-500); color:#fff; display:grid; place-items:center; flex:none; }

/* ---------- Problem / empathy ---------- */
.problem { display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,64px); align-items:center; }
.problem__list { display:flex; flex-direction:column; gap:14px; }
.problem__item { display:flex; gap:14px; align-items:flex-start; font-size:18px; color:var(--gray-700); }
.problem__item .x { width:30px; height:30px; border-radius:9px; flex:none; display:grid; place-items:center; background:var(--danger-soft); color:var(--danger); border:1px solid var(--danger-line); font-weight:800; }
.problem__solve { background:var(--brand-grad-soft); border:1px solid var(--cyan-100); border-radius:var(--r-lg); padding:clamp(24px,3vw,38px); }
.problem__solve h3 { font-size:clamp(22px,2.6vw,28px); }
.problem__solve p { font-size:18px; color:var(--gray-700); margin-top:14px; }
@media (max-width:820px){ .problem { grid-template-columns:1fr; } }

/* ---------- Feature cards (3 core) ---------- */
.feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.feat {
  background:#fff; border:1px solid var(--gray-100); border-radius:var(--r-lg);
  padding:32px 28px; box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease;
}
.feat:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.feat__ic { width:58px; height:58px; border-radius:16px; display:grid; place-items:center; color:#fff; margin-bottom:20px; }
.feat__ic svg { width:28px; height:28px; }
.feat--1 .feat__ic { background:linear-gradient(135deg,var(--cyan-500),var(--cyan-700)); }
.feat--2 .feat__ic { background:linear-gradient(135deg,var(--danger),#f87171); }
.feat--3 .feat__ic { background:linear-gradient(135deg,var(--teal-500),var(--teal-700)); }
.feat h3 { font-size:22px; }
.feat p { font-size:16.5px; color:var(--gray-600); margin-top:12px; }
@media (max-width:820px){ .feat-grid { grid-template-columns:1fr; } }

/* ---------- Detail blocks (alternating) ---------- */
.detail { display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,80px); align-items:center; }
.detail + .detail { margin-top:clamp(64px,8vw,110px); }
.detail--rev .detail__media { order:2; }
.detail__media { display:flex; justify-content:center; position:relative; }
.detail__badge { display:inline-flex; align-items:center; gap:9px; font-size:14px; font-weight:700; padding:7px 14px; border-radius:999px; }
.detail--scan .detail__badge { color:var(--cyan-800); background:var(--cyan-50); border:1px solid var(--cyan-100); }
.detail--sos .detail__badge { color:var(--danger-strong); background:var(--danger-soft); border:1px solid var(--danger-line); }
.detail--fam .detail__badge { color:var(--teal-700); background:#ecfdf5; border:1px solid #c7f0e0; }
.detail h2 { font-size:clamp(28px,3.6vw,40px); margin-top:18px; }
.detail__copy > p { font-size:19px; color:var(--gray-600); margin-top:18px; }
.detail__pts { margin-top:24px; display:flex; flex-direction:column; gap:13px; }
.detail__pts li { display:flex; gap:12px; align-items:flex-start; font-size:17px; color:var(--gray-700); }
.detail__pts svg { width:22px; height:22px; color:var(--teal-600); flex:none; margin-top:2px; }
@media (max-width:820px){
  .detail { grid-template-columns:1fr; }
  .detail--rev .detail__media { order:0; }
}

/* halo behind detail phones */
.media-halo::before {
  content:""; position:absolute; width:78%; aspect-ratio:1; border-radius:50%;
  background:var(--brand-grad); filter:blur(60px); opacity:.18; z-index:0;
}
.media-halo .phone { position:relative; z-index:1; }
.detail--sos .media-halo::before { background:radial-gradient(circle,var(--danger),transparent 70%); opacity:.16; }

/* ---------- Trust ---------- */
.trust { background:var(--ink); color:#fff; }
.trust .section__head h2 { color:#fff; }
.trust .section__head p { color:#aebfce; }
.trust .eyebrow { color:var(--cyan-300); }
.trust .eyebrow::before { background:var(--cyan-300); }
.trust-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.trust-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.10); border-radius:var(--r-md); padding:24px; }
.trust-card__ic { width:46px; height:46px; border-radius:12px; background:rgba(34,211,238,.14); color:var(--cyan-300); display:grid; place-items:center; margin-bottom:16px; }
.trust-card__ic svg { width:23px; height:23px; }
.trust-card h3 { color:#fff; font-size:18px; }
.trust-card p { color:#aebfce; font-size:15px; margin-top:8px; }
@media (max-width:820px){ .trust-grid { grid-template-columns:1fr; } }

/* ---------- Steps ---------- */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; counter-reset:step; }
.step { position:relative; padding-top:8px; }
.step__n { width:46px; height:46px; border-radius:14px; background:var(--brand-grad); color:#fff; font-family:var(--font-brand); font-weight:800; font-size:20px; display:grid; place-items:center; box-shadow:var(--shadow-brand); }
.step h3 { font-size:19px; margin-top:18px; }
.step p { font-size:16px; color:var(--gray-600); margin-top:10px; }
.step:not(:last-child) .step__n::after {
  content:""; position:absolute; top:23px; left:58px; right:-12px; height:2px;
  background:repeating-linear-gradient(90deg,var(--cyan-300) 0 7px,transparent 7px 14px);
}
@media (max-width:900px){ .steps { grid-template-columns:1fr 1fr; } .step__n::after { display:none !important; } }
@media (max-width:520px){ .steps { grid-template-columns:1fr; } }

/* ---------- FAQ ---------- */
.faq { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq details {
  background:#fff; border:1px solid var(--gray-200); border-radius:var(--r-md);
  padding:4px 22px; transition:border-color .2s, box-shadow .2s;
}
.faq details[open] { border-color:var(--cyan-200); box-shadow:var(--shadow-sm); }
.faq summary {
  list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:18px 0; font-size:19px; font-weight:700; color:var(--gray-900);
}
.faq summary::-webkit-details-marker { display:none; }
.faq summary .chev { width:26px; height:26px; flex:none; transition:transform .25s; color:var(--cyan-700); }
.faq details[open] summary .chev { transform:rotate(45deg); }
.faq p { font-size:17px; color:var(--gray-600); padding:0 0 20px; max-width:680px; }

/* ---------- Roadmap ---------- */
.road { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.road-card { border:1px dashed var(--gray-300); border-radius:var(--r-md); padding:24px; background:var(--gray-50); }
.road-card .tag { font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--cyan-700); }
.road-card h3 { font-size:18px; margin-top:12px; }
.road-card p { font-size:15px; color:var(--gray-600); margin-top:8px; }
@media (max-width:820px){ .road { grid-template-columns:1fr; } }

/* ---------- CTA banner ---------- */
.cta-band { position:relative; overflow:hidden; background:var(--brand-grad); color:#fff; border-radius:var(--r-xl); padding:clamp(40px,6vw,72px); text-align:center; box-shadow:var(--shadow-brand); }
.cta-band::before { content:""; position:absolute; inset:0; background:radial-gradient(60% 100% at 80% 0,rgba(255,255,255,.22),transparent 60%); }
.cta-band__in { position:relative; max-width:680px; margin:0 auto; }
.cta-band h2 { color:#fff; font-size:clamp(28px,4vw,44px); }
.cta-band p { color:rgba(255,255,255,.9); font-size:20px; margin-top:18px; }
.cta-band .stores { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-top:30px; }

.store-badge { display:inline-flex; align-items:center; gap:11px; background:#0c1622; color:#fff; border-radius:14px; padding:11px 18px; min-height:56px; }
.store-badge svg { width:26px; height:26px; flex:none; }
.store-badge .l { line-height:1.15; text-align:left; }
.store-badge .l small { display:block; font-size:11px; opacity:.8; }
.store-badge .l b { font-size:17px; font-weight:700; }
.cta-band .store-badge { background:rgba(12,22,34,.92); }

/* ---------- Footer ---------- */
.footer { background:var(--ink); color:#aebfce; padding-block:60px 36px; }
.footer__top { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:32px; }
.footer h4 { color:#fff; font-size:14px; text-transform:uppercase; letter-spacing:.08em; margin-bottom:16px; }
.footer a { display:block; padding:6px 0; font-size:15px; color:#aebfce; transition:color .15s; }
.footer a:hover { color:#fff; }
.footer__brand p { font-size:15px; margin-top:16px; max-width:300px; }
.footer__disc { font-size:13px; color:#7d90a3; border-top:1px solid rgba(255,255,255,.08); margin-top:40px; padding-top:24px; display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; }
@media (max-width:820px){ .footer__top { grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .footer__top { grid-template-columns:1fr; } }

/* ---------- Cookie banner ---------- */
.cookie {
  position:fixed; left:16px; right:16px; bottom:16px; z-index:80; max-width:560px; margin:0 auto;
  background:#fff; border:1px solid var(--gray-200); border-radius:var(--r-lg); box-shadow:var(--shadow-lg);
  padding:20px 22px; display:flex; gap:16px; align-items:center; flex-wrap:wrap;
}
.cookie p { font-size:14.5px; color:var(--gray-600); flex:1; min-width:220px; }
.cookie b { color:var(--gray-900); }
.cookie__btns { display:flex; gap:10px; }
.cookie .btn { padding:10px 18px; min-height:44px; font-size:14px; }
.cookie.hide { display:none; }

/* reveal on scroll */
.reveal { opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal { opacity:1; transform:none; } html{scroll-behavior:auto;} }

/* ---------- Legal / content pages ---------- */
.legal-page { background:var(--mist); border-bottom:1px solid var(--gray-100); }
.legal { max-width:820px; padding-block:clamp(40px,6vw,80px); }
.legal__back { display:inline-flex; align-items:center; gap:8px; font-size:15px; font-weight:600; color:var(--cyan-800); margin-bottom:26px; }
.legal__back:hover { color:var(--cyan-600); }
.legal h1 { font-size:clamp(30px,4.4vw,46px); }
.legal__updated { font-size:14px; color:var(--gray-500); margin-top:12px; }
.legal__body { margin-top:clamp(28px,4vw,44px); background:#fff; border:1px solid var(--gray-100); border-radius:var(--r-lg); box-shadow:var(--shadow-sm); padding:clamp(24px,4vw,48px); }
.legal__body h2 { font-size:clamp(20px,2.4vw,26px); margin-top:40px; }
.legal__body h2:first-child { margin-top:0; }
.legal__body h3 { font-size:18px; margin-top:26px; }
.legal__body p, .legal__body li { font-size:16.5px; color:var(--gray-700); margin-top:14px; line-height:1.7; }
.legal__body ul { list-style:disc; padding-left:22px; margin-top:12px; }
.legal__body li { margin-top:8px; }
.legal__body a { color:var(--cyan-800); text-decoration:underline; text-underline-offset:2px; }
.legal__body a:hover { color:var(--cyan-600); }
.legal__body strong { color:var(--gray-900); }
.legal__note { display:flex; gap:12px; align-items:flex-start; background:var(--brand-grad-soft); border:1px solid var(--cyan-100); border-radius:var(--r-md); padding:16px 18px; margin-top:18px; font-size:15px; color:var(--gray-700); }
.legal__note .ic { width:24px; height:24px; flex:none; color:var(--cyan-700); }
.legal__ph { background:#fff7ed; border:1px dashed #fdba74; color:#9a3412; border-radius:6px; padding:1px 7px; font-weight:700; font-size:.92em; }
