/* =========================================================
   ANTTI PETTERI ORPO — PREMIUM NORDIC EXECUTIVE SITE
   Scandinavian minimal · Editorial · Statesman grade
   ========================================================= */

:root{
  --navy-900:#0A1628;
  --navy-800:#0F1E38;
  --navy-700:#142748;
  --navy-600:#1D3361;
  --ice-100:#F4F8FC;
  --ice-200:#E8EEF6;
  --ice-300:#D5E4F1;
  --ice-400:#B9CDE3;
  --slate-500:#64748B;
  --slate-600:#475569;
  --slate-700:#334155;
  --silver:#C7CDD4;
  --silver-2:#9CA4B0;
  --white:#FFFFFF;
  --black:#05070B;
  --accent:#BFA06A;         /* warm silver-gold for regal trim */
  --accent-2:#6F8CAE;       /* muted Nordic blue */
  --line:rgba(10,22,40,.08);
  --line-strong:rgba(10,22,40,.16);

  --serif:"Playfair Display","Cormorant Garamond",Georgia,serif;
  --sans:"Inter","Manrope","Helvetica Neue",Arial,sans-serif;

  --shadow-sm:0 2px 10px rgba(10,22,40,.06);
  --shadow-md:0 18px 40px -20px rgba(10,22,40,.25);
  --shadow-lg:0 40px 80px -30px rgba(10,22,40,.35);

  --radius-sm:4px;
  --radius-md:10px;
  --radius-lg:18px;

  --container:1320px;
  --gutter:28px;

  --ease:cubic-bezier(.2,.8,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--navy-900);
  background:var(--white);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
svg{display:block}

h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:500;
  letter-spacing:-.01em;
  color:var(--navy-900);
  margin:0 0 .4em;
  line-height:1.12;
}
h1{font-size:clamp(2.4rem,5.4vw,5.25rem);letter-spacing:-.025em}
h2{font-size:clamp(1.8rem,3.4vw,3.15rem);letter-spacing:-.02em}
h3{font-size:clamp(1.25rem,1.8vw,1.75rem)}
h4{font-size:1.125rem;font-family:var(--sans);font-weight:600;letter-spacing:.02em;text-transform:uppercase}
p{margin:0 0 1em}

/* ---------- Utilities ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--sans);font-size:.72rem;font-weight:600;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--slate-600);
}
.eyebrow::before{
  content:"";width:28px;height:1px;background:var(--accent);
}
.eyebrow--light{color:var(--ice-300)}
.eyebrow--light::before{background:var(--accent)}

.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1rem 1.9rem;font-size:.78rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  border-radius:999px;transition:all .4s var(--ease);
  border:1px solid transparent;cursor:pointer;white-space:nowrap;
}
.btn--primary{background:var(--navy-900);color:var(--white)}
.btn--primary:hover{background:var(--accent);color:var(--navy-900);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--navy-900);border-color:var(--navy-900)}
.btn--ghost:hover{background:var(--navy-900);color:var(--white)}
.btn--light{background:var(--white);color:var(--navy-900)}
.btn--light:hover{background:var(--accent);color:var(--navy-900)}
.btn--outline-light{border:1px solid rgba(255,255,255,.35);color:var(--white);background:transparent}
.btn--outline-light:hover{background:var(--white);color:var(--navy-900)}
.btn .arrow{width:14px;height:14px;transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

section{padding:clamp(4rem,8vw,8rem) 0;position:relative}
.section--dark{background:var(--navy-900);color:var(--ice-200)}
.section--dark h1,.section--dark h2,.section--dark h3{color:var(--white)}
.section--ice{background:var(--ice-100)}

.split-rule{
  display:block;height:1px;width:64px;background:var(--accent);margin:1rem 0 1.5rem;
}

/* ---------- Top bar ---------- */
.topbar{
  background:var(--navy-900);color:var(--ice-300);
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  padding:.55rem 0;
}
.topbar__row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.topbar__left{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}
.topbar__left span::before{content:"·";color:var(--accent);margin-right:.9rem}
.topbar__left span:first-child::before{display:none}
.topbar__right{display:flex;gap:1.2rem}
.topbar__right a{opacity:.72;transition:opacity .3s}
.topbar__right a:hover{opacity:1;color:var(--accent)}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid var(--line);
  transition:all .35s var(--ease);
}
.site-header.is-scrolled{background:rgba(255,255,255,.96);box-shadow:var(--shadow-sm)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 0;gap:2rem;
}
.brand{
  display:flex;align-items:center;gap:.9rem;
  font-family:var(--serif);font-size:1.15rem;color:var(--navy-900);
  letter-spacing:.01em;
}
.brand__crest{
  width:42px;height:42px;border-radius:50%;
  background:var(--navy-900);color:var(--white);
  display:grid;place-items:center;
  font-family:var(--serif);font-size:1.05rem;letter-spacing:.02em;
  border:1px solid var(--accent);
  position:relative;
}
.brand__crest::after{
  content:"";position:absolute;inset:-5px;border-radius:50%;
  border:1px solid var(--line);
}
.brand__name{font-weight:500;line-height:1.1}
.brand__name small{
  display:block;font-family:var(--sans);font-size:.62rem;
  letter-spacing:.3em;text-transform:uppercase;color:var(--slate-500);
  margin-top:3px;
}
.nav__menu{display:flex;gap:2rem;list-style:none;padding:0;margin:0}
.nav__menu a{
  position:relative;font-size:.78rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;color:var(--navy-900);
  padding:.4rem 0;
}
.nav__menu a::after{
  content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--accent);
  transition:width .4s var(--ease);
}
.nav__menu a:hover::after,.nav__menu a.is-active::after{width:100%}
.nav__menu a.is-active{color:var(--navy-900)}
.nav__cta{display:flex;align-items:center;gap:.8rem}
.nav__toggle{
  display:none;width:40px;height:40px;border:1px solid var(--line-strong);
  border-radius:50%;align-items:center;justify-content:center;
}
.nav__toggle span{
  width:16px;height:1px;background:var(--navy-900);position:relative;
}
.nav__toggle span::before,.nav__toggle span::after{
  content:"";position:absolute;left:0;width:16px;height:1px;background:var(--navy-900);
}
.nav__toggle span::before{top:-5px}
.nav__toggle span::after{top:5px}

