/* ============================================================
   P.S.G. & Associates — Chartered Accountants
   Design system: "Ledger & Brass"
   Editorial · Indigo ink · Brass gold · Ivory paper
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@600;700&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* palette (drawn from firm profile) */
  --ink:        #14122a;
  --ink-2:      #1a1830;
  --indigo:     #2f2a76;
  --indigo-2:   #3b3690;
  --slate:      #565b6e;
  --brass:      #b89455;
  --brass-deep: #97742f;
  --gold:       #d8b877;
  --cream:      #eef1f6;
  --paper:      #ffffff;
  --paper-2:    #f5f6f9;
  --line:       rgba(24,28,56,.12);
  --line-soft:  rgba(24,28,56,.07);

  --on-dark:    #eef0f6;
  --on-dark-mut:#a7abc2;

  /* type */
  --display: "Plus Jakarta Sans", system-ui, sans-serif;
  --body:    "Hanken Grotesk", system-ui, sans-serif;
  --mono:    "Spline Sans Mono", ui-monospace, monospace;
  --logo:    "Poppins", system-ui, sans-serif;

  /* metrics */
  --maxw: 1280px;
  --gut: clamp(20px, 5vw, 80px);
  --radius: 8px;
  --radius-lg: 18px;

  /* elevation */
  --shadow-sm: 0 1px 2px rgba(20,24,55,.04), 0 4px 16px rgba(20,24,55,.05);
  --shadow-md: 0 8px 20px rgba(20,24,55,.07), 0 22px 48px rgba(20,24,55,.10);
  --shadow-lg: 0 16px 40px rgba(20,24,55,.12), 0 40px 80px rgba(20,24,55,.12);

  --ease: cubic-bezier(.22,1,.36,1);
  --ease-2: cubic-bezier(.65,.05,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.62;
  font-size:clamp(15px,1.05vw,17px);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--indigo); color:var(--gold); }

/* (paper grain removed for a clean, professional white surface) */

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.wrap-wide{ max-width:1520px; }
section{ position:relative; }

.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--brass-deep);
  display:inline-flex; align-items:center; gap:.7em;
  font-weight:500;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:var(--brass);
  display:inline-block;
}
.eyebrow.center::before{ display:none; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:700; line-height:1.08; letter-spacing:-.025em; }
.display{
  font-size:clamp(2.5rem,6.6vw,5.9rem);
  font-weight:700;
  letter-spacing:-.038em;
  line-height:1.02;
}
.h-sec{ font-size:clamp(1.9rem,4.2vw,3.4rem); font-weight:700; letter-spacing:-.03em; }
.ital{ font-style:normal; color:var(--indigo); }
.lead{ font-size:clamp(1.08rem,1.6vw,1.35rem); color:var(--slate); line-height:1.55; font-weight:400; }

/* ---------- Buttons ---------- */
.btn{
  position:relative; display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--mono); font-size:.8rem; letter-spacing:.12em; text-transform:uppercase;
  padding:1.05em 1.8em; border-radius:var(--radius);
  background:var(--indigo); color:var(--on-dark);
  overflow:hidden; transition:color .5s var(--ease), transform .4s var(--ease);
  isolation:isolate;
}
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:var(--brass); transform:translateY(102%);
  transition:transform .5s var(--ease);
}
.btn:hover{ color:var(--ink); }
.btn:hover::after{ transform:translateY(0); }
.btn .arr{ transition:transform .4s var(--ease); }
.btn:hover .arr{ transform:translate(3px,-3px); }

.btn-ghost{
  background:transparent; color:var(--ink);
  border:1px solid var(--line);
}
.btn-ghost::after{ background:var(--ink); }
.btn-ghost:hover{ color:var(--paper); }

.link-u{
  font-family:var(--mono); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:.6em; color:var(--ink);
  position:relative; padding-bottom:.25em;
}
.link-u::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--brass); transform:scaleX(.0); transform-origin:left;
  transition:transform .45s var(--ease);
}
.link-u:hover::after{ transform:scaleX(1); }
.link-u .arr{ color:var(--brass); transition:transform .4s var(--ease); }
.link-u:hover .arr{ transform:translateX(4px); }

