/* =========================================================================
   Eraqus Advisors — styles.css
   Premium corporate advisory theme. Vanilla CSS, no frameworks.
   ========================================================================= */

/* ---------- Fonts (self-hosted, latin subset) ---------- */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/inter-400.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/inter-500.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/inter-600.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/inter-700.woff2') format('woff2');}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/playfair-display-600.woff2') format('woff2');}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/playfair-display-700.woff2') format('woff2');}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:800;font-display:swap;src:url('../fonts/playfair-display-800.woff2') format('woff2');}

/* ---------- Design tokens ---------- */
:root{
  --navy:#3D4D65;
  --deep-navy:#222E40;
  --ink:#15171C;
  --steel:#6E8CA6;
  --mist:#8CA3BC;
  --silver:#C9D3DC;
  --cream:#F4F2EE;
  --white:#FFFFFF;

  --text:#2b3344;
  --muted:#5d6678;
  --line:#e4e7ec;
  --line-soft:#eef0f3;

  --serif:'Playfair Display',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;

  --container:1180px;
  --radius:10px;
  --radius-sm:7px;
  --shadow-sm:0 1px 2px rgba(21,23,28,.06),0 1px 3px rgba(21,23,28,.05);
  --shadow:0 6px 24px rgba(34,46,64,.08);
  --shadow-lg:0 18px 48px rgba(34,46,64,.14);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--sans);color:var(--text);background:var(--white);
  font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--navy);text-decoration:none;}
a:hover{color:var(--steel);}
ul{margin:0;padding:0;}
h1,h2,h3,h4{font-family:var(--serif);color:var(--deep-navy);line-height:1.2;font-weight:700;margin:0 0 .6em;}
h1{font-size:clamp(2rem,4.4vw,3rem);}
h2{font-size:clamp(1.6rem,3.2vw,2.25rem);}
h3{font-size:clamp(1.2rem,2vw,1.45rem);}
h4{font-size:1.1rem;}
p{margin:0 0 1.1rem;}
strong{color:var(--deep-navy);}
:focus-visible{outline:3px solid var(--steel);outline-offset:2px;border-radius:3px;}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px;}
.container-narrow{max-width:820px;}
.section{padding:84px 0;}
.section-sm{padding:56px 0;}
.section--cream{background:var(--cream);}
.section--navy{background:var(--deep-navy);color:#d7deea;}
.section--navy h2,.section--navy h3{color:#fff;}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:.78rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--steel);margin:0 0 .9rem;display:block;}
.section--navy .eyebrow{color:var(--mist);}
.section-head{max-width:760px;margin:0 auto 52px;text-align:center;}
.section-head.left{margin-left:0;text-align:left;}
.lead{font-size:1.13rem;color:var(--muted);line-height:1.7;}
.center{text-align:center;}
.mt-0{margin-top:0;}.mb-0{margin-bottom:0;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:600;
  font-size:.97rem;line-height:1;padding:.85rem 1.5rem;border-radius:var(--radius-sm);
  border:1.5px solid transparent;cursor:pointer;transition:transform .2s var(--ease),
  background .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease);
  text-align:center;}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--navy);color:#fff;box-shadow:var(--shadow-sm);}
.btn-primary:hover{background:var(--deep-navy);color:#fff;box-shadow:var(--shadow);}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--silver);}
.btn-outline:hover{border-color:var(--navy);color:var(--navy);background:rgba(61,77,101,.04);}
.btn-light{background:#fff;color:var(--deep-navy);}
.btn-light:hover{background:var(--cream);color:var(--deep-navy);}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4);}
.btn-ghost-light:hover{background:rgba(255,255,255,.1);color:#fff;border-color:#fff;}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;}
.btn-row.center{justify-content:center;}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:#fff;
  border-bottom:1px solid var(--line);}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:74px;}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0;}
.brand:hover{color:inherit;}
.brand-mark{width:42px;height:42px;flex-shrink:0;}
.brand-text{display:flex;flex-direction:column;font-family:var(--serif);font-weight:700;
  font-size:1.2rem;color:var(--deep-navy);line-height:1.05;}
.brand-text small{font-family:var(--sans);font-weight:600;font-size:.6rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--steel);margin-top:3px;}