@media (max-width:980px){
  .nav__menu{
    position:fixed;inset:76px 0 auto 0;background:var(--white);
    flex-direction:column;align-items:flex-start;gap:0;
    padding:1rem 1.5rem 2rem;border-bottom:1px solid var(--line);
    transform:translateY(-110%);transition:transform .5s var(--ease);
    box-shadow:var(--shadow-md);
  }
  .nav__menu.is-open{transform:translateY(0)}
  .nav__menu li{width:100%;border-bottom:1px solid var(--line)}
  .nav__menu a{display:block;padding:1rem 0;font-size:.85rem}
  .nav__toggle{display:flex}
  .nav__cta .btn{display:none}
}

/* ========================================================
   PASSCODE GATE
   ======================================================== */
.gate{
  min-height:100vh;position:relative;overflow:hidden;
  background:#05070B;color:var(--white);
  display:grid;place-items:center;
  font-family:var(--sans);
}
.gate__bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(111,140,174,.3), transparent 60%),
    radial-gradient(900px 500px at 10% 100%, rgba(191,160,106,.18), transparent 60%),
    linear-gradient(180deg,#050912 0%, #0A1628 60%, #0E1A31 100%);
}
.gate__aurora{
  position:absolute;inset:0;z-index:1;opacity:.55;
  background:
    radial-gradient(ellipse 800px 300px at 50% 10%, rgba(100,180,200,.35), transparent 70%),
    radial-gradient(ellipse 600px 240px at 30% 30%, rgba(160,110,200,.25), transparent 70%),
    radial-gradient(ellipse 500px 180px at 75% 25%, rgba(140,200,170,.3), transparent 70%);
  filter:blur(30px);
  animation:aurora 18s var(--ease) infinite alternate;
}
@keyframes aurora{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(-30px,20px,0) scale(1.05)}
}
.gate__grid{
  position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.12;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, black 20%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, black 20%, transparent 75%);
}
.gate__stars{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,.8), transparent 60%),
    radial-gradient(1px 1px at 80% 20%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(1.5px 1.5px at 65% 70%, rgba(255,255,255,.9), transparent 60%),
    radial-gradient(1px 1px at 30% 80%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(1px 1px at 50% 50%, rgba(255,255,255,.7), transparent 60%),
    radial-gradient(1px 1px at 90% 60%, rgba(255,255,255,.5), transparent 60%);
}
.gate__skyline{
  position:absolute;left:0;right:0;bottom:0;z-index:3;height:28vh;
  background:linear-gradient(180deg,transparent 0%,rgba(5,7,11,.3) 40%,rgba(5,7,11,.95) 100%);
}
.gate__skyline svg{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:min(1600px,120%);height:100%;opacity:.85;
}

.gate__panel{
  position:relative;z-index:10;
  width:min(520px,90vw);padding:3.2rem 2.6rem;
  background:rgba(15,30,56,.55);
  backdrop-filter:blur(30px) saturate(160%);
  -webkit-backdrop-filter:blur(30px) saturate(160%);
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  box-shadow:0 40px 100px -20px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.08);
  text-align:center;
  animation:gateIn .9s var(--ease) both;
}
@keyframes gateIn{
  from{opacity:0;transform:translateY(20px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.gate__crest{
  margin:0 auto 1.8rem;width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent) 0%,#8c7547 100%);
  display:grid;place-items:center;
  font-family:var(--serif);color:var(--navy-900);font-size:1.4rem;
  box-shadow:0 0 0 1px rgba(255,255,255,.25),0 12px 40px -10px rgba(191,160,106,.6);
  position:relative;
}
.gate__crest::after{
  content:"";position:absolute;inset:-10px;border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
}
.gate__panel .eyebrow{color:var(--ice-300);justify-content:center;display:flex;margin-bottom:.8rem}
.gate__panel .eyebrow::before{background:var(--accent)}
.gate__title{
  font-family:var(--serif);color:var(--white);font-size:2rem;
  margin:0 0 .7rem;line-height:1.2;
}
.gate__subtitle{
  color:var(--ice-300);font-size:.92rem;margin:0 0 2rem;
  letter-spacing:.01em;
}
.gate__form{display:flex;flex-direction:column;gap:1rem}
.gate__input-wrap{
  position:relative;
}
.gate__input{
  width:100%;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.15);
  border-radius:12px;color:var(--white);
  font-family:var(--sans);font-size:1rem;letter-spacing:.25em;
  padding:1.15rem 1.25rem;text-align:center;
  transition:all .3s var(--ease);
}
.gate__input::placeholder{color:rgba(255,255,255,.35);letter-spacing:.2em;font-size:.82rem;text-transform:uppercase}
.gate__input:focus{
  outline:none;background:rgba(255,255,255,.1);
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(191,160,106,.18);
}
.gate__label{
  display:block;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ice-300);margin-bottom:.6rem;
}
.gate__btn{
  padding:1.1rem 1.6rem;background:var(--white);color:var(--navy-900);
  border-radius:12px;font-size:.78rem;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  transition:all .35s var(--ease);
}
.gate__btn:hover{background:var(--accent);transform:translateY(-2px)}
.gate__error{
  min-height:20px;font-size:.78rem;color:#ff9aa2;letter-spacing:.08em;
  margin-top:.2rem;opacity:0;transform:translateY(-4px);
  transition:all .3s var(--ease);
}
.gate__error.is-visible{opacity:1;transform:translateY(0);animation:shake .4s var(--ease)}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-6px)}
  75%{transform:translateX(6px)}
}
.gate__foot{
  margin-top:2rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.45);
}
.gate__flag{
  display:inline-flex;align-items:center;gap:.5rem;
}
.gate__flag-ico{
  width:22px;height:14px;background:#fff;position:relative;border-radius:1px;
  overflow:hidden;border:1px solid rgba(255,255,255,.4);
}
.gate__flag-ico::before,.gate__flag-ico::after{
  content:"";position:absolute;background:#003580;
}
.gate__flag-ico::before{left:6px;top:0;bottom:0;width:3px}
.gate__flag-ico::after{left:0;right:0;top:5px;height:3px}