/* ============================================================
   Header
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.4rem var(--gut);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.nav.scrolled{
  background:rgba(251,249,243,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  padding-block:.85rem;
  box-shadow:0 1px 0 var(--line-soft);
}
.brand{ display:flex; align-items:center; z-index:1001; }
.logo{ display:flex; flex-direction:column; gap:.34em; }
.logo-word{
  font-family:var(--logo); font-weight:700; color:var(--indigo);
  font-size:clamp(1.1rem,1.7vw,1.5rem); letter-spacing:-.02em; line-height:1;
  display:flex; align-items:center;
}
.logo-amp{
  display:inline-grid; place-items:center;
  background:var(--indigo); color:#fff; font-weight:700;
  padding:.06em .42em .12em; margin:0 .26em; line-height:1;
  clip-path:polygon(0 0, 100% 9%, 100% 91%, 0 100%);
  transition:transform .5s var(--ease), background .4s var(--ease);
}
.brand:hover .logo-amp{ transform:rotate(-3deg) scale(1.05); background:var(--brass-deep); }
.logo-sub{
  display:flex; align-items:center; gap:.5em;
  font-family:var(--mono); font-size:.54rem; letter-spacing:.34em; text-transform:uppercase; color:var(--brass-deep);
}
.logo-sub::before,.logo-sub::after{ content:""; height:1px; flex:1 1 14px; min-width:10px; background:var(--brass); opacity:.7; }

.nav-links{ display:flex; align-items:center; gap:.2rem; }
.nav-links a{
  font-family:var(--mono); font-size:.76rem; letter-spacing:.08em; text-transform:uppercase;
  padding:.6rem .85rem; position:relative; color:var(--ink-2);
  transition:color .35s var(--ease);
}
.nav-links a .dot{
  position:absolute; left:50%; bottom:.2rem; width:4px; height:4px; border-radius:50%;
  background:var(--brass); transform:translateX(-50%) scale(0); transition:transform .35s var(--ease);
}
.nav-links a:hover{ color:var(--indigo); }
.nav-links a:hover .dot,.nav-links a.active .dot{ transform:translateX(-50%) scale(1); }
.nav-links a.active{ color:var(--indigo); }
.nav-cta{ margin-left:.6rem; }
/* keep the Connect button's label white on its indigo background (overrides .nav-links a colour) */
.nav-links a.nav-cta,
.nav-links a.nav-cta.active{ color:var(--on-dark); }
.nav-links a.nav-cta:hover{ color:var(--ink); }   /* dark text once the brass fill rises on hover */

.burger{ display:none; flex-direction:column; gap:5px; padding:.5rem; z-index:1001; }
.burger span{ width:26px; height:1.5px; background:var(--ink); transition:transform .4s var(--ease),opacity .3s; }
.burger.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* mobile menu */
.m-menu{
  position:fixed; inset:0; z-index:1000;
  background:var(--ink);
  display:flex; flex-direction:column; justify-content:center; padding:var(--gut);
  clip-path:circle(0% at 100% 0); transition:clip-path .7s var(--ease);
  pointer-events:none;
}
.m-menu.open{ clip-path:circle(150% at 100% 0); pointer-events:auto; }
.m-menu a{
  font-family:var(--display); font-weight:600; letter-spacing:-.03em; font-size:clamp(2rem,9vw,3.2rem); color:var(--on-dark);
  padding:.25rem 0; display:flex; align-items:baseline; gap:1rem;
  opacity:0; transform:translateY(20px);
}
.m-menu.open a{ animation:mIn .6s var(--ease) forwards; }
.m-menu a span{ font-family:var(--mono); font-size:.8rem; color:var(--brass); }
.m-menu a:hover{ color:var(--gold); padding-left:.6rem; }
@keyframes mIn{ to{ opacity:1; transform:none; } }

/* ============================================================
   Hero
   ============================================================ */
.hero{ position:relative; padding:clamp(8rem,16vh,12rem) 0 clamp(3rem,8vh,6rem); overflow:hidden; }
.hero-bg{
  position:absolute; inset:0; z-index:-2;
  background:
    radial-gradient(1100px 700px at 78% -8%, rgba(47,42,118,.10), transparent 60%),
    radial-gradient(900px 600px at -5% 100%, rgba(184,148,85,.12), transparent 55%);
}
.hero-grid-lines{
  position:absolute; inset:0; z-index:-1; pointer-events:none;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:clamp(60px,7vw,110px) clamp(60px,7vw,110px);
  -webkit-mask-image:radial-gradient(120% 90% at 50% 20%,#000,transparent 80%);
          mask-image:radial-gradient(120% 90% at 50% 20%,#000,transparent 80%);
  opacity:.7;
}
.hero-inner{ display:grid; grid-template-columns:1.45fr .85fr; gap:clamp(2rem,5vw,5rem); align-items:end; }
.hero-tag{ margin-bottom:1.6rem; }
.hero h1{ margin-bottom:1.8rem; }
.hero h1 .line{ display:block; overflow:hidden; }
.hero h1 .line > span{ display:block; transform:translateY(110%); }
.hero-aside{ padding-bottom:.5rem; }
.hero-aside .lead{ margin-bottom:2rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; }

.hero-meta{
  margin-top:clamp(3rem,7vh,6rem);
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);
}
.hero-meta .cell{ padding:1.5rem 0 0; border-right:1px solid var(--line-soft); padding-right:1rem; }
.hero-meta .cell:last-child{ border-right:none; }
.hero-meta .k{ font-family:var(--display); font-weight:700; font-size:clamp(1.8rem,3vw,2.6rem); letter-spacing:-.03em; color:var(--indigo); line-height:1; }
.hero-meta .v{ font-family:var(--mono); font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--slate); margin-top:.7em; }

/* reveal mask animation for hero lines (run on load) */
.preload .line > span{ transform:translateY(110%); }

@media(max-width:820px){
  .hero-inner{ grid-template-columns:1fr; gap:2rem; align-items:start; }
}
@media(max-width:560px){
  .hero-meta{ grid-template-columns:1fr 1fr; }
  .hero-meta .cell{ padding:1.2rem 1rem 0 0; border-bottom:1px solid var(--line-soft); }
  .hero-meta .cell:nth-child(2n){ border-right:none; }
  .hero-actions{ width:100%; }
  .hero-actions .btn{ flex:1 1 auto; justify-content:center; }
}

