/* ═══════════════════════════════════════════
   AmehX Consulting — Shared Stylesheet
   ═══════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  --ink:#0D1B2A; --ink2:#1E2D3D; --ink3:#2E3F52;
  --gold:#B8933A; --amber:#D4A84B;
  --ivory:#F7F4EF; --steel:#2C4A6E; --slate:#5A7A94;
  --n700:#374A5A;
  --n600:#4A5C6D; --n500:#6B7C8D; --n400:#8D9DAD;
  --n300:#B8C4CC; --n200:#D9E0E6; --n100:#EEF1F4;
  --white:#FFF;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans','Helvetica Neue',sans-serif;
  --mono:'DM Mono','Courier New',monospace;
  --ease:cubic-bezier(.25,.46,.45,.94);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);color:var(--ink);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:var(--sans)}
img{max-width:100%;display:block}

/* ── UTILITIES ── */
.wrap{width:100%;max-width:1200px;margin:0 auto;padding:0 clamp(20px,5vw,72px);box-sizing:border-box}
.wrap--sm{width:100%;max-width:880px;margin:0 auto;padding:0 clamp(20px,5vw,72px);box-sizing:border-box}
.overline{font-size:.6rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.rule{width:48px;height:2px;background:var(--gold);margin:20px 0}
.sec-head{margin-bottom:56px}
.sec-head .sec-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:600;color:var(--ink);line-height:1.08;letter-spacing:-.015em;margin-top:8px}
.sec-head .sec-sub{font-size:1rem;color:var(--n600);line-height:1.8;margin-top:14px;max-width:600px}
.dark .sec-head .sec-title,.ink .sec-head .sec-title{color:var(--white)}
.dark .sec-head .sec-sub,.ink .sec-head .sec-sub{color:var(--n400)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:all .25s var(--ease);cursor:pointer}
.btn-gold{background:var(--gold);color:var(--white);padding:14px 32px;border:1.5px solid var(--gold)}
.btn-gold:hover{background:var(--amber);border-color:var(--amber);transform:translateY(-2px);box-shadow:0 8px 24px rgba(184,147,58,.3)}
.btn-ghost{background:transparent;color:var(--white);padding:13px 31px;border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost:hover{border-color:rgba(255,255,255,.8);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);padding:13px 31px;border:1.5px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--white)}
.btn-text{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--gold);padding-bottom:2px;transition:color .2s,border-color .2s}
.btn-text:hover{color:var(--amber);border-color:var(--amber)}
.btn-text .arr{transition:transform .2s;display:inline-block}
.btn-text:hover .arr{transform:translateX(4px)}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

/* ══ NAV ══ */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;height:70px;display:flex;align-items:center;transition:background .3s,border-color .3s,box-shadow .3s;border-bottom:1px solid transparent}
.nav.scroll{background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom-color:var(--n200);box-shadow:0 1px 24px rgba(13,27,42,.07)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.nav-logo{font-family:var(--serif);font-size:1.6rem;font-weight:600;color:var(--white);letter-spacing:.04em;transition:color .3s}
.nav-logo em{color:var(--gold);font-style:normal}
.nav.scroll .nav-logo{color:var(--ink)}
/* On light-hero pages the logo/links are always dark */
.nav.light-page .nav-logo{color:var(--ink)}
.nav.light-page .nav-links a{color:var(--n600)}
.nav.light-page .nav-links a:hover{color:var(--ink)}
.nav.light-page .hamburger span{background:var(--ink)}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-size:.8125rem;font-weight:500;color:rgba(255,255,255,.7);letter-spacing:.04em;transition:color .2s;position:relative;padding-bottom:3px}
.nav-links a::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--white)}
.nav.scroll .nav-links a{color:var(--n600)}
.nav.scroll .nav-links a:hover,.nav.scroll .nav-links a.active{color:var(--ink)}
.nav.light-page .nav-links a.active{color:var(--ink)}
.nav-cta{font-size:.725rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border-bottom:1.5px solid var(--gold);padding-bottom:2px;transition:color .2s,border-color .2s}
.nav-cta:hover{color:var(--amber);border-color:var(--amber)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--white);transition:all .25s}
.nav.scroll .hamburger span{background:var(--ink)}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mob-menu{display:none;position:fixed;top:70px;inset-block-end:0;left:0;right:0;background:var(--ink);z-index:899;padding:48px 32px;flex-direction:column;gap:28px;overflow-y:auto}
.mob-menu.open{display:flex}
.mob-menu a{font-family:var(--serif);font-size:1.875rem;font-weight:300;color:var(--white);transition:color .2s}
.mob-menu a:hover{color:var(--gold)}
.mob-cta-row{margin-top:auto;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:12px}