/* ---------- Navigation ---------- */
.main-nav{display:flex;align-items:center;}
.nav-list{display:flex;align-items:center;gap:2px;list-style:none;}
.nav-list>li{position:relative;}
.nav-list>li>a{display:inline-flex;align-items:center;gap:4px;padding:.6rem .6rem;font-weight:500;
  font-size:.9rem;color:var(--text);border-radius:6px;position:relative;white-space:nowrap;}
.nav-list>li>a:hover,.nav-list>li>a:focus-visible{color:var(--navy);}
/* underline animation */
.nav-list>li>a::after{content:"";position:absolute;left:.6rem;right:.6rem;bottom:.4rem;height:2px;
  background:var(--steel);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease);}
.nav-list>li:hover>a::after,.nav-list>li:focus-within>a::after{transform:scaleX(1);}
.nav-list .chev{width:11px;height:11px;transition:transform .25s var(--ease);}
.has-dropdown:hover .chev,.has-dropdown:focus-within .chev{transform:rotate(180deg);}

/* dropdown */
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:288px;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:8px;list-style:none;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s;}
.dropdown::before{content:"";position:absolute;top:-8px;left:0;right:0;height:8px;}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown,.dropdown.open{
  opacity:1;visibility:visible;transform:translateY(0);}
.dropdown li a{display:block;padding:.6rem .8rem;border-radius:6px;font-size:.92rem;color:var(--text);
  font-weight:500;transition:background .18s,color .18s;}
.dropdown li a:hover,.dropdown li a:focus-visible{background:var(--cream);color:var(--navy);}
.dropdown li.is-overview a{color:var(--navy);font-weight:600;border-bottom:1px solid var(--line-soft);
  border-radius:6px 6px 0 0;margin-bottom:4px;}

.nav-cta{margin-left:6px;}
.nav-cta a{white-space:nowrap;padding:.7rem 1.1rem;font-size:.9rem;}
/* CTA button keeps white text (override the generic nav-link colour + underline) */
.nav-list .nav-cta a,
.nav-list .nav-cta a:hover,
.nav-list .nav-cta a:focus-visible{color:#fff;}
.nav-list .nav-cta a::after{display:none;}
.submenu-toggle{display:none;}
.nav-toggle{display:none;}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(160deg,#2a384e 0%,#222E40 55%,#1a2433 100%);
  color:#dde4ef;overflow:hidden;}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(620px 420px at 88% 12%,rgba(140,163,188,.22),transparent 60%),
  radial-gradient(520px 360px at 10% 92%,rgba(110,140,166,.16),transparent 60%);pointer-events:none;}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;
  align-items:center;padding:92px 0 100px;}