/* ============================================================
   Generic section shells
   ============================================================ */
.sec{ padding:clamp(3.5rem,8vh,6.5rem) 0; }
.sec-head{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,5vw,5rem); align-items:end; margin-bottom:clamp(2.5rem,6vh,4.5rem); }
.sec-head .right{ justify-self:end; max-width:42ch; }
@media(max-width:780px){ .sec-head{ grid-template-columns:1fr; } .sec-head .right{ justify-self:start; } }

.dark{ background:var(--ink); color:var(--on-dark); }
.dark .lead{ color:var(--on-dark-mut); }
.dark .eyebrow{ color:var(--gold); }
.dark .eyebrow::before{ background:var(--gold); }
.dark .ital{ color:var(--gold); }

/* ---------- Intro / about strip ---------- */
.intro{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,6rem); align-items:start; }
.intro .big{ font-family:var(--display); font-size:clamp(1.5rem,2.6vw,2.2rem); font-weight:600; line-height:1.24; letter-spacing:-.02em; }
.intro .big .ital{ font-style:normal; }
.intro .col p{ margin-bottom:1.2rem; color:var(--slate); }
@media(max-width:820px){ .intro{ grid-template-columns:1fr; gap:2rem; } }

/* ============================================================
   Service / value cards (numbered list rows)
   ============================================================ */
.rows{ border-top:1px solid var(--line); }
.row{
  display:grid; grid-template-columns:5rem 1fr auto; gap:clamp(1rem,3vw,3rem);
  align-items:center; padding:clamp(1.4rem,3vw,2.2rem) 0;
  border-bottom:1px solid var(--line-soft);
  position:relative; transition:padding .5s var(--ease);
}
.row::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(90deg,var(--cream),transparent);
  opacity:0; transition:opacity .5s var(--ease);
  margin-inline:calc(var(--gut) * -.5);
}
.row:hover{ padding-inline:1.2rem; }
.row:hover::before{ opacity:1; }
.row .num{ font-family:var(--mono); font-size:.85rem; color:var(--brass-deep); letter-spacing:.1em; }
.row .ttl{ font-family:var(--display); font-size:clamp(1.3rem,2.4vw,1.9rem); font-weight:600; letter-spacing:-.025em; transition:color .4s,transform .5s var(--ease); }
.row:hover .ttl{ color:var(--indigo); }
.row .desc{ grid-column:2 / -1; color:var(--slate); max-width:60ch; font-size:.96rem; margin-top:.35rem; }
.row .go{
  width:46px; height:46px; border:1px solid var(--line); border-radius:50%;
  display:grid; place-items:center; color:var(--brass-deep);
  transition:background .4s var(--ease),color .4s,border-color .4s,transform .5s var(--ease);
}
.row:hover .go{ background:var(--indigo); color:var(--gold); border-color:var(--indigo); transform:rotate(45deg); }
@media(max-width:760px){
  .row{ grid-template-columns:auto 1fr; }
  .row .desc{ grid-column:1/-1; }
  .row .go{ display:none; }
}

/* ============================================================
   Cards grid
   ============================================================ */
.cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr)); gap:clamp(1rem,1.6vw,1.4rem); }
.card{
  background:var(--paper); padding:clamp(1.6rem,2.6vw,2.2rem);
  position:relative; overflow:hidden;
  border:1px solid var(--line-soft); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
  min-height:clamp(210px,24vw,280px); display:flex; flex-direction:column;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(184,148,85,.4); }
.card .c-num{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.18em; color:var(--brass-deep);
  margin-bottom:auto; display:inline-grid; place-items:center;
  width:2.4em; height:2.4em; border-radius:50%; background:var(--cream); align-self:flex-start;
}
.card .c-ico{ color:var(--indigo); margin-bottom:.9rem; display:flex; }
.card .c-ico svg{ width:30px; height:30px; }
.card h3{ font-size:clamp(1.2rem,1.9vw,1.5rem); margin:.9rem 0 .55rem; transition:color .4s var(--ease); }
.card:hover h3{ color:var(--indigo); }
.card p{ color:var(--slate); font-size:.94rem; }

/* ============================================================
   Marquee
   ============================================================ */
.marquee{ overflow:hidden; border-block:1px solid var(--line-soft); padding:1.25rem 0; background:var(--paper-2); }
.marquee-track{ display:flex; gap:3rem; width:max-content; animation:slide 34s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--display); font-weight:600; font-size:clamp(1.15rem,2vw,1.65rem); letter-spacing:-.02em; color:var(--indigo); display:flex; align-items:center; gap:3rem; white-space:nowrap; }
.marquee-track span::after{ content:"✦"; font-style:normal; color:var(--brass); font-size:.8em; }
@keyframes slide{ to{ transform:translateX(-50%); } }

/* ============================================================
   Partners / leadership
   ============================================================ */