/* ══ PAGE HERO (sub-pages) ══ */
.page-hero{background:var(--ink);padding:140px 0 72px;position:relative;overflow:hidden}
.page-hero-ring{position:absolute;border-radius:50%;border:1px solid rgba(184,147,58,.04)}
.page-hero-ring.r1{width:700px;height:700px;right:-100px;top:-150px;animation:spin 90s linear infinite}
.page-hero-ring.r2{width:400px;height:400px;right:60px;top:60px;animation:spin 60s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.page-hero-inner{position:relative;z-index:2}
.page-hero-eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.page-hero-eyebrow::before{content:'';display:block;width:32px;height:1px;background:var(--gold)}
.page-hero-title{font-family:var(--serif);font-size:clamp(2.25rem,5vw,4rem);font-weight:300;line-height:1.06;color:var(--white);letter-spacing:-.02em;max-width:780px;margin-bottom:16px}
.page-hero-title strong{font-weight:700;color:var(--gold)}
.page-hero-sub{font-size:clamp(.9rem,1.3vw,1.0625rem);color:var(--n400);max-width:560px;line-height:1.75;font-weight:300}

/* ══ HERO (home) ══ */
.hero{min-height:100vh;background:var(--ink);display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;padding:100px 0 72px}
.hero-bg-ring{position:absolute;border-radius:50%;border:1px solid rgba(184,147,58,.055)}
.hero-bg-ring.r1{width:900px;height:900px;right:-200px;top:-180px;animation:spin 90s linear infinite}
.hero-bg-ring.r2{width:560px;height:560px;right:0px;top:80px;animation:spin 70s linear infinite reverse}
.hero-bg-ring.r3{width:320px;height:320px;right:120px;top:200px;animation:spin 50s linear infinite}
.hero-inner{position:relative;z-index:2}
.hero-eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:20px;opacity:0;animation:fu .8s .1s var(--ease) forwards}
.hero-eyebrow::before{content:'';display:block;width:32px;height:1px;background:var(--gold)}
.hero-headline{font-family:var(--serif);font-size:clamp(2rem,6vw,5.25rem);font-weight:300;line-height:1.04;color:var(--white);letter-spacing:-.02em;max-width:800px;margin-bottom:12px;overflow-wrap:break-word;word-break:break-word;opacity:0;animation:fu .9s .25s var(--ease) forwards}
.hero-headline strong{font-weight:700;color:var(--gold)}
.hln{display:block}
.hero-tagline{font-size:clamp(.9rem,1.4vw,1.0625rem);color:var(--n400);max-width:580px;line-height:1.75;font-weight:300;margin-bottom:44px;opacity:0;animation:fu .9s .45s var(--ease) forwards}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fu .9s .6s var(--ease) forwards}
@keyframes fu{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* TICKER */
.ticker-wrap{overflow:hidden;margin-top:72px;border-top:1px solid rgba(255,255,255,.07);padding-top:28px;opacity:0;animation:fu .9s .9s var(--ease) forwards}
.ticker-label{font-size:.575rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--n500);margin-bottom:14px}
.ticker-track{display:flex;gap:48px;overflow:hidden;position:relative}
.ticker-track::after{content:'';position:absolute;right:0;top:0;bottom:0;width:80px;background:linear-gradient(to left,var(--ink) 0%,transparent 100%);pointer-events:none}
.ticker-inner{display:flex;gap:48px;animation:ticker 28s linear infinite;white-space:nowrap}
.ticker-inner:hover{animation-play-state:paused}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{font-family:var(--serif);font-size:1.0625rem;font-weight:600;color:var(--n400);letter-spacing:.02em}

