:root{
  --bg:#0b1016;
  --bg-soft:#0f1620;
  --panel:#121b27;
  --panel-2:#172231;
  --surface:#101823;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.12);
  --text:#eaf0f6;
  --muted:#a8b3c1;
  --accent:#f05a22;
  --accent-2:#ff7c4c;
  --ok:#71c2ff;
  --shadow:0 24px 80px rgba(0,0,0,.35);
  --radius:24px;
  --max:1220px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(240,90,34,.16), transparent 22%),
    radial-gradient(circle at 85% 18%, rgba(113,194,255,.08), transparent 20%),
    linear-gradient(180deg, #0a0f15 0%, #0b1016 100%);
  font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.6;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg, rgba(255,255,255,.12), transparent 75%);
  z-index:0;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.site-shell,.site-header,.site-footer,main{position:relative;z-index:1}
.container{width:min(calc(100% - 40px), var(--max));margin:0 auto}
.site-header{
  position:sticky;top:0;z-index:20;
  backdrop-filter:blur(18px);
  background:rgba(10,15,21,.72);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav-wrap{
  display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 0;
}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-badge{
  width:210px;max-width:44vw;padding:10px 14px;border-radius:18px;
  background:rgba(255,255,255,.95);
  box-shadow:0 18px 40px rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.65);
}
.brand-badge img{width:100%;height:auto}
.brand-text{display:flex;flex-direction:column;gap:2px}
.brand-text strong{font-family:"Sora",sans-serif;font-size:.98rem;letter-spacing:-.02em}
.brand-text span{font-size:.82rem;color:var(--muted)}
.main-nav{display:flex;align-items:center;gap:24px;color:var(--muted);font-size:.95rem}
.main-nav a{position:relative;padding:8px 0}
.main-nav a:hover,.main-nav a.is-active{color:var(--text)}
.main-nav a.is-active::after,.main-nav a:hover::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;border-radius:999px;background:var(--accent)
}
.hero{padding:84px 0 56px}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px}
.panel,.card,.news-card,.method-card,.contact-card,.hero-main,.hero-side-card,.aside-card,.prose-card{
  background:linear-gradient(180deg, rgba(18,27,39,.82), rgba(12,18,27,.92));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.hero-main{padding:40px}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;border-radius:999px;
  font-size:.86rem;font-weight:700;letter-spacing:.01em;
  background:rgba(240,90,34,.12);color:#ffb194;border:1px solid rgba(240,90,34,.16)
}
h1,h2,h3,h4{margin:0;line-height:1.1;letter-spacing:-.03em;font-family:"Sora",sans-serif}
h1{font-size:clamp(2.8rem,6vw,5.2rem);max-width:12ch;margin:18px 0 18px}
.hero-lead{font-size:1.08rem;color:var(--muted);max-width:64ch;margin:0 0 24px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:0 0 26px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;padding:13px 20px;font-weight:700;border:1px solid transparent;
  transition:.22s ease;min-width:150px
}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:white;box-shadow:0 18px 42px rgba(240,90,34,.28)}
.btn-secondary{background:rgba(255,255,255,.02);border-color:var(--line-2);color:var(--text)}
.btn:hover{transform:translateY(-1px)}
.highlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.highlight-item{
  padding:18px;border-radius:18px;background:rgba(255,255,255,.02);border:1px solid var(--line)
}
.highlight-item strong{display:block;margin-bottom:6px}
.highlight-item span{color:var(--muted)}
.hero-side{display:grid;gap:18px}
.hero-side-card{padding:28px}
.hero-side-card h3{font-size:1.2rem;margin-bottom:10px}
.hero-side-card p,.hero-side-card li,.lead,.card p,.news-card p,.method-card p,.contact-card p,.prose-card p,.article-standfirst,.article-meta{color:var(--muted)}
.hero-side-list{display:grid;gap:14px;padding:0;margin:18px 0 0;list-style:none}
.hero-side-list li{display:flex;gap:12px}
.hero-side-list .index{
  width:34px;height:34px;display:grid;place-items:center;border-radius:50%;
  background:rgba(240,90,34,.14);color:#ffb194;font-weight:800;flex:0 0 34px
}
.section{padding:42px 0}
.section-head{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:end;margin-bottom:22px}
.section-head h2{font-size:clamp(2rem,4vw,3.2rem)}
.section-head .lead{font-size:1.03rem;margin:0}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card,.news-card,.method-card,.contact-card{padding:28px}
.card-code{
  width:48px;height:48px;border-radius:16px;display:grid;place-items:center;
  background:rgba(240,90,34,.12);color:#ffb194;font-family:"Sora",sans-serif;font-weight:800;
  margin-bottom:18px;border:1px solid rgba(240,90,34,.18)
}
.card h3,.news-card h3,.method-card h3,.contact-card h3{font-size:1.22rem;margin-bottom:10px}
.list{margin:0;padding-left:18px;color:var(--muted)}
.split-grid{display:grid;grid-template-columns:.96fr 1.04fr;gap:18px}
.story-panel{padding:32px}
.cap-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.cap-card{
  padding:22px;border-radius:20px;background:rgba(255,255,255,.02);
  border:1px solid var(--line)
}
.cap-card strong{display:block;margin-bottom:8px}
.cap-card span{color:var(--muted)}
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.method-step{
  width:36px;height:36px;border-radius:50%;display:grid;place-items:center;margin-bottom:14px;
  background:rgba(113,194,255,.12);color:#bfe4ff;font-weight:800;border:1px solid rgba(113,194,255,.18)
}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.news-card .meta,.article-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:.88rem;margin:0 0 12px}
.news-card .meta span,.article-meta span{
  padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--line)
}
.news-card .link, .ghost-link{
  color:#ffb194;font-weight:700
}
.contact-wrap{
  display:grid;grid-template-columns:1.08fr .92fr;gap:18px
}
.contact-card.dark{
  background:linear-gradient(135deg,#151f2d 0%, #0e1520 100%);
}
.contact-list{list-style:none;padding:0;margin:0;display:grid;gap:10px;color:var(--muted)}
.site-footer{padding:28px 0 56px}
.footer-grid{
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  padding-top:18px;border-top:1px solid rgba(255,255,255,.08);color:var(--muted)
}
.footer-links{display:flex;gap:16px;flex-wrap:wrap}
.article-hero{padding:72px 0 30px}
.article-hero h1{
  max-width:18ch;
  font-size:clamp(2.2rem,4.8vw,4rem);
}
.article-content{padding:20px 0 50px}
.article-grid{display:grid;grid-template-columns:1fr 320px;gap:18px}
.prose-card{padding:34px}
.prose-card h2{font-size:1.4rem;margin:28px 0 10px}
.article-cover{
  margin:0 0 24px;
  padding:14px;
  border-radius:24px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
}
.article-cover img{
  width:100%;
  max-width:920px;
  height:auto;
  margin:0 auto;
  border-radius:16px;
  object-fit:cover;
}
.article-list{color:var(--muted);padding-left:20px}
.article-list.compact{margin:0}
.article-aside{display:grid;gap:16px}
.aside-card{padding:22px}
.aside-card h3{font-size:1.05rem;margin-bottom:10px}
.empty-state{
  padding:24px;border-radius:18px;background:rgba(255,255,255,.02);border:1px dashed var(--line);color:var(--muted)
}
@media (max-width:1100px){
  .hero-grid,.section-head,.split-grid,.contact-wrap,.article-grid{grid-template-columns:1fr}
  .card-grid,.news-grid{grid-template-columns:1fr}
  .method-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav-wrap{flex-wrap:wrap}
  .main-nav{width:100%;justify-content:space-between;gap:14px;overflow:auto}
  .highlight-grid,.cap-grid,.method-grid{grid-template-columns:1fr}
  .hero-main,.hero-side-card,.story-panel,.prose-card{padding:26px}
  .brand-badge{width:180px}
  h1{max-width:none}
}
@media (max-width:540px){
  .container{width:min(calc(100% - 28px), var(--max))}
  .hero-actions{flex-direction:column}
  .btn{width:100%}
  .brand{align-items:flex-start}
  .brand-badge{width:150px}
}


.article-banner{
  margin-top:18px;
  padding:14px;
  border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
}
.article-banner img{
  width:100%;
  max-width:760px;
  height:auto;
  margin:0 auto;
  border-radius:14px;
}
.logo-strip{
  margin:28px 0 6px;
}
.logo-strip h3{
  margin:0 0 8px;
  font-size:1rem;
}
.logo-strip p,
.source-note{
  color:var(--muted);
}
.logo-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.logo-card{
  min-height:116px;
  padding:16px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(12,18,27,.08);
  display:flex;
  align-items:center;
  justify-content:center;
}
.logo-card img{
  max-width:100%;
  max-height:96px;
  width:auto;
  height:auto;
  object-fit:contain;
}
.logo-card.is-gov{
  grid-column:1 / -1;
  min-height:132px;
  padding:20px 24px;
}
.logo-card.is-gov img{
  max-height:104px;
}
.logo-card.is-wide img{
  max-height:78px;
}
.funding-card img{
  width:100%;
  height:auto;
  border-radius:14px;
  margin-top:10px;
}
.source-note{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
  font-size:.92rem;
}
@media (max-width:680px){
  .logo-grid{grid-template-columns:1fr}
}


.article-end-logos{
  margin-top:32px;
  padding-top:22px;
  border-top:1px solid var(--line);
}
.article-end-logos .logo-grid{
  margin-top:16px;
}

.news-thumb{
  display:block;
  margin:-6px -6px 16px;
  overflow:hidden;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}
.news-thumb img{
  width:100%;
  height:180px;
  object-fit:cover;
}