.leaders{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,3rem); }
.leader{
  background:var(--paper); border:1px solid var(--line-soft); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  display:grid; grid-template-columns:auto 1fr; gap:1.6rem; padding:clamp(1.4rem,3vw,2rem);
  position:relative; overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.leader:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.leader .ph{
  width:clamp(110px,14vw,160px); aspect-ratio:1; border-radius:50%;
  overflow:hidden; background:var(--cream); flex:none; position:relative;
  border:1px solid var(--line);
}
.leader .ph img{ width:100%; height:100%; object-fit:cover; object-position:top center; filter:grayscale(.15) contrast(1.02); transition:filter .6s var(--ease),transform .8s var(--ease); }
.leader:hover .ph img{ filter:grayscale(0); transform:scale(1.05); }
.leader .role{ font-family:var(--mono); font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--brass-deep); }
.leader h3{ font-size:clamp(1.4rem,2.4vw,1.9rem); margin:.5rem 0 .9rem; }
.leader ul li{ position:relative; padding-left:1.2rem; margin-bottom:.5rem; color:var(--slate); font-size:.9rem; }
.leader ul li::before{ content:"—"; position:absolute; left:0; color:var(--brass); }
@media(max-width:880px){ .leaders{ grid-template-columns:1fr; } }
@media(max-width:480px){ .leader{ grid-template-columns:1fr; text-align:left; } }

/* ============================================================
   Stats band
   ============================================================ */
.band{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(255,255,255,.08); }
.band .stat{ padding:clamp(2rem,4vw,3.4rem) clamp(1rem,2vw,2rem); background:var(--ink); }
.band .stat .k{ font-family:var(--display); font-weight:700; font-size:clamp(2.4rem,5vw,4rem); letter-spacing:-.03em; color:var(--gold); line-height:1; }
.band .stat .v{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--on-dark-mut); margin-top:.9em; }
@media(max-width:740px){ .band{ grid-template-columns:1fr 1fr; } }

/* ============================================================
   Sectors / tag cloud
   ============================================================ */
.tags{ display:flex; flex-wrap:wrap; gap:.7rem; }
.tag{
  font-family:var(--mono); font-size:.82rem; letter-spacing:.04em;
  padding:.7em 1.2em; border:1px solid var(--line); border-radius:100px;
  transition:background .4s var(--ease),color .4s,border-color .4s,transform .4s var(--ease);
  color:var(--ink-2);
}
.tag:hover{ background:var(--indigo); color:var(--gold); border-color:var(--indigo); transform:translateY(-3px); }

.sector-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(.9rem,1.4vw,1.2rem); }
@media(max-width:900px){ .sector-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:520px){ .sector-grid{ grid-template-columns:1fr; } }
.sector{
  background:var(--paper); padding:1.5rem 1.5rem; display:flex; flex-direction:column; gap:.55rem;
  min-height:160px; justify-content:flex-start;
  border:1px solid var(--line-soft); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), background .5s var(--ease); position:relative;
}
.sector:hover{ transform:translateY(-6px); background:var(--ink); color:var(--on-dark); box-shadow:var(--shadow-md); }
.sector .s-num{ font-family:var(--mono); font-size:.68rem; letter-spacing:.2em; color:var(--brass-deep); transition:color .4s; }
.sector:hover .s-num{ color:var(--gold); }
.sector h3{ font-size:1.3rem; transition:color .4s; }
.sector:hover h3{ color:var(--gold); }
.sector .s-line{ font-size:.86rem; color:var(--slate); transition:color .4s; margin-top:.2rem; }
.sector:hover .s-line{ color:var(--on-dark-mut); }

/* ============================================================
   Insights / Ledger cards
   ============================================================ */
