/* ============================================================
   Ban Phát triển Sáng tạo Công nghiệp Văn hóa — shared styles
   ============================================================ */
:root{
  --gold:#C2A14D; --gold-2:#A6862F; --gold-soft:#E4D2A0;
  --maroon:#7A1418; --maroon-2:#5A0E12;
  --ink:#211C14; --ink-soft:#5B5446;
  --cream:#FBF7EF; --cream-2:#F3EAD8; --line:#E6DCC5;
  --white:#fff; --shadow:0 18px 48px -22px rgba(60,40,10,.40);
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Be Vietnam Pro',system-ui,-apple-system,'Segoe UI',sans-serif;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.7;font-weight:400;overflow-x:clip;letter-spacing:.005em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif)}
section{position:relative}
.kicker{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-2)}
.kicker::before{content:"";width:26px;height:1.5px;background:var(--gold)}
h2.title{font-family:var(--serif);font-weight:700;font-size:clamp(28px,4.2vw,46px);line-height:1.12;color:var(--ink);margin:14px 0 0;letter-spacing:-.005em}
.lead{color:var(--ink-soft);font-size:clamp(15px,1.5vw,18px);max-width:720px;margin-top:18px;line-height:1.75}
.sec-pad{padding:clamp(64px,9vw,116px) 0}

/* ---------- HEADER ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.35s}
.bar{display:flex;align-items:center;justify-content:space-between;height:74px;transition:.35s}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:42px;height:42px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.15))}
.brand .bt{line-height:1.12}
.brand .bt b{font-family:var(--serif);font-weight:700;font-size:16px;display:block;color:var(--white);letter-spacing:.01em}
.brand .bt span{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);font-weight:500}
header.scrolled .brand .bt b,header.solid .brand .bt b{color:var(--ink)}
header.scrolled .brand .bt span,header.solid .brand .bt span{color:var(--gold-2)}
nav.menu{display:flex;align-items:center;gap:30px}
nav.menu a{font-size:14px;font-weight:500;color:rgba(255,255,255,.86);position:relative;padding:4px 0;transition:.2s}
nav.menu a:hover{color:var(--white)}
nav.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:.25s}
nav.menu a:hover::after{width:100%}
header.scrolled nav.menu a,header.solid nav.menu a{color:var(--ink-soft)}
header.scrolled nav.menu a:hover,header.solid nav.menu a:hover{color:var(--ink)}
header.scrolled,header.solid{background:rgba(251,247,239,.94);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
header.scrolled .bar,header.solid .bar{height:64px}
.hgroup{display:flex;align-items:center;gap:18px}
.cta-btn{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#fff;padding:10px 20px;border-radius:999px;font-size:13.5px;font-weight:600;box-shadow:0 8px 20px -8px rgba(166,134,47,.7);transition:.2s;white-space:nowrap}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px -8px rgba(166,134,47,.85)}
.lang{display:flex;gap:2px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:3px}
header.scrolled .lang,header.solid .lang{background:var(--cream-2);border-color:var(--line)}
.lang button{border:0;background:transparent;color:rgba(255,255,255,.82);font-family:var(--sans);font-size:12px;font-weight:600;padding:5px 9px;border-radius:999px;cursor:pointer;transition:.18s;line-height:1}
header.scrolled .lang button,header.solid .lang button{color:var(--ink-soft)}
.lang button.on{background:var(--white);color:var(--maroon);box-shadow:0 2px 8px -2px rgba(0,0,0,.25)}
header.scrolled .lang button.on,header.solid .lang button.on{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#fff}
.burger{display:none;flex-direction:column;gap:5px;background:0;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s}
header.scrolled .burger span,header.solid .burger span{background:var(--ink)}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;
  background:radial-gradient(120% 120% at 80% 0%,#3a0c10 0%,#5A0E12 38%,#43090d 70%,#2a0608 100%);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(40% 60% at 18% 80%,rgba(194,161,77,.22),transparent 70%),
  radial-gradient(30% 40% at 90% 70%,rgba(194,161,77,.12),transparent 70%)}
.hero-motif{position:absolute;right:-8%;top:50%;transform:translateY(-50%);width:min(60vw,720px);opacity:.10;pointer-events:none}
.hero-motif img{width:100%;filter:brightness(0) invert(1)}
.hero .wrap{position:relative;z-index:2;padding-top:120px;padding-bottom:80px}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:1px solid rgba(228,210,160,.35);color:var(--gold-soft);font-size:12.5px;font-weight:500;padding:8px 16px;border-radius:999px;letter-spacing:.02em;backdrop-filter:blur(6px)}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(194,161,77,.25)}
.hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(32px,4.4vw,56px);line-height:1.08;margin:24px 0 0;max-width:17ch;letter-spacing:-.01em}
.hero h1 em{font-style:normal;color:var(--gold-soft)}
.hero p.sub{margin-top:24px;max-width:600px;font-size:clamp(15px,1.7vw,19px);color:rgba(255,255,255,.84);font-weight:300;line-height:1.7}
.hero-actions{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap}
.btn-g{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#3a0c10;padding:15px 30px;border-radius:999px;font-weight:700;font-size:15px;box-shadow:0 16px 34px -14px rgba(194,161,77,.8);transition:.22s}
.btn-g:hover{transform:translateY(-3px)}
.btn-o{border:1.5px solid rgba(228,210,160,.5);color:#fff;padding:15px 30px;border-radius:999px;font-weight:600;font-size:15px;transition:.22s;display:inline-flex;align-items:center;gap:9px}
.btn-o:hover{background:rgba(255,255,255,.08);border-color:var(--gold-soft)}
.hero-note{margin-top:46px;font-size:12.5px;color:rgba(255,255,255,.5);display:inline-flex;align-items:center;gap:8px}
.hero-note::before{content:"";width:18px;height:1px;background:rgba(255,255,255,.4)}
.scroll-ind{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;width:26px;height:42px;border:2px solid rgba(228,210,160,.45);border-radius:14px;display:flex;justify-content:center;padding-top:7px}
.scroll-ind i{width:4px;height:8px;border-radius:2px;background:var(--gold-soft);animation:sd 1.6s infinite}
@keyframes sd{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}100%{opacity:0;transform:translateY(12px)}}

/* ---------- ABOUT ---------- */
.about-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:56px;align-items:center}
.about-grid p{color:var(--ink-soft);margin-top:18px;font-size:16px;line-height:1.8}
.about-facts{display:flex;flex-direction:column;gap:14px;background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:20px;padding:32px;box-shadow:var(--shadow)}
.fact{padding:15px 0;border-bottom:1px dashed var(--line)}
.fact:last-child{border-bottom:0}
.fact .k{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.fact .v{font-family:var(--serif);font-size:19px;color:var(--ink);margin-top:5px;line-height:1.35}

/* ---------- CONTEXT ---------- */
.bg-cream2{background:var(--cream-2)}
.ctx-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.ctx-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;transition:.25s;position:relative;overflow:hidden}
.ctx-card::before{content:"";position:absolute;left:0;top:0;width:3px;height:0;background:var(--maroon);transition:.3s}
.ctx-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.ctx-card:hover::before{height:100%}
.ctx-num{font-family:var(--serif);font-size:30px;color:var(--gold-soft);font-weight:700;line-height:1}
.ctx-card h4{font-family:var(--serif);font-size:21px;margin:10px 0 8px;color:var(--maroon)}
.ctx-card p{font-size:14.5px;color:var(--ink-soft);line-height:1.65}

