/* ============================================================
   PHẠM MINH CHÍNH – EXECUTIVE GOVERNMENT PORTAL
   Premium design system – original, unified, statesmanlike
   ============================================================ */

:root{
  --ink:#0c1322;
  --ink-2:#141b2d;
  --charcoal:#2a2f3a;
  --graphite:#4a5064;
  --mist:#eceef2;
  --paper:#f6f4ef;
  --ivory:#fbfaf6;
  --white:#ffffff;
  --red:#8a1820;
  --red-deep:#6b0f16;
  --red-ember:#b2263e;
  --gold:#c9a24b;
  --gold-soft:#d9b972;
  --gold-deep:#8a6a24;
  --navy:#0f1e3a;
  --navy-2:#0a152a;
  --line:rgba(12,19,34,0.12);
  --line-strong:rgba(12,19,34,0.25);
  --shadow-sm:0 2px 10px rgba(12,19,34,0.06);
  --shadow-md:0 20px 60px rgba(12,19,34,0.12);
  --shadow-lg:0 40px 90px rgba(12,19,34,0.18);
  --radius-sm:4px;
  --radius:10px;
  --radius-lg:18px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --serif:'Playfair Display', 'DM Serif Display', Georgia, serif;
  --sans:'Inter','Manrope','Montserrat',system-ui,sans-serif;
  --max:1320px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  color:var(--charcoal);
  background:var(--ivory);
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);font-weight:600;letter-spacing:-.01em;line-height:1.15}
h1{font-size:clamp(2.4rem,5.2vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.8vw,3.2rem)}
h3{font-size:clamp(1.3rem,2vw,1.8rem)}
p{max-width:72ch}

.container{max-width:var(--max);margin:0 auto;padding:0 28px}
.narrow{max-width:980px;margin:0 auto;padding:0 28px}

/* ============== EYEBROW / LABELS ============== */
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:.72rem;font-weight:600;
  letter-spacing:.32em;text-transform:uppercase;color:var(--red);
}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--gold)}
.eyebrow.light{color:var(--gold-soft)}
.eyebrow.light::before{background:var(--gold)}

/* ============== PASSCODE GATE ============== */
#gate{
  position:fixed;inset:0;z-index:9999;
  background:
    radial-gradient(1200px 600px at 15% 10%, rgba(201,162,75,.18), transparent 60%),
    radial-gradient(1000px 700px at 85% 90%, rgba(138,24,32,.35), transparent 65%),
    linear-gradient(135deg,#08111f 0%,#0f1e3a 45%,#3a0c14 100%);
  display:grid;place-items:center;
  overflow:hidden;opacity:1;transition:opacity .9s var(--ease),visibility .9s;
}
#gate.hidden{opacity:0;visibility:hidden;pointer-events:none}
#gate .skyline{
  position:absolute;left:0;right:0;bottom:0;height:38%;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1600 300' preserveAspectRatio='xMidYMax slice'><g fill='%23000000' opacity='0.45'><rect x='0' y='210' width='80' height='90'/><rect x='80' y='180' width='40' height='120'/><rect x='120' y='200' width='60' height='100'/><rect x='180' y='140' width='30' height='160'/><rect x='210' y='170' width='50' height='130'/><rect x='260' y='120' width='40' height='180'/><polygon points='300,120 310,90 320,120'/><rect x='300' y='120' width='20' height='180'/><rect x='320' y='190' width='70' height='110'/><rect x='390' y='160' width='35' height='140'/><rect x='425' y='135' width='55' height='165'/><rect x='480' y='175' width='45' height='125'/><rect x='525' y='100' width='40' height='200'/><polygon points='545,100 545,75 560,85 560,100'/><rect x='565' y='150' width='60' height='150'/><rect x='625' y='190' width='75' height='110'/><rect x='700' y='130' width='45' height='170'/><rect x='745' y='165' width='50' height='135'/><rect x='795' y='110' width='35' height='190'/><polygon points='813,110 822,80 830,110'/><rect x='830' y='150' width='55' height='150'/><rect x='885' y='180' width='70' height='120'/><rect x='955' y='140' width='40' height='160'/><rect x='995' y='170' width='60' height='130'/><rect x='1055' y='120' width='50' height='180'/><rect x='1105' y='165' width='40' height='135'/><rect x='1145' y='195' width='70' height='105'/><rect x='1215' y='130' width='50' height='170'/><polygon points='1240,130 1240,100 1255,115 1255,130'/><rect x='1265' y='160' width='55' height='140'/><rect x='1320' y='185' width='80' height='115'/><rect x='1400' y='150' width='45' height='150'/><rect x='1445' y='175' width='60' height='125'/><rect x='1505' y='135' width='50' height='165'/><rect x='1555' y='185' width='45' height='115'/></g></svg>") repeat-x bottom center;
  background-size:auto 100%;
  opacity:.55;
}
#gate .glow{
  position:absolute;inset:-10% -10% auto -10%;height:40%;
  background:radial-gradient(ellipse at center, rgba(201,162,75,.28), transparent 70%);
  animation:drift 14s linear infinite;
}
@keyframes drift{0%,100%{transform:translateX(-4%)}50%{transform:translateX(4%)}}
#gate .star{
  position:absolute;top:12%;left:50%;width:54px;height:54px;transform:translateX(-50%);
  color:var(--gold);filter:drop-shadow(0 0 14px rgba(201,162,75,.45));
  animation:pulse 3.5s ease-in-out infinite;
}
@keyframes pulse{50%{transform:translateX(-50%) scale(1.08);filter:drop-shadow(0 0 22px rgba(201,162,75,.7))}}
#gate .panel{
  position:relative;z-index:2;
  width:min(540px,92vw);
  padding:56px 44px 44px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius-lg);
  color:#fff;text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
}
#gate .crest{
  width:64px;height:64px;margin:0 auto 26px;
  border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,var(--gold-soft),var(--gold-deep));
  color:var(--red-deep);font-family:var(--serif);font-size:1.4rem;font-weight:700;
  box-shadow:0 8px 26px rgba(201,162,75,.4), inset 0 0 12px rgba(255,255,255,.25);
}
#gate h1{
  font-family:var(--serif);color:#fff;font-size:1.9rem;font-weight:500;margin-bottom:8px;letter-spacing:.01em;
}
#gate .sub{font-size:.78rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:36px}
#gate label{display:block;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:#cfd3dc;margin-bottom:12px}
#gate .field{
  position:relative;display:flex;align-items:center;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);padding:0 4px 0 16px;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
