:root{
  --bg:#07111d;
  --panel:#0d1825;
  --panel2:#101d2c;
  --ink:#f4efe6;
  --muted:#b8b2a7;
  --soft:#8f8a82;
  --line:rgba(218,199,156,.20);
  --gold:#cbb47a;
  --gold2:#e4c981;
  --paper:#f7f2e8;
  --paperInk:#17202b;
  --paperMuted:#536070;
  --max:980px;
  --wide:1180px;
  --radius:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",Arial,sans-serif;line-height:1.78;letter-spacing:.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.site-header{position:sticky;top:0;z-index:30;background:rgba(7,17,29,.86);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav{max-width:var(--wide);margin:0 auto;padding:17px 28px;display:flex;align-items:center;justify-content:space-between;gap:26px}
.brand{display:flex;align-items:center;gap:12px;font-weight:600;letter-spacing:.08em;color:var(--gold)}
.brand img{height:30px;width:auto;object-fit:contain}.brand span{font-size:13px;white-space:nowrap}
.nav-links{display:flex;align-items:center;gap:20px;font-size:13px;color:var(--muted)}
.nav-links a{white-space:nowrap}.nav-links a:hover{color:var(--ink)}.nav-cta{padding:8px 13px;border:1px solid var(--gold);border-radius:999px;color:var(--gold)!important}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);font-size:24px}
.hero{min-height:86vh;position:relative;display:flex;align-items:center;border-bottom:1px solid var(--line);overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,17,29,.94) 0%,rgba(7,17,29,.82) 44%,rgba(7,17,29,.60) 100%),url('images/home.webp') center/cover no-repeat;filter:saturate(.9)}
.hero-inner{position:relative;max-width:var(--wide);margin:0 auto;width:100%;padding:110px 28px 90px}.eyebrow{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}.hero h1{font-size:clamp(38px,5vw,68px);line-height:1.08;margin:0 0 22px;font-weight:620;letter-spacing:-.04em;max-width:840px}.hero .subtitle{font-size:19px;line-height:1.9;color:#e5dfd3;max-width:830px;margin:0 0 28px}.trust-anchor{color:var(--gold);font-size:14px;letter-spacing:.12em;text-transform:uppercase;margin:28px 0}.actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 18px;border-radius:999px;border:1px solid var(--gold);color:#07111d;background:var(--gold);font-size:14px;font-weight:600}.btn.secondary{background:transparent;color:var(--gold)}.btn:hover{transform:translateY(-1px)}
main{background:linear-gradient(180deg,#07111d 0%,#0a1421 38%,#07111d 100%)}
.section{padding:86px 28px;border-bottom:1px solid rgba(218,199,156,.12)}.section.compact{padding:58px 28px}.container{max-width:var(--max);margin:0 auto}.wide{max-width:var(--wide);margin:0 auto}.section h2{font-size:clamp(28px,3.4vw,44px);line-height:1.18;margin:0 0 22px;font-weight:610;letter-spacing:-.03em}.section h3{font-size:23px;line-height:1.35;margin:38px 0 10px;font-weight:600;color:#fff}.lead{font-size:18px;color:#ddd5ca;margin:0 0 24px}.body-text{font-size:16.5px;color:var(--muted)}.body-text p{margin:0 0 18px}.note{font-size:13px;color:var(--soft);margin-top:18px}.divider{height:1px;background:var(--line);margin:36px 0}.gold{color:var(--gold)}
.reading-block{max-width:880px}.split-list{margin:30px 0 0;border-top:1px solid var(--line)}.split-item{padding:24px 0;border-bottom:1px solid var(--line)}.split-item h3{margin:0 0 8px;font-size:20px}.split-item p{margin:0;color:var(--muted)}.split-item .tag{display:inline-block;color:var(--gold);font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}
.data-bar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;margin:30px 0;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.data-bar b{display:block;font-size:20px;color:#fff;line-height:1.2}.data-bar span{display:block;font-size:13px;color:var(--muted);margin-top:5px}.flow{border-top:1px solid var(--line);margin-top:28px}.flow-step{display:grid;grid-template-columns:160px 1fr;gap:24px;border-bottom:1px solid var(--line);padding:24px 0}.flow-step b{color:var(--gold);font-size:13px;letter-spacing:.14em;text-transform:uppercase}.flow-step p{margin:0;color:var(--muted)}
.table-wrap{overflow-x:auto;margin:26px 0;border:1px solid var(--line);border-radius:14px}table{width:100%;border-collapse:collapse;min-width:650px}th,td{padding:17px 18px;border-bottom:1px solid rgba(218,199,156,.14);text-align:left;vertical-align:top}th{font-size:13px;color:var(--gold);letter-spacing:.08em;text-transform:uppercase;font-weight:600}td{color:var(--muted)}tr:last-child td{border-bottom:0}
.quote-panel{background:linear-gradient(180deg,rgba(203,180,122,.09),rgba(203,180,122,.03));border:1px solid var(--line);border-radius:var(--radius);padding:28px;margin:30px 0;color:#e8dfcf}.quote-panel p{margin:0}.soft-panel{background:rgba(255,255,255,.035);border:1px solid rgba(218,199,156,.12);border-radius:var(--radius);padding:28px;margin:28px 0}.soft-panel h3{margin-top:0}.paper{background:var(--paper);color:var(--paperInk);padding:84px 28px}.paper h2,.paper h3{color:var(--paperInk)}.paper .lead{color:#303946}.paper .body-text,.paper p,.paper td{color:var(--paperMuted)}.paper .divider,.paper .split-item,.paper .split-list{border-color:rgba(23,32,43,.14)}.paper .table-wrap{border-color:rgba(23,32,43,.16)}.paper th{color:#8e6f2e}.paper td,.paper th{border-color:rgba(23,32,43,.12)}
.page-hero{padding:84px 28px 58px;border-bottom:1px solid var(--line);background:radial-gradient(circle at 85% 15%,rgba(203,180,122,.16),transparent 34%),linear-gradient(180deg,#07111d,#0d1825)}.page-hero .container{max-width:980px}.page-hero h1{font-size:clamp(38px,5vw,62px);line-height:1.08;margin:0 0 18px;letter-spacing:-.04em}.page-hero p{font-size:18px;color:var(--muted);max-width:820px;margin:0}.breadcrumb{font-size:12px;color:var(--gold);letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}.cta-strip{padding:62px 28px;background:#0d1825;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.cta-strip .wide{display:flex;align-items:center;justify-content:space-between;gap:30px}.cta-strip h2{font-size:30px;margin:0 0 8px}.cta-strip p{margin:0;color:var(--muted);max-width:720px}
.form-box{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:18px;padding:28px;margin-top:26px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{display:flex;flex-direction:column;gap:7px}.field label{font-size:13px;color:var(--gold)}input,select,textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(218,199,156,.22);border-radius:10px;color:var(--ink);padding:12px 12px;font:inherit}textarea{min-height:110px}.full{grid-column:1/-1}.site-footer{padding:46px 28px;color:var(--soft);background:#050b13}.footer-inner{max-width:var(--wide);margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:34px;border-top:1px solid var(--line);padding-top:28px}.footer-links{display:flex;gap:14px;flex-wrap:wrap;font-size:13px}.legal-small{font-size:12px;line-height:1.7;color:#817c74;margin-top:18px}.lang{font-size:12px;color:var(--gold);margin-left:8px}.archive-title{font-size:30px!important}.case-meta{color:var(--gold);font-size:13px;letter-spacing:.13em;text-transform:uppercase}.warning{font-size:13px;color:#a9a093;border-top:1px solid var(--line);padding-top:18px;margin-top:30px}
@media (max-width:900px){.nav{padding:14px 18px}.nav-toggle{display:block}.nav-links{position:absolute;left:0;right:0;top:61px;background:#07111d;border-bottom:1px solid var(--line);display:none;flex-direction:column;align-items:flex-start;padding:20px 24px;gap:16px}.nav-links.open{display:flex}.hero{min-height:auto}.hero-inner{padding:86px 22px 68px}.section,.paper{padding:58px 22px}.page-hero{padding:62px 22px 42px}.data-bar{grid-template-columns:1fr}.flow-step{grid-template-columns:1fr;gap:8px}.cta-strip .wide{display:block}.cta-strip .actions{margin-top:22px}.form-grid{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr}.brand span{display:none}table{min-width:560px}.hero .subtitle{font-size:17px}.section h2{font-size:30px}}

/* V6.1 client-journey refinements */
.kicker{color:var(--gold);font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin:30px 0 10px}.index-list{margin:28px 0;border-top:1px solid var(--line)}.index-row{display:grid;grid-template-columns:230px 1fr;border-bottom:1px solid var(--line);padding:20px 0;gap:30px}.index-row b{color:#fff}.index-row p{margin:0;color:var(--muted)}.paper .index-row{border-color:rgba(23,32,43,.14)}.paper .index-row b{color:var(--paperInk)}.paper .index-row p{color:var(--paperMuted)}.plain-list{margin:22px 0 0;padding:0;list-style:none;border-top:1px solid var(--line)}.plain-list li{padding:14px 0;border-bottom:1px solid var(--line);color:var(--muted)}.plain-list b{color:#fff}.paper .plain-list{border-color:rgba(23,32,43,.14)}.paper .plain-list li{border-color:rgba(23,32,43,.14);color:var(--paperMuted)}.paper .plain-list b{color:var(--paperInk)}.article-list{border-top:1px solid var(--line);margin-top:28px}.article-list a{display:block;padding:22px 0;border-bottom:1px solid var(--line)}.article-list h3{margin:0 0 6px!important}.article-list p{margin:0;color:var(--muted)}.section-narrow{padding:70px 28px;border-bottom:1px solid rgba(218,199,156,.12)}.section-narrow .container{max-width:860px}.case-lede{font-size:18px;color:#ddd5ca;margin:0 0 28px}.small-caps{font-size:12px;color:var(--gold);letter-spacing:.16em;text-transform:uppercase}.program-block{padding:28px 0;border-top:1px solid var(--line)}.program-block:last-child{border-bottom:1px solid var(--line)}.program-block h3{margin-top:0}.program-block p{margin:0 0 12px;color:var(--muted)}@media(max-width:900px){.index-row{grid-template-columns:1fr;gap:6px}.section-narrow{padding:54px 22px}}


/* V6.2 visual consistency refinements */
body{background:var(--paper);color:var(--paperInk)}
main{background:var(--paper)}
.site-header{background:rgba(7,17,29,.94)}
.nav{padding:14px 24px;gap:18px}.brand img{height:28px}.brand span{display:none}.nav-links{gap:15px;font-size:12.5px}.nav-cta{border-radius:4px;padding:8px 12px;background:rgba(203,180,122,.14)}
.hero{background:#07111d;color:var(--ink)}
.hero:before{background:linear-gradient(90deg,rgba(7,17,29,.98) 0%,rgba(7,17,29,.88) 52%,rgba(7,17,29,.72) 100%),url('images/home.webp') center/cover no-repeat;filter:saturate(.65) brightness(.8)}
.hero h1{max-width:820px}.hero .subtitle{max-width:900px}
.section,.section-narrow,.paper{background:var(--paper);color:var(--paperInk);border-bottom:1px solid rgba(23,32,43,.10);padding:68px 28px}.section-narrow .container,.section .container,.paper .container{max-width:900px}.section h2,.section-narrow h2,.paper h2{color:var(--paperInk)}.section h3,.section-narrow h3,.paper h3{color:var(--paperInk)}.lead,.section .lead,.section-narrow .lead,.paper .lead{color:#374252}.body-text,.section .body-text,.section-narrow .body-text,.paper .body-text{color:var(--paperMuted)}.body-text p{margin-bottom:16px}.plain-list,.index-list,.article-list{border-color:rgba(23,32,43,.14)}.plain-list li,.index-row,.article-list a,.program-block{border-color:rgba(23,32,43,.14);color:var(--paperMuted)}.plain-list b,.index-row b{color:var(--paperInk)}.flow{border-color:rgba(23,32,43,.15)}.flow-step{border-color:rgba(23,32,43,.12)}.flow-step b{color:#8e6f2e}.flow-step p{color:var(--paperMuted)}.quote-panel,.soft-panel,.form-box{background:#fff;border-color:rgba(23,32,43,.12);box-shadow:0 10px 30px rgba(7,17,29,.05)}.page-hero{background:#07111d;color:var(--ink);border-bottom:0}.page-hero h1{color:#fff}.page-hero p{color:#d8d0c3}.breadcrumb{color:var(--gold)}.cta-strip{background:#07111d;color:var(--ink);border:0}.cta-strip h2{color:#fff}.cta-strip p{color:#c9c0b2}.btn{border-radius:6px;padding:13px 20px;background:#b89a55;border-color:#b89a55;color:#07111d;box-shadow:none;transition:.18s ease}.btn.secondary{background:transparent;color:#b89a55;border-color:rgba(184,154,85,.72)}.btn:hover{transform:none;background:#d1b36b;border-color:#d1b36b}.btn.secondary:hover{background:rgba(184,154,85,.12);color:#b89a55}.site-footer{background:#050b13;color:var(--soft)}.footer-brand img{height:34px;width:auto;object-fit:contain}.footer-inner{grid-template-columns:1.05fr 1.15fr;gap:46px}.footer-grid{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:22px}.footer-grid b{display:block;color:var(--gold);font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}.footer-grid a{display:block;color:#9d968d;font-size:13px;line-height:1.9}.footer-grid a:hover{color:#f4efe6}.text-link{color:#8e6f2e;border-bottom:1px solid rgba(142,111,46,.35)}.inline-note{margin:0;color:#4b5562}.compact-note{padding:34px 28px;background:#efe8d9}.warning{color:#746b5d;border-color:rgba(23,32,43,.14)}
@media(max-width:900px){.nav{padding:13px 18px}.brand img{height:26px}.nav-links{top:55px}.section,.section-narrow,.paper{padding:50px 22px}.footer-grid{grid-template-columns:1fr}.footer-brand img{height:30px}.nav-links{font-size:14px}.nav-cta{border-radius:6px}.hero-inner{padding:76px 22px 60px}.hero h1{font-size:38px}.hero .subtitle{font-size:16px}}

/* V6.3 usability refinements: smaller CTA buttons + stronger contrast */
:root{
  --paper:#faf6ee;
  --paperInk:#111927;
  --paperMuted:#394655;
  --paperSoft:#5c6673;
  --gold:#c6a767;
  --gold2:#d9bd7a;
}
body{color:var(--paperInk);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.section,.section-narrow,.paper{background:var(--paper);color:var(--paperInk)}
.body-text,.section .body-text,.section-narrow .body-text,.paper .body-text,
.section p,.section-narrow p,.paper p,.index-row p,.article-list p,.program-block p,
.plain-list li,.flow-step p,td{color:var(--paperMuted)}
.note,.warning,.inline-note,.compact-note p{color:var(--paperSoft)}
.gold,.kicker,.small-caps,.breadcrumb,.field label{color:#8b6b29}
.text-link{color:#73551b;border-bottom-color:rgba(115,85,27,.35)}

/* Buttons: remove oversized pill look, make CTAs lighter and more institutional */
.actions{gap:10px;margin-top:24px}
.btn{
  min-height:0;
  padding:9px 14px;
  border-radius:3px;
  font-size:13px;
  line-height:1.25;
  font-weight:600;
  letter-spacing:.02em;
  background:#b58f43;
  border:1px solid #b58f43;
  color:#07111d;
  box-shadow:none;
}
.btn.secondary{
  background:transparent;
  color:#8b6b29;
  border-color:rgba(139,107,41,.55);
}
.hero .btn.secondary,.cta-strip .btn.secondary,.page-hero .btn.secondary{
  color:#d7bd7a;
  border-color:rgba(215,189,122,.62);
}
.hero .btn,.cta-strip .btn,.page-hero .btn{padding:10px 15px;font-size:13px;border-radius:3px}
.nav-cta{padding:6px 10px!important;border-radius:3px!important;font-size:12px!important;background:rgba(198,167,103,.10)!important;color:#d9bd7a!important}
.btn:hover{background:#c8a456;border-color:#c8a456;transform:none}
.btn.secondary:hover{background:rgba(139,107,41,.08);color:#73551b}
.hero .btn.secondary:hover,.cta-strip .btn.secondary:hover,.page-hero .btn.secondary:hover{background:rgba(215,189,122,.10);color:#e4cf98}

/* CTA strip should not visually overpower page content */
.cta-strip{padding:42px 28px;background:#07111d;color:var(--ink)}
.cta-strip h2{font-size:24px;line-height:1.25;margin-bottom:6px}
.cta-strip p{font-size:15px;line-height:1.65;color:#d1c8ba}
.cta-strip .actions{margin-top:0}

/* Form and panel contrast */
.form-box,.quote-panel,.soft-panel{background:#fffdf8;border-color:rgba(17,25,39,.14)}
input,select,textarea{background:#fff;color:var(--paperInk);border-color:rgba(17,25,39,.22)}
input::placeholder,textarea::placeholder{color:#7d8794}

/* Keep headings crisp on light backgrounds */
.section h2,.section-narrow h2,.paper h2,.section h3,.section-narrow h3,.paper h3{color:#101827}
.lead,.section .lead,.section-narrow .lead,.paper .lead{color:#263445}

/* Dark sections: preserve readability */
.hero .subtitle,.page-hero p{color:#ebe2d5}
.trust-anchor{color:#d7bd7a}
.site-footer{color:#aaa197}
.footer-grid a{color:#b8afa5}
.legal-small{color:#9a9288}

@media(max-width:900px){
  .btn{padding:9px 13px;font-size:13px;width:auto;max-width:100%}
  .actions{gap:8px}
  .cta-strip{padding:34px 22px}
  .cta-strip .actions{margin-top:18px}
}


/* V6.5 editorial block unification: replace rigid left-right rows and heavy tables with quiet summary blocks */
.index-list{
  margin:30px 0 0;
  border-top:0;
}
.index-row{
  display:block;
  grid-template-columns:none;
  gap:0;
  padding:30px 0 28px;
  border-bottom:1px solid rgba(17,25,39,.14);
}
.index-row:first-child{border-top:1px solid rgba(17,25,39,.14)}
.index-row b{
  display:block;
  color:var(--paperInk);
  font-size:24px;
  line-height:1.32;
  letter-spacing:.01em;
  margin:0 0 12px;
  font-weight:650;
}
.index-row p{
  margin:0;
  color:var(--paperMuted);
  font-size:17px;
  line-height:1.82;
}
.index-row .meta{
  display:block;
  margin-top:10px;
  color:#8b6b29;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.program-list{margin:30px 0 0;border-top:1px solid rgba(17,25,39,.14)}
.program-item{padding:30px 0 28px;border-bottom:1px solid rgba(17,25,39,.14)}
.program-item h3{margin:0 0 12px!important;font-size:25px!important;line-height:1.35;color:var(--paperInk)!important}
.program-item p{margin:0 0 12px;color:var(--paperMuted);font-size:16.5px;line-height:1.82}
.program-item .small-caps{display:block;margin-bottom:8px}
.program-item .program-meta{font-size:14px;color:#73551b;margin-top:14px}
.summary-table{margin:28px 0;border-top:1px solid rgba(17,25,39,.14)}
.summary-table .index-row b{font-size:21px}
.table-wrap{border-radius:0;border-color:rgba(17,25,39,.14);box-shadow:none}
@media(max-width:900px){
  .index-row{padding:24px 0 22px}
  .index-row b{font-size:21px}
  .index-row p{font-size:16px}
  .program-item h3{font-size:22px!important}
}

/* V6.6 Trust Evidence Closure */
.section-label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#8b6b29;margin:0 0 12px;font-weight:650}
.cta-strip .section-label,.section-label.dark{color:#d7bd7a}
.mini-link{display:inline-flex;margin-top:18px;color:#73551b;border-bottom:1px solid rgba(115,85,27,.32);font-size:14px;font-weight:600}
.hero .mini-link,.cta-strip .mini-link{color:#d7bd7a;border-bottom-color:rgba(215,189,122,.45)}
.action-log{margin:24px 0 0;padding:0;list-style:none;border-top:1px solid rgba(17,25,39,.14)}
.action-log li{padding:15px 0;border-bottom:1px solid rgba(17,25,39,.14);color:var(--paperMuted);font-size:16.5px;line-height:1.75}
.action-log li:before{content:'—';color:#8b6b29;margin-right:10px}
.program-item .program-meta{line-height:1.7}
@media(max-width:900px){.section-label{font-size:11px}.mini-link{font-size:14px}.action-log li{font-size:15.5px}}


/* V6.10 readability + home reception refinement */
.hero > .container,
.hero .hero-inner{
  position:relative;
  z-index:2;
}
.hero > .container{
  max-width:var(--wide);
  width:100%;
  padding:110px 28px 90px;
}
.hero h1,
.hero .eyebrow,
.hero p,
.hero .anchor-line,
.hero .actions{position:relative;z-index:2}
.hero p{color:#f0e7d9;font-size:18px;line-height:1.88;max-width:900px;margin:0 0 18px;text-shadow:0 1px 2px rgba(0,0,0,.35)}
.hero .anchor-line{color:#d7bd7a;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-top:20px;text-shadow:none}
.hero:before{z-index:0;filter:saturate(.72) brightness(.58)}
.hero:after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(7,17,29,.84),rgba(7,17,29,.62) 50%,rgba(7,17,29,.42));pointer-events:none}

/* Make real subsection titles visibly larger than section labels */
.section h2,.section-narrow h2,.paper h2{font-size:clamp(32px,3.7vw,48px);line-height:1.18;letter-spacing:-.035em;margin-bottom:24px}
.program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:clamp(24px,2.35vw,31px)!important;line-height:1.32!important;letter-spacing:-.015em!important}
.section-label{font-size:11px;letter-spacing:.20em;margin-bottom:16px;opacity:.92}
.body-text{font-size:17px;line-height:1.86}

/* Homepage should read like a reception path, not duplicated country modules */
.home-hero + .section-narrow,
.home-hero + .section-narrow + .paper{border-bottom:1px solid rgba(17,25,39,.10)}
.paper .body-text .text-link{display:inline-block;margin-top:10px;margin-right:12px}

@media(max-width:900px){
  .hero > .container{padding:76px 22px 60px}
  .hero p{font-size:16px;line-height:1.76}
  .hero:before{filter:saturate(.72) brightness(.50)}
  .section h2,.section-narrow h2,.paper h2{font-size:31px}
  .program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:23px!important}
}


/* V6.12 Typography + Hero/Footer refinement */
body{
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
strong,b{font-weight:520}
.brand span,.nav-links,.section-label,.eyebrow,.small-caps,.breadcrumb,.anchor-line{font-weight:450}
h1,h2,h3,.hero h1,.page-hero h1,.section h2,.section-narrow h2,.paper h2{font-weight:520}
.body-text,.lead,.hero p,.subtitle,p,li,td{font-weight:300}
/* Section markers should guide, not dominate */
.section-label{
  font-size:13px!important;
  letter-spacing:.15em!important;
  line-height:1.35!important;
  margin-bottom:14px!important;
  opacity:.86;
}
.breadcrumb,.eyebrow{
  font-size:12px!important;
  letter-spacing:.20em!important;
}
/* Subsection titles remain visibly stronger than markers */
.section h2,.section-narrow h2,.paper h2{font-size:clamp(30px,3.25vw,42px)!important;line-height:1.2!important}
.program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:clamp(22px,2.1vw,28px)!important;font-weight:520!important}
.hero .trust-line{
  color:#d7bd7a;
  font-size:17px;
  line-height:1.55;
  margin:8px 0 18px;
  letter-spacing:.015em;
}
.hero .region-line{
  color:#c8b98f;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin:22px 0 0;
}
.footer-brand img{height:38px;width:auto;object-fit:contain;margin-bottom:16px}
.footer-slogan{font-size:16px;line-height:1.8;color:#d8cda9;margin:10px 0 18px;max-width:420px}
.site-footer{background:#050b13 url('images/footer.webp') center top/cover no-repeat;position:relative}
.site-footer:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,11,19,.90),rgba(5,11,19,.97));pointer-events:none}.site-footer .footer-inner{position:relative;z-index:1}
@media(max-width:900px){
  body{font-weight:300}
  .section-label{font-size:12px!important;letter-spacing:.14em!important}
  .section h2,.section-narrow h2,.paper h2{font-size:29px!important}
  .program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:21px!important}
  .hero .trust-line{font-size:16px}.hero .region-line{font-size:12px;letter-spacing:.12em}
}

/* V6.13 typography balance + home image visibility
   Goal: avoid oversized page titles, keep subheadings readable, and let the hero image breathe. */
:root{
  --heading-weight:500;
  --text-weight:330;
}
body{font-weight:var(--text-weight)}
p,li,td,.body-text,.lead,.hero p,.page-hero p{font-weight:var(--text-weight)}
h1,h2,h3,.hero h1,.page-hero h1,.section h2,.section-narrow h2,.paper h2{font-weight:var(--heading-weight)}

/* Global title rhythm: page titles should not overpower the content below. */
.hero h1{
  font-size:clamp(38px,4.4vw,58px)!important;
  line-height:1.08!important;
  letter-spacing:-.035em!important;
  max-width:780px;
}
.page-hero h1{
  font-size:clamp(34px,3.7vw,48px)!important;
  line-height:1.12!important;
  letter-spacing:-.032em!important;
  max-width:860px;
}
.section h2,.section-narrow h2,.paper h2{
  font-size:clamp(26px,2.6vw,34px)!important;
  line-height:1.28!important;
  letter-spacing:-.025em!important;
  margin-bottom:18px!important;
}
.program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{
  font-size:clamp(21px,1.8vw,25px)!important;
  line-height:1.38!important;
  letter-spacing:-.01em!important;
  font-weight:500!important;
}
.section-label,.breadcrumb,.eyebrow{
  font-size:11px!important;
  letter-spacing:.16em!important;
  line-height:1.35!important;
  margin-bottom:12px!important;
  opacity:.78;
}
.body-text,.lead{
  font-size:17.5px!important;
  line-height:1.88!important;
}
.body-text p{margin-bottom:16px}
.index-row b{margin-bottom:10px!important}
.index-row p,.program-item p,.article-list p,.split-item p{
  font-size:16.8px!important;
  line-height:1.82!important;
}

/* Home first screen: keep readable text, but make the image visible on the right. */
.home-hero{
  min-height:78vh!important;
  background:#07111d;
}
.home-hero:before{
  background:url('images/home.webp') center right/cover no-repeat!important;
  filter:saturate(.88) brightness(.92) contrast(.96)!important;
  opacity:1!important;
}
.home-hero:after{
  background:
    linear-gradient(90deg,rgba(7,17,29,.88) 0%,rgba(7,17,29,.78) 38%,rgba(7,17,29,.38) 67%,rgba(7,17,29,.16) 100%),
    radial-gradient(circle at 78% 42%,rgba(203,180,122,.12),transparent 34%)!important;
}
.home-hero .hero-inner{
  max-width:var(--wide);
  padding-top:96px!important;
  padding-bottom:78px!important;
}
.home-hero p{
  max-width:780px!important;
  color:#f2eadd!important;
  font-size:17.5px!important;
  line-height:1.82!important;
}
.home-hero .trust-line{font-size:16.5px!important;color:#e0c987!important;margin:6px 0 16px!important}
.home-hero .region-line{font-size:12.5px!important;color:#d0c098!important;margin-top:18px!important}

/* Make footer image present but not overpower footer content. */
.site-footer:before{background:linear-gradient(180deg,rgba(5,11,19,.82),rgba(5,11,19,.96))!important}

@media(max-width:900px){
  .hero h1{font-size:36px!important;line-height:1.12!important}
  .page-hero h1{font-size:32px!important;line-height:1.16!important}
  .section h2,.section-narrow h2,.paper h2{font-size:26px!important;line-height:1.3!important}
  .program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:21px!important}
  .body-text,.lead{font-size:16px!important;line-height:1.78!important}
  .index-row p,.program-item p,.article-list p,.split-item p{font-size:15.8px!important;line-height:1.76!important}
  .home-hero{min-height:auto!important}
  .home-hero:before{background-position:center!important;filter:saturate(.82) brightness(.78)!important}
  .home-hero:after{background:linear-gradient(180deg,rgba(7,17,29,.86),rgba(7,17,29,.72) 60%,rgba(7,17,29,.58))!important}
  .home-hero .hero-inner{padding-top:76px!important;padding-bottom:62px!important}
  .home-hero p{font-size:16px!important;line-height:1.76!important}
}

/* V6.14 Balanced full-screen reading rhythm
   Target: page titles calm, subsection titles clear, body text readable. */
:root{
  --heading-weight:500;
  --text-weight:340;
}
body{font-weight:var(--text-weight);letter-spacing:.005em}
p,li,td,.body-text,.lead,.hero p,.page-hero p{font-weight:var(--text-weight)}

/* Overall hierarchy: avoid giant title / tiny body contrast. */
.hero h1{
  font-size:clamp(40px,4.2vw,58px)!important;
  line-height:1.1!important;
  font-weight:500!important;
  letter-spacing:-.035em!important;
  max-width:780px!important;
}
.page-hero h1{
  font-size:clamp(38px,4vw,56px)!important;
  line-height:1.12!important;
  font-weight:500!important;
  letter-spacing:-.032em!important;
  max-width:900px!important;
}
.section h2,.section-narrow h2,.paper h2{
  font-size:clamp(32px,3.2vw,43px)!important;
  line-height:1.25!important;
  font-weight:500!important;
  letter-spacing:-.025em!important;
  margin-bottom:20px!important;
}
.program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{
  font-size:clamp(25px,2.35vw,33px)!important;
  line-height:1.34!important;
  font-weight:500!important;
  letter-spacing:-.012em!important;
}
.section-label,.breadcrumb,.eyebrow{
  font-size:11px!important;
  letter-spacing:.17em!important;
  line-height:1.35!important;
  margin-bottom:14px!important;
  opacity:.72!important;
}
.body-text,.lead{
  font-size:19px!important;
  line-height:1.92!important;
}
.body-text p{margin-bottom:18px!important}
.index-row p,.program-item p,.article-list p,.split-item p,.paper p,.section p{
  font-size:18.5px!important;
  line-height:1.88!important;
}
.note,.legal-small,.warning{font-size:13px!important;line-height:1.75!important}

/* Editorial blocks: keep the comfortable rhythm shown in the reference screenshot. */
.index-row,.split-item,.program-item{
  padding-top:30px!important;
  padding-bottom:30px!important;
}
.index-row b{margin-bottom:12px!important;display:block}
.divider{margin:42px 0!important}
.section,.paper{padding-top:88px!important;padding-bottom:88px!important}
.section-narrow{padding-top:76px!important;padding-bottom:76px!important}

/* Home first screen: make the picture clearly visible on the right while keeping text safe. */
.home-hero{
  min-height:82vh!important;
}
.home-hero:before{
  background:url('images/home.webp') center right/cover no-repeat!important;
  filter:saturate(.95) brightness(1.02) contrast(.98)!important;
  opacity:1!important;
}
.home-hero:after{
  background:
    linear-gradient(90deg,rgba(7,17,29,.92) 0%,rgba(7,17,29,.82) 36%,rgba(7,17,29,.46) 62%,rgba(7,17,29,.08) 100%),
    radial-gradient(circle at 78% 42%,rgba(203,180,122,.10),transparent 36%)!important;
}
.home-hero .hero-inner{
  padding-top:104px!important;
  padding-bottom:86px!important;
}
.home-hero p{
  max-width:700px!important;
  color:#f3ecdf!important;
  font-size:18px!important;
  line-height:1.86!important;
}
.home-hero .trust-line{font-size:17px!important;color:#e0c987!important;margin:8px 0 18px!important}
.home-hero .region-line{font-size:12.5px!important;color:#d0c098!important;margin-top:20px!important}

@media(max-width:900px){
  .hero h1{font-size:36px!important;line-height:1.14!important}
  .page-hero h1{font-size:34px!important;line-height:1.16!important}
  .section h2,.section-narrow h2,.paper h2{font-size:29px!important;line-height:1.3!important}
  .program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:23px!important;line-height:1.36!important}
  .body-text,.lead{font-size:16.8px!important;line-height:1.82!important}
  .index-row p,.program-item p,.article-list p,.split-item p,.paper p,.section p{font-size:16.3px!important;line-height:1.8!important}
  .section,.paper{padding-top:60px!important;padding-bottom:60px!important}
  .section-narrow{padding-top:56px!important;padding-bottom:56px!important}
  .home-hero{min-height:auto!important}
  .home-hero:before{background-position:center!important;filter:saturate(.88) brightness(.80)!important}
  .home-hero:after{background:linear-gradient(180deg,rgba(7,17,29,.88),rgba(7,17,29,.72) 62%,rgba(7,17,29,.52))!important}
  .home-hero .hero-inner{padding-top:78px!important;padding-bottom:64px!important}
  .home-hero p{font-size:16px!important;line-height:1.78!important;max-width:100%!important}
}

/* V6.15 Conservative typography adjustment
   User note: previous reference screenshot was zoomed; reduce section and subsection titles further. */
:root{
  --heading-weight:480;
  --text-weight:340;
}
body{font-weight:var(--text-weight)}
h1,h2,h3,.hero h1,.page-hero h1,.section h2,.section-narrow h2,.paper h2{font-weight:var(--heading-weight)!important}
.hero h1{
  font-size:clamp(34px,3.55vw,50px)!important;
  line-height:1.12!important;
  letter-spacing:-.03em!important;
  max-width:760px!important;
}
.page-hero h1{
  font-size:clamp(30px,3.2vw,44px)!important;
  line-height:1.15!important;
  letter-spacing:-.026em!important;
  max-width:860px!important;
}
.section h2,.section-narrow h2,.paper h2{
  font-size:clamp(24px,2.25vw,32px)!important;
  line-height:1.32!important;
  letter-spacing:-.018em!important;
  margin-bottom:16px!important;
}
.program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{
  font-size:clamp(19px,1.65vw,24px)!important;
  line-height:1.42!important;
  letter-spacing:-.006em!important;
  font-weight:500!important;
}
.section-label,.breadcrumb,.eyebrow{
  font-size:10.5px!important;
  letter-spacing:.16em!important;
  line-height:1.35!important;
  margin-bottom:12px!important;
  opacity:.68!important;
}
.body-text,.lead{
  font-size:17px!important;
  line-height:1.88!important;
}
.index-row p,.program-item p,.article-list p,.split-item p,.paper p,.section p{
  font-size:16.8px!important;
  line-height:1.86!important;
}
.index-row,.split-item,.program-item{
  padding-top:24px!important;
  padding-bottom:24px!important;
}
.section,.paper{padding-top:76px!important;padding-bottom:76px!important}
.section-narrow{padding-top:66px!important;padding-bottom:66px!important}
.divider{margin:34px 0!important}
.home-hero p{font-size:17px!important;line-height:1.82!important;max-width:720px!important}
.home-hero .trust-line{font-size:15.5px!important}
@media(max-width:900px){
  .hero h1{font-size:31px!important;line-height:1.16!important}
  .page-hero h1{font-size:28px!important;line-height:1.18!important}
  .section h2,.section-narrow h2,.paper h2{font-size:24px!important;line-height:1.34!important}
  .program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:19px!important;line-height:1.42!important}
  .body-text,.lead{font-size:16px!important;line-height:1.78!important}
  .index-row p,.program-item p,.article-list p,.split-item p,.paper p,.section p{font-size:15.8px!important;line-height:1.76!important}
  .section,.paper{padding-top:52px!important;padding-bottom:52px!important}
  .section-narrow{padding-top:48px!important;padding-bottom:48px!important}
}

/* V6.16 Wide Reading + No-Oversized Headings
   Goal: full-screen desktop sections should read like a calm editorial page:
   headings fit naturally on one line when possible, body remains readable. */
:root{
  --max:1160px;
  --wide:1240px;
  --heading-weight:470;
  --text-weight:340;
}
.container{max-width:var(--max)!important}
.section-narrow .container{max-width:var(--max)!important}
.page-hero .container{max-width:var(--max)!important}
body{font-weight:var(--text-weight);letter-spacing:.002em}

/* Desktop hierarchy: reduce oversized chapter/subsection titles. */
.hero h1{
  font-size:clamp(33px,3.25vw,48px)!important;
  line-height:1.14!important;
  font-weight:470!important;
  letter-spacing:-.025em!important;
  max-width:760px!important;
}
.page-hero h1{
  font-size:clamp(30px,2.65vw,40px)!important;
  line-height:1.18!important;
  font-weight:470!important;
  letter-spacing:-.02em!important;
  max-width:1040px!important;
}
.section h2,.section-narrow h2,.paper h2{
  font-size:clamp(24px,2vw,30px)!important;
  line-height:1.36!important;
  font-weight:470!important;
  letter-spacing:-.012em!important;
  margin-bottom:18px!important;
  max-width:1120px!important;
}
.program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{
  font-size:clamp(18px,1.45vw,22px)!important;
  line-height:1.45!important;
  font-weight:500!important;
  letter-spacing:0!important;
}
.section-label,.breadcrumb,.eyebrow{
  font-size:10px!important;
  letter-spacing:.15em!important;
  line-height:1.35!important;
  margin-bottom:12px!important;
  opacity:.66!important;
}
.body-text,.lead{
  font-size:17px!important;
  line-height:1.88!important;
}
.index-row p,.program-item p,.article-list p,.split-item p,.paper p,.section p,.section-narrow p{
  font-size:16.8px!important;
  line-height:1.86!important;
}
.page-hero p{
  font-size:17px!important;
  line-height:1.82!important;
  max-width:980px!important;
}
.section,.paper{padding-top:68px!important;padding-bottom:68px!important}
.section-narrow{padding-top:58px!important;padding-bottom:58px!important}
.index-row,.split-item,.program-item{padding-top:22px!important;padding-bottom:22px!important}

/* Home hero image: keep picture visible without reducing text contrast. */
.home-hero{min-height:80vh!important}
.home-hero:before{filter:saturate(.94) brightness(1.03) contrast(.98)!important;background-position:center right!important}
.home-hero:after{background:linear-gradient(90deg,rgba(7,17,29,.90) 0%,rgba(7,17,29,.78) 34%,rgba(7,17,29,.44) 62%,rgba(7,17,29,.08) 100%)!important}
.home-hero p{font-size:16.8px!important;line-height:1.82!important;max-width:720px!important}
.home-hero .trust-line{font-size:15.5px!important}
.home-hero .region-line{font-size:12px!important;letter-spacing:.14em!important}

@media(max-width:900px){
  :root{--max:100%}
  .hero h1{font-size:30px!important;line-height:1.18!important}
  .page-hero h1{font-size:27px!important;line-height:1.22!important}
  .section h2,.section-narrow h2,.paper h2{font-size:23px!important;line-height:1.4!important}
  .program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:18px!important;line-height:1.48!important}
  .body-text,.lead{font-size:15.8px!important;line-height:1.78!important}
  .index-row p,.program-item p,.article-list p,.split-item p,.paper p,.section p,.section-narrow p{font-size:15.8px!important;line-height:1.78!important}
  .section,.paper{padding-top:50px!important;padding-bottom:50px!important}
  .section-narrow{padding-top:46px!important;padding-bottom:46px!important}
  .home-hero{min-height:auto!important}
}

/* V6.17 Editorial Column Density
   Keep headings wide enough to avoid awkward wraps, but constrain body copy so pages do not look thin after widening. */
:root{
  --max:1120px;
  --wide:1240px;
  --textcol:860px;
  --headingcol:1040px;
}
.container{max-width:var(--max)!important}

/* Headings may use a wider line, but paragraphs return to a comfortable reading column. */
.section h2,.section-narrow h2,.paper h2,.page-hero h1{
  max-width:var(--headingcol)!important;
}
.lead,.body-text,.page-hero p,
.section p,.section-narrow p,.paper p{
  max-width:var(--textcol);
}
.body-text > p,.lead{max-width:var(--textcol)}

/* Editorial blocks: title + summary should feel like a compact reading card, not a full-width empty row. */
.index-row,.split-item,.program-item,.article-list a{
  max-width:920px;
}
.index-list,.split-list,.program-list,.article-list,.summary-table{
  max-width:920px;
}
.index-row p,.split-item p,.program-item p,.article-list p{
  max-width:840px;
}

/* Slightly tighten oversized vertical air after going back to a narrower reading column. */
.section,.paper{padding-top:62px!important;padding-bottom:62px!important}
.section-narrow{padding-top:54px!important;padding-bottom:54px!important}
.index-row,.split-item,.program-item{padding-top:20px!important;padding-bottom:20px!important}
.divider{margin:30px 0!important}

/* Body copy: a touch denser and calmer. */
.body-text,.lead{font-size:16.7px!important;line-height:1.84!important}
.index-row p,.program-item p,.article-list p,.split-item p,.paper p,.section p,.section-narrow p{
  font-size:16.5px!important;
  line-height:1.84!important;
}

/* Page hero: retain impact without leaving a wide, empty plane of text. */
.page-hero .container{max-width:1120px!important}
.page-hero h1{max-width:980px!important}
.page-hero p{max-width:860px!important}

/* Home hero is a reception desk: text column stays compact, image breathes on the right. */
.home-hero .hero-inner{max-width:1240px!important}
.home-hero h1{max-width:720px!important}
.home-hero p{max-width:680px!important}
.home-hero .actions{max-width:680px}

/* If a section needs a deliberately wide element, tables/data bars can still breathe. */
.table-wrap,.data-bar,.flow{max-width:1040px}

@media(max-width:900px){
  :root{--textcol:100%;--headingcol:100%}
  .lead,.body-text,.page-hero p,.section p,.section-narrow p,.paper p,
  .index-row,.split-item,.program-item,.article-list a,
  .index-list,.split-list,.program-list,.article-list,.summary-table{
    max-width:100%;
  }
  .section,.paper{padding-top:48px!important;padding-bottom:48px!important}
  .section-narrow{padding-top:44px!important;padding-bottom:44px!important}
}

/* V6.18 Consistent Editorial Spacing
   No page-section should behave like a separate full-screen slide.
   Use one calm reading rhythm across Home and inner pages: consistent container,
   consistent vertical padding, and stable content widths. */
:root{
  --max:1040px;
  --wide:1180px;
  --textcol:960px;
  --headingcol:1040px;
}
.container,
.section-narrow .container,
.paper .container,
.page-hero .container{
  max-width:var(--max)!important;
}
.wide{max-width:var(--wide)!important}

/* One vertical rhythm across the site. */
.section,
.paper,
.section-narrow{
  padding-top:60px!important;
  padding-bottom:60px!important;
}
.section.compact,
.compact-note{
  padding-top:42px!important;
  padding-bottom:42px!important;
}
.page-hero{
  padding-top:72px!important;
  padding-bottom:48px!important;
}
.cta-strip{
  padding-top:44px!important;
  padding-bottom:44px!important;
}

/* Headings and body copy share a stable page width; no sudden wide/narrow jumps. */
.section h2,
.section-narrow h2,
.paper h2,
.page-hero h1,
.section h3,
.section-narrow h3,
.paper h3,
.index-row b,
.split-item h3,
.program-item h3,
.article-list h3{
  max-width:var(--headingcol)!important;
}
.lead,
.body-text,
.page-hero p,
.section p,
.section-narrow p,
.paper p,
.body-text > p,
.index-row p,
.split-item p,
.program-item p,
.article-list p{
  max-width:var(--textcol)!important;
}

/* Editorial blocks now use the same width as the main reading area. */
.index-list,
.split-list,
.program-list,
.article-list,
.summary-table,
.index-row,
.split-item,
.program-item,
.article-list a,
.flow,
.table-wrap,
.data-bar,
.action-log,
.quote-panel,
.soft-panel{
  max-width:var(--max)!important;
}
.index-row,
.split-item,
.program-item,
.article-list a{
  padding-top:22px!important;
  padding-bottom:22px!important;
}
.divider{margin:30px 0!important}

/* Typography remains quiet, but prevents oversized rows from behaving like slide screens. */
.page-hero h1{
  font-size:clamp(28px,2.45vw,38px)!important;
  line-height:1.22!important;
}
.section h2,
.section-narrow h2,
.paper h2{
  font-size:clamp(23px,1.9vw,29px)!important;
  line-height:1.38!important;
  margin-bottom:16px!important;
}
.program-item h3,
.article-list h3,
.index-row b,
.split-item h3,
.section h3,
.section-narrow h3,
.paper h3{
  font-size:clamp(18px,1.35vw,21px)!important;
  line-height:1.46!important;
}
.body-text,
.lead{
  font-size:16.5px!important;
  line-height:1.82!important;
}
.index-row p,
.program-item p,
.article-list p,
.split-item p,
.paper p,
.section p,
.section-narrow p{
  font-size:16.3px!important;
  line-height:1.82!important;
}
.section-label{
  margin-bottom:10px!important;
}

/* Home keeps a distinct reception hero, but sections below follow the same editorial rhythm. */
.home-hero{min-height:74vh!important}
.home-hero .hero-inner{max-width:var(--wide)!important;padding-top:92px!important;padding-bottom:74px!important}
.home-hero h1{max-width:720px!important}
.home-hero p,.home-hero .actions{max-width:700px!important}
.home-hero + .section,
.home-hero + .section-narrow,
.home-hero + .paper{
  padding-top:60px!important;
}

@media(max-width:900px){
  :root{--max:100%;--wide:100%;--textcol:100%;--headingcol:100%}
  .section,.paper,.section-narrow{padding-top:46px!important;padding-bottom:46px!important}
  .section.compact,.compact-note{padding-top:34px!important;padding-bottom:34px!important}
  .page-hero{padding-top:56px!important;padding-bottom:38px!important}
  .cta-strip{padding-top:36px!important;padding-bottom:36px!important}
  .page-hero h1{font-size:26px!important;line-height:1.24!important}
  .section h2,.section-narrow h2,.paper h2{font-size:22px!important;line-height:1.42!important}
  .program-item h3,.article-list h3,.index-row b,.split-item h3,.section h3,.section-narrow h3,.paper h3{font-size:18px!important;line-height:1.46!important}
  .body-text,.lead,.index-row p,.program-item p,.article-list p,.split-item p,.paper p,.section p,.section-narrow p{font-size:15.7px!important;line-height:1.76!important}
  .home-hero{min-height:auto!important}
  .home-hero .hero-inner{padding-top:74px!important;padding-bottom:54px!important}
}

/* V6.19 — tighter editorial spacing
   The site now reads as a continuous editorial page, not as separate full-screen slides. */
.section,
.section-narrow,
.paper{
  padding-top:42px!important;
  padding-bottom:42px!important;
}
.section.compact,
.compact-note{
  padding-top:30px!important;
  padding-bottom:30px!important;
}
.page-hero{
  padding-top:54px!important;
  padding-bottom:34px!important;
}
.cta-strip{
  padding-top:44px!important;
  padding-bottom:44px!important;
}
.program-item,
.article-list a,
.index-row,
.split-item{
  padding-top:16px!important;
  padding-bottom:16px!important;
}
.program-item + .program-item,
.split-item + .split-item{
  margin-top:0!important;
}
.article-list,
.index-list,
.plain-list{
  margin-top:18px!important;
}
.divider{
  margin:22px 0!important;
}
.section-label{
  margin-bottom:8px!important;
}
.section h2,
.section-narrow h2,
.paper h2{
  margin-bottom:12px!important;
}
.body-text p{
  margin-bottom:13px!important;
}
.soft-panel,
.quote-panel,
.form-box{
  margin-top:18px!important;
  margin-bottom:18px!important;
  padding:22px!important;
}
.flow-step{
  padding-top:16px!important;
  padding-bottom:16px!important;
}
.home-hero + .section,
.home-hero + .section-narrow,
.home-hero + .paper{
  padding-top:46px!important;
}
@media(max-width:900px){
  .section,
  .section-narrow,
  .paper{
    padding-top:34px!important;
    padding-bottom:34px!important;
  }
  .page-hero{
    padding-top:46px!important;
    padding-bottom:30px!important;
  }
  .cta-strip{
    padding-top:34px!important;
    padding-bottom:34px!important;
  }
  .program-item,
  .article-list a,
  .index-row,
  .split-item{
    padding-top:14px!important;
    padding-bottom:14px!important;
  }
}

/* V6.20 Case + CTA + Home Refinement */
:root{
  --max:900px;
  --wide:1080px;
}
.container{max-width:900px}
.section-narrow .container{max-width:790px}
.page-hero .container{max-width:900px}
.body-text{max-width:790px}
.paper .body-text,.section .body-text,.section-narrow .body-text{max-width:790px}
.article-list,.program-list,.index-list,.action-log{max-width:860px}

/* Navigation CTA: understated text button, not a box */
.nav{gap:22px}
.nav-links{gap:18px}
.nav-cta{
  padding:0!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  color:#d7bd7a!important;
  font-size:13px!important;
  letter-spacing:.02em!important;
  border-bottom:1px solid rgba(215,189,122,.36)!important;
  line-height:1.45!important;
}
.nav-cta:hover{color:#f0d99b!important;border-bottom-color:#f0d99b!important}

/* Buttons: smaller, tighter, less banner-like */
.btn{
  padding:7px 12px!important;
  min-width:0!important;
  min-height:0!important;
  border-radius:2px!important;
  font-size:12.5px!important;
  line-height:1.25!important;
  font-weight:520!important;
  letter-spacing:.01em!important;
}
.hero .btn,.cta-strip .btn,.page-hero .btn{padding:8px 12px!important;font-size:12.5px!important}
.actions{gap:8px!important;margin-top:20px!important}
.cta-strip .actions{margin-top:0!important;flex-shrink:0}

/* Home hero: reduce repeated brand feeling by making eyebrow quieter */
.home-hero .eyebrow{opacity:.82;letter-spacing:.20em;font-size:11px!important}
.home-hero h1{max-width:760px}
.home-hero p{max-width:760px}
.home-hero .trust-line{font-size:15px;letter-spacing:.04em;color:#e7cf91;margin-top:-8px}

/* Slightly narrower editorial rhythm */
.section,.section-narrow,.paper{padding-left:26px;padding-right:26px}
@media(max-width:900px){
  :root{--max:100%;--wide:100%}
  .container,.section-narrow .container,.page-hero .container,.body-text,.article-list,.program-list,.index-list,.action-log{max-width:100%}
  .nav-cta{border-bottom:0!important;color:#d7bd7a!important}
  .btn{padding:8px 12px!important;font-size:13px!important}
}


/* V6.21 Home hero wording and brand scale */
.home-hero .hero-brand-word{
  font-family: Inter, Arial, sans-serif;
  font-size: clamp(34px, 5.2vw, 70px);
  line-height: .95;
  letter-spacing: .10em;
  font-weight: 560;
  color: #f4efe6;
  margin: 0 0 22px;
  text-transform: uppercase;
}
.home-hero h1{
  font-size: clamp(28px, 2.55vw, 40px)!important;
  line-height: 1.22!important;
  letter-spacing: -.025em!important;
  margin-bottom: 12px!important;
}
.home-hero .trust-line{
  font-size: clamp(15px, 1.25vw, 18px)!important;
  line-height: 1.55!important;
  color: #e5c77e!important;
  letter-spacing: .035em!important;
  margin: 0 0 20px!important;
}
.home-hero .anchor-line{
  font-size: 12.5px!important;
  letter-spacing: .13em!important;
  color: #d8bf7a!important;
  margin-top: 24px!important;
}
.home-hero .region-line{
  font-size: 12px!important;
  letter-spacing: .18em!important;
  color: #d8d0c0!important;
  margin-top: 12px!important;
}
@media(max-width:700px){
  .home-hero .hero-brand-word{font-size:42px;letter-spacing:.08em;margin-bottom:18px}
  .home-hero h1{font-size:28px!important}
}


/* V6.22 next-step reading links */
.next-steps{background:var(--paper);color:var(--paperInk);border-top:1px solid rgba(17,25,39,.10);border-bottom:1px solid rgba(17,25,39,.10);padding:34px 28px 38px}
.next-steps .container{max-width:820px}
.next-steps h2{font-size:22px!important;line-height:1.35!important;font-weight:460!important;letter-spacing:-.015em!important;margin:0 0 18px;color:var(--paperInk)}
.next-links{display:flex;flex-wrap:wrap;gap:10px 18px;border-top:1px solid rgba(17,25,39,.12);padding-top:18px}
.next-links a{display:inline-flex;align-items:center;gap:7px;color:#73551b;font-size:14px;line-height:1.5;border-bottom:1px solid rgba(115,85,27,.25);padding-bottom:2px}
.next-links a em{font-style:normal;font-size:13px;transition:transform .16s ease}
.next-links a:hover em{transform:translateX(2px)}
.next-links a:hover{color:#4f3b13;border-bottom-color:rgba(79,59,19,.55)}
@media(max-width:900px){.next-steps{padding:28px 22px 32px}.next-steps h2{font-size:20px!important}.next-links{display:block}.next-links a{display:flex;width:max-content;max-width:100%;margin:0 0 10px}}

/* V6.23 Desktop body readability refinement
   Full-screen desktop review showed body copy was too small and tiring to read.
   Keep heading/container system unchanged; only lift readable content one step. */
@media (min-width:901px){
  body{font-size:17px;}
  .body-text,
  .section p,
  .section-narrow p,
  .paper p,
  .page-hero p,
  .program-item p,
  .index-row p,
  .article-list p,
  .split-item p,
  .flow-step p,
  .plain-list li,
  .action-log li,
  td{
    font-size:18px;
    line-height:1.86;
  }
  .lead{font-size:19.5px;line-height:1.78;}
  .hero p{font-size:19px;line-height:1.82;}
  .note,.warning,.inline-note{font-size:14px;line-height:1.75;}
  .text-link,.mini-link{font-size:15px;}
  th{font-size:13.5px;}
  .legal-small{font-size:12px;line-height:1.72;}
  .footer-grid a{font-size:13.5px;}
}

/* V6.24 Body Fine Readability
   User request: keep titles / section markers / subsection titles unchanged;
   only lift Chinese body copy slightly and make the smallest text less tiring. */
@media (min-width:901px){
  body{font-size:17.5px;}
  .body-text,
  .section p,
  .section-narrow p,
  .paper p,
  .page-hero p,
  .program-item p,
  .index-row p,
  .article-list p,
  .split-item p,
  .flow-step p,
  .plain-list li,
  .action-log li,
  td{
    font-size:19px!important;
    line-height:1.88!important;
  }
  .lead{
    font-size:20px!important;
    line-height:1.8!important;
  }
  .hero p{
    font-size:19.5px!important;
    line-height:1.84!important;
  }
  .note,
  .warning,
  .inline-note,
  .compact-note p,
  .program-item .program-meta,
  .case-meta{
    font-size:15px!important;
    line-height:1.78!important;
  }
  .legal-small{
    font-size:13.5px!important;
    line-height:1.78!important;
  }
  .footer-grid a,
  .footer-links,
  .next-links a,
  .mini-link,
  .text-link{
    font-size:15px!important;
    line-height:1.72!important;
  }
  th{
    font-size:14px!important;
  }
  input,select,textarea{
    font-size:16.5px!important;
  }
}

@media (max-width:900px){
  .body-text,
  .lead,
  .section p,
  .section-narrow p,
  .paper p,
  .page-hero p,
  .program-item p,
  .index-row p,
  .article-list p,
  .split-item p,
  .flow-step p,
  .plain-list li,
  .action-log li,
  td{
    font-size:16.3px!important;
    line-height:1.8!important;
  }
  .note,
  .warning,
  .inline-note,
  .legal-small,
  .footer-grid a,
  .next-links a,
  .mini-link{
    font-size:13.8px!important;
    line-height:1.72!important;
  }
}

/* V6.34 readability refinements */
.paper .data-bar b{color:#17202b!important;}
.paper .data-bar span{color:#4a5360!important;}
.paper .data-bar{border-color:rgba(23,32,43,.18)!important;}

/* V6.35 Home OPEN and resource coordination refinements */
.home-hero .hero-brand-word{
  font-size:clamp(30px,4.15vw,56px)!important;
  line-height:1!important;
  letter-spacing:.095em!important;
  font-weight:520!important;
  margin-bottom:18px!important;
}
.home-hero h1{
  font-size:clamp(32px,3.15vw,46px)!important;
  line-height:1.18!important;
  letter-spacing:-.018em!important;
  margin-bottom:10px!important;
}
.home-hero .trust-line{
  font-size:clamp(15px,1.25vw,18px)!important;
  line-height:1.5!important;
  margin:0 0 20px!important;
}
.home-hero .anchor-line{
  display:block!important;
  margin-top:34px!important;
  line-height:1.85!important;
  letter-spacing:.13em!important;
}
.home-hero .region-line{
  margin-top:14px!important;
  letter-spacing:.18em!important;
}
.home-hero .hero-inner{
  padding-top:92px!important;
  padding-bottom:82px!important;
}
@media(max-width:700px){
  .home-hero .hero-brand-word{font-size:38px!important;letter-spacing:.08em!important;margin-bottom:16px!important;}
  .home-hero h1{font-size:30px!important;}
  .home-hero .anchor-line{margin-top:28px!important;}
}


/* V6.36 Contact, language switch and form submission */
.lang-switch{display:inline-flex;align-items:center;gap:8px;margin-left:8px;font-size:12px;color:var(--gold);white-space:nowrap}
.lang-switch a,.lang-switch span{font-size:12px;color:var(--gold);letter-spacing:.06em}
.lang-current{opacity:.55}
.contact-form-box h3{margin-top:0}
.contact-options{display:grid;grid-template-columns:1fr 150px;gap:22px;align-items:start;margin-top:22px;padding-top:20px;border-top:1px solid rgba(23,32,43,.12)}
.contact-options h4{margin:0 0 8px;font-size:16px;color:var(--paperInk)}
.contact-options a{color:#8e6f2e;border-bottom:1px solid rgba(142,111,46,.35)}
.qr-card{background:#fff;border:1px solid rgba(23,32,43,.12);border-radius:12px;padding:12px;text-align:center;box-shadow:0 8px 22px rgba(7,17,29,.05)}
.qr-card img{display:block;width:126px;height:126px;object-fit:cover;margin:0 auto 8px}
.qr-card p{margin:0;font-size:13px;color:var(--paperMuted)}
.form-status{font-size:13px;color:#8e6f2e;margin:12px 0 0;min-height:1.2em}
.form-status.error{color:#9d3b2c}
.home-hero .anchor-line{white-space:nowrap;font-size:clamp(11px,1.05vw,13px)}
@media(max-width:900px){.contact-options{grid-template-columns:1fr}.qr-card{max-width:160px}.home-hero .anchor-line{white-space:normal}}


/* V6.41 launch polish: keep budget figures informative rather than sales-led. */
.index-row p strong,.program-meta strong{font-weight:520;color:inherit;letter-spacing:0;}
.program-meta{font-size:15px;color:#5f6670;}
.contact-options .note{font-size:15px!important;color:#47515f!important;line-height:1.75!important;}
.contact-options .note a{color:#8e6f2e;border-bottom:1px solid rgba(142,111,46,.35);}

/* V6.50 footer image update: Hong Kong blue-hour footer with readable overlay. */
.site-footer{
  background-image:url('images/footer.webp')!important;
  background-position:center center!important;
  background-size:cover!important;
  background-repeat:no-repeat!important;
}
.site-footer:before{
  background:
    linear-gradient(90deg,rgba(5,11,19,.94) 0%,rgba(5,11,19,.86) 40%,rgba(5,11,19,.70) 72%,rgba(5,11,19,.62) 100%),
    linear-gradient(180deg,rgba(5,11,19,.56) 0%,rgba(5,11,19,.84) 64%,rgba(5,11,19,.96) 100%)!important;
}
@media(max-width:700px){
  .site-footer{
    background-image:url('images/footer-mobile.webp')!important;
    background-position:center top!important;
  }
  .site-footer:before{
    background:linear-gradient(180deg,rgba(5,11,19,.84),rgba(5,11,19,.97))!important;
  }
}
