:root {
  --slate: #0F1822;
  --slate2: #16222F;
  --wine: #6A1F3A;
  --cyan: #BE1622;
  --teal: #28C49C;
  --gold: #F4B740;
  --red: #EE5B43;
  --ink: #13202B;
  --body: #46566A;
  --mut: #93A1B1;
  --line: #E4E9EF;
  --bg: #FFFFFF;
  --soft: #F4F7FA;
  --flame: #BE1622;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Segoe UI', Helvetica, Arial, sans-serif; color: var(--body); background: var(--bg); line-height: 1.6; font-size: 17px; }
.wrap { max-width: 1400px; margin: 0 auto; padding: 0 48px; }
a { text-decoration: none; color: inherit; }
h1, h2, h3 { font-family: 'Segoe UI', Helvetica, sans-serif; color: var(--ink); font-weight: 800; line-height: 1.16; letter-spacing: -.01em; }
.eyebrow { font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--cyan); font-weight: 800; }

.btn { display: inline-block; padding: 14px 26px; border-radius: 8px; font-weight: 700; font-size: 15px; cursor: pointer; border: 0; transition: .2s; }
.btn-primary { background: var(--cyan); color: #fff; }
.btn-primary:hover { background: #d81f2e; }
.btn-dark { background: var(--wine); color: #fff; }
.btn-dark:hover { background: #852a4b; }
.btn-ghost { background: transparent; border: 1px solid rgba(255,255,255,.25); color: #fff; }

nav { position: sticky; top: 0; z-index: 60; background: rgba(15,24,34,.9); backdrop-filter: blur(10px); border-bottom: 1px solid rgba(255,255,255,.08); }
nav .wrap { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.brand { display: flex; align-items: center; gap: 11px; color: #fff; font-weight: 800; }
.brand .logo { width: 28px; height: 28px; border-radius: 7px; background: linear-gradient(135deg, var(--cyan), var(--teal)); display: grid; place-items: center; color: #04141d; }
.navlinks { display: flex; gap: 24px; font-size: 15px; color: #c4ceda; }
.navlinks a:hover { color: #fff; }
@media (max-width: 880px) { .navlinks { display: none; } }

/* HERO */
.hero { position: relative; background: var(--slate); color: #eaf0f6; overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(700px 420px at 85% 10%, rgba(190,22,34,.18), transparent 60%), radial-gradient(600px 460px at 10% 100%, rgba(106,31,58,.55), transparent 60%); }
.hero .wrap { position: relative; display: grid; grid-template-columns: 1fr 1.04fr; gap: 38px; padding: 70px 48px 76px; align-items: center; }
@media (max-width: 940px) { .hero .wrap { grid-template-columns: 1fr; padding: 48px 24px; } }
.hero h1 { font-size: 50px; color: #fff; margin: 16px 0 16px; }
.hero h1 .u { color: var(--cyan); }
.hero p.sub { font-size: 18px; color: #c4ceda; max-width: 520px; }
.cta { display: flex; gap: 12px; margin: 28px 0 20px; flex-wrap: wrap; }
.tags { font-size: 13px; color: var(--mut); }
.tags b { color: #dde4ec; }

/* map console */
.console { background: linear-gradient(160deg, #142231, #0e1924); border: 1px solid rgba(255,255,255,.1); border-radius: 16px; padding: 14px; box-shadow: 0 40px 80px -40px #000; }
.console .bar { display: flex; justify-content: space-between; align-items: center; font-size: 11.5px; color: var(--mut); padding: 2px 6px 10px; }
.live { display: inline-flex; align-items: center; gap: 7px; color: var(--teal); font-weight: 700; }
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--teal); animation: p 2s infinite; }
@keyframes p { 0% { box-shadow: 0 0 0 0 rgba(40,196,156,.55); } 70% { box-shadow: 0 0 0 9px rgba(40,196,156,0); } 100% { box-shadow: 0 0 0 0 rgba(40,196,156,0); } }
.maparea { position: relative; border-radius: 11px; overflow: hidden; background: #0b141d; }
.maparea svg { display: block; width: 100%; height: auto; }
.float { position: absolute; background: rgba(13,22,31,.86); backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,.12); border-radius: 10px; padding: 10px 12px; font-size: 11.5px; color: #dbe3ec; }
.float .k { color: var(--mut); font-size: 9.5px; text-transform: uppercase; letter-spacing: .08em; }
.float .v { font-size: 15px; font-weight: 800; color: #fff; }
.fl-tl { top: 12px; left: 12px; }
.fl-br { bottom: 12px; right: 12px; }
.legend { display: flex; gap: 14px; padding: 10px 6px 2px; font-size: 11px; color: var(--mut); }
.legend i { display: inline-block; width: 9px; height: 9px; border-radius: 50%; margin-right: 5px; vertical-align: middle; }

/* counters strip */
.kpis { background: var(--slate2); border-top: 1px solid rgba(255,255,255,.07); }
.kpis .wrap { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; padding: 0; }
.kpi { padding: 24px 28px; border-right: 1px solid rgba(255,255,255,.07); color: #eaf0f6; }
.kpi:last-child { border-right: 0; }
.kpi .n { font-size: 30px; font-weight: 800; color: #fff; }
.kpi .l { font-size: 12.5px; color: var(--mut); text-transform: uppercase; letter-spacing: .07em; }
@media (max-width: 760px) { .kpis .wrap { grid-template-columns: 1fr 1fr; } .kpi { border-bottom: 1px solid rgba(255,255,255,.07); } }

/* sources */
.sources { background: var(--soft); border-bottom: 1px solid var(--line); }
.sources .wrap { display: flex; flex-wrap: wrap; gap: 14px 24px; align-items: center; padding: 18px 48px; }
.sources .lab { font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--mut); }
.sources .s { font-size: 14px; font-weight: 600; color: var(--ink); display: inline-flex; gap: 6px; align-items: center; }

section { padding: 96px 0; }
section.dark { background: var(--slate); color: #dfe7ef; }
section.dark h2 { color: #fff; }
section.soft { background: var(--soft); }
.center { text-align: center; max-width: 760px; margin: 0 auto 52px; }
.center h2 { font-size: 36px; margin: 12px 0 10px; }
.lead { max-width: 820px; margin-bottom: 44px; }
.lead h2 { font-size: 36px; margin: 12px 0; }
.lead p { font-size: 17px; }

.access { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
@media (max-width: 760px) { .access { grid-template-columns: 1fr; } }
.acard { border: 1px solid var(--line); border-radius: 14px; padding: 30px; background: #fff; }
.acard .ic { width: 48px; height: 48px; border-radius: 11px; display: grid; place-items: center; font-size: 22px; margin-bottom: 14px; }
.acard h3 { font-size: 22px; margin-bottom: 8px; }
.acard ul { list-style: none; margin: 12px 0 18px; font-size: 15px; }
.acard li { padding: 5px 0 5px 22px; position: relative; }
.acard li::before { content: "›"; position: absolute; left: 0; color: var(--cyan); font-weight: 800; }
.trust { margin-top: 22px; background: var(--soft); border-radius: 12px; padding: 18px 22px; font-size: 15px; }
.trust b { color: var(--ink); }

.mgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 980px) { .mgrid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .mgrid { grid-template-columns: 1fr; } }
.mod { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 20px; }
.mod .mi { width: 38px; height: 38px; border-radius: 9px; background: rgba(190,22,34,.16); color: var(--cyan); display: grid; place-items: center; font-size: 18px; margin-bottom: 12px; }
.mod h4 { font-size: 15px; color: #fff; margin-bottom: 6px; }
.mod p { font-size: 13.5px; color: #aebccb; }
.tag { display: inline-block; margin-top: 9px; font-size: 10px; color: var(--gold); border: 1px solid rgba(244,183,64,.45); padding: 2px 8px; border-radius: 20px; }

.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 880px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .steps { grid-template-columns: 1fr; } }
.step { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 24px; }
.step .num { width: 30px; height: 30px; border-radius: 8px; background: var(--wine); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 13px; margin-bottom: 12px; }
.step .k { font-size: 12px; letter-spacing: .1em; color: var(--cyan); font-weight: 800; }
.step h4 { font-size: 19px; margin: 5px 0 8px; }
.step p { font-size: 14px; }

.impact { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 760px) { .impact { grid-template-columns: 1fr; } }
.istat { text-align: center; padding: 28px; border-radius: 14px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); }
.istat .big { font-size: 52px; font-weight: 800; color: var(--cyan); line-height: 1; }
.istat .l { font-size: 14px; color: #aebccb; margin-top: 10px; }

.sci { display: grid; grid-template-columns: 1fr 1fr; gap: 42px; align-items: start; }
@media (max-width: 880px) { .sci { grid-template-columns: 1fr; } }
.drow { display: flex; gap: 13px; padding: 15px 0; border-top: 1px solid var(--line); }
.drow:first-child { border-top: 0; }
.drow .nn { color: var(--teal); font-weight: 800; min-width: 26px; }
.drow b { display: block; color: var(--ink); font-size: 15px; }
.drow span { font-size: 14px; }
.card2 { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 24px; margin-bottom: 16px; }
.card2 h4 { font-size: 19px; margin-bottom: 8px; }
.card2 p { font-size: 14.5px; }
.logos { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.logos span { font-size: 12px; color: var(--mut); border: 1px solid var(--line); border-radius: 7px; padding: 6px 10px; }

.wgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 880px) { .wgrid { grid-template-columns: 1fr; } }
.wid { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 22px; }
.wid h4 { font-size: 12px; text-transform: uppercase; letter-spacing: .06em; color: var(--mut); margin-bottom: 13px; }
.vig .lvl { font-size: 28px; font-weight: 800; color: var(--gold); }
.risk { display: flex; justify-content: space-between; padding: 9px 0; border-top: 1px dashed var(--line); font-size: 14px; color: var(--ink); }
.risk:first-of-type { border-top: 0; }
.pill { padding: 2px 11px; border-radius: 20px; font-size: 12px; font-weight: 700; }
.r1 { background: rgba(40,196,156,.14); color: #13a07e; }
.r2 { background: rgba(244,183,64,.18); color: #b9821a; }
.r3 { background: rgba(238,91,67,.15); color: #d6432c; }
.alert { padding: 10px 0; border-top: 1px solid var(--line); }
.alert:first-of-type { border-top: 0; }
.alert .t { font-size: 11px; color: var(--cyan); font-weight: 700; }
.alert .d { font-size: 14px; color: var(--ink); }

.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 820px) { .split { grid-template-columns: 1fr; gap: 32px; } }
.checklist { list-style: none; margin: 16px 0; font-size: 16px; }
.checklist li { padding: 8px 0 8px 28px; position: relative; color: var(--ink); }
.checklist li::before { content: ""; position: absolute; left: 0; top: 15px; width: 8px; height: 8px; border-radius: 50%; background: var(--cyan); }
.news { background: linear-gradient(160deg, var(--wine), #3f1224); color: #fff; border-radius: 16px; padding: 32px; }
.news h3 { color: #fff; font-size: 24px; margin: 8px 0 6px; }
.news p { color: #f0dfe6; font-size: 15px; }
.news input { width: 100%; padding: 13px 14px; border-radius: 9px; border: 0; margin: 8px 0; font-size: 14px; }

footer { background: var(--slate); color: #c4ceda; padding: 48px 0 26px; }
.fg { display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.fnote { font-size: 13px; color: var(--mut); border-top: 1px solid rgba(255,255,255,.08); margin-top: 22px; padding-top: 18px; }
.cap { text-align: center; font-size: 12px; color: var(--mut); padding: 14px; background: var(--slate); }

.cobrand { display: flex; align-items: center; gap: 13px; }
.cobrand .brandlogo { height: 26px; width: auto; display: block; }
.cobrand .cilogo { height: 23px; width: auto; display: block; }
.cobrand .cbdiv { width: 1px; height: 24px; background: rgba(255,255,255,.34); }

@media (max-width: 1200px) {
  .wrap { padding: 0 36px; }
  .sources .wrap { padding: 18px 36px; }
  .hero .wrap { padding: 70px 36px 76px; }
}

@media (max-width: 768px) {
  .wrap { padding: 0 20px; }
  .sources .wrap { padding: 18px 20px; }
  .hero .wrap { padding: 48px 20px; }
  section { padding: 64px 0; }
}