/* ---------- VISION ---------- */
.vision{background:radial-gradient(120% 120% at 10% 0%,#2c0709,#5A0E12 60%,#43090d);color:#fff}
.vision .title{color:#fff}.vision .kicker{color:var(--gold-soft)}
.v2035{background:rgba(255,255,255,.05);border:1px solid rgba(228,210,160,.28);border-radius:22px;padding:38px;margin-top:34px;backdrop-filter:blur(6px)}
.v2035 .vk{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);font-weight:600}
.v2035 .vv{font-family:var(--serif);font-size:clamp(20px,2.4vw,28px);line-height:1.45;margin-top:14px;color:#fff;font-weight:600}
.mission-h{margin-top:48px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);font-weight:600}
.mission-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:22px}
.m-card{background:rgba(255,255,255,.04);border:1px solid rgba(228,210,160,.2);border-radius:16px;padding:26px;transition:.25s}
.m-card:hover{background:rgba(194,161,77,.12);border-color:var(--gold)}
.m-card .mn{font-family:var(--serif);font-size:28px;color:var(--gold-soft);font-weight:700}
.m-card h4{font-size:16px;margin:10px 0 6px;color:#fff}
.m-card p{font-size:13.5px;color:rgba(255,255,255,.7);line-height:1.6}

/* ---------- VALUES ---------- */
.val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.val{background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:18px;padding:32px;transition:.25s;position:relative}
.val:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--gold-soft)}
.val .vi{width:48px;height:48px;border-radius:13px;background:linear-gradient(135deg,var(--gold-soft),var(--gold));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;font-size:22px;color:#3a0c10;margin-bottom:16px}
.val h4{font-family:var(--serif);font-size:23px;color:var(--maroon)}
.val .ven{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);font-weight:600;margin:2px 0 10px}
.val p{font-size:14.5px;color:var(--ink-soft);line-height:1.65}