.posts{ display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:clamp(1.4rem,2.4vw,2rem); }
.post{
  display:flex; flex-direction:column;
  background:var(--paper); border:1px solid var(--line-soft); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm); overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.post:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.post .p-top{ position:relative; overflow:hidden; aspect-ratio:16/10; background:linear-gradient(135deg,var(--cream),#e4e8f0); }
.post .p-top .p-cat{ position:absolute; top:1rem; left:1rem; z-index:2; font-family:var(--mono); font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; background:var(--paper); color:var(--indigo); padding:.5em .9em; border-radius:100px; box-shadow:var(--shadow-sm); }
.post .p-art{ position:absolute; inset:0; display:grid; place-items:center; font-family:var(--display); font-weight:700; font-size:clamp(3rem,8vw,5rem); color:var(--indigo); opacity:.18; transition:transform .8s var(--ease),opacity .6s; }
.post:hover .p-art{ transform:scale(1.12) rotate(-3deg); opacity:.3; }
.post .p-meta{ font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; color:var(--brass-deep); text-transform:uppercase; padding:clamp(1.3rem,2vw,1.6rem) clamp(1.3rem,2vw,1.6rem) 0; }
.post h3{ font-size:clamp(1.2rem,1.8vw,1.55rem); line-height:1.18; transition:color .4s; padding-inline:clamp(1.3rem,2vw,1.6rem); margin-top:.55rem; }
.post:hover h3{ color:var(--indigo); }
.post p{ color:var(--slate); font-size:.92rem; padding:.55rem clamp(1.3rem,2vw,1.6rem) clamp(1.4rem,2vw,1.7rem); }

.post-wide{
  display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(1.5rem,4vw,3rem);
  align-items:center; border:1px solid var(--line); background:var(--paper);
  margin-bottom:clamp(2rem,5vh,3.5rem);
}
.post-wide .pw-art{ aspect-ratio:16/10; position:relative; overflow:hidden; background:linear-gradient(135deg,var(--indigo),var(--ink)); display:grid; place-items:center; }
.post-wide .pw-art .glyph{ font-family:var(--display); font-weight:700; font-size:clamp(4rem,10vw,8rem); color:var(--gold); opacity:.7; }
.post-wide .pw-body{ padding:clamp(1.5rem,3vw,2.5rem); }
@media(max-width:820px){ .post-wide{ grid-template-columns:1fr; } }

/* ============================================================
   Downloads / Resources
   ============================================================ */
.files{ border-top:1px solid var(--line); }
.file{
  display:grid; grid-template-columns:auto 1fr auto auto; gap:clamp(1rem,2.5vw,2rem);
  align-items:center; padding:1.5rem 0; border-bottom:1px solid var(--line-soft);
  position:relative; transition:padding-inline .5s var(--ease);
}
.file::before{ content:""; position:absolute; inset:0 calc(var(--gut)*-.4); background:var(--cream); opacity:0; z-index:-1; transition:opacity .4s; }
.file:hover{ padding-inline:1rem; }
.file:hover::before{ opacity:1; }
.file .f-ico{ width:48px; height:60px; border:1px solid var(--line); position:relative; flex:none; background:var(--paper); }
.file .f-ico::before{ content:""; position:absolute; top:0; right:0; border-width:0 14px 14px 0; border-style:solid; border-color:var(--cream) var(--paper); }
.file .f-ico span{ position:absolute; bottom:6px; left:6px; font-family:var(--mono); font-size:.5rem; letter-spacing:.1em; color:var(--brass-deep); }
.file .f-name{ font-family:var(--display); font-weight:600; letter-spacing:-.02em; font-size:clamp(1.1rem,1.8vw,1.4rem); }
.file .f-sub{ font-family:var(--mono); font-size:.68rem; letter-spacing:.12em; color:var(--slate); text-transform:uppercase; margin-top:.3em; }
.file .f-size{ font-family:var(--mono); font-size:.75rem; color:var(--slate); }
.file .f-dl{ width:46px; height:46px; border:1px solid var(--line); border-radius:50%; display:grid; place-items:center; color:var(--indigo); transition:background .4s,color .4s,transform .4s; }
.file:hover .f-dl{ background:var(--brass); color:var(--ink); transform:translateY(3px); }
@media(max-width:680px){ .file{ grid-template-columns:auto 1fr auto; } .file .f-size{ display:none; } }

/* ============================================================
   Approach timeline
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:clamp(.9rem,1.3vw,1.1rem); }
.step{
  background:var(--paper); padding:clamp(1.4rem,2.4vw,1.9rem) clamp(1.1rem,1.6vw,1.4rem);
  display:flex; flex-direction:column; gap:.7rem; min-height:230px;
  border:1px solid var(--line-soft); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), background .5s var(--ease);
}
.step:hover{ transform:translateY(-6px); background:var(--ink); color:var(--on-dark); box-shadow:var(--shadow-md); }
.step .st-n{ font-family:var(--display); font-weight:700; font-size:2.2rem; color:var(--brass-deep); line-height:1; }
.step:hover .st-n{ color:var(--gold); }
.step h3{ font-size:1.25rem; }
.step:hover h3{ color:var(--gold); }
.step p{ font-size:.86rem; color:var(--slate); margin-top:auto; }
.step:hover p{ color:var(--on-dark-mut); }
@media(max-width:980px){ .steps{ grid-template-columns:1fr 1fr; } .steps .step:nth-child(5){ grid-column:1 / -1; } }
@media(max-width:520px){ .steps{ grid-template-columns:1fr; } .steps .step:nth-child(5){ grid-column:auto; } }

/* ============================================================
   Contact
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5rem); align-items:start; }
@media(max-width:880px){ .contact-grid{ grid-template-columns:1fr; } }
.field{ position:relative; margin-bottom:1.8rem; }
.field input,.field textarea,.field select{
  width:100%; background:transparent; border:none; border-bottom:1px solid var(--line);
  padding:.9rem 0; font-family:var(--body); font-size:1rem; color:var(--ink); transition:border-color .4s;
}
.field textarea{ resize:vertical; min-height:90px; }
.field label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--slate); display:block; margin-bottom:.3rem; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--brass); }
.contact-info .ci{ padding:1.6rem 0; border-bottom:1px solid var(--line-soft); }
.contact-info .ci .ci-k{ font-family:var(--mono); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--brass-deep); margin-bottom:.6rem; }
.contact-info .ci .ci-v{ font-family:var(--display); font-weight:600; letter-spacing:-.02em; font-size:clamp(1.15rem,1.9vw,1.5rem); }
.contact-info .ci a{ transition:color .3s; }
.contact-info .ci a:hover{ color:var(--indigo); }

/* ============================================================
   CTA strip
   ============================================================ */
.cta{ position:relative; overflow:hidden; background:var(--ink); color:var(--on-dark); text-align:center; padding:clamp(5rem,12vh,8rem) 0; }
.cta::before{
  content:""; position:absolute; inset:0; z-index:0; opacity:.5;
  background:radial-gradient(700px 400px at 50% -10%,rgba(184,148,85,.25),transparent 60%);
}
.cta .wrap{ position:relative; z-index:1; }
.cta h2{ font-size:clamp(2.2rem,6vw,5rem); margin-bottom:1.4rem; }
.cta .ital{ color:var(--gold); }
.cta p{ color:var(--on-dark-mut); max-width:54ch; margin:0 auto 2.4rem; }

/* ============================================================
   Footer
   ============================================================ */
.foot{ background:var(--ink-2); color:var(--on-dark); padding:clamp(3.5rem,8vh,6rem) 0 2rem; }
.foot-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:clamp(1.5rem,4vw,3rem); padding-bottom:3rem; border-bottom:1px solid rgba(255,255,255,.1); }
.foot h4{ font-family:var(--mono); font-weight:500; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:1.4rem; }
.foot .f-brand .b-name{ font-family:var(--display); font-weight:700; letter-spacing:-.025em; font-size:1.55rem; }
.foot .f-brand p{ color:var(--on-dark-mut); margin-top:1rem; max-width:34ch; font-size:.92rem; }
.foot ul li{ margin-bottom:.7rem; }
.foot ul a{ color:var(--on-dark-mut); font-size:.92rem; transition:color .3s,padding-left .3s; }
.foot ul a:hover{ color:var(--gold); padding-left:.4rem; }
.foot-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; padding-top:2rem; font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; color:var(--on-dark-mut); }
@media(max-width:820px){ .foot-top{ grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .foot-top{ grid-template-columns:1fr; } }

/* ============================================================
   Page hero (interior pages)
   ============================================================ */
.phead{ padding:clamp(8rem,16vh,11rem) 0 clamp(2.5rem,6vh,4rem); position:relative; overflow:hidden; }
.phead-bg{ position:absolute; inset:0; z-index:-1; background:radial-gradient(900px 500px at 85% 0,rgba(47,42,118,.09),transparent 60%); }
.phead .crumbs{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--slate); margin-bottom:1.4rem; display:flex; gap:.6rem; align-items:center; }
.phead .crumbs a:hover{ color:var(--indigo); }
.phead .crumbs .sep{ color:var(--brass); }
.phead h1{ font-size:clamp(2.6rem,7vw,5.4rem); }
.phead .lead{ margin-top:1.6rem; max-width:56ch; }

