:root{
  --royal:#0051BA;
  --royal-deep:#003865;
  --royal-soft:#2d6fca;
  --silver:#B2B3B2;
  --white:#FFFFFF;
  --black:#000000;
  --bg:#06101f;
  --bg-2:#0a1630;
  --panel:#0e1d39;
  --panel-2:#13284d;
  --ink:#f7f9fc;
  --muted:#c1cad8;
  --line:rgba(255,255,255,.12);
  --line-strong:rgba(178,179,178,.3);
  --shadow:0 16px 36px rgba(0,0,0,.3);
  --radius:20px;
  --radius-sm:14px;
  --max:1280px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,Arial,Helvetica,sans-serif;
  min-height:100vh;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(0,81,186,.28), transparent 26%),
    radial-gradient(circle at top right, rgba(178,179,178,.12), transparent 22%),
    linear-gradient(180deg, #040b16 0%, #091122 35%, #081120 100%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button, input, select, textarea{font:inherit}
.container{width:min(calc(100% - 32px), var(--max)); margin:0 auto}
.hidden{display:none !important}

.site-header{
  position:sticky; top:0; z-index:20;
  backdrop-filter:blur(14px);
  background:rgba(4,11,22,.82);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:14px 0;
}
.brand{display:flex; align-items:center; gap:16px; min-width:0}
.brand img{
  width:72px; height:72px; object-fit:contain;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-radius:16px; padding:6px;
  box-shadow:var(--shadow);
  border:1px solid rgba(178,179,178,.25);
}
.brand-title{display:flex; flex-direction:column; gap:4px; min-width:0}
.brand-title strong{font-size:1.14rem; letter-spacing:.02em}
.brand-title span{color:var(--muted); font-size:.92rem}

.top-nav{display:flex; gap:10px; flex-wrap:wrap}
.top-nav a{
  padding:10px 14px; border:1px solid var(--line); border-radius:999px;
  color:var(--muted); background:rgba(255,255,255,.02); transition:.18s ease;
}
.top-nav a.active,.top-nav a:hover{
  color:var(--white);
  border-color:rgba(178,179,178,.38);
  background:linear-gradient(180deg, rgba(0,81,186,.42), rgba(0,56,101,.72));
}

.hero{padding:34px 0 20px}
.hero-card{
  background:linear-gradient(135deg, rgba(0,81,186,.22), rgba(10,22,48,.96) 42%, rgba(7,16,31,.98));
  border:1px solid rgba(178,179,178,.18);
  border-radius:30px;
  padding:30px;
  box-shadow:var(--shadow);
}
.hero-card h1{margin:0 0 10px; font-size:clamp(2rem,4vw,3rem); line-height:1.06}
.hero-card p{margin:0; color:var(--muted); max-width:860px; line-height:1.58}

.section{padding:0 0 40px}
.panel{
  background:linear-gradient(180deg, rgba(14,29,57,.94), rgba(9,20,39,.94));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:20px;
}
.panel-tight{padding:18px}

input[type="search"],
input[type="text"],
select,
textarea{
  width:100%; padding:12px 14px; border-radius:12px;
  border:1px solid var(--line); background:#091325; color:var(--ink);
  outline:none;
}
input[type="search"]:focus,
input[type="text"]:focus,
select:focus,
textarea:focus{border-color:rgba(178,179,178,.42)}
textarea{resize:vertical; min-height:120px}
small{display:block; margin-top:6px; color:var(--muted)}

.kpi-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.kpi-card{
  padding:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
}
.kpi-card span{
  display:block; font-size:.82rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
}
.kpi-card strong{
  display:block; margin-top:8px; font-size:1.9rem; font-weight:800; color:var(--white);
}

.eyebrow,.mini-label{
  display:inline-block; font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; color:var(--silver);
}
.hero-homepage{padding:36px 0 18px}
.hero-grid-home{
  display:grid; grid-template-columns:1.55fr .95fr; gap:18px; align-items:stretch;
}
.hero-copy-wide h1{font-family:Barlow,Inter,Arial,sans-serif; text-transform:uppercase; font-size:clamp(2.3rem,5vw,4.4rem); line-height:.94; margin:10px 0 14px}
.hero-copy-wide p{font-size:1.03rem}
.hero-actions{display:flex; flex-wrap:wrap; gap:12px; margin-top:22px}
.cta-button,.ghost-button{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 18px; border-radius:999px; font-weight:800; letter-spacing:.01em; transition:.18s ease;
}
.cta-button{
  color:var(--white); background:linear-gradient(180deg, rgba(45,111,202,.95), rgba(0,81,186,.92));
  border:1px solid rgba(178,179,178,.38);
}
.ghost-button{
  color:var(--white); border:1px solid var(--line); background:rgba(255,255,255,.03);
}
.cta-button:hover,.ghost-button:hover{transform:translateY(-1px)}
.hero-stack{display:grid; gap:14px}
.hero-stat strong{display:block; font-size:1.2rem; margin:8px 0 8px}
.hero-stat p{margin:0; color:var(--muted); line-height:1.5}
.section-ribbon{
  display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin:0 0 16px;
  padding:0 0 10px; border-bottom:1px solid var(--line);
}
.section-ribbon span{font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; color:var(--silver)}
.section-ribbon strong{font-family:Barlow,Inter,Arial,sans-serif; text-transform:uppercase; font-size:clamp(1.3rem,2.7vw,2.2rem)}
.callout-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px}
.callout-card h2,.feature-band h2{margin:.35rem 0 .65rem; font-family:Barlow,Inter,Arial,sans-serif; text-transform:uppercase; letter-spacing:.01em}
.callout-card p,.feature-band p,.muted-copy{margin:0; color:var(--muted); line-height:1.58}
.callout-card-media{display:grid; grid-template-columns:1.2fr .8fr; gap:18px; align-items:center}
.content-image{
  width:100%; max-height:250px; object-fit:contain; border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid var(--line); padding:12px;
}
.home-center-action{display:flex; justify-content:center; margin-top:18px}
.feature-band{display:flex; justify-content:space-between; gap:18px; align-items:center}

.footer{padding:0 0 32px; color:var(--muted)}
.footer-bar{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  padding-top:18px;
  border-top:1px solid var(--line);
}

@media (max-width: 1024px){
  .kpi-grid,.hero-grid-home,.callout-grid,.callout-card-media,.feature-band{grid-template-columns:1fr}
  .feature-band{display:grid}
}
@media (max-width: 720px){
  .header-inner{align-items:flex-start; flex-direction:column}
  .brand img{width:62px;height:62px}
  .hero-card{padding:24px}
  .hero-actions,.footer-bar{flex-direction:column; align-items:flex-start}
  .kpi-grid{grid-template-columns:1fr}
}