#gate .field:focus-within{border-color:var(--gold-soft);background:rgba(255,255,255,.1)}
#gate input{
  flex:1;background:transparent;border:none;outline:none;color:#fff;
  padding:18px 8px;font-family:var(--sans);font-size:1rem;letter-spacing:.3em;
}
#gate input::placeholder{color:rgba(255,255,255,.45);letter-spacing:.25em;font-size:.9rem}
#gate .go{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,var(--gold) 0%, var(--gold-deep) 100%);
  color:#1a1208;font-weight:600;padding:12px 22px;border-radius:8px;
  font-size:.78rem;letter-spacing:.25em;text-transform:uppercase;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
#gate .go:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(201,162,75,.45)}
#gate .hint{margin-top:22px;font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.5)}
#gate .err{
  margin-top:18px;min-height:22px;font-size:.82rem;color:#ffb2b2;letter-spacing:.1em;
  opacity:0;transform:translateY(-4px);transition:opacity .3s,transform .3s;
}
#gate .err.show{opacity:1;transform:translateY(0);animation:shake .5s var(--ease)}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}

/* ============== NAVIGATION ============== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  background:rgba(251,250,246,.72);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border-bottom:1px solid rgba(12,19,34,.06);
  transition:padding .35s var(--ease),background .35s var(--ease);
}
.nav.scrolled{padding:12px 0;background:rgba(251,250,246,.92);box-shadow:0 2px 20px rgba(12,19,34,.05)}
.nav .row{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:14px}
.brand .seal{
  width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,#fff3cf,var(--gold) 55%,var(--gold-deep));
  color:var(--red-deep);font-family:var(--serif);font-weight:700;font-size:1.05rem;
  box-shadow:0 4px 12px rgba(138,24,32,.2), inset 0 0 6px rgba(255,255,255,.4);
}
.brand .tag{line-height:1.15}
.brand .tag b{font-family:var(--serif);font-size:1.05rem;color:var(--ink);letter-spacing:.01em;font-weight:600}
.brand .tag span{display:block;font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--red)}

.menu{display:flex;align-items:center;gap:4px}
.menu a{
  position:relative;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  color:var(--charcoal);padding:10px 14px;border-radius:6px;
}
.menu a:hover{color:var(--ink)}
.menu a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;
  background:var(--red);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}
.menu a.active{color:var(--red)}

.ham{display:none;width:44px;height:44px;border-radius:8px;border:1px solid var(--line);position:relative}
.ham span{position:absolute;left:12px;right:12px;height:2px;background:var(--ink);transition:transform .3s var(--ease),opacity .3s var(--ease),top .3s var(--ease)}
.ham span:nth-child(1){top:15px}
.ham span:nth-child(2){top:21px}
.ham span:nth-child(3){top:27px}
.ham.open span:nth-child(1){top:21px;transform:rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){top:21px;transform:rotate(-45deg)}

@media (max-width:960px){
  .ham{display:block}
  .menu{
    position:fixed;top:72px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--ivory);border-top:1px solid var(--line);
    padding:10px;max-height:0;overflow:hidden;transition:max-height .4s var(--ease);
  }
  .menu.open{max-height:540px;box-shadow:0 20px 40px rgba(12,19,34,.1)}
  .menu a{padding:14px 18px;border-bottom:1px solid var(--line)}
  .menu a::after{display:none}
}

/* ============== BUTTONS ============== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 28px;border-radius:6px;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease);
}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 12px 30px rgba(138,24,32,.25)}
.btn-primary:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 16px 38px rgba(138,24,32,.35)}
.btn-ghost{border:1px solid rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-outline{border:1px solid var(--ink);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#1a1208}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(201,162,75,.35)}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ============== HERO (HOME) ============== */
.hero{
  position:relative;min-height:100vh;padding:140px 0 80px;
  display:flex;align-items:center;color:#fff;overflow:hidden;
  background:linear-gradient(115deg,#0a152a 0%,#0f1e3a 55%,#5a0d16 100%);
}
.hero .bg{
  position:absolute;inset:0;z-index:0;
  background-position:center right;background-size:cover;
  opacity:.55;
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(10,21,42,.92) 0%,rgba(15,30,58,.65) 50%, rgba(90,13,22,.3) 100%),
    radial-gradient(800px 500px at 15% 30%, rgba(201,162,75,.18), transparent 70%);
}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:center}
.hero .copy .rib{display:inline-flex;align-items:center;gap:14px;font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:26px}
.hero .copy .rib::before{content:"";width:44px;height:1px;background:var(--gold)}
.hero h1{
  color:#fff;font-weight:500;font-size:clamp(2.6rem,5.8vw,5rem);
  letter-spacing:-.02em;line-height:1.05;margin-bottom:22px;
}
.hero h1 .underline{position:relative;display:inline-block;color:var(--gold-soft)}
.hero h1 .underline::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,var(--gold),transparent)}
.hero .lead{font-size:1.12rem;color:rgba(255,255,255,.82);max-width:560px;margin-bottom:36px;line-height:1.7}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px}
.hero .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:560px;padding-top:30px;border-top:1px solid rgba(255,255,255,.18)}
.hero .stats b{display:block;font-family:var(--serif);font-size:2rem;color:var(--gold-soft);font-weight:500}
.hero .stats span{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7)}

