:root{
    --navy-900:#06173a;
    --navy-800:#0a1f44;
    --navy-700:#0e2a5c;
    --navy-600:#163873;
    --navy-500:#2d4e91;
    --navy-100:#e5ebf6;
    --navy-50:#f3f5fb;

    --emerald-700:#0a7a52;
    --emerald-600:#0f9d6e;
    --emerald-500:#1bbf86;
    --emerald-100:#d6f3e7;
    --emerald-50:#ecfaf3;

    --gold-700:#9a7a3a;
    --gold-600:#c9a35b;
    --gold-500:#dcc080;
    --gold-100:#f4ead3;
    --gold-50:#faf5e6;

    --ink-900:#0c1424;
    --ink-700:#28324a;
    --ink-500:#5a6479;
    --ink-400:#8893a8;
    --ink-300:#b7c0d2;
    --ink-200:#d8dee8;
    --ink-100:#eef1f7;
    --ink-50:#f6f7fb;
    --bg:#fbfbfd;
    --white:#ffffff;

    --radius-sm:8px;
    --radius:14px;
    --radius-lg:22px;
    --radius-xl:32px;

    --shadow-xs:0 1px 0 rgba(12,20,36,.04), 0 1px 2px rgba(12,20,36,.04);
    --shadow-sm:0 1px 2px rgba(12,20,36,.04), 0 4px 12px rgba(12,20,36,.04);
    --shadow-md:0 2px 4px rgba(12,20,36,.04), 0 10px 30px rgba(12,20,36,.06);
    --shadow-lg:0 4px 8px rgba(12,20,36,.06), 0 24px 60px rgba(12,20,36,.10);
    --shadow-navy:0 18px 40px -10px rgba(6,23,58,.45);

    --font-sans:"Manrope", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
    --font-serif:"Newsreader", ui-serif, Georgia, serif;
    --font-mono:"JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0;background:var(--bg);color:var(--ink-900);
    font-family:var(--font-sans);-webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility}
  body{overflow-x:hidden}
  a{color:inherit;text-decoration:none}
  button{font-family:inherit}
  img{max-width:100%;display:block}
  ::selection{background:var(--navy-800);color:#fff}

  .wrap{max-width:1240px;margin:0 auto;padding:0 24px}
  @media (max-width:640px){ .wrap{padding:0 18px} }

  .eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;
    letter-spacing:.14em;text-transform:uppercase;font-weight:600;
    color:var(--emerald-700)}
  .eyebrow .dot{width:6px;height:6px;border-radius:99px;background:var(--emerald-600)}
  .eyebrow.gold{color:var(--gold-700)}
  .eyebrow.gold .dot{background:var(--gold-600)}
  .eyebrow.navy{color:var(--navy-700)}
  .eyebrow.navy .dot{background:var(--navy-700)}

  h1,h2,h3,h4{font-family:var(--font-sans);letter-spacing:-.02em;
    color:var(--ink-900);margin:0;line-height:1.06;font-weight:700}
  h1{font-size:clamp(40px, 6vw, 72px);letter-spacing:-.035em;font-weight:700}
  h2{font-size:clamp(30px, 4vw, 48px);letter-spacing:-.03em}
  h3{font-size:clamp(20px, 2.2vw, 28px);letter-spacing:-.02em}
  h4{font-size:18px;font-weight:600;letter-spacing:-.01em}
  .serif{font-family:var(--font-serif);font-style:italic;font-weight:400;
    letter-spacing:-.01em}
  p{margin:0;color:var(--ink-700);line-height:1.55}
  .mono{font-family:var(--font-mono);letter-spacing:0}

  .btn{display:inline-flex;align-items:center;gap:10px;height:50px;padding:0 22px;
    border-radius:99px;border:0;font-weight:600;font-size:15px;cursor:pointer;
    transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
    white-space:nowrap}
  .btn:active{transform:translateY(1px)}
  .btn-primary{background:var(--navy-800);color:#fff;box-shadow:var(--shadow-navy)}
  .btn-primary:hover{background:var(--navy-700);box-shadow:0 22px 50px -10px rgba(6,23,58,.55)}
  .btn-emerald{background:var(--emerald-600);color:#fff;
    box-shadow:0 18px 36px -10px rgba(15,157,110,.55)}
  .btn-emerald:hover{background:var(--emerald-500)}
  .btn-ghost{background:transparent;color:var(--ink-900);
    box-shadow:inset 0 0 0 1px var(--ink-200)}
  .btn-ghost:hover{background:var(--white);box-shadow:inset 0 0 0 1px var(--ink-300), var(--shadow-sm)}
  .btn-gold{background:var(--gold-600);color:var(--navy-900);
    box-shadow:0 14px 30px -10px rgba(201,163,91,.55)}
  .btn-gold:hover{background:var(--gold-500)}
  .btn-sm{height:40px;padding:0 16px;font-size:14px}
  .btn-arrow{display:inline-flex;width:24px;height:24px;border-radius:99px;
    background:rgba(255,255,255,.15);align-items:center;justify-content:center;font-size:14px}
  .btn-primary .btn-arrow{background:var(--emerald-600)}
  .btn-emerald .btn-arrow{background:rgba(255,255,255,.22)}

  .chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;
    border-radius:99px;font-size:12px;font-weight:600;
    background:var(--ink-50);color:var(--ink-700);
    box-shadow:inset 0 0 0 1px var(--ink-100)}
  .chip.emerald{background:var(--emerald-50);color:var(--emerald-700);
    box-shadow:inset 0 0 0 1px var(--emerald-100)}
  .chip.gold{background:var(--gold-50);color:var(--gold-700);
    box-shadow:inset 0 0 0 1px var(--gold-100)}
  .chip.navy{background:var(--navy-50);color:var(--navy-700);
    box-shadow:inset 0 0 0 1px var(--navy-100)}

  .card{background:var(--white);border-radius:var(--radius-lg);
    box-shadow:var(--shadow-sm);border:1px solid var(--ink-100)}
  .card-flat{background:var(--white);border-radius:var(--radius);
    border:1px solid var(--ink-100)}

  /* Subtle grid bg used as imagery placeholder */
  .grid-bg{
    background-image:
      linear-gradient(rgba(10,31,68,.05) 1px, transparent 1px),
      linear-gradient(90deg, rgba(10,31,68,.05) 1px, transparent 1px);
    background-size:28px 28px;
  }
  .dotted-bg{
    background-image:radial-gradient(rgba(10,31,68,.10) 1px, transparent 1.4px);
    background-size:20px 20px}

  .section{padding:96px 0;position:relative}
  @media (max-width:768px){ .section{padding:64px 0} }

  /* nav, common */
  .pill-tag{display:inline-flex;align-items:center;gap:8px;height:30px;padding:0 12px;
    background:#fff;border:1px solid var(--ink-100);border-radius:99px;
    font-size:12px;font-weight:600;color:var(--ink-700)}
  .pill-tag svg{width:13px;height:13px}

  .kpi-num{font-size:clamp(38px,4.4vw,52px);font-weight:700;letter-spacing:-.04em;
    line-height:1;color:var(--ink-900)}
  .kpi-num .unit{color:var(--emerald-600);font-size:.55em;vertical-align:top}

  hr.rule{border:0;height:1px;background:var(--ink-100);margin:0}

  /* sticky FABs */
  .fab-wrap{position:fixed;right:18px;bottom:18px;z-index:60;
    display:flex;flex-direction:column;gap:12px;align-items:flex-end}
  .fab{display:inline-flex;align-items:center;gap:10px;height:52px;padding:0 18px;
    border-radius:99px;background:var(--emerald-600);color:#fff;font-weight:700;font-size:14px;
    box-shadow:0 16px 40px -10px rgba(15,157,110,.5);border:0;cursor:pointer}
  .fab.consult{background:var(--navy-800);color:#fff;
    box-shadow:0 16px 40px -10px rgba(6,23,58,.55)}
  .fab svg{width:18px;height:18px}

  /* sections sleeve color */
  .bleed-navy{background:var(--navy-900);color:#fff}
  .bleed-navy h1,.bleed-navy h2,.bleed-navy h3,.bleed-navy h4{color:#fff}
  .bleed-navy p{color:rgba(255,255,255,.72)}

  .underline-link{color:var(--navy-700);font-weight:600;
    border-bottom:1px solid var(--ink-200);padding-bottom:2px}
  .underline-link:hover{color:var(--emerald-700);border-color:var(--emerald-600)}

  .ring-emerald{box-shadow:inset 0 0 0 1px var(--emerald-100)}

  /* utility */
  .row{display:flex;gap:16px}
  .col{display:flex;flex-direction:column;gap:16px}
  .between{display:flex;align-items:center;justify-content:space-between}
  .center{display:flex;align-items:center;justify-content:center}
  .gap-6{gap:6px} .gap-8{gap:8px} .gap-12{gap:12px} .gap-16{gap:16px} .gap-24{gap:24px}

  /* logo mark */
  .fd-mark{width:36px;height:36px;border-radius:9px;background:var(--navy-800);
    color:#fff;display:inline-flex;align-items:center;justify-content:center;
    font-weight:700;font-size:16px;letter-spacing:-.02em;position:relative;overflow:hidden}
  .fd-mark::after{content:"";position:absolute;inset:auto -2px -2px auto;
    width:14px;height:14px;background:var(--emerald-500);border-radius:0 9px 0 9px}
  .fd-mark span{position:relative;z-index:1}

  /* tiny chart helpers */
  .spark-bar{display:flex;align-items:flex-end;gap:3px;height:42px}
  .spark-bar i{display:block;width:8px;border-radius:3px;background:var(--navy-100)}
  .spark-bar i.hi{background:var(--emerald-500)}

  .progress{height:6px;border-radius:99px;background:var(--ink-100);overflow:hidden}
  .progress > i{display:block;height:100%;background:var(--emerald-500);border-radius:99px}

  /* scroll-spy fade-in */
  .reveal{opacity:0;transform:translateY(14px);transition:opacity .7s ease, transform .7s ease}
  .reveal.in{opacity:1;transform:none}

  /* placeholders */
  .img-stub{background:
      repeating-linear-gradient(135deg, rgba(10,31,68,.04) 0 10px, rgba(10,31,68,.07) 10px 20px);
    border-radius:var(--radius);position:relative;overflow:hidden;
    border:1px solid var(--ink-100)}
  .img-stub::after{content:attr(data-label);position:absolute;left:14px;top:12px;
    font-family:var(--font-mono);font-size:11px;color:var(--ink-500);
    background:rgba(255,255,255,.85);padding:4px 8px;border-radius:6px;
    border:1px solid var(--ink-100)}

  /* form */
  .field{display:flex;flex-direction:column;gap:6px}
  .field label{font-size:13px;font-weight:600;color:var(--ink-700)}
  .field input,.field select,.field textarea{
    height:46px;border-radius:12px;border:1px solid var(--ink-200);
    padding:0 14px;font:500 14px var(--font-sans);background:#fff;color:var(--ink-900);
    outline:none;transition:border-color .15s ease, box-shadow .15s ease}
  .field textarea{height:auto;min-height:96px;padding:12px 14px;resize:vertical}
  .field input:focus,.field select:focus,.field textarea:focus{
    border-color:var(--navy-500);box-shadow:0 0 0 4px rgba(45,78,145,.12)}

  /* country list */
  details > summary{cursor:pointer;list-style:none}
  details > summary::-webkit-details-marker{display:none}


  /* ============================================================
     MOBILE RESPONSIVENESS — auto-fit buttons, fonts & sections
     ============================================================ */

  /* Global overflow safety — nothing forces a horizontal scrollbar */
  html, body { max-width: 100%; overflow-x: hidden; }
  body * { min-width: 0; }
  img, svg, video, canvas, table { max-width: 100%; height: auto; }
  input, select, textarea { max-width: 100%; }

  @media (max-width: 760px){
    /* Buttons auto-fit: wrap long labels, comfortable tap target, never overflow */
    .btn{
      height: auto;
      min-height: 48px;
      padding: 12px 18px;
      font-size: 14px;
      line-height: 1.25;
      white-space: normal;
      text-align: center;
      max-width: 100%;
    }
    .btn-sm{ min-height: 40px; padding: 10px 15px; font-size: 13px; }
    .btn-arrow{ flex: 0 0 auto; }

    /* CTA rows: let buttons grow to full width instead of cramping */
    .cta-row .btn, .btn-block { flex: 1 1 240px; }

    /* Headings without inline sizes scale down gracefully */
    h1{ font-size: clamp(28px, 8.5vw, 40px); letter-spacing: -.02em; }
    h2{ font-size: clamp(24px, 6.8vw, 34px); }
    h3{ font-size: clamp(19px, 5.4vw, 24px); }

    /* Tighter section rhythm on phones */
    .section{ padding: 52px 0; }

    /* FABs: smaller so they don't cover content / CTAs */
    .fab{ height: 46px; padding: 0 15px; font-size: 13px; }
    .fab svg{ width: 16px; height: 16px; }
    .fab-wrap{ right: 12px; bottom: 12px; gap: 9px; }

    /* Cards/panels with big fixed inner padding breathe down on phones */
    .card{ padding: 22px 18px; }
    .wrap{ padding: 0 18px; }
  }

  /* Small phones (iPhone SE / Mini, ~360–414px) */
  @media (max-width: 480px){
    h1{ font-size: clamp(26px, 9vw, 34px); }
    h2{ font-size: clamp(22px, 7.6vw, 28px); }
    .btn{ width: 100%; }            /* full-width primary CTAs */
    .btn-arrow{ display: none; }    /* drop the arrow chip when space is tight */
    .wrap{ padding: 0 15px; }
    .card{ padding: 18px 15px; border-radius: 16px; }
    /* anything explicitly laid out as a 2/3/4-col grid collapses to one column */
    [style*="grid-template-columns: repeat(4"],
    [style*="grid-template-columns: repeat(3"],
    [style*="grid-template-columns:repeat(4"],
    [style*="grid-template-columns:repeat(3"]{
      grid-template-columns: 1fr !important;
    }
  }

  /* Tiny phones (<=360px) — Galaxy Fold cover, older Androids */
  @media (max-width: 360px){
    .wrap{ padding: 0 13px; }
    h1{ font-size: 25px; }
    .section{ padding: 44px 0; }
  }

  /* ── Mobile: dock the 3 action buttons into a single bottom row ── */
  @media (max-width: 640px){
    .fab-wrap{
      left: 0 !important; right: 0 !important; bottom: 14px !important;
      flex-direction: row !important;
      justify-content: center !important;
      align-items: center !important;
      gap: 52px !important;
      padding: 0 10px;
    }
    .fab-wrap .fab{
      height: 46px; padding: 0 15px; font-size: 12.5px; font-weight: 700;
      flex: 0 1 auto; white-space: nowrap;
      box-shadow: 0 8px 22px -6px rgba(6,23,58,.45);
    }
    /* Frankie AI launcher → raised circular button in the centre */
    [aria-label="Open Frankie AI assistant"]{
      left: 50% !important; right: auto !important; bottom: 8px !important;
      transform: translateX(-50%);
      width: 60px !important; height: 60px !important;
      z-index: 61 !important;
      border: 3px solid #fff !important;
      box-shadow: 0 12px 28px -6px rgba(10,31,68,.5) !important;
    }
  }