/* ══ TRUST BAR ══ */
.trust{background:var(--ink2);border-top:1px solid rgba(184,147,58,.15);border-bottom:1px solid rgba(184,147,58,.15);padding:22px 0}
.trust-inner{display:flex;align-items:center;gap:40px;flex-wrap:wrap;justify-content:center}
.trust-lbl{font-size:.575rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--n500);white-space:nowrap}
.trust-divider{width:1px;height:20px;background:rgba(255,255,255,.1)}
.trust-clients{display:flex;gap:36px;flex-wrap:wrap;justify-content:center}
.trust-client{font-family:var(--serif);font-size:.9375rem;font-weight:600;color:var(--n400);letter-spacing:.02em}

/* ══ STATS / KPI ══ */
.stats{background:var(--ivory);padding:72px 0;border-bottom:1px solid var(--n200)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:40px;text-align:center}
.stat-num{font-family:var(--serif);font-size:clamp(2.5rem,4vw,3.5rem);font-weight:600;color:var(--ink);line-height:1;display:block}
.stat-num em{color:var(--gold);font-style:normal}
.stat-lbl{font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--n500);margin-top:8px;display:block}

/* ══ FIRM VALUE PROP (3 cols) ══ */
.vp{padding:88px 0;background:var(--white)}
.vp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--n200);margin-top:56px}
.vp-card{background:var(--white);padding:40px 36px;transition:background .25s}
.vp-card:hover{background:var(--ivory)}
.vp-num{font-family:var(--mono);font-size:.625rem;color:var(--gold);letter-spacing:.14em;margin-bottom:20px;display:block}
.vp-title{font-family:var(--serif);font-size:1.375rem;font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:14px}
.vp-body{font-size:.875rem;color:var(--n600);line-height:1.75}

/* ══ VIRTUAL TABS ══ */
.vtab-nav{display:flex;border-bottom:1px solid var(--n200);gap:0;overflow-x:auto;scrollbar-width:none}
.vtab-nav::-webkit-scrollbar{display:none}
.vtab-btn{padding:16px 28px;font-size:.8rem;font-weight:600;color:var(--n500);letter-spacing:.04em;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s;cursor:pointer}
.vtab-btn:hover{color:var(--ink)}
.vtab-btn.active{color:var(--ink);border-bottom-color:var(--gold)}
.vtab-panel{display:none;animation:panelIn .35s var(--ease) forwards}
.vtab-panel.active{display:block}
@keyframes panelIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ══ CAPABILITIES ══ */
.cap-section{padding:80px 0;background:var(--ivory)}
.cap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:2px;background:var(--n200);margin-top:8px}
.cap-card{background:var(--white);padding:36px 32px;position:relative;overflow:hidden;transition:background .25s;cursor:pointer}
.cap-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.cap-card:hover{background:var(--ivory)}
.cap-card:hover::before{transform:scaleX(1)}
.cap-icon{width:44px;height:44px;border:1px solid var(--n200);display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.cap-icon svg{width:20px;height:20px;stroke:var(--steel);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.cap-tag{font-size:.575rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.cap-title{font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:12px}
.cap-body{font-size:.875rem;color:var(--n600);line-height:1.7;margin-bottom:20px}
.cap-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.cap-tag-pill{font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--steel);border:1px solid var(--n200);padding:3px 10px}

/* ══ INDUSTRIES ══ */
.ind-section{padding:80px 0;background:var(--white)}
.ind-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;margin-top:8px}
.ind-card{border:1px solid var(--n200);padding:36px 32px;position:relative;overflow:hidden;transition:all .3s var(--ease)}
.ind-card:hover{border-color:var(--n300);box-shadow:0 12px 40px rgba(13,27,42,.08);transform:translateY(-3px)}
.ind-sector{font-size:.575rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.ind-title{font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--ink);margin-bottom:14px;line-height:1.2}
.ind-body{font-size:.875rem;color:var(--n600);line-height:1.75;margin-bottom:20px}
.ind-bullets{list-style:none;display:flex;flex-direction:column;gap:8px}
.ind-bullets li{font-size:.8125rem;color:var(--n600);display:flex;gap:8px}
.ind-bullets li::before{content:'→';color:var(--gold);font-size:.7rem;flex-shrink:0;margin-top:1px}

/* ══ CASE STUDIES ══ */
.cases{padding:88px 0;background:var(--white)}
.cases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px}
.case-card{border:1px solid var(--n200);padding:36px;position:relative;overflow:hidden;transition:all .3s var(--ease);cursor:pointer}
.case-card:hover{box-shadow:0 16px 48px rgba(13,27,42,.1);transform:translateY(-4px);border-color:var(--n300)}
.case-card.feat{background:var(--ink);border-color:transparent;grid-column:1/-1}
.case-card.feat .case-sector{color:var(--gold)}
.case-card.feat .case-title{color:var(--white)}
.case-card.feat .case-body{color:var(--n300)}
.case-card.feat .case-kpis{border-top-color:rgba(255,255,255,.1)}
.case-card.feat .kpi-n{color:var(--white)}
.case-card.feat .kpi-l{color:var(--n500)}
.case-card.feat .btn-text{color:var(--gold);border-color:var(--gold)}
.case-sector{font-size:.575rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.case-title{font-family:var(--serif);font-size:1.3125rem;font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:14px}
.case-body{font-size:.875rem;color:var(--n600);line-height:1.7;margin-bottom:22px}
.case-kpis{display:flex;gap:28px;flex-wrap:wrap;border-top:1px solid var(--n200);padding-top:20px;margin-top:20px}
.kpi-n{font-family:var(--serif);font-size:1.875rem;font-weight:600;color:var(--ink);line-height:1;display:block}
.kpi-n em{color:var(--gold);font-style:normal}
.kpi-l{font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--n500);margin-top:4px;display:block}