.portrait{
  position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 40px 80px rgba(0,0,0,.5);
}
.portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}
.portrait::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(10,21,42,.85));
}
.portrait .cap{
  position:absolute;left:24px;right:24px;bottom:24px;z-index:2;color:#fff;
}
.portrait .cap b{font-family:var(--serif);font-size:1.3rem;display:block;margin-bottom:4px;font-weight:500}
.portrait .cap span{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-soft)}

/* Hero marquee */
.marquee{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  padding:14px 0;background:rgba(0,0,0,.35);border-top:1px solid rgba(255,255,255,.1);
  overflow:hidden;
}
.marquee .track{display:flex;gap:70px;animation:scroll 36s linear infinite;white-space:nowrap}
.marquee span{font-family:var(--serif);font-style:italic;color:rgba(255,255,255,.7);font-size:.95rem}
.marquee i{color:var(--gold-soft);font-style:normal;margin:0 24px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@media(max-width:960px){
  .hero{padding:120px 0 120px}
  .hero .container{grid-template-columns:1fr;gap:40px}
  .portrait{max-width:400px;margin:0 auto}
  .hero .stats{grid-template-columns:repeat(3,1fr);gap:16px}
}

/* ============== SECTION FRAME ============== */
section{padding:110px 0;position:relative}
.section-head{margin-bottom:60px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end}
.section-head .left h2{max-width:14ch}
.section-head .right{color:var(--graphite);font-size:1.02rem}
@media(max-width:860px){.section-head{grid-template-columns:1fr;gap:24px}}

/* ============== WELCOME / INTRO (HOME) ============== */
.welcome{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.welcome .grid{display:grid;grid-template-columns:1.15fr 1fr;gap:70px;align-items:center}
.welcome .panel{position:relative;padding-left:40px;border-left:2px solid var(--red)}
.welcome .panel h2{margin-bottom:22px}
.welcome .sig{
  display:flex;align-items:center;gap:16px;margin-top:38px;padding-top:22px;border-top:1px solid var(--line);
}
.welcome .sig .dot{width:42px;height:42px;border-radius:50%;background:var(--red);display:grid;place-items:center;color:#fff;font-family:var(--serif);font-weight:600}
.welcome .sig b{font-family:var(--serif);font-size:1.05rem;color:var(--ink);font-weight:500}
.welcome .sig span{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red)}
.welcome .frame{position:relative}
.welcome .frame .ph{aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.welcome .frame .ph img{width:100%;height:100%;object-fit:cover;object-position:center top}
.welcome .frame .badge{
  position:absolute;bottom:-28px;left:-28px;width:170px;
  padding:22px;background:var(--ink);color:#fff;border-radius:var(--radius);
  box-shadow:0 18px 40px rgba(12,19,34,.25);
}
.welcome .frame .badge b{font-family:var(--serif);font-size:1.9rem;color:var(--gold-soft);font-weight:500;display:block}
.welcome .frame .badge span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.75)}
@media(max-width:860px){.welcome .grid{grid-template-columns:1fr;gap:50px}.welcome .frame .badge{left:0}}

/* ============== PILLARS ============== */
.pillars{background:var(--ivory)}
.pillars .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.pillar{
  position:relative;padding:36px 28px 32px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
}
.pillar::before{
  content:"";position:absolute;top:0;left:0;width:0;height:3px;background:var(--red);
  transition:width .4s var(--ease);
}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.pillar:hover::before{width:100%}
.pillar .num{font-family:var(--serif);color:var(--gold);font-size:2rem;font-weight:500;margin-bottom:18px;display:block}
.pillar h3{font-size:1.25rem;margin-bottom:12px;color:var(--ink)}
.pillar p{font-size:.95rem;color:var(--graphite)}
@media(max-width:960px){.pillars .grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pillars .grid{grid-template-columns:1fr}}

/* ============== METRICS COUNTERS ============== */
.metrics{
  background:var(--ink);color:#fff;position:relative;overflow:hidden;
}
.metrics::before{
  content:"";position:absolute;inset:0;opacity:.25;
  background:
    radial-gradient(600px 400px at 10% 20%, rgba(201,162,75,.35), transparent 65%),
    radial-gradient(500px 400px at 90% 80%, rgba(138,24,32,.4), transparent 60%);
}
.metrics .container{position:relative}
.metrics .section-head h2{color:#fff}
.metrics .section-head .right{color:rgba(255,255,255,.75)}
.metrics .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.15)}
.metric{padding:44px 30px;border-right:1px solid rgba(255,255,255,.15);position:relative}
.metric:last-child{border-right:none}
.metric b{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.6rem);color:var(--gold-soft);font-weight:500;display:block}
.metric .k{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:6px;display:block}
.metric p{font-size:.9rem;color:rgba(255,255,255,.7);margin-top:14px}
@media(max-width:960px){.metrics .grid{grid-template-columns:repeat(2,1fr)}.metric:nth-child(2){border-right:none}.metric:nth-child(1),.metric:nth-child(2){border-bottom:1px solid rgba(255,255,255,.15)}}
@media(max-width:560px){.metrics .grid{grid-template-columns:1fr}.metric{border-right:none;border-bottom:1px solid rgba(255,255,255,.15)}.metric:last-child{border-bottom:none}}

