:root{
  --bg:#0B1220; --bg2:#101B31; --text:#E6EEF8;
  --muted:rgba(230,238,248,.72); --muted2:rgba(230,238,248,.55);
  --line:rgba(230,238,248,.14); --shadow:0 18px 50px rgba(0,0,0,.45);
  --radius:18px; --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background: radial-gradient(1200px 600px at 20% -10%, rgba(125,211,252,.18), transparent 55%),
              radial-gradient(900px 500px at 90% 10%, rgba(167,243,208,.12), transparent 60%),
              linear-gradient(180deg, var(--bg) 0%, var(--bg2) 100%);
  line-height:1.55;
}
a{color:inherit; text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max); margin:0 auto; padding:0 20px}
.skip-link{position:absolute; left:-999px; width:1px; height:1px; overflow:hidden;}
.skip-link:focus{left:20px; top:20px; width:auto; height:auto; background:rgba(15,25,48,.92); border:1px solid var(--line); padding:10px 12px; border-radius:12px; z-index:9999;}

.header{position:sticky; top:0; z-index:20; backdrop-filter:blur(10px); background:rgba(11,18,32,.72); border-bottom:1px solid rgba(230,238,248,.10);}
.nav{display:flex; align-items:center; justify-content:space-between; padding:12px 0;}
.brand{display:flex; gap:12px; align-items:center;}
.brand img{height:40px; width:auto}
.brand .tag{font-size:12px; color:var(--muted2); border:1px solid rgba(230,238,248,.14); padding:4px 10px; border-radius:999px;}
.menu{display:flex; gap:18px; align-items:center;}
.menu a{font-size:14px; color:var(--muted); padding:8px 10px; border-radius:12px;}
.menu a[aria-current="page"]{color:var(--text); background:rgba(230,238,248,.08); border:1px solid rgba(230,238,248,.10);}
.menu a:hover{color:var(--text); text-decoration:none; background:rgba(230,238,248,.06);}
.nav-btn{display:none; background:rgba(230,238,248,.07); border:1px solid rgba(230,238,248,.14); color:var(--text); padding:10px 12px; border-radius:12px;}

.hero{padding:54px 0 18px;}
.hero-wrap{display:grid; grid-template-columns:1.1fr .9fr; gap:18px;}
.hero-card{background:linear-gradient(180deg, rgba(15,25,48,.86), rgba(15,25,48,.72)); border:1px solid rgba(230,238,248,.14); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden;}
.hero-card .bg{background:url("../img/hero-bg.svg") center/cover no-repeat; padding:26px;}
h1{margin:0 0 10px; font-size:38px; line-height:1.12; letter-spacing:-.02em;}
.subhead{margin:0 0 14px; font-size:16px; color:var(--muted); max-width:62ch;}
.badges{display:flex; flex-wrap:wrap; gap:10px; margin:14px 0 0;}
.badge{font-size:12px; padding:7px 10px; border-radius:999px; border:1px solid rgba(230,238,248,.14); background:rgba(11,18,32,.35); color:var(--muted);}
.cta-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px}
.btn{display:inline-flex; align-items:center; padding:12px 14px; border-radius:14px; border:1px solid rgba(230,238,248,.16); background:rgba(230,238,248,.07); color:var(--text); font-weight:650; font-size:14px; text-decoration:none !important;}
.btn.primary{background:linear-gradient(135deg, rgba(125,211,252,.18), rgba(167,243,208,.12)); border-color:rgba(125,211,252,.35);}
.btn:hover{filter:brightness(1.05)}

.side{display:grid; gap:14px;}
.panel{background:rgba(15,25,48,.70); border:1px solid rgba(230,238,248,.14); border-radius:var(--radius); padding:18px;}
.panel h2{font-size:14px; margin:0 0 10px; color:var(--muted); letter-spacing:.08em; text-transform:uppercase;}
.panel p{margin:0; color:var(--muted)}
.panel ul{margin:10px 0 0; padding-left:18px; color:var(--muted)}
.panel li{margin:6px 0}

.kpi{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:12px;}
.kpi .box{border:1px solid rgba(230,238,248,.14); border-radius:16px; padding:12px; background:rgba(11,18,32,.35);}
.kpi .num{font-size:18px; font-weight:800;}
.kpi .lbl{font-size:12px; color:var(--muted2);}

.section{padding:26px 0;}
.section h2{font-size:22px; margin:0 0 12px;}
.section p{margin:0 0 12px; color:var(--muted); max-width:86ch;}

.grid3{display:grid; grid-template-columns:repeat(3, 1fr); gap:14px;}
.split{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
.card{background:rgba(15,25,48,.62); border:1px solid rgba(230,238,248,.14); border-radius:var(--radius); padding:18px;}
.card h3{margin:0 0 8px; font-size:16px}
.card p{margin:0; color:var(--muted); font-size:14px}
.callout{background:linear-gradient(135deg, rgba(125,211,252,.12), rgba(167,243,208,.08)); border:1px solid rgba(125,211,252,.22); border-radius:var(--radius); padding:18px;}
.callout p{margin:0; color:var(--muted)}
.hr{height:1px; background:rgba(230,238,248,.12); margin:10px 0 0;}

.gallery{display:grid; grid-template-columns:repeat(12, 1fr); gap:14px;}
.pic{position:relative; border-radius:18px; overflow:hidden; border:1px solid rgba(230,238,248,.14); background:rgba(11,18,32,.35); box-shadow:0 10px 30px rgba(0,0,0,.28);}
.pic img{width:100%; height:100%; object-fit:cover; display:block; transform:scale(1.01);}
.pic .cap{position:absolute; left:0; right:0; bottom:0; padding:10px 12px; background:linear-gradient(180deg, transparent, rgba(0,0,0,.55)); font-size:12px; color:rgba(230,238,248,.90);}
.span-7{grid-column:span 7;} .span-5{grid-column:span 5;} .span-6{grid-column:span 6;}

.form{display:grid; gap:12px; max-width:760px;}
.field{display:grid; gap:6px;}
label{font-size:13px; color:var(--muted)}
input, textarea{width:100%; padding:12px; border-radius:14px; border:1px solid rgba(230,238,248,.16); background:rgba(11,18,32,.45); color:var(--text); outline:none;}
textarea{min-height:140px; resize:vertical}
input:focus, textarea:focus{border-color:rgba(125,211,252,.55)}
.note{font-size:12px; color:var(--muted2)}
.notice{border:1px dashed rgba(230,238,248,.18); border-radius:14px; padding:12px; color:var(--muted); background:rgba(11,18,32,.35);}

.footer{margin-top:22px; border-top:1px solid rgba(230,238,248,.12); background:rgba(11,18,32,.55); padding:22px 0;}
.footer .row{display:flex; justify-content:space-between; align-items:flex-start; gap:14px; flex-wrap:wrap;}
.footer .small{color:var(--muted2); font-size:12px}
.footer a{color:var(--muted)}

@media (max-width:980px){
  .hero-wrap{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr; gap:12px;}
  .span-7,.span-5,.span-6{grid-column:span 1;}
  h1{font-size:32px}
}
@media (max-width:720px){
  .nav-btn{display:inline-flex}
  .menu{position:absolute; right:20px; top:62px; flex-direction:column; min-width:240px; background:rgba(11,18,32,.95); border:1px solid rgba(230,238,248,.14); border-radius:16px; padding:10px; display:none;}
  .menu.open{display:flex}
  .menu a{padding:10px 12px}
  .brand .tag{display:none}
}