/* ============================================================
   Reveal animations
   ============================================================ */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease),transform .9s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-d="1"]{ transition-delay:.08s; }
[data-reveal][data-d="2"]{ transition-delay:.16s; }
[data-reveal][data-d="3"]{ transition-delay:.24s; }
[data-reveal][data-d="4"]{ transition-delay:.32s; }
[data-reveal][data-d="5"]{ transition-delay:.40s; }
[data-reveal][data-d="6"]{ transition-delay:.48s; }
@media(prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; }
  [data-reveal]{ opacity:1; transform:none; }
  .line > span{ transform:none!important; }
}

/* ============================================================
   Misc
   ============================================================ */
.divider-quote{ font-family:var(--display); font-size:clamp(1.7rem,3.6vw,2.9rem); font-weight:700; line-height:1.18; max-width:24ch; letter-spacing:-.03em; }
.divider-quote .ital{ font-style:normal; }
.note{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; color:var(--slate); text-transform:uppercase; }

/* ---------- Responsive nav ---------- */
@media(max-width:1080px){
  .nav-links{ display:none; }
  .burger{ display:flex; }
}

/* form success */
.form-msg{ display:none; font-family:var(--mono); font-size:.8rem; color:var(--indigo); padding:1rem; border:1px solid var(--brass); background:var(--cream); margin-top:1rem; border-radius:var(--radius); }
.form-msg.show{ display:block; }
.form-err{ display:none; font-family:var(--mono); font-size:.78rem; line-height:1.5; color:#9a2f2a; padding:.9rem 1rem; border:1px solid rgba(154,47,42,.35); background:rgba(154,47,42,.06); margin-top:1rem; border-radius:var(--radius); }
.form-err.show{ display:block; }

/* ============================================================
   Article (long-form reading)
   ============================================================ */
.art-head{ padding:clamp(7.5rem,15vh,10.5rem) 0 clamp(1.8rem,4vh,2.6rem); position:relative; overflow:hidden; }
.art-head .phead-bg{ position:absolute; inset:0; z-index:-1; background:radial-gradient(900px 500px at 85% -10%,rgba(47,42,118,.10),transparent 60%); }
.art-head .wrap{ max-width:880px; }
.art-cat{ display:inline-block; font-family:var(--mono); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--indigo); background:var(--cream); padding:.55em 1em; border-radius:100px; margin-bottom:1.6rem; }
.art-title{ font-size:clamp(2rem,4.6vw,3.5rem); line-height:1.08; letter-spacing:-.03em; max-width:20ch; }
.art-sub{ margin-top:1.3rem; font-size:clamp(1.05rem,1.7vw,1.3rem); color:var(--slate); line-height:1.5; max-width:60ch; }
.art-byline{ display:flex; align-items:center; gap:1rem; margin-top:2.2rem; padding-top:1.6rem; border-top:1px solid var(--line-soft); flex-wrap:wrap; }
.art-byline .a-ph{ width:50px; height:50px; border-radius:50%; overflow:hidden; flex:none; border:1px solid var(--line); background:var(--cream); }
.art-byline .a-ph img{ width:100%; height:100%; object-fit:cover; object-position:top center; }
.art-byline .a-name{ font-family:var(--display); font-weight:700; font-size:1rem; letter-spacing:-.01em; }
.art-byline .a-role{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--brass-deep); margin-top:.25em; }
.art-byline .a-dot{ width:4px; height:4px; border-radius:50%; background:var(--brass); }
.art-byline .a-meta{ font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; color:var(--slate); text-transform:uppercase; }