/* ══ USP / WHY AMEHX ══ */
.usp{padding:88px 0;background:var(--ink)}
.usp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2px;background:rgba(255,255,255,.06);margin-top:8px}
.usp-card{background:var(--ink);padding:40px 36px;border-top:3px solid transparent;transition:border-color .3s}
.usp-card:hover{border-top-color:var(--gold)}
.usp-icon{font-size:1.5rem;margin-bottom:20px;color:var(--gold);display:block}
.usp-title{font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--white);line-height:1.2;margin-bottom:12px}
.usp-body{font-size:.875rem;color:var(--n400);line-height:1.75;margin-bottom:16px}
.usp-vs{font-size:.7rem;font-weight:600;letter-spacing:.06em;color:var(--n600);font-style:italic;border-left:2px solid rgba(184,147,58,.3);padding-left:12px;line-height:1.6}
.usp-table-wrap{margin-top:56px;overflow-x:auto}
.usp-table{width:100%;border-collapse:collapse;min-width:600px}
.usp-table th{padding:13px 18px;font-size:.625rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--n400);text-align:left;border-bottom:1px solid rgba(255,255,255,.08)}
.usp-table td{padding:16px 18px;font-size:.875rem;color:var(--n400);line-height:1.6;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:top}
.usp-table td:first-child{color:var(--white);font-weight:500}
.usp-table td:last-child{color:rgba(120,210,150,.9)}

/* ══ WHO WE ARE ══ */
.who{padding:88px 0;background:var(--ivory)}
.who-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:72px;align-items:start;margin-top:56px}
.who-body{font-size:1rem;color:var(--n600);line-height:1.85;margin-bottom:18px}
.principles{display:flex;flex-direction:column;gap:2px;background:var(--n200);margin-top:40px}
.principle{background:var(--white);padding:20px 24px;display:flex;gap:20px;align-items:flex-start;transition:background .2s}
.principle:hover{background:var(--ivory)}
.p-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:6px}
.p-title{font-size:.8125rem;font-weight:600;color:var(--ink);margin-bottom:4px}
.p-body{font-size:.8rem;color:var(--n600);line-height:1.6}
.team-card{background:var(--ink);padding:40px;margin-bottom:24px}
.team-title{font-family:var(--serif);font-size:1.5rem;font-weight:300;color:var(--white);line-height:1.3;margin-bottom:16px}
.team-body{font-size:.875rem;color:var(--n400);line-height:1.75}
.certs-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.cert{font-family:var(--mono);font-size:.65rem;color:var(--steel);border:1px solid var(--n200);padding:5px 12px}

