: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}