.gate__success{position:fixed;inset:0;background:var(--navy-900);z-index:50;opacity:0;pointer-events:none;transition:opacity .7s var(--ease)}
.gate__success.is-active{opacity:1;pointer-events:auto}

/* ========================================================
   HERO (Home)
   ======================================================== */
.hero{
  position:relative;min-height:92vh;color:var(--white);
  background:var(--navy-900);overflow:hidden;
  padding:0;
}
.hero__media{
  position:absolute;inset:0;z-index:0;
}
.hero__media img{
  width:100%;height:100%;object-fit:cover;object-position:center 22%;
  filter:saturate(.92) contrast(1.05);
}
.hero__overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(10,22,40,.2) 0%, rgba(10,22,40,.55) 55%, rgba(10,22,40,.92) 100%),
    linear-gradient(90deg, rgba(10,22,40,.85) 0%, rgba(10,22,40,.35) 50%, rgba(10,22,40,.1) 100%);
}
.hero__grid{
  position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.08;
  background-image:
    linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:140px 140px;
}
.hero__content{
  position:relative;z-index:3;min-height:92vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:8rem 0 4rem;
}
.hero__tag{
  display:inline-flex;align-items:center;gap:.9rem;margin-bottom:1.3rem;
  font-family:var(--sans);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ice-300);
}
.hero__tag-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(191,160,106,.25)}
.hero__title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(2.8rem,7vw,6.5rem);line-height:1.04;letter-spacing:-.02em;
  color:var(--white);margin:0 0 1.4rem;max-width:15ch;
}
.hero__title em{font-style:italic;color:var(--accent);font-weight:400}
.hero__sub{
  max-width:60ch;color:var(--ice-300);font-size:1.1rem;line-height:1.7;
  margin:0 0 2rem;
}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}

.hero__meta{
  position:absolute;z-index:4;right:var(--gutter);bottom:3.5rem;
  display:flex;flex-direction:column;gap:1rem;align-items:flex-end;
  color:var(--ice-300);font-family:var(--sans);font-size:.72rem;
  letter-spacing:.2em;text-transform:uppercase;text-align:right;
}
.hero__meta-line{display:flex;align-items:center;gap:.8rem}
.hero__meta-line::before{content:"";width:40px;height:1px;background:var(--accent)}

.hero__scroll{
  position:absolute;left:var(--gutter);bottom:2rem;z-index:4;
  display:flex;align-items:center;gap:.8rem;color:var(--ice-300);
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
}
.hero__scroll-line{width:1px;height:38px;background:linear-gradient(180deg,transparent,var(--accent))}

.hero__stats{
  position:relative;margin-top:-4rem;z-index:5;
}
.hero__stats-inner{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--white);box-shadow:var(--shadow-lg);border-radius:var(--radius-lg);
  overflow:hidden;
}
.hero__stat{
  padding:2rem 1.8rem;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:.4rem;
}
.hero__stat:last-child{border-right:none}
.hero__stat-num{
  font-family:var(--serif);font-size:clamp(2rem,3.5vw,3rem);
  color:var(--navy-900);line-height:1;letter-spacing:-.02em;
}
.hero__stat-num sup{font-size:.5em;vertical-align:super;color:var(--accent);margin-left:.1em}
.hero__stat-label{
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--slate-500);
}

@media(max-width:820px){
  .hero__stats-inner{grid-template-columns:repeat(2,1fr)}
  .hero__stat{border-bottom:1px solid var(--line)}
  .hero__stat:nth-child(odd){border-right:1px solid var(--line)}
  .hero__stat:nth-child(2n){border-right:none}
  .hero__meta,.hero__scroll{display:none}
  .hero__content{padding:7rem 0 6rem}
}

/* ========================================================
   PAGE HEADERS (non-home)
   ======================================================== */
.pagehead{
  position:relative;min-height:60vh;color:var(--white);overflow:hidden;
  background:var(--navy-900);
}
.pagehead__media{position:absolute;inset:0;z-index:0}
.pagehead__media img{width:100%;height:100%;object-fit:cover;object-position:center 25%;filter:saturate(.9)}
.pagehead__overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(10,22,40,.55) 0%, rgba(10,22,40,.85) 100%);
}
.pagehead__inner{position:relative;z-index:2;min-height:60vh;display:flex;flex-direction:column;justify-content:flex-end;padding:8rem 0 3.5rem}
.pagehead__title{color:var(--white);font-family:var(--serif);font-weight:400;margin:0;line-height:1.05}
.pagehead__sub{color:var(--ice-300);max-width:62ch;margin-top:1.1rem;font-size:1.05rem;line-height:1.7}
.breadcrumbs{
  display:flex;gap:.6rem;align-items:center;
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ice-300);margin-bottom:1.2rem;
}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs span{opacity:.5}

/* ========================================================
   COMMON SECTIONS
   ======================================================== */