/* ══ INSIGHTS / BLOG ══ */
.insights{padding:80px 0;background:var(--white);border-top:1px solid var(--n100)}
.insights-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-top:8px}
.insight-card{border:1px solid var(--n200);padding:32px;transition:all .3s var(--ease);cursor:pointer;display:flex;flex-direction:column}
.insight-card:hover{border-color:var(--n300);box-shadow:0 8px 32px rgba(13,27,42,.07)}
.insight-card a{text-decoration:none;color:inherit;display:flex;flex-direction:column;flex:1}
.insight-cat{font-size:.575rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.insight-title{font-family:var(--serif);font-size:1.125rem;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:14px}
.insight-body{font-size:.8125rem;color:var(--n600);line-height:1.7;margin-bottom:20px;flex:1}
.insight-meta{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--n400);margin-top:auto}

/* Insights listing page filter */
.insights-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px}
.filter-btn{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:8px 18px;border:1.5px solid var(--n200);color:var(--n500);background:var(--white);cursor:pointer;transition:all .2s}
.filter-btn:hover,.filter-btn.active{background:var(--ink);color:var(--white);border-color:var(--ink)}
.insights-empty{text-align:center;padding:60px 0;color:var(--n400);font-size:.9rem}

/* Single post */
.post-hero{background:var(--ink);padding:140px 0 72px;position:relative;overflow:hidden}
.post-hero-ring{position:absolute;border-radius:50%;border:1px solid rgba(184,147,58,.04)}
.post-hero-ring.r1{width:700px;height:700px;right:-100px;top:-150px;animation:spin 90s linear infinite}
.post-meta-bar{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-bottom:28px}
.post-cat{font-size:.575rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.post-date{font-size:.7rem;color:var(--n500);letter-spacing:.06em}
.post-read{font-size:.7rem;color:var(--n500)}
.post-body-wrap{padding:72px 0 88px;background:var(--white)}
.post-body{font-size:1rem;color:var(--n700);line-height:1.85;max-width:740px}
.post-body h2{font-family:var(--serif);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:600;color:var(--ink);line-height:1.15;margin:40px 0 16px}
.post-body h3{font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--ink);margin:28px 0 12px}
.post-body p{margin-bottom:20px}
.post-body ul,.post-body ol{margin:16px 0 20px 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.post-body ul li,.post-body ol li{font-size:.9375rem;color:var(--n600);display:flex;gap:10px;line-height:1.7}
.post-body ul li::before{content:'→';color:var(--gold);flex-shrink:0}
.post-body ol{counter-reset:items}
.post-body ol li{counter-increment:items}
.post-body ol li::before{content:counter(items)'.';color:var(--gold);font-family:var(--mono);font-size:.8rem;flex-shrink:0;margin-top:2px}
.post-body blockquote{border-left:3px solid var(--gold);padding:20px 28px;background:var(--ivory);margin:24px 0;font-family:var(--serif);font-size:1.125rem;color:var(--ink);font-style:italic;line-height:1.6}
.post-body strong{color:var(--ink);font-weight:600}
.post-back{display:inline-flex;align-items:center;gap:8px;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--gold);padding-bottom:2px;margin-top:48px;transition:color .2s}
.post-back:hover{color:var(--amber)}
.post-back .arr{display:inline-block;transition:transform .2s}
.post-back:hover .arr{transform:translateX(-4px)}
.related-posts{padding:72px 0;background:var(--ivory);border-top:1px solid var(--n200)}