/* ---------- CAPS ---------- */
.caps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.cap{position:relative;overflow:hidden;background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:18px;padding:32px 30px;transition:.3s}
.cap::after{content:attr(data-n);position:absolute;right:20px;top:4px;font-family:var(--serif);font-weight:700;font-size:66px;line-height:1;color:var(--gold);opacity:.15;transition:.3s;pointer-events:none}
.cap:hover{box-shadow:var(--shadow);transform:translateY(-5px);border-color:var(--gold-soft)}
.cap:hover::after{opacity:.3;transform:scale(1.06)}
.cap .ci{width:54px;height:54px;border-radius:15px;background:linear-gradient(135deg,var(--gold-soft),var(--gold));display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:0 10px 22px -10px rgba(166,134,47,.7);position:relative;z-index:1}
.cap .ci svg{width:27px;height:27px;stroke:#3a0c10;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.cap h4{font-family:var(--serif);font-size:21px;color:var(--maroon);margin-bottom:9px;font-weight:600;position:relative;z-index:1;line-height:1.22}
.cap p{font-size:14px;color:var(--ink-soft);line-height:1.65;position:relative;z-index:1}

/* ---------- PROJECTS ---------- */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.proj{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 28px;transition:.3s;position:relative;overflow:hidden;min-height:256px;display:flex;flex-direction:column;cursor:pointer}
.proj::after{content:"";position:absolute;right:-40px;top:-40px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(194,161,77,.12),transparent 70%);transition:.4s}
.proj:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold-soft)}
.proj:hover::after{transform:scale(1.5)}
.proj .pn{font-family:var(--serif);font-size:14px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--maroon),var(--maroon-2));width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center}
.proj h3{font-family:var(--serif);font-size:23px;color:var(--ink);margin:16px 0 2px;line-height:1.18}
.proj .psub{font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.proj p.pd{font-size:14px;color:var(--ink-soft);margin-top:12px;flex:1;line-height:1.65}
.proj .kpi{margin-top:16px;padding-top:14px;border-top:1px dashed var(--line);display:flex;gap:8px;align-items:flex-start}
.proj .kpi .kl{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);font-weight:700;flex:0 0 auto;padding-top:2px}
.proj .kpi .kv{font-size:13px;color:var(--maroon);font-weight:600;line-height:1.4}
.proj .more{margin-top:14px;font-size:12.5px;font-weight:600;color:var(--gold-2);display:inline-flex;align-items:center;gap:6px;opacity:0;transform:translateX(-6px);transition:.25s}
.proj:hover .more{opacity:1;transform:none}

/* ---------- SUB-BOARDS ---------- */
.sb-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.sb{display:flex;gap:22px;background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:18px;padding:32px;transition:.25s}
.sb:hover{box-shadow:var(--shadow)}
.sb .sn{flex:0 0 auto;font-family:var(--serif);font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--gold-2);writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);border-right:2px solid var(--gold-soft);padding-right:14px;text-transform:uppercase}
.sb h4{font-family:var(--serif);font-size:22px;color:var(--maroon);line-height:1.2}
.sb p{font-size:14px;color:var(--ink-soft);margin:10px 0 14px;line-height:1.65}
.sb .chair{font-size:12.5px;color:var(--ink)}
.sb .chair b{color:var(--gold-2);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:11px}