/* ----- Section header ----- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:3rem;flex-wrap:wrap}
.sec-head__left{max-width:62ch}
.sec-head__title{margin:.6rem 0 0}
.sec-head__desc{color:var(--slate-600);margin-top:1rem;font-size:1.05rem;line-height:1.7;max-width:58ch}

/* ----- Welcome split (home) ----- */
.welcome{display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem;align-items:center}
.welcome__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/5}
.welcome__media img{width:100%;height:100%;object-fit:cover;object-position:center 18%;transition:transform 1.2s var(--ease)}
.welcome__media:hover img{transform:scale(1.04)}
.welcome__media-sig{
  position:absolute;left:1.4rem;bottom:1.4rem;color:var(--white);
  font-family:var(--serif);font-size:1.1rem;line-height:1.2;
  text-shadow:0 2px 14px rgba(0,0,0,.4);
}
.welcome__media-sig small{display:block;font-family:var(--sans);font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;margin-top:.3rem;opacity:.85}
.welcome__text h2{margin-top:.6rem}
.welcome__quote{
  border-left:2px solid var(--accent);padding:.4rem 0 .4rem 1.4rem;
  font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--navy-700);
  margin:2rem 0;line-height:1.5;
}
.welcome__sign{display:flex;align-items:center;gap:1rem;margin-top:2rem}
.welcome__sign-sig{
  font-family:var(--serif);font-size:1.8rem;font-style:italic;color:var(--navy-900);
  letter-spacing:-.01em;line-height:1;
}
.welcome__sign-info{font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--slate-500)}
.welcome__sign-info strong{display:block;color:var(--navy-900);margin-bottom:2px}
@media(max-width:900px){.welcome{grid-template-columns:1fr;gap:2.5rem}.welcome__media{aspect-ratio:4/5;max-width:520px}}

/* ----- Metrics strip ----- */
.metrics{background:var(--ice-100);padding:5rem 0}
.metrics__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.metrics__cell{
  padding:2.2rem 0;border-top:1px solid var(--line-strong);
  display:flex;flex-direction:column;gap:.3rem;
}
.metrics__num{
  font-family:var(--serif);font-size:clamp(2.3rem,4vw,3.8rem);
  letter-spacing:-.02em;line-height:1;color:var(--navy-900);
}
.metrics__num sup{color:var(--accent);font-size:.5em;vertical-align:super}
.metrics__label{font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:var(--slate-600)}
.metrics__note{font-size:.82rem;color:var(--slate-500);margin-top:.6rem;line-height:1.5}
@media(max-width:860px){.metrics__grid{grid-template-columns:repeat(2,1fr)}}

/* ----- Priorities grid ----- */
.priorities{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem}
.priority{
  grid-column:span 4;background:var(--white);border:1px solid var(--line);
  padding:2rem 1.8rem;border-radius:var(--radius-md);
  transition:all .5s var(--ease);position:relative;overflow:hidden;
}
.priority:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.priority__num{
  font-family:var(--serif);font-size:.85rem;color:var(--accent);
  letter-spacing:.12em;
}
.priority__icon{
  width:52px;height:52px;border-radius:50%;background:var(--ice-200);
  display:grid;place-items:center;margin:1rem 0 1.4rem;
  color:var(--navy-900);transition:all .4s var(--ease);
}
.priority:hover .priority__icon{background:var(--navy-900);color:var(--accent)}
.priority__title{font-family:var(--serif);font-size:1.25rem;margin:0 0 .5rem;color:var(--navy-900)}
.priority__desc{color:var(--slate-600);font-size:.95rem;line-height:1.65;margin:0}
.priority__arrow{
  position:absolute;bottom:1.4rem;right:1.4rem;width:34px;height:34px;
  border-radius:50%;border:1px solid var(--line-strong);
  display:grid;place-items:center;transition:all .4s var(--ease);
}
.priority:hover .priority__arrow{background:var(--navy-900);color:var(--accent);border-color:var(--navy-900)}
@media(max-width:980px){.priority{grid-column:span 6}}
@media(max-width:640px){.priority{grid-column:span 12}}

/* ----- Leadership highlights (image strip) ----- */
.leadhl{background:var(--navy-900);color:var(--ice-200);padding:7rem 0}
.leadhl .sec-head__title{color:var(--white)}
.leadhl .sec-head__desc{color:var(--ice-300)}
.leadhl__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem}
.leadhl__card{
  position:relative;overflow:hidden;border-radius:var(--radius-md);
  aspect-ratio:3/4;color:var(--white);transition:transform .6s var(--ease);
  background:#000;
}
.leadhl__card:hover{transform:translateY(-6px)}
.leadhl__card img{width:100%;height:100%;object-fit:cover;object-position:center 18%;transition:transform 1.2s var(--ease);opacity:.85}
.leadhl__card:hover img{transform:scale(1.08);opacity:1}
.leadhl__card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 30%, rgba(5,7,11,.9));
}
.leadhl__cap{position:absolute;left:1.4rem;right:1.4rem;bottom:1.4rem;z-index:2}
.leadhl__cap-num{font-family:var(--serif);font-size:.85rem;color:var(--accent);letter-spacing:.18em;display:block;margin-bottom:.4rem}
.leadhl__cap-title{font-family:var(--serif);font-size:1.35rem;line-height:1.2;margin:0 0 .3rem;color:var(--white)}
.leadhl__cap-meta{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ice-300)}
.leadhl__card--wide{grid-column:span 6}
.leadhl__card--std{grid-column:span 3}
.leadhl__card--wide{aspect-ratio:16/11}
@media(max-width:980px){
  .leadhl__card--wide{grid-column:span 12;aspect-ratio:16/10}
  .leadhl__card--std{grid-column:span 6}
}
@media(max-width:560px){.leadhl__card--std{grid-column:span 12;aspect-ratio:4/3}}

