:root{
  --bg:#eef2f7;
  --panel:#ffffff;
  --ink:#0e1b2a;
  --muted:#5b6b7f;
  --brand:#d3222a;
  --blue:#1f4b7a;
  --line:#d8e0ec;
  --shadow: 0 18px 50px rgba(10,18,30,.12);
  --radius: 18px;
  --radius2: 12px;
  --max: 1120px;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color:var(--ink);
  background: radial-gradient(1100px 500px at 50% 0%, #ffffff 0%, var(--bg) 60%, var(--bg) 100%);
}
a{ color:inherit; text-decoration:none; }
.container{ width:min(var(--max), 92vw); margin:0 auto; }
.topbar{
  background: linear-gradient(90deg, #b7161d 0%, #d3222a 45%, #b7161d 100%);
  color:#fff;
  position:sticky;
  top:0;
  z-index:50;
  box-shadow: 0 10px 30px rgba(0,0,0,.12);
}
.topbar .row{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0; gap:16px; flex-wrap:wrap;
}
.brand{ display:flex; align-items:center; gap:12px; min-width:260px; }
.brand img{ width:42px; height:42px; border-radius:10px; }
.brand .t{ line-height:1.05; font-weight:800; letter-spacing:.2px; }
.brand .t span{ display:block; font-weight:700; opacity:.92; font-size:12px; }
.nav{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; justify-content:center; }
.nav a{ font-weight:700; opacity:.95; padding:10px 8px; border-bottom:2px solid transparent; }
.nav a:hover{ border-bottom-color:rgba(255,255,255,.85); }
.nav a[aria-current="page"]{ border-bottom-color:rgba(255,255,255,.95); }
.nav-right{ display:flex; align-items:center; gap:10px; }
.pill{
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.35);
  padding:10px 12px; border-radius: 12px;
  display:flex; align-items:center; gap:10px; font-weight:700;
}
.pill small{ opacity:.85; font-weight:700; }
.burger{
  display:none;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.12);
  color:#fff; padding:10px 12px; border-radius:12px; font-weight:800;
}
.hero{
  position:relative;
  min-height: 560px;
  display:flex;
  align-items:stretch;
  overflow:hidden;
  background:
    linear-gradient(120deg, rgba(15,32,60,.55), rgba(15,32,60,.12) 55%, rgba(255,255,255,.0) 100%),
    url("../img/hero-bg.png");
  background-size: cover;
  background-position: center;
  border-bottom: 1px solid var(--line);
}
.hero .content{
  position:relative; z-index:2;
  width:100%;
  display:grid;
  grid-template-columns: 1.3fr .9fr;
  gap: 22px;
  padding: 44px 0 34px;
  align-items:center;
}
.hero h1{ color:#fff; font-size: clamp(30px, 3.1vw, 48px); margin:4px 0 10px; letter-spacing:.2px; }
.hero p{ color: rgba(255,255,255,.92); font-size: 16px; line-height:1.6; margin:0 0 18px; max-width:52ch; }
.hero .sub{ color: rgba(255,255,255,.85); font-weight:700; }
.cta{ display:flex; gap:12px; flex-wrap:wrap; }
.btn{
  border:none; padding: 12px 18px; border-radius: 12px;
  font-weight:800; cursor:pointer; display:inline-flex; align-items:center; gap:10px;
}
.btn.primary{ background: var(--brand); color:#fff; }
.btn.secondary{ background: rgba(255,255,255,.14); color:#fff; border:1px solid rgba(255,255,255,.28); }
.hero-card{
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(255,255,255,.65);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 18px 18px 14px;
}
.hero-card .tag{ display:flex; justify-content:space-between; align-items:center; gap:12px; font-weight:900; color: var(--blue); }
.hero-card .tag span{
  background: rgba(31,75,122,.12);
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid rgba(31,75,122,.14);
}
.hero-card img{ width:100%; height:auto; border-radius: 14px; margin-top:12px; }
.section{ padding: 38px 0; }
.section .panel{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 12px 40px rgba(10,18,30,.06);
  overflow:hidden;
}
.section-title{ text-align:center; padding: 26px 18px 6px; }
.section-title h2{ margin:0; color: var(--blue); font-size: 28px; letter-spacing:.2px; }
.section-title p{ margin: 10px auto 0; color: var(--muted); max-width: 70ch; line-height:1.55; }
.cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 18px; padding: 18px 18px 26px; }
.card{
  border: 1px solid var(--line);
  border-radius: var(--radius2);
  background: linear-gradient(180deg, #fff 0%, #fbfcff 100%);
  padding: 18px;
  box-shadow: 0 10px 22px rgba(10,18,30,.05);
}
.card h3{ margin: 12px 0 8px; font-size: 16px; }
.card p{ margin: 0; color: var(--muted); line-height:1.55; font-size: 14px; }
.card .icon{ width:60px; height:60px; display:block; }
.band{
  background: linear-gradient(90deg, #213a63 0%, #2b568b 45%, #213a63 100%);
  color:#fff; padding: 18px; text-align:center; font-weight:900; letter-spacing:.2px; font-size: 20px;
}
.tiles{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; padding: 18px; background: linear-gradient(180deg, #ffffff 0%, #f6f8fc 100%); }
.tile{
  background:#fff; border:1px solid var(--line); border-radius: 12px;
  padding: 16px; font-weight:800; color: var(--blue); text-align:center;
  box-shadow: 0 10px 20px rgba(10,18,30,.05);
}
.dual{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px; padding: 18px; background: linear-gradient(180deg, #ffffff 0%, #f6f8fc 100%); }
.box{ border:1px solid var(--line); border-radius: 14px; overflow:hidden; background:#fff; box-shadow: 0 10px 20px rgba(10,18,30,.05); }
.box .head{ padding: 12px 14px; font-weight:900; color:#fff; }
.box.red .head{ background: linear-gradient(90deg, #b5161d, #d3222a); }
.box.green .head{ background: linear-gradient(90deg, #0b6f5a, #10836b); }
.box ul{ margin:0; padding: 14px 18px 18px 34px; color: var(--muted); }
.box li{ margin: 8px 0; font-weight:700; }
.split{ display:grid; grid-template-columns: 1.15fr .85fr; gap: 16px; padding: 18px; background: linear-gradient(180deg, #ffffff 0%, #f6f8fc 100%); }
.gallery{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.thumb{ border:1px solid var(--line); border-radius: 14px; overflow:hidden; background:#fff; box-shadow: 0 10px 22px rgba(10,18,30,.05); }
.thumb img{ width:100%; height:auto; display:block; }
.thumb .cap{ padding: 10px 12px 12px; font-weight:900; color: var(--blue); }
.news{ border:1px solid var(--line); border-radius: 14px; background:#fff; overflow:hidden; box-shadow: 0 10px 22px rgba(10,18,30,.05); }
.news .title{ background: linear-gradient(90deg, #213a63, #2b568b); color:#fff; padding: 12px 14px; font-weight:900; }
.news .item{ padding: 12px 14px; border-top:1px solid var(--line); color: var(--muted); font-weight:700; }
.form{ border:1px solid var(--line); border-radius: 14px; background:#fff; overflow:hidden; box-shadow: 0 10px 22px rgba(10,18,30,.05); }
.form .title{ background: linear-gradient(90deg, #213a63, #2b568b); color:#fff; padding: 12px 14px; font-weight:900; }
.form .body{ padding: 14px; display:grid; gap:10px; }
.input{ width:100%; padding: 11px 12px; border: 1px solid var(--line); border-radius: 10px; background: #f5f7fb; font-weight:700; color: var(--ink); }
textarea.input{ min-height: 120px; resize: vertical; }
.form .send{ margin-top: 6px; justify-content:center; width: 100%; background: var(--brand); color:#fff; }
footer{
  background: linear-gradient(180deg, #1c2d45, #132033);
  color: rgba(255,255,255,.86);
  padding: 24px 0;
  margin-top: 30px;
  border-top: 1px solid rgba(255,255,255,.12);
}
footer .frow{ display:flex; justify-content:space-between; gap: 14px; flex-wrap:wrap; align-items:center; }
footer a{ color:#fff; font-weight:800; opacity:.9; }
footer small{ display:block; opacity:.85; margin-top: 4px; }
.page-hero{ background: linear-gradient(90deg, #1c2d45, #2b568b); color:#fff; padding: 36px 0 26px; }
.page-hero h1{ margin:0; font-size: 34px; }
.page-hero p{ margin: 10px 0 0; opacity:.92; max-width: 80ch; line-height:1.6; }
.grid2{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px; padding: 18px; }
.kpi{ border:1px solid var(--line); border-radius: 14px; background:#fff; padding: 14px; box-shadow: 0 10px 20px rgba(10,18,30,.05); }
.kpi b{ color: var(--blue); }
@media (max-width: 980px){
  .hero .content{ grid-template-columns: 1fr; padding: 34px 0 24px; }
  .cards{ grid-template-columns: 1fr; }
  .tiles{ grid-template-columns: 1fr; }
  .dual{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .nav{ display:none; }
  .burger{ display:inline-flex; }
  .nav.open{ display:flex; flex-direction:column; width:100%; padding-bottom: 10px; }
  .nav-right{ width:100%; justify-content:flex-end; }
}