:root {
    --bg:#ffffff; --ink:#15161a; --near-black:#0b0b0c;
    --ink-soft:#4a4f56; --ink-dim:#6b7077; --line:#e7e6e1;
    --orange:#ff6a00; --orange-tint:#fff1e8;
    --blue:#3e8bff; --blue-deep:#2f6fd6; --blue-tint:#eaf1fe;
    --warm:#f4f3f0;
    --display:'Sora',system-ui,sans-serif; --sans:'Hanken Grotesk',system-ui,sans-serif;
  }
  * { margin:0; padding:0; box-sizing:border-box; }
  html, body { min-height:100%; }
  body { background:var(--bg); color:var(--ink); font-family:var(--sans); line-height:1.55; -webkit-font-smoothing:antialiased; }

  .page { display:none; }
  .page.active { display:block; }

  /* ============ HOME ============ */
  .shell { min-height:100vh; display:flex; flex-direction:column; }
  .topbar { flex:0 0 auto; display:flex; align-items:center; justify-content:space-between; padding:22px 40px; }
  .logo-img { height:30px; width:auto; display:block; }
  .topbar .support { color:var(--ink-dim); text-decoration:none; font-size:0.92rem; font-weight:500; transition:color .2s; }
  .topbar .support:hover { color:var(--blue-deep); }

  .shell main { flex:1 1 auto; display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:64px; padding:20px 56px; max-width:1180px; width:100%; margin:0 auto; }

  .visual { display:flex; flex-direction:column; align-items:center; gap:18px; }
  .phone { width:300px; aspect-ratio:1150/2405; position:relative; }
  .screen, .carousel { position:absolute; inset:0; }
  .carousel { overflow:hidden; }
  .track { display:flex; height:100%; touch-action:pan-y; cursor:grab; will-change:transform; }
  .track.dragging { cursor:grabbing; }
  .slide { flex:0 0 100%; height:100%; }
  .slide picture { display:block; width:100%; height:100%; }
  .slide img { width:100%; height:100%; object-fit:contain; display:block; pointer-events:none; user-select:none; -webkit-user-drag:none; }
  .dots { display:flex; gap:4px; }
  .dots button { width:24px; height:24px; border-radius:50%; background:transparent; border:0; padding:0; cursor:pointer; position:relative; -webkit-tap-highlight-color:transparent; }
  .dots button::before { content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:8px; height:8px; border-radius:50%; background:rgba(11,11,12,0.18); transition:background 200ms, transform 200ms; }
  .dots button.active::before { background:var(--near-black); transform:translate(-50%,-50%) scale(1.25); }

  .copy { max-width:520px; }
  .pill { display:inline-flex; align-items:center; gap:8px; background:var(--warm); color:var(--ink-soft); font-size:0.83rem; font-weight:600; padding:6px 14px; border-radius:100px; margin-bottom:24px; }
  .pill .dot { width:7px; height:7px; border-radius:50%; background:var(--orange); animation:pulse 2s infinite; }
  @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.35} }
  h1 { font-family:var(--display); font-weight:800; font-size:clamp(2.4rem,4.4vw,3.5rem); line-height:1.03; letter-spacing:-0.03em; margin-bottom:20px; }
  .sub { font-size:clamp(1.05rem,1.6vw,1.2rem); color:var(--ink-soft); margin-bottom:34px; }
  .badge-store { display:inline-flex; align-items:center; gap:12px; background:var(--near-black); color:#fff; padding:15px 26px; border-radius:14px; text-decoration:none; font-weight:600; transition:transform .2s, box-shadow .2s; box-shadow:0 10px 30px -10px rgba(11,11,12,0.35); }
  .badge-store:hover { transform:translateY(-2px); box-shadow:0 16px 40px -12px rgba(11,11,12,0.45); }
  .badge-store svg { width:27px; height:27px; }
  .badge-store small { display:block; font-size:0.7rem; font-weight:500; opacity:0.75; line-height:1; font-family:var(--sans); }
  .badge-store strong { display:block; font-size:1.2rem; font-weight:700; line-height:1.15; letter-spacing:-0.01em; font-family:var(--display); }
  .reassure { color:var(--ink-dim); font-size:0.9rem; margin-top:14px; display:flex; align-items:center; gap:7px; }
  .reassure svg { width:15px; height:15px; stroke:var(--blue); }

  .home-foot { border-top:1px solid var(--line); padding:22px 40px 28px; display:flex; flex-direction:column; gap:14px; }
  .foot-copy { color:var(--ink-dim); font-size:0.84rem; }
  .foot-links { display:flex; gap:24px; flex-wrap:wrap; }
  .foot-links a { color:var(--ink-soft); text-decoration:none; font-size:0.88rem; transition:color .2s; cursor:pointer; }
  .foot-links a:hover { color:var(--blue-deep); }

  /* ============ LEGAL DOCS ============ */
  .doc-wrap { max-width:760px; margin:0 auto; padding:0 28px; }
  .doc-nav { display:flex; align-items:center; justify-content:space-between; padding:22px 0; }
  .doc-nav .back { color:var(--ink-dim); text-decoration:none; font-size:0.94rem; font-weight:500; transition:color .2s; cursor:pointer; }
  .doc-nav .back:hover { color:var(--blue-deep); }
  .doc-head { padding:42px 0 28px; border-bottom:1px solid var(--line); margin-bottom:38px; }
  .doc-head h1 { font-family:var(--display); font-weight:700; font-size:clamp(2.1rem,5vw,2.8rem); letter-spacing:-0.03em; margin-bottom:10px; }
  .doc-head .updated { color:var(--ink-dim); font-size:0.94rem; }
  .doc-content { padding-bottom:64px; }
  .doc-content h2 { font-family:var(--display); font-weight:600; font-size:1.3rem; letter-spacing:-0.01em; margin:36px 0 12px; }
  .doc-content p { color:var(--ink-soft); margin-bottom:16px; }
  .doc-content ul { margin:0 0 16px 22px; color:var(--ink-soft); }
  .doc-content li { margin-bottom:7px; }
  .doc-content a { color:var(--blue-deep); }
  .note { background:#fbfbf9; border:1px solid var(--line); border-left:3px solid var(--orange); border-radius:12px; padding:15px 18px; color:var(--ink-soft); font-size:0.92rem; margin-bottom:30px; }
  .doc-foot { border-top:1px solid var(--line); padding:30px 0; }
  .doc-foot .foot-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; max-width:760px; margin:0 auto; padding:0 28px; }

  @media (max-width:880px) {
    .topbar { padding:18px 22px; }
    .logo-img { height:26px; }
    .shell main { grid-template-columns:1fr; gap:42px; padding:34px 22px; text-align:center; }
    .copy { max-width:none; margin:0 auto; }
    .pill, .reassure { margin-left:auto; margin-right:auto; }
    .reassure { justify-content:center; }
    .visual { order:-1; }
    .phone { width:258px; }
    .home-foot { padding:18px 22px; justify-content:center; text-align:center; }
  }

  /* ============ HOME SECTIONS ============ */
  .brand { display:inline-flex; flex-direction:column; gap:3px; text-decoration:none; }
  .brand-by { font-family:var(--sans); font-size:0.72rem; font-weight:500; color:var(--ink-dim); letter-spacing:0.01em; }

  .section-inner { max-width:1180px; margin:0 auto; padding:0 56px; }
  .section-eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:0.72rem; font-weight:600; color:#1f56ad; text-transform:uppercase; letter-spacing:0.06em; margin-bottom:14px; }
  .section-eyebrow .d { width:7px; height:7px; border-radius:50%; background:var(--orange); }
  .section-title { font-family:var(--display); font-weight:700; font-size:clamp(1.7rem,3vw,2.3rem); line-height:1.1; letter-spacing:-0.03em; max-width:660px; }

  .features { padding:84px 0; border-top:1px solid var(--line); background:var(--warm); }
  .feature-grid { margin-top:42px; display:grid; grid-template-columns:repeat(auto-fit,minmax(258px,1fr)); gap:18px; }
  .feature-card { background:#fff; border:1px solid var(--line); border-radius:16px; padding:24px; transition:transform .2s, box-shadow .2s, border-color .2s; }
  .feature-card:hover { transform:translateY(-3px); box-shadow:0 18px 40px -22px rgba(11,11,12,0.25); border-color:#dcdbd5; }
  .fc-mark { width:42px; height:42px; border-radius:11px; background:var(--blue-tint); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
  .fc-mark svg { width:21px; height:21px; fill:none; stroke:var(--blue-deep); stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
  .feature-card:nth-child(3n+2) .fc-mark { background:var(--orange-tint); }
  .feature-card:nth-child(3n+2) .fc-mark svg { stroke:var(--orange); }
  .feature-card h3 { font-family:var(--display); font-weight:600; font-size:1.08rem; letter-spacing:-0.01em; margin-bottom:8px; }
  .feature-card p { color:var(--ink-soft); font-size:0.92rem; line-height:1.5; }

  .company { padding:84px 0; border-top:1px solid var(--line); }
  .company-inner { max-width:760px; }
  .company .section-title { margin-bottom:18px; }
  .company p { color:var(--ink-soft); font-size:1.02rem; line-height:1.6; margin-bottom:14px; }
  .company strong { color:var(--ink); font-weight:700; }
  .company-contact { font-size:0.95rem; }
  .company-contact a { color:var(--blue-deep); text-decoration:none; }
  .company-contact a:hover { text-decoration:underline; }

  .data-sources { padding:84px 0; border-top:1px solid var(--line); background:var(--warm); }
  .data-sources .section-inner { max-width:860px; }
  .data-sources .section-title { max-width:none; }
  .data-lede { color:var(--ink-soft); font-size:1.02rem; line-height:1.6; max-width:none; margin-top:18px; }
  .data-detail { color:var(--ink-soft); font-size:0.9rem; line-height:1.6; max-width:none; margin-top:14px; }
  .logo-wall { margin-top:36px; background:#fff; border:1px solid var(--line); border-radius:16px; padding:36px 34px; }
  .logo-wall img { display:block; width:100%; max-width:100%; height:auto; margin:0 auto; }
  .logo-caption { text-align:center; color:var(--ink-dim); font-size:0.8rem; margin-top:22px; }

  .faq { padding:84px 0; border-top:1px solid var(--line); }
  .faq-list { margin-top:34px; max-width:760px; }
  .faq-item { padding:22px 0; border-bottom:1px solid var(--line); }
  .faq-item:first-child { border-top:1px solid var(--line); }
  .faq-item h3 { font-family:var(--display); font-weight:600; font-size:1.08rem; letter-spacing:-0.01em; margin-bottom:8px; }
  .faq-item p { color:var(--ink-soft); font-size:0.98rem; line-height:1.6; }

  .foot-row { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; }
  .foot-legal { color:var(--ink-dim); font-size:0.74rem; line-height:1.5; max-width:900px; }

  .brand-mark { font-family:var(--display); font-weight:700; font-size:1.15rem; letter-spacing:-0.02em; color:var(--ink); text-decoration:none; }
  .doc-content strong { color:var(--ink); font-weight:700; }

  @media (max-width:880px) {
    .section-inner { padding:0 22px; }
    .features, .company, .data-sources, .faq { padding:60px 0; }
    .logo-wall { padding:22px 16px; }
    .feature-grid { grid-template-columns:1fr; margin-top:32px; }
    .home-foot { text-align:left; padding:22px 22px 28px; }
    .foot-row { flex-direction:column; align-items:flex-start; gap:12px; }
  }