/* ----- Updates preview cards (home) ----- */
.updates__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.update{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);
  overflow:hidden;transition:all .5s var(--ease);display:flex;flex-direction:column;
}
.update:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.update__media{position:relative;aspect-ratio:16/10;overflow:hidden}
.update__media img{width:100%;height:100%;object-fit:cover;object-position:center 25%;transition:transform 1s var(--ease)}
.update:hover .update__media img{transform:scale(1.06)}
.update__tag{
  position:absolute;top:1rem;left:1rem;z-index:2;background:var(--white);
  color:var(--navy-900);padding:.4rem .8rem;font-size:.64rem;
  letter-spacing:.24em;text-transform:uppercase;border-radius:2px;
}
.update__body{padding:1.5rem 1.7rem 1.8rem;display:flex;flex-direction:column;flex:1}
.update__meta{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--slate-500);margin-bottom:.7rem}
.update__meta span{margin:0 .6rem;color:var(--accent)}
.update__title{font-family:var(--serif);font-size:1.25rem;margin:0 0 .7rem;color:var(--navy-900);line-height:1.3}
.update__desc{color:var(--slate-600);font-size:.95rem;margin:0 0 1.4rem;flex:1}
.update__more{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--navy-900);display:inline-flex;align-items:center;gap:.5rem}
.update__more::after{content:"→";transition:transform .3s var(--ease)}
.update__more:hover::after{transform:translateX(4px)}
.update__more:hover{color:var(--accent)}
@media(max-width:960px){.updates__grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.updates__grid{grid-template-columns:1fr}}

/* ----- CTA band ----- */
.ctaband{
  position:relative;padding:6rem 0;color:var(--white);overflow:hidden;
  background:var(--navy-900);
}
.ctaband__media{position:absolute;inset:0;z-index:0;opacity:.22}
.ctaband__media img{width:100%;height:100%;object-fit:cover}
.ctaband__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;align-items:center}
.ctaband h2{color:var(--white);margin:0}
.ctaband p{color:var(--ice-300);font-size:1.05rem;max-width:56ch;margin:1.1rem 0 0}
.ctaband__actions{display:flex;gap:1rem;justify-content:flex-end;flex-wrap:wrap}
@media(max-width:820px){.ctaband__inner{grid-template-columns:1fr}.ctaband__actions{justify-content:flex-start}}

/* ========================================================
   FOOTER
   ======================================================== */
.footer{background:#070E1D;color:var(--ice-300);padding:5rem 0 0;position:relative;overflow:hidden}
.footer::before{
  content:"";position:absolute;inset:0 0 auto 0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3.5rem}
.footer__brand{display:flex;align-items:center;gap:.9rem;margin-bottom:1.1rem;color:var(--white)}
.footer__brand .brand__crest{background:transparent;border-color:var(--accent);color:var(--white)}
.footer__brand .brand__name{color:var(--white)}
.footer__brand .brand__name small{color:var(--silver-2)}
.footer p{color:var(--silver-2);font-size:.92rem;line-height:1.7}
.footer h4{color:var(--white);margin:0 0 1.4rem;font-size:.78rem;letter-spacing:.26em}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.7rem}
.footer ul a{font-size:.92rem;color:var(--silver-2);transition:all .3s}
.footer ul a:hover{color:var(--accent);padding-left:4px}
.footer__contact p{font-size:.92rem;color:var(--silver-2);margin:0 0 .5rem}
.footer__contact a{color:var(--ice-200)}
.footer__contact a:hover{color:var(--accent)}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:1.8rem 0;
  display:flex;justify-content:space-between;align-items:center;gap:1.2rem;flex-wrap:wrap;
  font-size:.8rem;color:var(--silver-2);
}
.footer__bottom a{color:var(--ice-200)}
.footer__bottom a strong{color:var(--white)}
.footer__bottom a:hover{color:var(--accent)}
.socials{display:flex;gap:.7rem}
.socials a{
  width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(255,255,255,.12);
  display:grid;place-items:center;color:var(--silver);
  transition:all .35s var(--ease);
}
.socials a:hover{background:var(--accent);color:var(--navy-900);border-color:var(--accent);transform:translateY(-3px)}
.socials svg{width:15px;height:15px}
@media(max-width:980px){.footer__grid{grid-template-columns:1fr 1fr;gap:2.2rem}}
@media(max-width:560px){.footer__grid{grid-template-columns:1fr}}

/* ========================================================
   ABOUT PAGE
   ======================================================== */
.bio{display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem;align-items:start}
.bio__media{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/5;box-shadow:var(--shadow-md);
}
.bio__media img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.bio__media-caption{
  position:absolute;left:0;right:0;bottom:0;padding:1.5rem;
  color:var(--white);
  background:linear-gradient(180deg,transparent,rgba(5,7,11,.75));
  font-size:.75rem;letter-spacing:.24em;text-transform:uppercase;
}
.bio__data{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-top:2rem;padding:1.8rem;background:var(--ice-100);border-radius:var(--radius-md)}
.bio__data-item{font-size:.82rem}
.bio__data-item strong{display:block;color:var(--slate-500);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;margin-bottom:.3rem;font-weight:600}
.bio__data-item span{font-family:var(--serif);font-size:1.1rem;color:var(--navy-900)}
.bio__text .lead{font-family:var(--serif);font-size:1.45rem;line-height:1.5;color:var(--navy-800);margin-bottom:1.5rem;font-style:italic}
@media(max-width:900px){.bio{grid-template-columns:1fr;gap:2.5rem}.bio__media{max-width:520px}}