/* ---------- ROADMAP ---------- */
.road{background:var(--cream-2)}
.rm{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:52px;position:relative}
.rm::before{content:"";position:absolute;top:30px;left:8%;right:8%;height:2px;background:repeating-linear-gradient(90deg,var(--gold-soft) 0 10px,transparent 10px 18px)}
.rp{padding:0 22px;position:relative;text-align:center}
.rp .rdot{width:60px;height:60px;border-radius:50%;background:#fff;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto;position:relative;z-index:2;font-family:var(--serif);font-weight:700;color:var(--maroon);box-shadow:0 8px 20px -10px rgba(166,134,47,.6)}
.rp .ry{font-size:12.5px;letter-spacing:.12em;color:var(--gold-2);font-weight:700;margin-top:18px}
.rp h4{font-family:var(--serif);font-size:21px;color:var(--maroon);margin:6px 0 12px}
.rp p{font-size:13.5px;color:var(--ink-soft);text-align:left;line-height:1.7}

/* ---------- IMPACT ---------- */
.impact{background:radial-gradient(120% 120% at 80% 0%,#3a0c10,#5A0E12 55%,#2a0608);color:#fff;text-align:center}
.impact .kicker{color:var(--gold-soft);justify-content:center;display:inline-flex}.impact .title{color:#fff}
.imp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:52px}
.imp .in{font-family:var(--serif);font-size:clamp(34px,5vw,52px);font-weight:700;color:var(--gold-soft);line-height:1}
.imp .il{font-size:13.5px;color:rgba(255,255,255,.72);margin-top:8px;line-height:1.5}
.imp-note{margin-top:48px;font-size:14px;color:rgba(255,255,255,.66);max-width:760px;margin-left:auto;margin-right:auto;border-top:1px solid rgba(228,210,160,.25);padding-top:26px;line-height:1.7}

/* ---------- NEWS (home preview + listing) ---------- */
.news-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}
.news-all{font-size:13.5px;font-weight:600;color:var(--gold-2);display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:.2s}
.news-all:hover{gap:11px;color:var(--maroon)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.na{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.na:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--gold-soft)}
.na .thumb{aspect-ratio:16/10;background:var(--cream-2) center/cover no-repeat;position:relative}
.na .thumb .cat{position:absolute;left:12px;top:12px;background:rgba(122,20,24,.92);color:#fff;font-size:10.5px;font-weight:600;letter-spacing:.04em;padding:5px 11px;border-radius:999px;backdrop-filter:blur(4px)}
.na .nb{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.na .date{font-size:11.5px;letter-spacing:.06em;color:var(--gold-2);font-weight:600}
.na h3{font-family:var(--serif);font-size:21px;color:var(--ink);margin:8px 0 10px;line-height:1.25;transition:.2s}
.na:hover h3{color:var(--maroon)}
.na p{font-size:13.5px;color:var(--ink-soft);line-height:1.6;flex:1}
.na .rd{margin-top:14px;font-size:12.5px;font-weight:600;color:var(--gold-2);display:inline-flex;align-items:center;gap:6px}
/* category filter */
.cat-filter{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.cat-filter button{border:1px solid var(--line);background:#fff;color:var(--ink-soft);font-family:var(--sans);font-size:13px;font-weight:500;padding:8px 16px;border-radius:999px;cursor:pointer;transition:.2s}
.cat-filter button:hover{border-color:var(--gold-soft)}
.cat-filter button.on{background:linear-gradient(135deg,var(--maroon),var(--maroon-2));color:#fff;border-color:transparent}

/* ---------- ORG ---------- */
.org-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:48px;max-width:840px;margin-left:auto;margin-right:auto}
.leader{background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);transition:.3s}
.leader:hover{transform:translateY(-5px)}
.leader .ph{aspect-ratio:4/5;background:var(--cream-2) center top/cover no-repeat;position:relative}
.leader .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(90,14,18,.42),transparent 38%)}
.leader .lb{padding:22px 26px 28px}
.leader .role{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);font-weight:700}
.leader h4{font-family:var(--serif);font-size:25px;color:var(--ink);margin:4px 0 10px}
.leader p{font-size:13.5px;color:var(--ink-soft);line-height:1.65}

/* ---------- CONTACT ---------- */
.contact{background:linear-gradient(160deg,#fff,var(--cream-2))}
.contact-box{background:radial-gradient(130% 130% at 0% 0%,#5A0E12,#3a0c10);color:#fff;border-radius:28px;padding:clamp(40px,6vw,72px);text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.contact-box::before{content:"";position:absolute;right:-60px;bottom:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(194,161,77,.18),transparent 70%)}
.contact-box .kicker{color:var(--gold-soft);justify-content:center;display:flex}
.contact-box .kicker::before{display:none}
.contact-box h2{font-family:var(--serif);font-weight:700;font-size:clamp(26px,4vw,42px);margin:12px 0 6px;color:#fff;position:relative}
.contact-box .csub{font-family:var(--serif);font-size:clamp(17px,2vw,22px);color:var(--gold-soft);font-style:italic}
.cinfo{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:36px;position:relative}
.ci{background:rgba(255,255,255,.06);border:1px solid rgba(228,210,160,.25);border-radius:14px;padding:16px 22px;min-width:190px}
.ci .cl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);font-weight:600}
.ci .cv{font-size:15px;color:#fff;margin-top:4px;font-weight:500}
.cparent{margin-top:30px;font-size:13px;color:rgba(255,255,255,.6);position:relative}
.cparent b{color:var(--gold-soft);font-weight:600}

/* ---------- FOOTER ---------- */
footer{background:#2a0608;color:rgba(255,255,255,.6);padding:42px 0;text-align:center}
.fbrand{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:14px}
.fbrand img{width:40px;height:40px;object-fit:contain;filter:brightness(0) invert(1);opacity:.9}
.fbrand b{font-family:var(--serif);font-size:18px;color:#fff}
footer .fr{font-size:12.5px;max-width:560px;margin:10px auto 0;color:rgba(255,255,255,.45);line-height:1.6}

/* ============================================================
   SUB-PAGE: detail hero (project / article)
   ============================================================ */
.dhero{background:radial-gradient(120% 120% at 80% 0%,#3a0c10,#5A0E12 50%,#2a0608);color:#fff;padding:128px 0 56px;position:relative;overflow:hidden}
.dhero::before{content:"";position:absolute;right:-6%;top:30%;width:min(46vw,520px);aspect-ratio:1;background:radial-gradient(circle,rgba(194,161,77,.14),transparent 70%)}
.dhero .wrap{position:relative;z-index:2}
.crumbs{font-size:13px;color:rgba(255,255,255,.6);display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.crumbs a{color:var(--gold-soft)}.crumbs a:hover{color:#fff}
.crumbs span.sep{opacity:.5}
.dhero .pn-big{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#3a0c10;font-family:var(--serif);font-weight:700;font-size:22px;margin:24px 0 0}
.dhero h1{font-family:var(--serif);font-weight:700;font-size:clamp(26px,3.4vw,40px);line-height:1.14;margin:16px 0 0;max-width:none}
.dhero .dsub{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;margin-top:14px}
.dhero .dmeta{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px;font-size:13.5px;color:rgba(255,255,255,.7)}
.dhero .dmeta .pill{background:rgba(255,255,255,.08);border:1px solid rgba(228,210,160,.28);padding:5px 14px;border-radius:999px;color:var(--gold-soft)}

/* project detail body */
.dbody{padding:clamp(48px,7vw,86px) 0}
.dlayout{display:grid;grid-template-columns:1fr 320px;gap:54px;align-items:start}
.dmain .lede{font-size:clamp(17px,1.9vw,21px);line-height:1.65;color:var(--ink);font-family:var(--serif);font-weight:600;border-left:3px solid var(--gold);padding-left:22px}
.dblock{margin-top:42px}
.dblock h3{font-family:var(--serif);font-size:26px;color:var(--maroon);margin-bottom:18px;display:flex;align-items:center;gap:12px}
.dblock h3::before{content:"";width:22px;height:2px;background:var(--gold)}
.dlist{display:flex;flex-direction:column;gap:12px}
.dlist .it{display:flex;gap:14px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:18px 20px}
.dlist .it .dot{flex:0 0 auto;width:9px;height:9px;border-radius:50%;background:var(--gold);margin-top:8px}
.dlist .it p{font-size:14.5px;color:var(--ink-soft);line-height:1.65}
.dpartners{display:flex;flex-wrap:wrap;gap:10px}
.dpartners span{background:var(--cream-2);border:1px solid var(--line);color:var(--ink);font-size:13px;font-weight:500;padding:8px 16px;border-radius:999px}
/* sidebar */
.daside{position:sticky;top:90px;display:flex;flex-direction:column;gap:18px}
.kpi-card{background:radial-gradient(130% 130% at 0% 0%,#5A0E12,#3a0c10);color:#fff;border-radius:20px;padding:30px;box-shadow:var(--shadow)}
.kpi-card .kh{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;margin-bottom:18px}
.kpi-card .kr{padding:14px 0;border-bottom:1px solid rgba(228,210,160,.18);display:flex;gap:12px;align-items:flex-start}
.kpi-card .kr:last-child{border-bottom:0;padding-bottom:0}
.kpi-card .kr .y{font-family:var(--serif);font-weight:700;color:var(--gold-soft);font-size:17px;flex:0 0 auto;min-width:46px}
.kpi-card .kr .t{font-size:13.5px;color:rgba(255,255,255,.84);line-height:1.5}
.aside-cta{background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:20px;padding:26px;text-align:center}
.aside-cta p{font-size:14px;color:var(--ink-soft);margin-bottom:14px}

/* project nav (prev/next + back) */
.dnav{border-top:1px solid var(--line);margin-top:60px;padding-top:30px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.dnav a{font-size:14px;font-weight:600;color:var(--maroon);display:inline-flex;align-items:center;gap:8px;transition:.2s}
.dnav a:hover{color:var(--gold-2)}

/* ============================================================
   SUB-PAGE: article detail
   ============================================================ */
.article{padding:clamp(40px,6vw,72px) 0}
.article-wrap{max-width:780px;margin:0 auto;padding:0 24px}
.article-cover{width:100%;aspect-ratio:16/8;object-fit:cover;border-radius:20px;box-shadow:var(--shadow);margin-bottom:36px;background:var(--cream-2)}
.article-body p{font-size:16.5px;line-height:1.85;color:var(--ink);margin-bottom:22px}
.article-body h3{font-family:var(--serif);font-size:27px;color:var(--maroon);margin:38px 0 16px}
.article-body .fig{margin:30px 0}
.article-body .fig img{width:100%;border-radius:16px;background:var(--cream-2)}
.article-body .fig figcaption{font-size:13px;color:var(--ink-soft);font-style:italic;margin-top:10px;text-align:center}
.article-src{margin-top:40px;padding:22px 26px;background:var(--cream-2);border:1px solid var(--line);border-radius:16px;font-size:13.5px;color:var(--ink-soft)}
.article-src a{color:var(--maroon);font-weight:600}
.share-row{display:flex;gap:10px;align-items:center;margin-top:28px;flex-wrap:wrap}
.share-row .sl{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.share-row a{width:38px;height:38px;border-radius:50%;background:var(--cream-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--maroon);transition:.2s}
.share-row a:hover{background:var(--maroon);color:#fff;border-color:transparent}
.related{background:var(--cream-2);padding:clamp(48px,7vw,80px) 0}

/* reveal */
.rv{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:60;background:rgba(42,6,8,.97);backdrop-filter:blur(10px);display:flex;flex-direction:column;padding:90px 32px 40px;gap:6px;transform:translateX(100%);transition:.35s;visibility:hidden}
.drawer.open{transform:none;visibility:visible}
.drawer a{color:#fff;font-family:var(--serif);font-size:24px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.drawer .dclose{position:absolute;top:24px;right:26px;background:0;border:0;color:#fff;font-size:34px;cursor:pointer;line-height:1}
.drawer .dlang{display:flex;gap:8px;margin-top:24px}
.drawer .dlang button{flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:#fff;padding:12px;border-radius:10px;font-family:var(--sans);font-weight:600;cursor:pointer}
.drawer .dlang button.on{background:var(--gold);color:#3a0c10;border-color:var(--gold)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .about-grid{grid-template-columns:1fr;gap:34px}
  .mission-grid,.ctx-grid,.val-grid,.caps-grid,.proj-grid,.news-grid{grid-template-columns:repeat(2,1fr)}
  .sb-grid,.org-grid{grid-template-columns:1fr}
  .rm{grid-template-columns:1fr;gap:30px}.rm::before{display:none}
  .rp{text-align:left;display:grid;grid-template-columns:60px 1fr;gap:18px;align-items:start}
  .rp .ry{margin-top:0}.imp-grid{gap:24px}
  .dlayout{grid-template-columns:1fr;gap:36px}
  .daside{position:static}
}
@media(max-width:680px){
  nav.menu{display:none}
  .burger{display:flex}
  .hgroup .cta-btn{display:none}
  .ctx-grid,.val-grid,.caps-grid,.proj-grid,.mission-grid,.imp-grid,.news-grid{grid-template-columns:1fr}
  .lang button.collapse{display:none}
  .hero h1{font-size:clamp(32px,9vw,46px)}
  .sb .sn{writing-mode:horizontal-tb;transform:none;border-right:0;border-bottom:2px solid var(--gold-soft);padding:0 0 8px}
  .sb{flex-direction:column;gap:14px}
}
@media(min-width:681px){.drawer{display:none}}

/* ---------- LEGAL BASIS ---------- */
.legal-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;margin-top:48px;align-items:start}
.legal-col h3{font-family:var(--serif);font-size:21px;color:var(--maroon);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.legal-col h3::before{content:"";width:20px;height:2px;background:var(--gold)}
.decrees{display:flex;flex-direction:column;gap:0;position:relative;padding-left:26px}
.decrees::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:repeating-linear-gradient(var(--gold-soft) 0 6px,transparent 6px 12px)}
.decree{position:relative;padding:0 0 22px 0}
.decree::before{content:"";position:absolute;left:-26px;top:5px;width:13px;height:13px;border-radius:50%;background:#fff;border:2.5px solid var(--gold)}
.decree:last-child{padding-bottom:0}
.decree .dref{font-family:var(--serif);font-weight:700;font-size:18px;color:var(--maroon);display:inline}
.decree .ddate{display:inline-block;margin-left:10px;font-size:11.5px;font-weight:600;letter-spacing:.04em;color:#fff;background:var(--gold-2);padding:2px 9px;border-radius:999px;vertical-align:middle}
.decree p{font-size:14px;color:var(--ink-soft);margin-top:7px;line-height:1.6}
.idcard{background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:18px;padding:12px 26px;box-shadow:var(--shadow)}
.idrow{padding:16px 0;border-bottom:1px dashed var(--line)}
.idrow:last-child{border-bottom:0}
.idrow .idk{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);font-weight:600}
.idrow .idv{font-size:15px;color:var(--ink);margin-top:4px;line-height:1.5}

/* ---------- CONTACT addresses ---------- */
.contact-addr{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px;position:relative;text-align:left}
.addr{background:rgba(255,255,255,.05);border:1px solid rgba(228,210,160,.22);border-radius:14px;padding:18px 20px}
.addr .al{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;margin-bottom:6px}
.addr .av{font-size:13.5px;color:rgba(255,255,255,.86);line-height:1.55}
@media(max-width:980px){.legal-grid{grid-template-columns:1fr;gap:34px}.contact-addr{grid-template-columns:1fr}}

/* ---------- ORG CHART ---------- */
.orgchart{margin:50px auto 8px;max-width:960px;text-align:center}
.oc-tier{display:flex;justify-content:center;align-items:stretch;gap:16px;flex-wrap:wrap;position:relative;padding-top:38px}
.oc-tier:first-child{padding-top:0}
.oc-tier::before{content:"";position:absolute;top:0;left:50%;width:2px;height:38px;background:var(--gold-soft);transform:translateX(-50%)}
.oc-tier:first-child::before{display:none}
.oc-node{background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:14px;padding:16px 22px;min-width:150px;box-shadow:0 10px 26px -18px rgba(60,40,10,.5);text-align:center}
.oc-node .ocn{font-family:var(--serif);font-size:17px;color:var(--ink);font-weight:600;line-height:1.25}
.oc-node .ocr{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2);font-weight:600;margin-bottom:5px}
.oc-node.lead{background:radial-gradient(130% 130% at 0% 0%,#5A0E12,#3a0c10);border-color:transparent}
.oc-node.lead .ocn{color:#fff}.oc-node.lead .ocr{color:var(--gold-soft)}
.oc-node.unit{min-width:120px;padding:14px 16px}
.oc-node.unit .ocnum{font-family:var(--serif);font-weight:700;color:var(--gold-soft);font-size:15px}
.oc-node.unit .ocn{font-size:14.5px;margin-top:2px}
.oc-node.side{background:#fff;border-style:dashed}
.oc-tier-label{margin-top:38px;position:relative;padding-top:38px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2);font-weight:700}
.oc-tier-label::before{content:"";position:absolute;top:0;left:50%;width:2px;height:30px;background:var(--gold-soft);transform:translateX(-50%)}
.oc-network{margin-top:38px;position:relative;padding-top:38px}
.oc-network::before{content:"";position:absolute;top:0;left:50%;width:2px;height:38px;background:var(--gold-soft);transform:translateX(-50%)}
.oc-network .bar{display:inline-block;background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#3a0c10;font-weight:600;font-size:14px;padding:13px 28px;border-radius:999px}
.org-leaders-h{margin-top:64px;font-family:var(--serif);font-size:26px;color:var(--maroon);text-align:center}
@media(max-width:680px){
  .oc-node{min-width:0;flex:1 1 100%}
  .oc-node.unit{flex:1 1 44%}
  .oc-tier{gap:10px}
}

/* ---------- RICH FOOTER ---------- */
footer.site-foot{background:linear-gradient(180deg,#2a0608,#1c0405);color:rgba(255,255,255,.66);padding:0;text-align:left}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:40px;padding:64px 24px 44px}
.foot-brand .fbrand{display:flex;align-items:center;gap:12px;margin-bottom:6px;justify-content:flex-start}
.foot-brand .fbrand img{width:46px;height:46px;object-fit:contain;filter:none;opacity:1}
.foot-brand .fbrand b{font-family:var(--serif);font-size:22px;color:#fff;letter-spacing:.02em}
.foot-name{font-family:var(--serif);font-size:17px;color:var(--gold-soft);margin-bottom:14px}
.foot-desc{font-size:13.5px;line-height:1.7;color:rgba(255,255,255,.6);max-width:340px}
.foot-tag{margin-top:16px;font-family:var(--serif);font-style:italic;font-size:15px;color:var(--gold-soft)}
.foot-col h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#fff;font-weight:600;margin-bottom:18px}
.foot-col a{display:block;font-size:13.5px;color:rgba(255,255,255,.62);padding:7px 0;transition:.2s}
.foot-col a:hover{color:var(--gold-soft);transform:translateX(3px)}
.foot-contact .fc-row{font-size:13.5px;color:rgba(255,255,255,.66);line-height:1.65;margin-bottom:12px}
.foot-contact .fc-row .fcl{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2);font-weight:600;display:block;margin-bottom:2px}
.foot-contact .fc-row a{color:rgba(255,255,255,.8);transition:.2s}
.foot-contact .fc-row a:hover{color:var(--gold-soft)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;border-top:1px solid rgba(228,210,160,.14);padding:22px 24px;max-width:var(--maxw);margin:0 auto}
.foot-bottom div{font-size:12.5px;color:rgba(255,255,255,.45)}
.foot-bottom .fb-legal{color:rgba(228,210,160,.6)}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px;padding:48px 24px 32px}.foot-brand{grid-column:1 / -1}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}.foot-bottom{flex-direction:column;align-items:flex-start}}

/* ---------- MEMBERS ---------- */
.mem-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:48px}
.mem{display:flex;gap:24px;background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:20px;padding:30px;transition:.3s;align-items:flex-start}
.mem:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:var(--gold-soft)}
.mem .mlogo{flex:0 0 auto;width:128px;height:96px;background:#fff center/contain no-repeat;background-size:contain;border:1px solid var(--line);border-radius:14px;box-shadow:0 6px 16px -10px rgba(60,40,10,.4)}
.mem .mbody{flex:1;min-width:0}
.mem .mrole{display:inline-block;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:linear-gradient(135deg,var(--gold),var(--gold-2));padding:4px 12px;border-radius:999px;font-weight:600}
.mem h3{font-family:var(--serif);font-size:24px;color:var(--maroon);margin:11px 0 2px;line-height:1.2}
.mem .msector{font-size:12.5px;color:var(--gold-2);font-weight:600;letter-spacing:.02em}
.mem p{font-size:14px;color:var(--ink-soft);line-height:1.65;margin-top:11px}
.mem .mvisit{margin-top:14px;font-size:13px;font-weight:600;color:var(--maroon);display:inline-flex;align-items:center;gap:6px;transition:.2s}
.mem .mvisit:hover{color:var(--gold-2);gap:10px}
.mem-cta{margin-top:46px;text-align:center;max-width:640px;margin-left:auto;margin-right:auto;background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:20px;padding:36px;box-shadow:var(--shadow)}
.mem-cta h3{font-family:var(--serif);font-size:25px;color:var(--maroon);margin-bottom:9px}
.mem-cta p{font-size:14.5px;color:var(--ink-soft);line-height:1.65;margin-bottom:18px}
@media(max-width:880px){.mem-grid{grid-template-columns:1fr}}
@media(max-width:560px){.mem{flex-direction:column;gap:16px}.mem .mlogo{width:140px;height:84px}}

/* ---------- VCIDA VALUES (5 Forces) ---------- */
.val{display:flex;flex-direction:column}
.val .vi{width:56px;height:56px;border-radius:16px;font-size:28px;font-weight:700}
.val h4{font-size:25px;margin-bottom:4px}
.val .vtag{font-size:14.5px;color:var(--ink);font-weight:500;margin:0 0 16px;line-height:1.55}
.val .vbul{list-style:none;margin:0 0 18px;padding:0;display:flex;flex-direction:column;gap:8px;flex:1}
.val .vbul li{font-size:13.5px;color:var(--ink-soft);padding-left:18px;position:relative;line-height:1.5}
.val .vbul li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--gold)}
.val .vmotto{font-family:var(--serif);font-style:italic;font-size:16.5px;color:var(--gold-2);border-top:1px dashed var(--line);padding-top:15px;margin-top:auto}
/* spirit */
.spirit{margin-top:58px;background:radial-gradient(130% 130% at 0% 0%,#5A0E12,#3a0c10);border-radius:26px;padding:clamp(36px,5vw,56px);text-align:center;color:#fff;position:relative;overflow:hidden}
.spirit::after{content:"";position:absolute;right:-60px;bottom:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(194,161,77,.16),transparent 70%)}
.spirit-h{font-family:var(--serif);font-weight:700;font-size:clamp(24px,3vw,32px);color:var(--gold-soft);margin-bottom:26px;position:relative}
.spirit-lines{display:flex;flex-direction:column;gap:13px;max-width:600px;margin:0 auto;position:relative}
.spirit-line{display:flex;align-items:baseline;justify-content:center;gap:12px;flex-wrap:wrap}
.spirit-line b{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--gold-soft);letter-spacing:.01em}
.spirit-line span{font-size:15px;color:rgba(255,255,255,.78)}
@media(max-width:980px){.val-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.val-grid{grid-template-columns:1fr}.spirit-line{flex-direction:column;gap:2px}}

/* ---------- CONTACT PAGE ---------- */
.contact-layout{display:grid;grid-template-columns:1.3fr .9fr;gap:40px;align-items:start}
.ct-channels{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ct-ch{background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:14px;padding:18px;transition:.2s;display:block}
.ct-ch:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--gold-soft)}
.ct-ch .cl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);font-weight:600;display:block}
.ct-ch b{font-size:15px;color:var(--ink);margin-top:5px;display:block;word-break:break-word}
.ct-h{font-family:var(--serif);font-size:22px;color:var(--maroon);margin:34px 0 16px}
.addr-list{display:flex;flex-direction:column;gap:12px}
.addr-card{background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px 20px}
.addr-card .al{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2);font-weight:600;margin-bottom:4px}
.addr-card .av{font-size:14.5px;color:var(--ink);line-height:1.5}
.ct-map{width:100%;height:300px;border:0;border-radius:16px;margin-top:4px;box-shadow:var(--shadow)}
.ct-form-card{background:linear-gradient(160deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:20px;padding:32px;box-shadow:var(--shadow);position:sticky;top:90px}
.ct-form-card h3{font-family:var(--serif);font-size:24px;color:var(--maroon)}
.ct-form-lead{font-size:13.5px;color:var(--ink-soft);line-height:1.6;margin:8px 0 18px}
.ct-form{display:flex;flex-direction:column;gap:12px}
.ct-form input,.ct-form textarea{font-family:var(--sans);font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:11px;padding:12px 14px;transition:.2s}
.ct-form input:focus,.ct-form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(194,161,77,.18)}
.ct-form .btn-g{border:0;cursor:pointer;text-align:center;margin-top:4px}
.ct-form-note{font-size:12px;color:var(--ink-soft);font-style:italic;line-height:1.5;margin-top:2px}
@media(max-width:880px){.contact-layout{grid-template-columns:1fr;gap:30px}.ct-form-card{position:static}.ct-channels{grid-template-columns:1fr}}

/* ---------- VCIDA 5 FORCES diagram ---------- */
.forces{max-width:540px;margin:46px auto 8px}
.forces svg{width:100%;height:auto;overflow:visible;display:block}
.forces .flines line{stroke:var(--gold-soft);stroke-width:2;stroke-dasharray:3 6;opacity:.65}
.forces .fnode circle{fill:url(#fgold);stroke:#fff;stroke-width:2.5;filter:drop-shadow(0 6px 14px rgba(166,134,47,.45))}
.forces .fnode .fl{font-family:var(--serif);font-weight:700;font-size:36px;fill:#3a0c10;text-anchor:middle}
.forces .fnode .fn{font-family:var(--sans);font-weight:600;font-size:17px;fill:var(--maroon);text-anchor:middle;paint-order:stroke;stroke:var(--cream);stroke-width:5px;stroke-linejoin:round}
.forces .fcenter circle{fill:url(#fmaroon);filter:drop-shadow(0 8px 20px rgba(90,14,18,.45))}
.forces .fcenter .fc1{font-family:var(--serif);font-weight:700;font-size:27px;fill:#fff;text-anchor:middle;letter-spacing:1.5px}
.forces .fcenter .fc2{font-family:var(--sans);font-size:11px;font-weight:600;fill:var(--gold-soft);text-anchor:middle;letter-spacing:3px}

/* ---------- ARTICLE dhero: title aligns to content width ---------- */
body[data-page="article"] .dhero .wrap{max-width:780px}
body[data-page="article"] .dhero h1{max-width:none}