/* Loading skeleton */
.skeleton{background:linear-gradient(90deg,var(--n100) 25%,var(--n200) 50%,var(--n100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-card{border:1px solid var(--n200);padding:32px;height:240px}

/* ══ CTA BAND ══ */
.cta-band{background:var(--ink);padding:88px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 700px 300px at 50% 50%,rgba(184,147,58,.05) 0%,transparent 70%)}
.cta-band .wrap{position:relative;z-index:1}
.cta-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:300;color:var(--white);line-height:1.1;letter-spacing:-.01em;margin-bottom:8px}
.cta-title strong{font-weight:700}
.cta-sub{font-size:1rem;color:var(--n400);margin-bottom:40px;font-weight:300}
.cta-contact{margin-top:32px;font-size:.875rem;color:var(--n500)}
.cta-contact a{color:var(--slate);transition:color .2s}
.cta-contact a:hover{color:var(--white)}

/* ══ CONTACT ══ */
.contact-sec{padding:88px 0;background:var(--ivory)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;margin-top:48px}
.contact-info-row{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
.contact-info-row a{font-size:.875rem;color:var(--steel);transition:color .2s}
.contact-info-row a:hover{color:var(--ink)}
.contact-steps{list-style:none;display:flex;flex-direction:column;gap:0;background:var(--n200);counter-reset:steps}
.contact-steps li{background:var(--white);padding:16px 20px;display:flex;align-items:flex-start;gap:16px;counter-increment:steps;transition:background .2s}
.contact-steps li:hover{background:var(--ivory)}
.contact-steps li::before{content:counter(steps);font-family:var(--mono);font-size:.7rem;font-weight:500;color:var(--gold);border:1px solid var(--gold);width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.contact-steps span{font-size:.875rem;color:var(--n700);line-height:1.6}

/* Form */
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fg{display:flex;flex-direction:column;gap:7px}
.fg.full{grid-column:1/-1}
.flbl{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--n600)}
.finp,.fsel,.ftxt{font-family:var(--sans);font-size:.9375rem;color:var(--ink);background:var(--white);border:1.5px solid var(--n300);padding:12px 14px;outline:none;transition:border-color .2s,box-shadow .2s;width:100%;appearance:none;-webkit-appearance:none}
.ftxt{resize:vertical;min-height:96px}
.finp::placeholder,.ftxt::placeholder{color:var(--n400)}
.finp:focus,.fsel:focus,.ftxt:focus{border-color:var(--steel);box-shadow:0 0 0 3px rgba(44,74,110,.1)}
.finp.err,.fsel.err,.ftxt.err{border-color:#C0392B}
.fsub{margin-top:20px;width:100%;justify-content:center}
.form-note{font-size:.75rem;color:var(--n500);margin-top:12px;text-align:center}
/* Honeypot field */
.hp-field{position:absolute;left:-9999px;top:-9999px;opacity:0;pointer-events:none;tabindex:-1}
/* Success state */
#form-ok{display:none;text-align:center;padding:28px 0}
#form-ok .ok-icon{font-size:2rem;color:var(--gold);margin-bottom:16px}
#form-ok .ok-title{font-family:var(--serif);font-size:1.75rem;color:var(--ink);margin-bottom:10px}
#form-ok p{font-size:.9375rem;color:var(--n600);line-height:1.7}
/* Error banner */
.form-error{background:#FEF2F2;border:1px solid #FECACA;color:#991B1B;padding:12px 16px;font-size:.8125rem;margin-bottom:16px;display:none}
.form-error.show{display:block}

/* ══ FOOTER ══ */
.footer{background:var(--ink);border-top:1px solid rgba(184,147,58,.15);padding:56px 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo{font-family:var(--serif);font-size:1.4rem;font-weight:600;color:var(--white);letter-spacing:.04em;margin-bottom:12px}
.footer-logo em{color:var(--gold);font-style:normal}
.footer-tag{font-size:.8125rem;color:var(--n500);line-height:1.7;max-width:240px}
.footer-col-hd{font-size:.625rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:.8125rem;color:var(--n500);transition:color .2s}
.footer-col ul a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.footer-legal{font-size:.7rem;color:var(--n600)}

/* ══ MODALS ══ */
.overlay{position:fixed;inset:0;background:rgba(13,27,42,.88);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;opacity:0;pointer-events:none;transition:opacity .3s;overflow-y:auto;backdrop-filter:blur(4px)}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--white);max-width:800px;width:100%;position:relative;transform:translateY(20px);transition:transform .35s var(--ease)}
.overlay.open .modal{transform:none}
.mhdr{background:var(--ink);padding:40px 44px 32px;position:relative}
.mhdr::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold) 0%,transparent 65%)}
.m-sector{font-size:.575rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.m-title{font-family:var(--serif);font-size:clamp(1.375rem,3vw,1.875rem);font-weight:300;color:var(--white);line-height:1.15}
.m-close{position:absolute;top:18px;right:18px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:var(--n400);font-size:1.125rem;border:1px solid rgba(255,255,255,.1);transition:color .2s;cursor:pointer}
.m-close:hover{color:var(--white)}
.mrow{display:grid;grid-template-columns:130px 1fr;border-bottom:1px solid var(--n100)}
.mrow:last-child{border:none}
.mlbl{padding:20px 20px;font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);background:var(--ivory);border-right:1px solid var(--n200);display:flex;align-items:flex-start}
.mcnt{padding:20px 26px;font-size:.9375rem;color:var(--n700);line-height:1.75}
.mcnt strong{color:var(--ink);font-weight:600}
.mkpis{padding:24px 44px;background:var(--ivory);display:flex;gap:32px;flex-wrap:wrap;border-top:1px solid var(--n200)}
.scap-body{padding:32px 44px}
.scap-body p{font-size:.9375rem;color:var(--n700);line-height:1.8;margin-bottom:14px}
.scap-body ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin:16px 0}
.scap-body ul li{font-size:.875rem;color:var(--n600);display:flex;gap:10px}
.scap-body ul li::before{content:'→';color:var(--gold);flex-shrink:0}