/* Timeline */
.timeline{position:relative;margin-top:4rem}
.timeline::before{
  content:"";position:absolute;left:120px;top:0;bottom:0;width:1px;background:var(--line-strong);
}
.timeline__item{
  display:grid;grid-template-columns:120px 1fr;gap:2rem;align-items:start;
  padding:1.4rem 0;position:relative;
}
.timeline__year{
  font-family:var(--serif);font-size:1.5rem;color:var(--navy-900);
  padding-top:.2rem;
}
.timeline__dot{
  position:absolute;left:113px;top:1.8rem;width:15px;height:15px;border-radius:50%;
  background:var(--white);border:2px solid var(--accent);z-index:2;
  box-shadow:0 0 0 4px rgba(191,160,106,.16);
}
.timeline__body{padding-left:3rem;max-width:60ch}
.timeline__title{font-family:var(--serif);font-size:1.35rem;margin:0 0 .4rem;color:var(--navy-900)}
.timeline__desc{color:var(--slate-600);margin:0;line-height:1.7}
@media(max-width:680px){
  .timeline::before{left:0}
  .timeline__item{grid-template-columns:1fr;gap:.4rem}
  .timeline__dot{left:-6px;top:.8rem}
  .timeline__body{padding-left:1.5rem}
  .timeline__year{padding-left:1.5rem}
}

/* Philosophy cards */
.philosophy{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.ph-card{
  padding:2.2rem;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius-md);
}
.ph-card__num{font-family:var(--serif);font-size:3rem;color:var(--accent);line-height:1;letter-spacing:-.02em}
.ph-card h3{margin:1rem 0 .6rem}
.ph-card p{color:var(--slate-600);margin:0}
@media(max-width:860px){.philosophy{grid-template-columns:1fr}}

/* ========================================================
   GOVERNANCE PAGE
   ======================================================== */
.gov-pillars{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem}
.pillar{
  grid-column:span 4;padding:2.4rem 2rem;background:var(--white);
  border-radius:var(--radius-md);border:1px solid var(--line);
  transition:all .5s var(--ease);position:relative;
}
.pillar:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:transparent}
.pillar__num{
  font-family:var(--serif);font-size:.9rem;color:var(--slate-500);
  letter-spacing:.2em;margin-bottom:1.1rem;
}
.pillar__num span{color:var(--accent)}
.pillar__icon{
  width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:var(--accent);display:grid;place-items:center;margin-bottom:1.4rem;
}
.pillar h3{font-size:1.35rem;margin:0 0 .6rem}
.pillar p{color:var(--slate-600);margin:0;line-height:1.7}
.pillar ul{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-direction:column;gap:.4rem}
.pillar li{font-size:.88rem;color:var(--slate-600);padding-left:1rem;position:relative}
.pillar li::before{content:"";position:absolute;left:0;top:.75em;width:6px;height:1px;background:var(--accent)}
@media(max-width:960px){.pillar{grid-column:span 6}}
@media(max-width:600px){.pillar{grid-column:span 12}}

/* Gov data split */
.gov-data{background:var(--navy-900);color:var(--ice-200)}
.gov-data .sec-head__title{color:var(--white)}
.gov-data .sec-head__desc{color:var(--ice-300)}
.gov-data__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:center}
.gov-data__bars{display:flex;flex-direction:column;gap:1.5rem}
.bar{display:flex;flex-direction:column;gap:.5rem}
.bar__head{display:flex;justify-content:space-between;font-size:.82rem;letter-spacing:.08em}
.bar__label{color:var(--ice-200);font-weight:500}
.bar__val{font-family:var(--serif);color:var(--accent);font-size:1.2rem}
.bar__track{height:6px;background:rgba(255,255,255,.1);border-radius:999px;overflow:hidden}
.bar__fill{height:100%;background:linear-gradient(90deg,var(--ice-300),var(--accent));border-radius:999px;width:0;transition:width 1.5s var(--ease)}
.gov-data__chart{
  aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  padding:2rem;position:relative;
}
.gov-data__chart img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md);opacity:.85;object-position:center 28%}
.gov-data__chart-label{
  position:absolute;left:1.5rem;bottom:1.5rem;right:1.5rem;
  color:var(--white);font-family:var(--serif);font-size:1.2rem;line-height:1.3;
}
.gov-data__chart-label small{display:block;font-family:var(--sans);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ice-300);margin-bottom:.4rem}
@media(max-width:880px){.gov-data__grid{grid-template-columns:1fr;gap:2.5rem}}

/* ========================================================
   ECONOMY PAGE
   ======================================================== */
.econ-hero{
  background:var(--ice-100);padding:6rem 0;
}
.econ-hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.econ-hero__text .lead{font-family:var(--serif);font-size:1.6rem;line-height:1.45;color:var(--navy-800)}
.econ-hero__metrics{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:2rem}
.ec-mini{padding:1.4rem 1.2rem;background:var(--white);border-radius:var(--radius-md);border:1px solid var(--line)}
.ec-mini__val{font-family:var(--serif);font-size:2rem;color:var(--navy-900);line-height:1;letter-spacing:-.02em}
.ec-mini__val sup{color:var(--accent);font-size:.5em;vertical-align:super;margin-left:2px}
.ec-mini__label{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--slate-500);margin-top:.6rem}
.econ-hero__visual{
  position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-md);
}
.econ-hero__visual img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
@media(max-width:880px){.econ-hero__inner{grid-template-columns:1fr}.econ-hero__visual{max-width:500px;aspect-ratio:4/5}}

/* Strategy grid */
.strategy{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem;margin-top:3rem}
.strat{
  grid-column:span 3;padding:2rem 1.5rem;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius-md);transition:all .5s var(--ease);
  display:flex;flex-direction:column;gap:.6rem;
}
.strat:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:transparent}
.strat__icon{width:48px;height:48px;border-radius:12px;background:var(--ice-200);color:var(--navy-900);display:grid;place-items:center;margin-bottom:.5rem;transition:all .4s var(--ease)}
.strat:hover .strat__icon{background:var(--navy-900);color:var(--accent)}
.strat h3{font-size:1.15rem;margin:0 0 .4rem}
.strat p{font-size:.92rem;color:var(--slate-600);margin:0;line-height:1.6}
@media(max-width:960px){.strat{grid-column:span 6}}
@media(max-width:560px){.strat{grid-column:span 12}}