.hero h1{color:#fff;margin-bottom:1rem;letter-spacing:-.01em;}
.hero .lead{color:#c4cedd;font-size:1.18rem;max-width:42ch;}
.hero-eyebrow{color:var(--mist);}
.hero-points{list-style:none;margin:26px 0 30px;display:grid;gap:12px;}
.hero-points li{display:flex;align-items:flex-start;gap:10px;color:#cfd8e6;font-size:.98rem;}
.hero-points svg{flex-shrink:0;margin-top:3px;color:var(--mist);}
.hero-figure{position:relative;display:flex;align-items:center;justify-content:center;}
.hero-diamond{width:min(78%,360px);filter:drop-shadow(0 26px 60px rgba(0,0,0,.4));animation:floaty 7s ease-in-out infinite;}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(1.5deg)}}
.hero-card{position:absolute;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);
  border-radius:12px;padding:14px 18px;backdrop-filter:blur(4px);font-size:.85rem;color:#e6ecf5;}
.hero-card strong{color:#fff;display:block;font-family:var(--serif);font-size:1.05rem;}
.hero-card.c1{top:8%;left:-4%;}
.hero-card.c2{bottom:6%;right:-2%;}

/* ---------- Page banner (interior pages) ---------- */
.page-banner{background:linear-gradient(160deg,#2a384e,#222E40);color:#dbe2ee;padding:54px 0 46px;
  position:relative;overflow:hidden;}
.page-banner::after{content:"";position:absolute;inset:0;background:
  radial-gradient(480px 320px at 92% 0%,rgba(140,163,188,.18),transparent 60%);pointer-events:none;}
.page-banner .container{position:relative;z-index:1;}
.page-banner h1{color:#fff;margin-bottom:.5rem;}
.page-banner p{color:#c4cedd;max-width:62ch;margin:0;}

/* ---------- Breadcrumbs ---------- */
.breadcrumb{font-size:.83rem;color:var(--mist);margin-bottom:18px;}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;align-items:center;}
.breadcrumb a{color:#cdd6e3;}
.breadcrumb a:hover{color:#fff;}
.breadcrumb li+li::before{content:"/";margin-right:6px;color:rgba(255,255,255,.4);}
.breadcrumb [aria-current]{color:#fff;}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:24px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),
  border-color .3s var(--ease);height:100%;display:flex;flex-direction:column;}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--silver);}
.card .icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,#eef2f7,#dde5ee);color:var(--navy);margin-bottom:18px;}
.card .icon svg{width:26px;height:26px;}
.card h3{margin-bottom:.5rem;font-size:1.22rem;}
.card p{color:var(--muted);font-size:.96rem;margin-bottom:1rem;}
.card .card-link{margin-top:auto;font-weight:600;font-size:.92rem;color:var(--navy);
  display:inline-flex;align-items:center;gap:6px;}
.card .card-link svg{transition:transform .25s var(--ease);}
.card:hover .card-link svg{transform:translateX(4px);}
a.card{color:inherit;}

/* simple link list card (sub-services) */
.linkcard{display:flex;flex-direction:column;gap:4px;padding:22px 24px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);}
.linkcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--silver);}
.linkcard h3{font-size:1.12rem;margin-bottom:.3rem;}
.linkcard p{color:var(--muted);font-size:.92rem;margin:0;}
a.linkcard{color:inherit;}

/* ---------- Pillars (homepage) ---------- */
.pillar{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;}
.pillar .icon{width:54px;height:54px;}

/* ---------- Counters ---------- */
.counters{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;text-align:center;}
.counter .num{font-family:var(--serif);font-weight:800;font-size:clamp(2.4rem,5vw,3.4rem);
  color:#fff;line-height:1;letter-spacing:-.01em;}
.counter .num .plus{color:var(--mist);}
.counter .label{margin-top:10px;font-size:.98rem;color:#c4cedd;font-weight:500;}

/* ---------- Feature / why list ---------- */
.feature{display:flex;gap:16px;align-items:flex-start;}
.feature .tick{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:var(--cream);
  color:var(--navy);display:flex;align-items:center;justify-content:center;}
.section--navy .feature .tick{background:rgba(255,255,255,.1);color:#fff;}
.feature h3{font-size:1.1rem;margin-bottom:.3rem;}
.feature p{color:var(--muted);font-size:.94rem;margin:0;}
.section--navy .feature p{color:#bcc6d6;}

/* ---------- Process steps ---------- */
.steps{counter-reset:step;display:grid;gap:24px;}
.step{position:relative;padding-left:64px;}
.step::before{counter-increment:step;content:counter(step);position:absolute;left:0;top:0;
  width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;font-family:var(--serif);
  font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1.1rem;}
.step h3{font-size:1.12rem;margin-bottom:.25rem;}
.step p{color:var(--muted);margin:0;font-size:.95rem;}

/* ---------- Content / prose ---------- */
.prose p{margin-bottom:1.15rem;line-height:1.78;}
.prose.justify p{text-align:justify;text-justify:inter-word;}
.prose h2{margin-top:2.2rem;}
.prose h3{margin-top:1.6rem;}
.prose ul.bullets{list-style:none;margin:0 0 1.3rem;display:grid;gap:.6rem;}
.prose ul.bullets li{position:relative;padding-left:28px;color:var(--text);}
.prose ul.bullets li::before{content:"";position:absolute;left:4px;top:9px;width:9px;height:9px;
  border-radius:2px;transform:rotate(45deg);background:var(--steel);}
.content-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start;}
.sidebar{position:sticky;top:96px;display:grid;gap:22px;}
.sidebar .box{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:24px;}
.sidebar .box h3{font-size:1.05rem;}
.sidebar .box.navy{background:var(--deep-navy);color:#cdd6e3;border:none;}
.sidebar .box.navy h3{color:#fff;}
.sidebar .links{list-style:none;display:grid;gap:2px;}
.sidebar .links a{display:block;padding:.5rem .6rem;border-radius:6px;font-size:.92rem;font-weight:500;color:var(--text);}
.sidebar .links a:hover{background:#fff;color:var(--navy);}

.note{background:var(--cream);border-left:3px solid var(--steel);padding:18px 22px;border-radius:0 8px 8px 0;
  font-size:.92rem;color:var(--muted);margin:1.5rem 0;}

/* ---------- FAQ accordion ---------- */
.faq{display:grid;gap:12px;max-width:840px;margin:0 auto;}
.faq-item{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden;}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--serif);
  font-weight:700;font-size:1.05rem;color:var(--deep-navy);padding:20px 56px 20px 24px;position:relative;}
.faq-q::after{content:"";position:absolute;right:24px;top:50%;width:12px;height:12px;
  border-right:2px solid var(--steel);border-bottom:2px solid var(--steel);transform:translateY(-65%) rotate(45deg);
  transition:transform .3s var(--ease);}
.faq-item.open .faq-q::after{transform:translateY(-35%) rotate(-135deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease);}
.faq-a-inner{padding:0 24px 20px;color:var(--muted);font-size:.96rem;}

/* ---------- Managing partner ---------- */
.partner{display:grid;grid-template-columns:300px 1fr;gap:44px;align-items:start;}
.partner-photo{position:relative;}
.partner-photo img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;}
.partner-photo .badge{position:absolute;bottom:-14px;left:-14px;background:var(--navy);color:#fff;
  padding:12px 16px;border-radius:10px;box-shadow:var(--shadow);font-size:.82rem;}
.partner-photo .badge strong{display:block;color:#fff;font-family:var(--serif);font-size:1.05rem;}
.partner .role{color:var(--steel);font-weight:600;font-size:.9rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.6rem;}
.linkedin-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.92rem;margin-top:.4rem;}

/* ---------- Insights cards ---------- */
.article-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);height:100%;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);}
.article-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--silver);}
.article-card .thumb{aspect-ratio:16/9;background:linear-gradient(150deg,#2a384e,#3D4D65);position:relative;
  overflow:hidden;}
.article-card .thumb img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .45s var(--ease);}
.article-card:hover .thumb img{transform:scale(1.045);}
.article-card .body{padding:24px;display:flex;flex-direction:column;flex:1;}
.tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--steel);margin-bottom:10px;}
.article-card h3{font-size:1.18rem;margin-bottom:.5rem;}
.article-card p{color:var(--muted);font-size:.94rem;flex:1;}
.byline{font-size:.85rem;color:var(--muted);margin-top:12px;display:flex;align-items:center;gap:8px;}
.byline .avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;}
a.article-card{color:inherit;}