/* ══ 404 ══ */
.not-found{min-height:100vh;background:var(--ink);display:flex;align-items:center;padding:100px 0}
.not-found-num{font-family:var(--serif);font-size:clamp(6rem,15vw,12rem);font-weight:700;color:rgba(184,147,58,.15);line-height:1;margin-bottom:-20px}
.not-found-title{font-family:var(--serif);font-size:clamp(1.75rem,4vw,3rem);font-weight:300;color:var(--white);margin-bottom:16px;line-height:1.1}
.not-found-body{font-size:1rem;color:var(--n400);line-height:1.75;max-width:480px;margin-bottom:36px}

/* ══ RESPONSIVE ══ */
@media(max-width:1024px){
  .who-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .vp-grid{grid-template-columns:1fr}
}

/* ── Tablet / large phone ── */
@media(max-width:768px){
  /* Nav collapse */
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  /* Modal / table adjustments */
  .mrow{grid-template-columns:1fr}
  .mlbl{border-right:none;border-bottom:1px solid var(--n200)}
  .mhdr{padding:28px 24px 22px}
  .scap-body,.mkpis{padding:20px 24px}
  .usp-table{font-size:.8rem}
  .usp-table td{padding:12px}
  .fgrid{grid-template-columns:1fr}
  /* Hero: convert block line-break spans to inline — text wraps naturally */
  .hln{display:inline}
  .hero{padding:80px 0 48px}
  .hero-tagline{max-width:100%;font-size:.9375rem}
  .ticker-wrap{margin-top:40px}
}

/* ── Mobile (phones up to 600 px) ── */
@media(max-width:600px){
  /* Headline: fluid font, never clips */
  .hero-headline{font-size:clamp(1.75rem,7.5vw,2.375rem)}
  /* CTAs: CSS grid is the most reliable way to get full-width stacked buttons —
     no flex-direction, no inline-flex, no width:100% cascade issues */
  .hero-ctas{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    width:100%
  }
  .hero-ctas .btn{
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    text-align:center;
    padding:15px 20px;
    box-sizing:border-box;
    letter-spacing:.06em
  }
}

/* ── Small phone grids ── */
@media(max-width:480px){
  .cases-grid,.cap-grid,.ind-grid,.usp-grid,.vp-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}

/* ── Analytics placeholder ──
   Uncomment and replace G-XXXXXXXXXX with your Google Analytics ID
   or use the Plausible snippet instead.
   ────────────────────────────────────────
   <script async src="https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX"></script>
   <script>
     window.dataLayer = window.dataLayer || [];
     function gtag(){dataLayer.push(arguments);}
     gtag('js', new Date());
     gtag('config', 'G-XXXXXXXXXX');
   </script>
   ──────────────────────────────────────── */