/* Animated chart band */
.chartband{background:var(--navy-900);color:var(--ice-200);padding:7rem 0}
.chartband h2{color:var(--white)}
.chartband__grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.linechart{
  position:relative;height:340px;border-radius:var(--radius-md);
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);padding:1.5rem;
}
.linechart svg{width:100%;height:100%}
.linechart-legend{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:1.2rem;font-size:.78rem;color:var(--ice-300)}
.linechart-legend span{display:inline-flex;align-items:center;gap:.45rem}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
@media(max-width:880px){.chartband__grid{grid-template-columns:1fr;gap:2rem}}

/* ========================================================
   INNOVATION PAGE
   ======================================================== */
.inno-intro{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.inno-intro__media{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:5/6;box-shadow:var(--shadow-md)}
.inno-intro__media img{width:100%;height:100%;object-fit:cover;object-position:center 25%}
.inno-intro__text h2{margin-bottom:1rem}
@media(max-width:880px){.inno-intro{grid-template-columns:1fr}.inno-intro__media{max-width:520px;aspect-ratio:5/6}}

/* Pillar columns */
.inno-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:4rem}
.inno-col{
  background:var(--white);border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--line);transition:all .5s var(--ease);
}
.inno-col:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.inno-col__media{aspect-ratio:4/3;overflow:hidden;background:#000}
.inno-col__media img{width:100%;height:100%;object-fit:cover;object-position:center 22%;transition:transform 1s var(--ease)}
.inno-col:hover .inno-col__media img{transform:scale(1.08)}
.inno-col__body{padding:1.8rem 1.6rem 2rem}
.inno-col__tag{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem}
.inno-col h3{font-size:1.3rem;margin:0 0 .6rem}
.inno-col p{color:var(--slate-600);margin:0;font-size:.95rem;line-height:1.65}
@media(max-width:960px){.inno-cols{grid-template-columns:1fr}}

/* Initiative list */
.init-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem;margin-top:3rem}
.init{
  display:grid;grid-template-columns:70px 1fr;gap:1.5rem;align-items:start;
  padding:1.8rem;background:var(--ice-100);border-radius:var(--radius-md);
  transition:all .4s var(--ease);
}
.init:hover{background:var(--navy-900);color:var(--ice-200)}
.init:hover h3{color:var(--white)}
.init:hover p{color:var(--ice-300)}
.init:hover .init__num{color:var(--accent)}
.init__num{font-family:var(--serif);font-size:2.2rem;color:var(--navy-900);line-height:1}
.init h3{margin:0 0 .4rem;font-size:1.15rem;transition:color .3s}
.init p{margin:0;color:var(--slate-600);font-size:.93rem;transition:color .3s}
@media(max-width:760px){.init-list{grid-template-columns:1fr}}

/* ========================================================
   GALLERY PAGE
   ======================================================== */
.gallery-filters{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:3rem}
.filter-btn{
  padding:.7rem 1.4rem;border-radius:999px;border:1px solid var(--line-strong);
  background:transparent;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:600;color:var(--slate-600);transition:all .3s;
}
.filter-btn.is-active,.filter-btn:hover{background:var(--navy-900);color:var(--white);border-color:var(--navy-900)}
.masonry{
  column-count:3;column-gap:1.3rem;
}
.masonry__item{
  break-inside:avoid;margin-bottom:1.3rem;
  border-radius:var(--radius-md);overflow:hidden;
  position:relative;cursor:pointer;transition:transform .5s var(--ease);
  background:#000;
}
.masonry__item:hover{transform:translateY(-4px)}
.masonry__item img{width:100%;height:auto;display:block;transition:transform 1s var(--ease);object-fit:cover}
.masonry__item:hover img{transform:scale(1.04)}
.masonry__cap{
  position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1.2rem .9rem;
  color:var(--white);z-index:2;opacity:0;transform:translateY(8px);
  transition:all .4s var(--ease);
  background:linear-gradient(180deg,transparent,rgba(5,7,11,.9));
}
.masonry__item:hover .masonry__cap{opacity:1;transform:translateY(0)}
.masonry__cap small{display:block;font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-bottom:.3rem}
.masonry__cap strong{font-family:var(--serif);font-weight:400;font-size:1.05rem;line-height:1.3}
@media(max-width:960px){.masonry{column-count:2}}
@media(max-width:560px){.masonry{column-count:1}}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:120;background:rgba(5,7,11,.95);
  display:none;align-items:center;justify-content:center;padding:2rem;
  animation:lbFade .3s var(--ease);
}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
.lightbox.is-open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}
.lightbox__close{
  position:absolute;top:1.5rem;right:1.5rem;width:46px;height:46px;
  border-radius:50%;border:1px solid rgba(255,255,255,.2);color:var(--white);
  display:grid;place-items:center;font-size:1.5rem;
}
.lightbox__close:hover{background:var(--accent);color:var(--navy-900);border-color:var(--accent)}
.lightbox__nav{
  position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;
  border-radius:50%;border:1px solid rgba(255,255,255,.2);color:var(--white);
  display:grid;place-items:center;font-size:1.2rem;
}
.lightbox__nav--prev{left:1.5rem}
.lightbox__nav--next{right:1.5rem}
.lightbox__nav:hover{background:var(--accent);color:var(--navy-900);border-color:var(--accent)}
.lightbox__caption{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  color:var(--ice-300);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;text-align:center;max-width:80%;
}

/* ========================================================
   NEWS PAGE
   ======================================================== */
.news-feature{
  display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:center;
}
.news-feature__media{position:relative;aspect-ratio:16/10;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.news-feature__media img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.news-feature__tag{
  position:absolute;top:1.4rem;left:1.4rem;background:var(--accent);color:var(--navy-900);
  padding:.5rem 1rem;font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;border-radius:2px;font-weight:600;
}
.news-feature h2{margin:.7rem 0 1rem;line-height:1.2}
.news-feature__meta{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--slate-500);margin-bottom:1rem}
.news-feature__meta span{color:var(--accent);margin:0 .6rem}
@media(max-width:900px){.news-feature{grid-template-columns:1fr;gap:2rem}}