.art-body{ max-width:720px; margin-inline:auto; padding-bottom:clamp(3rem,7vh,5rem); }
.art-body > p{ font-size:1.13rem; line-height:1.78; color:#2a2c3c; margin-bottom:1.5rem; }
.art-body > p.lede{ font-size:clamp(1.25rem,2vw,1.5rem); line-height:1.55; color:var(--ink); font-weight:400; margin-bottom:1.8rem; }
.art-body h2{ font-size:clamp(1.5rem,2.8vw,2.05rem); line-height:1.15; letter-spacing:-.025em; margin:2.8rem 0 1rem; }
.art-body h3{ font-size:clamp(1.18rem,2vw,1.45rem); line-height:1.2; letter-spacing:-.015em; color:var(--indigo); margin:2.1rem 0 .7rem; }
.art-body strong{ font-weight:600; color:var(--ink); }
.art-body em{ font-style:italic; }
.art-body .rule{ height:1px; background:var(--line-soft); border:none; margin:2.6rem 0; }
.art-body .stat-call{ font-family:var(--display); font-weight:700; font-size:clamp(1.6rem,3vw,2.2rem); color:var(--indigo); letter-spacing:-.02em; line-height:1.2; margin:2rem 0; padding-left:1.2rem; border-left:3px solid var(--brass); }
.art-cmp{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin:1.6rem 0 1.8rem; }
@media(max-width:640px){ .art-cmp{ grid-template-columns:1fr; } }
.art-cmp .box{ border:1px solid var(--line-soft); border-radius:var(--radius-lg); padding:1.4rem 1.5rem; box-shadow:var(--shadow-sm); background:var(--paper); }
.art-cmp .box.old{ background:var(--paper-2); }
.art-cmp .box.new{ border-color:rgba(184,148,85,.4); }
.art-cmp .box .lbl{ display:inline-block; font-family:var(--mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; padding:.4em .8em; border-radius:100px; margin-bottom:.9rem; }
.art-cmp .box.old .lbl{ background:rgba(86,91,110,.12); color:var(--slate); }
.art-cmp .box.new .lbl{ background:var(--indigo); color:var(--gold); }
.art-cmp .box p{ font-size:.98rem; line-height:1.6; color:var(--slate); margin:0; }
.art-cmp .box.new p{ color:#33354a; }
.art-back{ margin-top:2.5rem; }
.art-share{ margin-top:2.6rem; padding-top:1.6rem; border-top:1px solid var(--line-soft); display:flex; gap:1rem; align-items:center; flex-wrap:wrap; }
/* in-article download callout */
.art-dl{ display:flex; align-items:center; gap:1.1rem; flex-wrap:wrap; background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--radius-lg); padding:1.2rem 1.4rem; margin:1.9rem 0; box-shadow:var(--shadow-sm); }
.art-dl .dl-ico{ flex:none; width:46px; height:56px; border:1px solid var(--line); border-radius:6px; background:var(--paper); position:relative; display:grid; place-items:end center; }
.art-dl .dl-ico span{ font-family:var(--mono); font-size:.52rem; letter-spacing:.06em; color:var(--brass-deep); padding-bottom:7px; }
.art-dl .dl-ico::before{ content:""; position:absolute; top:0; right:0; border-width:0 13px 13px 0; border-style:solid; border-color:var(--cream) var(--paper); }
.art-dl .dl-txt{ flex:1 1 240px; }
.art-dl .dl-txt strong{ display:block; font-family:var(--display); font-weight:700; font-size:1.05rem; letter-spacing:-.01em; color:var(--ink); }
.art-dl .dl-txt span{ display:block; color:var(--slate); font-size:.92rem; margin-top:.2rem; }
.art-dl .btn{ margin-left:auto; }
@media(max-width:520px){ .art-dl .btn{ margin-left:0; width:100%; justify-content:center; } }
/* article lists */
.art-body ul, .art-body ol{ margin:.2rem 0 1.6rem; padding-left:1.4rem; }
.art-body li{ margin-bottom:.55rem; color:#2a2c3c; line-height:1.7; padding-left:.2rem; }
.art-body ul li{ list-style:disc; }
.art-body ol li{ list-style:decimal; }
.art-body li::marker{ color:var(--brass-deep); }
.art-body li strong{ color:var(--ink); }
/* article tables */
.tbl-wrap{ overflow-x:auto; margin:1.6rem 0 2rem; border:1px solid var(--line-soft); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); }
.art-body table{ width:100%; border-collapse:collapse; font-size:.92rem; min-width:460px; }
.art-body th, .art-body td{ text-align:left; padding:.75rem .9rem; border-bottom:1px solid var(--line-soft); vertical-align:top; line-height:1.45; }
.art-body thead th{ font-family:var(--mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--brass-deep); background:var(--paper-2); }
.art-body tbody tr:last-child td{ border-bottom:none; }
.art-body tbody tr:hover{ background:var(--paper-2); }
.art-body td:first-child{ font-weight:500; color:var(--ink); }

/* ============================================================
   Resources library (categories / sub-categories)
   ============================================================ */
.res-cat{ margin-top:clamp(2rem,4vh,3rem); }
.res-cat:first-of-type{ margin-top:0; }
.res-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:clamp(1rem,1.5vw,1.3rem); }
.res-group{
  background:var(--paper); border:1px solid var(--line-soft); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm); padding:clamp(1.3rem,2vw,1.7rem);
  transition:box-shadow .5s var(--ease), border-color .5s var(--ease);
}
.res-group:hover{ box-shadow:var(--shadow-md); border-color:rgba(184,148,85,.35); }
.res-group .rg-head{ display:flex; align-items:baseline; justify-content:space-between; gap:.8rem; padding-bottom:.4rem; }
.res-group h3{ font-size:1.18rem; letter-spacing:-.02em; }
.res-group .rg-src{ font-family:var(--mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--brass-deep); white-space:nowrap; }
.res-doc{ display:flex; align-items:center; gap:.85rem; padding:.78rem 0; border-top:1px solid var(--line-soft); color:var(--ink); transition:padding-left .35s var(--ease); }
.res-doc .badge{ font-family:var(--mono); font-size:.55rem; letter-spacing:.06em; padding:.45em 0; border-radius:6px; flex:none; width:3.2em; text-align:center; }
.res-doc .badge.pdf{ background:rgba(184,148,85,.18); color:var(--brass-deep); }
.res-doc .badge.web{ background:rgba(47,42,118,.10); color:var(--indigo); }
.res-doc .d-name{ flex:1; font-size:.94rem; line-height:1.3; }
.res-doc .d-name small{ display:block; font-family:var(--mono); font-size:.62rem; letter-spacing:.06em; color:var(--slate); text-transform:uppercase; margin-top:.25em; }
.res-doc:hover{ padding-left:.3rem; }
.res-doc:hover .d-name{ color:var(--indigo); }
.res-doc .ext{ color:var(--brass-deep); flex:none; font-size:.9rem; transition:transform .35s var(--ease); }
.res-doc:hover .ext{ transform:translate(2px,-2px); }
.res-note{ font-family:var(--mono); font-size:.7rem; letter-spacing:.04em; color:var(--slate); margin-top:1.6rem; }
.res-note a{ color:var(--indigo); border-bottom:1px solid var(--brass); }