/* ============== HIGHLIGHTS / SPLIT ============== */
.split{background:var(--paper)}
.split .row{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;min-height:620px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.split .pic{position:relative}
.split .pic img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.split .txt{background:#fff;padding:70px 60px;display:flex;flex-direction:column;justify-content:center}
.split .txt h2{margin-bottom:22px}
.split .txt ul{margin:28px 0 36px;display:grid;gap:14px}
.split .txt li{display:flex;gap:14px;font-size:.98rem;color:var(--graphite)}
.split .txt li::before{content:"";flex:0 0 10px;width:10px;height:10px;background:var(--red);margin-top:8px;border-radius:50%}
@media(max-width:860px){.split .row{grid-template-columns:1fr}.split .pic{min-height:360px}.split .txt{padding:50px 34px}}

/* ============== UPDATES / NEWS CARDS ============== */
.updates{background:var(--ivory)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.news{
  position:relative;background:#fff;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  display:flex;flex-direction:column;
}
.news:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.news .pic{aspect-ratio:16/10;overflow:hidden;position:relative}
.news .pic img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform 1.2s var(--ease)}
.news:hover .pic img{transform:scale(1.06)}
.news .pic .tag{position:absolute;top:18px;left:18px;background:var(--red);color:#fff;padding:6px 12px;border-radius:4px;font-size:.66rem;letter-spacing:.25em;text-transform:uppercase;font-weight:600}
.news .body{padding:28px;display:flex;flex-direction:column;gap:14px;flex:1}
.news .meta{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--red);font-weight:600}
.news h3{font-size:1.2rem;line-height:1.3}
.news p{font-size:.92rem;color:var(--graphite)}
.news .more{margin-top:auto;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);font-weight:600;display:inline-flex;gap:8px;align-items:center}
.news .more::after{content:"→";transition:transform .3s var(--ease)}
.news:hover .more::after{transform:translateX(4px)}
@media(max-width:960px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.news-grid{grid-template-columns:1fr}}

/* ============== CTA BAND ============== */
.cta{
  position:relative;padding:90px 0;color:#fff;overflow:hidden;
  background:linear-gradient(115deg,var(--red-deep),var(--red) 55%, #40070d);
}
.cta::before{
  content:"";position:absolute;inset:0;opacity:.3;
  background:radial-gradient(700px 400px at 80% 30%, rgba(201,162,75,.45), transparent 60%);
}
.cta .row{position:relative;display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:center}
.cta h2{color:#fff;max-width:18ch}
.cta .actions{display:flex;gap:14px;justify-content:flex-end;flex-wrap:wrap}
@media(max-width:860px){.cta .row{grid-template-columns:1fr}.cta .actions{justify-content:flex-start}}

/* ============== ABOUT PAGE ============== */
.page-hero{
  position:relative;padding:170px 0 100px;color:#fff;overflow:hidden;
  background:linear-gradient(115deg,#0a152a,#1a2240 60%, #4a0b13);
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(700px 500px at 85% 20%, rgba(201,162,75,.2), transparent 65%);
}
.page-hero .container{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.page-hero h1{color:#fff;font-weight:500;margin-bottom:22px}
.page-hero .trail{display:flex;gap:10px;font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:26px}
.page-hero .trail i{color:rgba(255,255,255,.4);font-style:normal}
.page-hero .lead{color:rgba(255,255,255,.82);max-width:58ch;font-size:1.08rem}
.page-hero .frame{aspect-ratio:1/1.15;border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.2);box-shadow:0 30px 70px rgba(0,0,0,.5)}
.page-hero .frame img{width:100%;height:100%;object-fit:cover;object-position:center top}
@media(max-width:860px){.page-hero .container{grid-template-columns:1fr}.page-hero{padding:140px 0 80px}}

/* Bio row */
.bio-row{background:var(--ivory)}
.bio-row .grid{display:grid;grid-template-columns:1fr 1.4fr;gap:70px;align-items:start}
.bio-row .stat-col{
  position:sticky;top:100px;
  display:grid;gap:12px;padding:30px;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
}
.bio-row .stat-col .k{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--red);font-weight:600}
.bio-row .stat-col .v{font-family:var(--serif);font-size:1.15rem;color:var(--ink);margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.bio-row .stat-col .row-last .v{border:none;margin:0;padding:0}
.bio-row p{font-size:1.02rem;margin-bottom:22px;color:var(--charcoal)}
.bio-row .pull{
  margin:40px 0;padding:30px 34px;border-left:3px solid var(--gold);
  background:var(--paper);border-radius:0 var(--radius) var(--radius) 0;
}
.bio-row .pull q{font-family:var(--serif);font-size:1.35rem;color:var(--ink);font-style:italic;quotes:"\201C""\201D";line-height:1.5}
@media(max-width:860px){.bio-row .grid{grid-template-columns:1fr;gap:36px}.bio-row .stat-col{position:static}}

/* Timeline */
.timeline{background:var(--paper);position:relative}
.tl{position:relative;max-width:860px;margin:40px auto 0;padding-left:30px}
.tl::before{content:"";position:absolute;left:6px;top:14px;bottom:14px;width:2px;background:linear-gradient(180deg,var(--gold),var(--red))}
.tl-item{position:relative;padding:0 0 42px 40px}
.tl-item::before{
  content:"";position:absolute;left:-6px;top:10px;width:24px;height:24px;border-radius:50%;
  background:#fff;border:3px solid var(--red);box-shadow:0 0 0 4px rgba(138,24,32,.12);
}
.tl-item .yr{font-family:var(--serif);font-size:1.4rem;color:var(--red);font-weight:500;margin-bottom:6px}
.tl-item h3{font-size:1.12rem;margin-bottom:8px}
.tl-item p{font-size:.96rem;color:var(--graphite)}

/* Philosophy cards */
.philosophy{background:var(--ivory)}
.philosophy .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:20px}
.ph-card{padding:40px 32px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);position:relative;overflow:hidden}
.ph-card::after{
  content:"";position:absolute;right:-60px;top:-60px;width:160px;height:160px;
  background:radial-gradient(circle,var(--gold-soft),transparent 60%);opacity:.25;
}
.ph-card .icon{
  width:54px;height:54px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--red),var(--red-deep));color:#fff;font-family:var(--serif);font-size:1.4rem;margin-bottom:22px
}
.ph-card h3{font-size:1.15rem;margin-bottom:10px}
.ph-card p{font-size:.95rem;color:var(--graphite)}
@media(max-width:860px){.philosophy .grid{grid-template-columns:1fr}}

/* ============== GOVERNANCE PAGE ============== */
.gov-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.gov-card{
  position:relative;padding:44px 34px 40px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.gov-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.gov-card .gi{
  width:56px;height:56px;border-radius:14px;display:grid;place-items:center;margin-bottom:22px;
  background:linear-gradient(135deg,rgba(201,162,75,.2),rgba(138,24,32,.15));
  color:var(--red);
}
.gov-card .gi svg{width:28px;height:28px}
.gov-card h3{font-size:1.18rem;margin-bottom:12px}
.gov-card p{font-size:.94rem;color:var(--graphite);margin-bottom:18px}
.gov-card ul{display:grid;gap:8px}
.gov-card li{position:relative;padding-left:18px;font-size:.88rem;color:var(--graphite)}
.gov-card li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:1px;background:var(--gold)}
@media(max-width:860px){.gov-grid{grid-template-columns:1fr}}

/* Data bars */
.data{background:var(--paper)}
.data .grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
.bars{display:grid;gap:22px}
.bar{padding:18px 22px;background:#fff;border:1px solid var(--line);border-radius:var(--radius)}
.bar .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.92rem;color:var(--ink);font-weight:600}
.bar .top b{font-family:var(--serif);color:var(--red);font-weight:500;font-size:1.15rem}
.bar .rail{height:8px;background:var(--mist);border-radius:4px;overflow:hidden}
.bar .fill{height:100%;background:linear-gradient(90deg,var(--red),var(--gold));border-radius:4px;width:0;transition:width 1.6s var(--ease)}
@media(max-width:860px){.data .grid{grid-template-columns:1fr;gap:40px}}

/* ============== ECONOMY PAGE ============== */
.feature{
  position:relative;padding:140px 0;color:#fff;overflow:hidden;
  background:linear-gradient(115deg,#0f1e3a,#1c2850);
}
.feature::before{
  content:"";position:absolute;inset:0;opacity:.25;
  background:radial-gradient(800px 500px at 20% 30%, rgba(201,162,75,.3), transparent 60%),
             radial-gradient(600px 400px at 85% 80%, rgba(138,24,32,.3), transparent 60%);
}
.feature .container{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.feature h2{color:#fff}
.feature p{color:rgba(255,255,255,.78)}
.feature .pic{aspect-ratio:5/6;border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,.15);box-shadow:0 40px 80px rgba(0,0,0,.5)}
.feature .pic img{width:100%;height:100%;object-fit:cover;object-position:center top}
@media(max-width:860px){.feature .container{grid-template-columns:1fr}}

.sectors{background:var(--ivory)}
.sec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.sec-card{
  position:relative;padding:36px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.sec-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.sec-card .n{font-family:var(--serif);font-size:2.6rem;color:var(--gold);font-weight:500;line-height:1}
.sec-card h3{font-size:1.15rem;margin-bottom:10px}
.sec-card p{font-size:.94rem;color:var(--graphite)}
@media(max-width:860px){.sec-grid{grid-template-columns:1fr}}

.counters{background:var(--ink);color:#fff}
.counters .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.ctr{padding:36px;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);background:rgba(255,255,255,.03)}
.ctr b{font-family:var(--serif);font-size:3rem;color:var(--gold-soft);font-weight:500;display:block;margin-bottom:6px}
.ctr span{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.ctr p{font-size:.92rem;color:rgba(255,255,255,.7);margin-top:16px}
@media(max-width:860px){.counters .grid{grid-template-columns:1fr}}

/* ============== DIPLOMACY PAGE ============== */
.diplo-hero{
  position:relative;padding:170px 0 100px;color:#fff;overflow:hidden;
  background:linear-gradient(115deg,#3a0810,#7a1520 60%, #0f1e3a);
}
.diplo-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(700px 500px at 10% 30%, rgba(201,162,75,.25), transparent 65%);
}
.diplo-hero .container{position:relative;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.diplo-hero h1{color:#fff;font-weight:500}
.diplo-hero .pic{aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.2)}
.diplo-hero .pic img{width:100%;height:100%;object-fit:cover;object-position:center top}

.partners{background:var(--paper)}
.p-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.partner{
  padding:28px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  text-align:center;transition:transform .4s var(--ease),border-color .4s var(--ease);
}
.partner:hover{transform:translateY(-4px);border-color:var(--gold)}
.partner b{font-family:var(--serif);display:block;font-size:1.15rem;color:var(--ink);margin-bottom:6px;font-weight:500}
.partner span{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--red)}
@media(max-width:960px){.p-grid{grid-template-columns:repeat(2,1fr)}}

.pillars-two{background:var(--ivory)}
.ptwo{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pt-card{padding:38px 32px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);position:relative}
.pt-card .num{font-family:var(--serif);color:var(--red);font-size:1.4rem;font-weight:500;margin-bottom:10px;display:block}
.pt-card h3{font-size:1.1rem;margin-bottom:10px}
.pt-card p{font-size:.92rem;color:var(--graphite)}
@media(max-width:860px){.ptwo{grid-template-columns:1fr}}

/* ============== GALLERY PAGE ============== */
.gall{background:var(--paper)}
.gall-grid{
  column-count:3;column-gap:20px;
}
.gall-item{
  break-inside:avoid;margin-bottom:20px;overflow:hidden;border-radius:var(--radius);
  cursor:pointer;position:relative;transition:transform .5s var(--ease);
  box-shadow:var(--shadow-sm);
}
.gall-item img{width:100%;display:block;transition:transform 1.2s var(--ease)}
.gall-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.gall-item:hover img{transform:scale(1.04)}
.gall-item::after{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(12,19,34,.75));
  opacity:0;transition:opacity .4s var(--ease);
}
.gall-item:hover::after{opacity:1}
.gall-item .cap{
  position:absolute;left:22px;right:22px;bottom:22px;color:#fff;z-index:2;
  opacity:0;transform:translateY(10px);transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.gall-item:hover .cap{opacity:1;transform:translateY(0)}
.gall-item .cap b{font-family:var(--serif);font-size:1.1rem;display:block;margin-bottom:4px;font-weight:500}
.gall-item .cap span{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-soft)}
@media(max-width:960px){.gall-grid{column-count:2}}
@media(max-width:560px){.gall-grid{column-count:1}}

/* Lightbox */
#lightbox{
  position:fixed;inset:0;background:rgba(8,12,22,.95);backdrop-filter:blur(10px);
  display:none;place-items:center;z-index:9998;padding:40px;
}
#lightbox.open{display:grid}
#lightbox img{max-width:90vw;max-height:85vh;border-radius:var(--radius);box-shadow:0 40px 80px rgba(0,0,0,.5)}
#lightbox .close{position:absolute;top:22px;right:22px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:1.5rem;display:grid;place-items:center;border:1px solid rgba(255,255,255,.2)}
#lightbox .close:hover{background:rgba(255,255,255,.2)}

/* ============== NEWS PAGE ============== */
.news-page .hero{background:linear-gradient(115deg,#0a152a,#2a0a12)}
.news-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:50px}
.chip{
  padding:10px 20px;border:1px solid var(--line);border-radius:50px;
  font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  color:var(--charcoal);background:#fff;cursor:pointer;transition:all .3s var(--ease);
}
.chip:hover,.chip.active{background:var(--red);color:#fff;border-color:var(--red)}

/* ============== CONTACT PAGE ============== */
.contact{background:var(--ivory)}
.c-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:60px}
.c-info{padding:44px;background:var(--ink);color:#fff;border-radius:var(--radius-lg);position:relative;overflow:hidden}
.c-info::before{
  content:"";position:absolute;inset:0;opacity:.2;
  background:radial-gradient(400px 300px at 80% 20%, var(--gold-soft), transparent 65%);
}
.c-info > *{position:relative;z-index:1}
.c-info h2{color:#fff;font-size:1.8rem;margin-bottom:14px}
.c-info p{color:rgba(255,255,255,.8);font-size:.95rem;margin-bottom:36px}
.c-info .line{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-top:1px solid rgba(255,255,255,.12)}
.c-info .line:last-of-type{border-bottom:1px solid rgba(255,255,255,.12)}
.c-info .line .ic{
  flex:0 0 44px;width:44px;height:44px;border-radius:10px;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));display:grid;place-items:center;color:var(--red-deep);font-weight:700;
}
.c-info .line b{display:block;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:6px;font-weight:600}
.c-info .line a,.c-info .line span{font-family:var(--serif);font-size:1.08rem;color:#fff}
.c-info .line a:hover{color:var(--gold-soft)}
.c-info .socials{display:flex;gap:12px;margin-top:32px}
.c-info .socials a{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:all .3s var(--ease)}
.c-info .socials a:hover{background:var(--gold);color:var(--red-deep)}
.c-info .socials svg{width:18px;height:18px}

.c-form{padding:50px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.c-form h2{margin-bottom:10px}
.c-form .sub{color:var(--graphite);margin-bottom:34px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:22px}
.fld{position:relative}
.fld label{display:block;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:8px}
.fld input,.fld textarea,.fld select{
  width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:8px;
  font-family:inherit;font-size:.98rem;color:var(--ink);background:#fff;
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.fld textarea{min-height:140px;resize:vertical}
.fld input:focus,.fld textarea:focus,.fld select:focus{
  outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(138,24,32,.08);
}
.c-form .send{margin-top:14px}
.c-form .ok{display:none;margin-top:22px;padding:14px 18px;background:#e8f3e8;border-left:3px solid #2d8a3e;color:#1d5a29;font-size:.92rem;border-radius:6px}
.c-form .ok.show{display:block}
@media(max-width:860px){.c-grid{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}.c-form{padding:34px}}

/* ============== FOOTER ============== */
footer{background:var(--navy-2);color:rgba(255,255,255,.78);padding:80px 0 30px;position:relative;overflow:hidden}
footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--red),var(--gold),var(--red))
}
footer .grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.1)}
footer h4{font-family:var(--sans);color:var(--gold-soft);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:700;margin-bottom:22px}
footer .brand-col .b-row{display:flex;align-items:center;gap:14px;margin-bottom:20px}
footer .brand-col .seal{
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,#fff3cf,var(--gold) 55%,var(--gold-deep));
  color:var(--red-deep);font-family:var(--serif);font-weight:700;font-size:1.2rem;
}
footer .brand-col .b-row b{font-family:var(--serif);color:#fff;font-size:1.25rem;font-weight:500;display:block}
footer .brand-col .b-row span{font-size:.64rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-soft)}
footer .brand-col p{font-size:.93rem;color:rgba(255,255,255,.65);max-width:44ch;margin-bottom:22px}
footer ul{display:grid;gap:10px}
footer li a{font-size:.92rem;color:rgba(255,255,255,.7)}
footer li a:hover{color:var(--gold-soft)}
footer .contact-col a{display:block;font-size:.92rem;margin-bottom:10px;color:rgba(255,255,255,.7)}
footer .contact-col a:hover{color:var(--gold-soft)}
footer .socials{display:flex;gap:10px;margin-top:18px}
footer .socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);display:grid;place-items:center;transition:all .3s var(--ease)}
footer .socials a:hover{background:var(--gold);color:var(--red-deep)}
footer .socials svg{width:16px;height:16px}
footer .base{padding-top:26px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:.82rem;color:rgba(255,255,255,.55)}
footer .base a{color:var(--gold-soft);font-weight:600}
footer .base a:hover{color:#fff}
@media(max-width:860px){footer .grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){footer .grid{grid-template-columns:1fr}}

/* ============== REVEAL ANIMATIONS ============== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}.reveal.d5{transition-delay:.5s}

/* ============== UTIL ============== */
.center{text-align:center}
.mt-40{margin-top:40px}
.mt-60{margin-top:60px}