/* article header meta */
.article-meta{display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;color:var(--muted);font-size:.9rem;margin-bottom:8px;}
.article-author{display:flex;align-items:center;gap:10px;}
.article-author img{width:42px;height:42px;border-radius:50%;object-fit:cover;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;
  text-align:center;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);}
.contact-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.contact-card .icon{width:54px;height:54px;border-radius:14px;margin:0 auto 16px;
  background:linear-gradient(150deg,#eef2f7,#dde5ee);color:var(--navy);display:flex;align-items:center;justify-content:center;}
.contact-card .icon svg{width:26px;height:26px;}
.contact-card h3{font-size:1.12rem;margin-bottom:.4rem;}
.contact-card a{font-weight:600;}
.info-row{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px;}
.info-row .icon{flex-shrink:0;width:42px;height:42px;border-radius:10px;background:var(--cream);
  color:var(--navy);display:flex;align-items:center;justify-content:center;}
.info-row .icon svg{width:20px;height:20px;}

/* ---------- Map embed (Contact page) ---------- */
.map-embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);background:var(--cream);}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg,#2a384e,#222E40);color:#fff;border-radius:16px;
  padding:54px;text-align:center;position:relative;overflow:hidden;}
.cta-band::after{content:"";position:absolute;inset:0;background:
  radial-gradient(420px 280px at 85% 20%,rgba(140,163,188,.22),transparent 60%);pointer-events:none;}