/* ============================================================
   Team page
   ============================================================ */
.team-grid{ display:grid; gap:clamp(1rem,1.8vw,1.6rem); }
.team-grid.partners{ grid-template-columns:repeat(2,1fr); max-width:840px; margin-inline:auto; }
.team-grid.members{ grid-template-columns:repeat(4,1fr); }
@media(max-width:900px){ .team-grid.members{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){ .team-grid.partners,.team-grid.members{ grid-template-columns:1fr; } }
@media(max-width:560px){ .team-grid.members{ grid-template-columns:1fr 1fr; } }

.person{
  background:var(--paper); border:1px solid var(--line-soft); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm); padding:clamp(1.6rem,2.6vw,2.3rem) clamp(1rem,2vw,1.6rem);
  text-align:center; display:flex; flex-direction:column; align-items:center;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
}
.person:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(184,148,85,.35); }
.person .ph{
  aspect-ratio:1; border-radius:50%; overflow:hidden; margin-bottom:1.4rem;
  background:var(--cream); border:1px solid var(--line); position:relative;
}
.person.partner .ph{ width:clamp(150px,18vw,200px); }
.person.member .ph{ width:clamp(120px,14vw,156px); }
.person.partner .ph img{ width:100%; height:100%; object-fit:cover; object-position:top center; filter:grayscale(.12) contrast(1.02); transition:filter .6s var(--ease), transform .8s var(--ease); }
.person.partner:hover .ph img{ filter:grayscale(0); transform:scale(1.05); }
.person .ph.shadow{
  background-color:var(--cream);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 120'%3E%3Cg fill='%239499b3'%3E%3Ccircle cx='60' cy='46' r='22'/%3E%3Cpath d='M18 116c0-26 19-42 42-42s42 16 42 42z'/%3E%3C/g%3E%3C/svg%3E");
  background-size:100% 100%; background-position:center; background-repeat:no-repeat;
}
.person h3{ font-size:clamp(1.2rem,1.9vw,1.5rem); letter-spacing:-.02em; line-height:1.15; }
.person .role{ font-family:var(--mono); font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--brass-deep); margin-top:.6rem; }