.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:4rem}
.article{
  display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius-md);overflow:hidden;transition:all .5s var(--ease);
}
.article:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:transparent}
.article__media{aspect-ratio:16/10;overflow:hidden}
.article__media img{width:100%;height:100%;object-fit:cover;object-position:center 25%;transition:transform 1s var(--ease)}
.article:hover .article__media img{transform:scale(1.06)}
.article__body{padding:1.6rem;display:flex;flex-direction:column;flex:1}
.article__meta{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--slate-500);margin-bottom:.6rem}
.article__meta span{color:var(--accent);margin:0 .5rem}
.article h3{font-size:1.2rem;margin:0 0 .6rem;line-height:1.3}
.article p{color:var(--slate-600);font-size:.92rem;margin:0 0 1rem;flex:1}
.article__link{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--navy-900);display:inline-flex;align-items:center;gap:.5rem}
.article__link::after{content:"→";transition:transform .3s}
.article__link:hover{color:var(--accent)}
.article__link:hover::after{transform:translateX(4px)}
@media(max-width:960px){.news-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.news-grid{grid-template-columns:1fr}}

/* Newsletter band */
.newsletter{background:var(--ice-100);padding:5rem 0}
.newsletter__inner{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.newsletter__form{display:flex;gap:.8rem;flex-wrap:wrap}
.newsletter__form input{
  flex:1;min-width:220px;padding:1.1rem 1.2rem;border-radius:999px;
  border:1px solid var(--line-strong);background:var(--white);
  font-family:var(--sans);font-size:.92rem;color:var(--navy-900);
}
.newsletter__form input:focus{outline:none;border-color:var(--navy-900);box-shadow:0 0 0 4px rgba(10,22,40,.08)}
@media(max-width:780px){.newsletter__inner{grid-template-columns:1fr}}

/* ========================================================
   CONTACT PAGE
   ======================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:3.5rem;align-items:start}
.contact-card{
  background:var(--navy-900);color:var(--ice-200);
  padding:2.6rem 2.4rem;border-radius:var(--radius-lg);
  position:relative;overflow:hidden;
}
.contact-card::before{
  content:"";position:absolute;top:-60px;right:-60px;width:180px;height:180px;
  border-radius:50%;background:radial-gradient(circle,rgba(191,160,106,.2),transparent 65%);
}
.contact-card h3{color:var(--white);margin:0 0 .6rem}
.contact-card p{color:var(--ice-300);font-size:.95rem}
.contact-card ul{list-style:none;padding:0;margin:2rem 0 0;display:flex;flex-direction:column;gap:1.1rem}
.contact-card li{display:grid;grid-template-columns:42px 1fr;gap:1rem;align-items:start}
.contact-card .ci{
  width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);
  display:grid;place-items:center;color:var(--accent);
}
.contact-card li strong{display:block;color:var(--white);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin-bottom:.3rem}
.contact-card li span,.contact-card li a{color:var(--ice-300);font-size:.95rem;font-family:var(--serif);display:block;word-break:break-word}
.contact-card li a:hover{color:var(--accent)}

.contact-form{background:var(--white);padding:2.6rem 2.4rem;border-radius:var(--radius-lg);border:1px solid var(--line)}
.contact-form h3{margin:0 0 2rem;font-size:1.8rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.2rem}
.form-grid .field--full{grid-column:span 2}
.field{display:flex;flex-direction:column;gap:.5rem}
.field label{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--slate-600);font-weight:600}
.field input,.field textarea{
  width:100%;padding:1rem;border-radius:8px;border:1px solid var(--line-strong);
  font-family:var(--sans);font-size:.95rem;color:var(--navy-900);background:var(--white);
  transition:all .3s var(--ease);
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--navy-900);box-shadow:0 0 0 3px rgba(10,22,40,.1)}
.contact-form .btn{margin-top:1.2rem}
.form-msg{margin-top:1rem;font-size:.88rem;color:var(--accent);opacity:0;transition:opacity .3s}
.form-msg.is-visible{opacity:1}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:2rem}.form-grid{grid-template-columns:1fr}.form-grid .field--full{grid-column:span 1}}

/* Map placeholder */
.map-band{background:var(--ice-100);padding:5rem 0}
.map{
  position:relative;aspect-ratio:21/9;border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(135deg,#1A2C4E 0%,#0A1628 100%);
  border:1px solid var(--line);
}
.map__svg{position:absolute;inset:0}
.map__svg svg{width:100%;height:100%}
.map__pin{
  position:absolute;left:52%;top:36%;transform:translate(-50%,-50%);
  width:20px;height:20px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 0 rgba(191,160,106,.7);animation:ping 2s infinite;
}
@keyframes ping{
  0%{box-shadow:0 0 0 0 rgba(191,160,106,.8)}
  100%{box-shadow:0 0 0 28px rgba(191,160,106,0)}
}
.map__tag{
  position:absolute;left:52%;top:calc(36% - 44px);transform:translateX(-50%);
  background:var(--white);color:var(--navy-900);padding:.5rem .9rem;
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600;
  border-radius:4px;box-shadow:var(--shadow-md);
}
.map__tag::after{
  content:"";position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);
  width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--white);
}

/* ========================================================
   REVEAL ANIMATION
   ======================================================== */
.reveal{opacity:0;transform:translateY(30px);transition:all 1s var(--ease)}
.reveal.is-in{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}
.reveal[data-delay="4"]{transition-delay:.4s}
.reveal[data-delay="5"]{transition-delay:.5s}

/* Kept simple: no reveal on reduced motion */
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none}
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
}