.cta-band>*{position:relative;z-index:1;}
.cta-band h2{color:#fff;}
.cta-band p{color:#c4cedd;max-width:60ch;margin:0 auto 26px;}

/* ---------- Footer ---------- */
.site-footer{background:var(--deep-navy);color:#aeb9c9;font-size:.92rem;}
.footer-top{padding:64px 0 44px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;}
.footer-brand .brand-text{color:#fff;}
.footer-brand .brand-text small{color:var(--mist);}
.footer-brand p{margin:18px 0 0;color:#9fabbd;max-width:34ch;line-height:1.7;}
.footer h4{color:#fff;font-family:var(--sans);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  font-weight:600;margin-bottom:16px;}
.footer-col ul{list-style:none;display:grid;gap:9px;}
.footer-col a{color:#aeb9c9;}
.footer-col a:hover{color:#fff;}
.footer-contact li{display:flex;gap:10px;margin-bottom:14px;align-items:flex-start;}
.footer-contact svg{flex-shrink:0;width:18px;height:18px;margin-top:3px;color:var(--mist);}
.footer-contact .maps-link{display:inline-flex;align-items:center;gap:6px;margin-top:2px;font-size:.85rem;
  color:var(--mist);font-weight:500;}
.footer-contact .maps-link:hover{color:#fff;}
.footer-contact .maps-link svg{margin-top:0;}
.footer-contact a{color:#cdd6e3;}
.socials{display:flex;gap:10px;margin-top:18px;}
.socials a{width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.07);
  display:flex;align-items:center;justify-content:center;color:#cdd6e3;transition:background .2s,color .2s,transform .2s;}
.socials a:hover{background:var(--steel);color:#fff;transform:translateY(-2px);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;
  flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:.85rem;color:#8c98ab;}
.footer-bottom a{color:#aeb9c9;}
.footer-bottom .legal{display:flex;gap:18px;flex-wrap:wrap;}

/* ---------- Scroll reveal animations ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.is-visible{opacity:1;transform:none;}
.reveal-delay-1{transition-delay:.08s;}
.reveal-delay-2{transition-delay:.16s;}
.reveal-delay-3{transition-delay:.24s;}
.reveal-delay-4{transition-delay:.32s;}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important;}
  .reveal{opacity:1;transform:none;}
}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:24px;padding:64px 0 72px;}
  .hero-figure{display:none;}
  .content-layout{grid-template-columns:1fr;}
  .sidebar{position:static;}
  .partner{grid-template-columns:240px 1fr;gap:32px;}
}

@media (max-width:1200px){
  /* Mobile nav */
  .nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:42px;
    background:none;border:1px solid var(--line);border-radius:8px;cursor:pointer;}
  .nav-toggle span{display:block;height:2px;width:22px;margin:0 auto;background:var(--deep-navy);
    transition:transform .3s var(--ease),opacity .2s;}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .nav-list{position:fixed;top:74px;left:0;right:0;bottom:0;background:#fff;flex-direction:column;
    align-items:stretch;gap:0;padding:14px 18px 40px;overflow-y:auto;transform:translateX(100%);
    transition:transform .32s var(--ease);box-shadow:var(--shadow-lg);}
  .nav-list.open{transform:translateX(0);}
  .nav-list>li{border-bottom:1px solid var(--line-soft);}
  .nav-list>li>a{padding:1rem .25rem;font-size:1.05rem;font-weight:600;justify-content:space-between;}
  .nav-list>li>a::after{display:none;}
  .nav-list .chev{display:none;}
  .has-dropdown{display:flex;flex-wrap:wrap;align-items:center;}
  .has-dropdown>a{flex:1;}
  .submenu-toggle{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;
    background:none;border:none;cursor:pointer;color:var(--navy);}
  .submenu-toggle svg{width:16px;height:16px;transition:transform .3s var(--ease);}
  .submenu-toggle[aria-expanded="true"] svg{transform:rotate(180deg);}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;
    width:100%;max-height:0;overflow:hidden;padding:0;transition:max-height .32s var(--ease);background:var(--cream);
    border-radius:8px;margin:0 0 8px;}
  .dropdown.open{max-height:640px;padding:6px;}
  .nav-cta{margin:18px 0 0;}
  .nav-cta a{width:100%;justify-content:center;padding:1rem;}
}

@media (max-width:820px){
  .section{padding:60px 0;}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
  .counters{grid-template-columns:1fr;gap:34px;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}
  .partner{grid-template-columns:1fr;}
  .partner-photo{max-width:280px;}
  .cta-band{padding:40px 24px;}
  /* avoid justified text harming readability on small screens */
  .prose.justify p{text-align:left;}
}

@media (max-width:520px){
  .footer-top{grid-template-columns:1fr;}
  .brand-text{font-size:1.15rem;}
  .section-head{margin-bottom:36px;}
  .btn{width:100%;justify-content:center;}
  .btn-row .btn{width:100%;}
}

/* ---------- Utilities ---------- */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0 0 0 0);white-space:nowrap;border:0;}
.skip-link{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;
  z-index:200;border-radius:0 0 8px 0;}
.skip-link:focus{left:0;color:#fff;}
