/* ===========================================================
   Immunity Networks — Enterprise Design System
   Shared across all pages. Brand: maroon #770026.
   =========================================================== */
:root{
  --maroon:#770026;
  --maroon-700:#5e001e;
  --maroon-900:#3d0014;
  --maroon-50:#fbeef2;
  --ink:#14161a;
  --slate:#4a5160;
  --muted:#8b93a3;
  --line:#e7e9ee;
  --bg:#ffffff;
  --bg-soft:#f6f7f9;
  --gold:#c9a24b;
  --green:#1f7a4d;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 10px 30px rgba(20,22,26,.08);
  --shadow-lg:0 24px 60px rgba(20,22,26,.14);
  --max:1200px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--maroon)}
h1,h2,h3,h4{line-height:1.16;letter-spacing:-.02em;font-weight:800}
h2.section{font-size:clamp(1.7rem,3.2vw,2.5rem);margin:.4rem 0 .8rem}
.lead{color:var(--slate);font-size:1.05rem;max-width:62ch}
.center{text-align:center}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.95rem;padding:.8rem 1.4rem;border-radius:999px;border:1.5px solid transparent;transition:.18s;cursor:pointer}
.btn-primary{background:var(--maroon);color:#fff}
.btn-primary:hover{background:var(--maroon-700);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-outline{background:#fff;color:var(--maroon);border-color:var(--line)}
.btn-outline:hover{border-color:var(--maroon);color:var(--maroon)}
.btn-gold{background:var(--gold);color:var(--maroon-900)}
.btn-gold:hover{filter:brightness(1.05)}

/* ---------- Top bar ---------- */
.topbar{background:var(--maroon-700);color:#fff;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 24px}
.topbar a{opacity:.92}.topbar a:hover{opacity:1}
.topbar .tb-links{display:flex;gap:1.4rem;flex-wrap:wrap}
@media(max-width:760px){.topbar .tb-meta{display:none}}

/* ---------- Header / Nav ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.93);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.7rem 0}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.2rem;color:var(--maroon)}
.brand span{color:var(--ink)}
.brand img{height:38px;width:auto;display:block}
footer.site .brand img{filter:brightness(0) invert(1)}
.logo-mark{width:38px;height:38px;border-radius:9px;background:linear-gradient(135deg,var(--maroon),var(--maroon-700));display:grid;place-items:center;color:#fff;font-weight:800;font-size:1.05rem;flex:none}
nav.menu{display:flex;gap:1.5rem;align-items:center}
nav.menu>a{font-weight:600;font-size:.95rem;color:var(--ink);padding:.4rem 0}
nav.menu>a:hover,nav.menu>a.active{color:var(--maroon)}
.has-drop{position:relative}
.has-drop>.drop{position:absolute;top:140%;left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:.8rem;min-width:300px;opacity:0;visibility:hidden;transition:.18s;display:grid;gap:.15rem}
.has-drop:hover>.drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:flex;flex-direction:row;align-items:center;gap:.65rem;padding:.5rem .65rem;border-radius:9px}.drop a .di{flex:none;width:32px;height:32px;border-radius:8px;background:var(--maroon-50);color:var(--maroon);display:grid;place-items:center;transition:.15s}.drop a .di svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.drop a .dt{display:flex;flex-direction:column;min-width:0}.drop a:hover .di{background:var(--maroon);color:#fff}
.drop a:hover{background:var(--maroon-50)}
.drop a b{font-size:.92rem;color:var(--ink)}
.drop a small{color:var(--slate);font-size:.78rem}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.hamburger{display:none;background:none;border:0;font-size:1.6rem;color:var(--maroon);cursor:pointer}
@media(max-width:980px){
  nav.menu{position:fixed;inset:60px 0 auto 0;flex-direction:column;background:#fff;padding:1rem 24px 1.4rem;border-bottom:1px solid var(--line);gap:.2rem;transform:translateY(-150%);transition:.25s;align-items:flex-start;max-height:80vh;overflow:auto}
  nav.menu.open{transform:translateY(0)}
  nav.menu>a,.has-drop{width:100%;padding:.7rem 0;border-bottom:1px solid var(--line)}
  .has-drop>.drop{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:0;padding:.3rem 0 .3rem .6rem;min-width:0}
  .hamburger{display:block}
  .nav-cta .btn.hide-sm{display:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;background:radial-gradient(1100px 600px at 80% -10%,#9a1240 0%,transparent 60%),linear-gradient(135deg,#5e001e 0%,#770026 55%,#3d0014 100%);overflow:hidden}
.hero .wrap{position:relative;z-index:2;padding:5rem 24px 4.5rem}
.hero-2col{display:grid;grid-template-columns:1.15fr .85fr;gap:2.5rem;align-items:center}
.hero .eyebrow{color:#f4c9d8}
.hero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);margin:.6rem 0 1rem}
.hero p.sub{font-size:1.12rem;color:#f3dfe6;max-width:56ch}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.8rem}
.hero-badges{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:2rem}
.hero-badge{display:flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;color:#fff;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);padding:.5rem .8rem;border-radius:999px}
.hero-badge b{color:var(--gold)}
.hero-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:18px;padding:1.6rem;backdrop-filter:blur(6px)}
.hero-card h3{font-size:1rem;color:#fff;margin-bottom:1rem;font-weight:700}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.stat{background:rgba(0,0,0,.18);border-radius:12px;padding:1rem}
.stat .n{font-size:1.7rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.stat .l{font-size:.78rem;color:#f0d4dd;line-height:1.3;margin-top:.2rem}
@media(max-width:880px){.hero-2col{grid-template-columns:1fr}.hero .wrap{padding-top:3.2rem}.hero-card{order:2}}

/* Page hero (interior, compact) */
.page-hero{background:linear-gradient(135deg,#5e001e,#770026 60%,#3d0014);color:#fff;padding:3.2rem 0}
.page-hero .eyebrow{color:#f4c9d8}
.page-hero h1{font-size:clamp(1.9rem,4vw,2.9rem);margin:.5rem 0 .7rem}
.page-hero p{color:#f3dfe6;max-width:60ch;font-size:1.05rem}
.crumbs{font-size:.82rem;color:#f0d4dd;margin-bottom:.6rem}
.crumbs a{opacity:.85}.crumbs a:hover{opacity:1}

/* ---------- Trust ---------- */
.trust{background:var(--bg-soft);border-bottom:1px solid var(--line)}
.trust .wrap{padding:1.5rem 24px}
.trust p{text-align:center;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);margin-bottom:1rem}
.trust-logos{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2.6rem;align-items:center}
.trust-logos span{font-weight:800;font-size:1.05rem;color:#8b93a3}

/* ---------- Sections ---------- */
section{padding:4.5rem 0}
section.tight{padding:3.2rem 0}
.sec-head{text-align:center;max-width:64ch;margin:0 auto 2.6rem}
.sec-head .lead{margin:.6rem auto 0}
/* Animated maroon underline under section headings (triggers when scrolled into view) */
.sec-head .eyebrow{position:relative;display:inline-block;padding-bottom:.55rem}
.sec-head .eyebrow::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:0;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--maroon),var(--gold));transition:width .7s cubic-bezier(.22,1,.36,1)}
.sec-head.in .eyebrow::after,.sec-head:hover .eyebrow::after{width:46px}
/* Left-aligned eyebrow underline for split/overview sections */
.split .eyebrow,.band .eyebrow{position:relative;display:inline-block;padding-bottom:.5rem}
.split .eyebrow::after{content:"";position:absolute;left:0;bottom:0;width:42px;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--maroon),var(--gold))}
.bg-soft{background:var(--bg-soft)}

/* Cards / product grid */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
@media(max-width:920px){.grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.grid-3,.grid-2{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;transition:.18s;display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px) scale(1.012);border-color:#e0c4ce}
.card .tag{align-self:flex-start;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--maroon);background:var(--maroon-50);padding:.28rem .6rem;border-radius:999px;margin-bottom:.9rem}
.card img.thumb{height:120px;object-fit:contain;margin:.2rem auto 1rem}
.card h3{font-size:1.15rem;margin-bottom:.35rem}
.card .desc{color:var(--slate);font-size:.92rem;margin-bottom:1rem}
.card ul.feat{list-style:none;margin-bottom:1.2rem;display:flex;flex-direction:column;gap:.4rem}
.card ul.feat li{font-size:.86rem;color:var(--ink);padding-left:1.3rem;position:relative}
.card ul.feat li::before{content:"";position:absolute;left:0;top:.5rem;width:7px;height:7px;border-radius:2px;background:var(--maroon)}
.card .more{margin-top:auto;font-weight:600;font-size:.9rem;color:var(--maroon)}
.card .more:hover{text-decoration:underline}

/* Feature/value tiles */
.tile{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;transition:.18s}
.tile:hover{background:#fff;box-shadow:var(--shadow-lg);border-color:#e0c4ce;transform:translateY(-4px) scale(1.015)}
.tile .ic{width:50px;height:50px;border-radius:13px;background:var(--maroon-50);color:var(--maroon);display:grid;place-items:center;margin-bottom:1rem;box-shadow:inset 0 0 0 1px rgba(119,0,38,.12);transition:.18s}
.tile:hover .ic{background:var(--maroon);color:#fff;box-shadow:0 8px 18px rgba(119,0,38,.28)}
.ic svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.tile h3{font-size:1.05rem;margin-bottom:.3rem}
.tile p{font-size:.88rem;color:var(--slate)}

/* Spec table */
.spec-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.spec-table th,.spec-table td{text-align:left;padding:.85rem 1.1rem;font-size:.9rem;border-bottom:1px solid var(--line)}
.spec-table th{background:var(--bg-soft);width:34%;font-weight:700;color:var(--ink)}
.spec-table tr:last-child th,.spec-table tr:last-child td{border-bottom:0}
.spec-table td{color:var(--slate)}

/* Two-column split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr}}
.split img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* Certifications */
.certs{display:flex;flex-wrap:wrap;gap:.7rem}
.cert{background:#fff;border:1px solid var(--line);border-radius:10px;padding:.65rem 1rem;font-weight:700;font-size:.82rem;color:var(--ink);display:flex;align-items:center;gap:.45rem}
.cert i{width:8px;height:8px;border-radius:50%;background:var(--gold);display:inline-block}

/* Feature band (maroon) */
.band{background:linear-gradient(135deg,#3d0014,#770026);color:#fff;border-radius:22px;overflow:hidden}
.band .inner{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;padding:3rem}
.band .eyebrow{color:#f4c9d8}
.band h2{font-size:clamp(1.6rem,3vw,2.3rem);margin:.5rem 0 1rem;color:#fff}
.band p{color:#f3dfe6;font-size:1rem;max-width:54ch}
.band .pts{display:grid;gap:.7rem;margin-top:1.4rem}
.band .pt{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;color:#fbe9ef}
.band .pt b{color:var(--gold)}
@media(max-width:820px){.band .inner{grid-template-columns:1fr;padding:2rem}}

/* Case studies */
.case{border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;background:#fff;transition:.18s}
.case:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.case .who{font-weight:800;font-size:1.1rem;color:var(--maroon)}
.case .metric{font-size:1.9rem;font-weight:800;margin:.6rem 0 .2rem;letter-spacing:-.02em}
.case p{font-size:.9rem;color:var(--slate)}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:s}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;position:relative}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-14px;left:1.2rem;width:32px;height:32px;border-radius:50%;background:var(--maroon);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.9rem}
.step h4{margin:.6rem 0 .3rem;font-size:1rem}
.step p{font-size:.86rem;color:var(--slate)}

/* CTA band */
.ctaband{background:var(--maroon);color:#fff;border-radius:22px;text-align:center;padding:3.2rem 2rem}
.ctaband h2{font-size:clamp(1.6rem,3vw,2.3rem);color:#fff;margin-bottom:.6rem}
.ctaband p{color:#f3dfe6;max-width:52ch;margin:0 auto 1.6rem}
.ctaband .btn-primary{background:#fff;color:var(--maroon)}
.ctaband .btn-primary:hover{background:#f3dfe6}

/* Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:620px){.form-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.35rem}
.field label{font-size:.82rem;font-weight:600;color:var(--ink)}
.field input,.field select,.field textarea{padding:.7rem .8rem;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.92rem}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--maroon-50);border-color:var(--maroon)}

/* Footer */
footer.site{background:#14161a;color:#c7ccd6;padding:3.5rem 0 2rem;font-size:.9rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2rem}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
footer h4{color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem}
footer a{color:#c7ccd6;display:block;padding:.25rem 0}
footer a:hover{color:#fff}
.foot-brand .brand,.foot-brand .brand span{color:#fff}
.foot-brand p{margin-top:.8rem;color:var(--muted);max-width:36ch}
.offices{font-size:.82rem;color:var(--muted);margin-top:.8rem;line-height:1.5}
.foot-bottom{border-top:1px solid #262a31;margin-top:2.5rem;padding-top:1.4rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:var(--muted)}

/* Floating CTA */
.float-cta{position:fixed;right:18px;bottom:18px;z-index:60;background:var(--maroon);color:#fff;font-weight:700;font-size:.9rem;padding:.85rem 1.3rem;border-radius:999px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.5rem}
.float-cta:hover{background:var(--maroon-700)}
@media(max-width:520px){.float-cta span.lbl{display:none}}

/* Real logo strip */
.logo-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.6rem 2.6rem}
.logo-row img{height:46px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.7;transition:.2s}
.logo-row img:hover{filter:grayscale(0);opacity:1}
.logo-row span{font-weight:800;font-size:1.05rem;color:#9aa1ae;letter-spacing:.02em}

/* Stats credibility band */
.statband{background:linear-gradient(135deg,#3d0014,#770026);color:#fff;border-radius:22px;padding:2.4rem 2rem}
.statband .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;text-align:center}
@media(max-width:720px){.statband .grid{grid-template-columns:1fr 1fr}}
.statband .n{font-size:2.4rem;font-weight:800;letter-spacing:-.02em;color:#fff}
.statband .n b{color:var(--gold)}
.statband .l{font-size:.85rem;color:#f3dfe6;margin-top:.2rem}

/* Video embed */
.video-wrap{position:relative;width:100%;padding-top:56.25%;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);background:#000}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* Award badges */
.award-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:720px){.award-row{grid-template-columns:1fr 1fr}}
.award{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;text-align:center;transition:.18s}
.award:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.award img{height:74px;width:auto;object-fit:contain;margin:0 auto .6rem}
.award p{font-size:.8rem;color:var(--slate);font-weight:600}

/* Product image in cards */
.card img.thumb{height:130px;object-fit:contain;margin:.2rem auto 1rem;background:var(--bg-soft);border-radius:10px;padding:.6rem;width:100%}

/* ===== Hero craft: animated network topology ===== */
.hero-craft{position:relative;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:1.4rem 1.4rem 1rem;backdrop-filter:blur(6px)}
.hero-craft .cap{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#f4c9d8;margin-bottom:.4rem}
.hero-craft svg{width:100%;height:auto;display:block}
.hc-link{stroke:rgba(255,255,255,.30);stroke-width:1.4;fill:none}
.hc-node{fill:rgba(255,255,255,.08);stroke:rgba(255,255,255,.55);stroke-width:1.4}
.hc-node.core{fill:rgba(201,162,75,.22);stroke:var(--gold)}
.hc-ico{stroke:#fff;stroke-width:1.5;fill:none}
.hc-label{fill:#f3dfe6;font:600 10px 'Inter',sans-serif;text-anchor:middle}
.hc-pulse{fill:var(--gold)}
.hc-row{fill:rgba(255,255,255,.06);stroke:rgba(255,255,255,.16)}
.hc-rowt{fill:#fff;font:700 12px 'Inter',sans-serif}
.hc-rows{fill:#f0d4dd;font:500 9.5px 'Inter',sans-serif}
.hc-node{animation:hcGlow 3.2s ease-in-out infinite}
.hc-node:nth-of-type(2){animation-delay:.4s}.hc-node:nth-of-type(3){animation-delay:.8s}.hc-node:nth-of-type(4){animation-delay:1.2s}
@keyframes hcGlow{0%,100%{opacity:.78}50%{opacity:1}}
.hc-stats{display:flex;gap:1rem;margin-top:.8rem;border-top:1px solid rgba(255,255,255,.14);padding-top:.8rem}
.hc-stats div{flex:1}
.hc-stats .n{font-size:1.25rem;font-weight:800;color:#fff}
.hc-stats .l{font-size:.68rem;color:#f0d4dd;line-height:1.25}
@media(prefers-reduced-motion:reduce){.hc-pulse,.hc-node{animation:none}}

/* ===== Premium hover & nav animations ===== */
/* Animated underline on top-level nav links */
nav.menu>a,.has-drop>a{position:relative}
nav.menu>a::after,.has-drop>a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--maroon),var(--gold));transition:width .26s cubic-bezier(.22,1,.36,1)}
nav.menu>a:hover::after,nav.menu>a.active::after,.has-drop:hover>a::after{width:100%}
.caret{font-size:.62em;opacity:.65;margin-left:.15rem;display:inline-block;transition:transform .2s}
.has-drop:hover .caret{transform:rotate(180deg)}
@media(max-width:980px){nav.menu>a::after,.has-drop>a::after{display:none}}

/* Dropdown polish (solid) */
.has-drop>.drop{min-width:320px}
.drop a{position:relative;transition:background .15s,transform .15s}
.drop a:hover{transform:translateX(3px)}

/* Card image zoom + arrow slide */
.card{overflow:hidden}
.card .thumb-wrap{overflow:hidden;border-radius:10px;margin-bottom:1rem;background:var(--bg-soft)}
.card img.thumb{transition:transform .4s cubic-bezier(.22,1,.36,1);margin:0 auto}
.card:hover img.thumb{transform:scale(1.07)}
.more{display:inline-flex;align-items:center;gap:.35rem;transition:gap .2s,color .2s}
.card:hover .more{gap:.6rem;color:var(--maroon-700)}

/* Tile icon pop already defined; add lift to case & step */
.case,.step{transition:.2s}
.case:hover,.step:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px) scale(1.012)}

/* Buttons: subtle premium shadow on hover */
.btn-primary:hover{box-shadow:0 10px 22px rgba(119,0,38,.30)}
.btn-gold:hover{box-shadow:0 10px 22px rgba(201,162,75,.35)}

/* Reveal-on-scroll for any .reveal element */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}

/* Maroon hover accent on boxes (heading -> maroon, top bar grows) */
.card h3,.tile h3{transition:color .2s}
.card:hover h3,.tile:hover h3,.case:hover .who{color:var(--maroon)}
.card{position:relative}
.card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--maroon),var(--gold));border-radius:14px 14px 0 0;transition:width .35s cubic-bezier(.22,1,.36,1)}
.card:hover::before{width:100%}
.tile{position:relative;overflow:hidden}
.tile::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--maroon),var(--gold));transition:width .35s cubic-bezier(.22,1,.36,1)}
.tile:hover::before{width:100%}
.cap-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}@media(max-width:760px){.cap-grid{grid-template-columns:1fr}}
.cap-card{display:flex;gap:1.1rem;padding:1.5rem;border:1px solid var(--line);border-radius:14px;background:#fff;transition:.18s;position:relative;overflow:hidden}
.cap-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--maroon),var(--gold));transition:width .35s}
.cap-card:hover::before{width:100%}
.cap-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:#e0c4ce}
.cap-card .ic{flex:none;width:48px;height:48px;border-radius:12px;background:var(--maroon-50);color:var(--maroon);display:grid;place-items:center;box-shadow:inset 0 0 0 1px rgba(119,0,38,.12)}
.cap-card:hover .ic{background:var(--maroon);color:#fff}
.cap-card h3{font-size:1.06rem;margin-bottom:.35rem}
.cap-card p{font-size:.9rem;color:var(--slate);margin-bottom:.6rem}
.cap-card .clink{font-weight:600;color:var(--maroon);font-size:.85rem;display:inline-flex;gap:.3rem;transition:gap .2s}
.cap-card:hover .clink{gap:.6rem}
.usecase{border:1px solid var(--line);border-radius:14px;background:#fff;padding:1.5rem;transition:.18s;position:relative;overflow:hidden}
.usecase::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--maroon),var(--gold));transition:width .35s}
.usecase:hover::before{width:100%}
.usecase:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.usecase .uc-tag{font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--maroon);background:var(--maroon-50);padding:.25rem .6rem;border-radius:999px;display:inline-block;margin-bottom:.7rem}
.usecase h3{font-size:1.08rem;margin-bottom:.4rem}
.usecase p{font-size:.9rem;color:var(--slate);margin-bottom:.7rem}
.usecase .uc-meta{font-size:.82rem;color:var(--ink);font-weight:600}
.faq{max-width:860px;margin:0 auto;display:grid;gap:.7rem}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:0 1.2rem;transition:.18s}
.faq details[open]{box-shadow:var(--shadow);border-color:#e0c4ce}
.faq summary{cursor:pointer;font-weight:700;font-size:1rem;padding:1.1rem 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--maroon);font-weight:800;font-size:1.4rem;line-height:1}
.faq details[open] summary{color:var(--maroon)}
.faq details[open] summary::after{content:"\2013"}
.faq p{color:var(--slate);padding-bottom:1.1rem;margin-top:-.2rem;font-size:.92rem}
.prose-links a{color:var(--maroon);font-weight:600;border-bottom:1px solid rgba(119,0,38,.25)}
.prose-links a:hover{border-color:var(--maroon)}
.leadband{background:radial-gradient(900px 500px at 85% -20%,#9a1240 0%,transparent 60%),linear-gradient(135deg,#3d0014,#770026);border-radius:22px;padding:2.6rem;color:#fff;overflow:hidden}
.lead-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2.2rem;align-items:center}
@media(max-width:820px){.lead-grid{grid-template-columns:1fr}}
.leadband h2{color:#fff;font-size:clamp(1.5rem,3vw,2.1rem);margin:.4rem 0 .7rem}
.leadband p{color:#f3dfe6;max-width:48ch}
.lead-points{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.lead-points span{font-size:.82rem;font-weight:600;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:.4rem .8rem;border-radius:999px}
.leadform{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:1.4rem;display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.leadform .full{grid-column:1/-1}
.leadform input,.leadform select{padding:.75rem .85rem;border:1px solid rgba(255,255,255,.28);border-radius:10px;background:rgba(255,255,255,.12);color:#fff;font-family:inherit;font-size:.92rem;width:100%}
.leadform input::placeholder{color:#eccada}
.leadform input:focus,.leadform select:focus{outline:2px solid rgba(255,255,255,.35);border-color:#fff}
.leadform select{color:#fff}.leadform select option{color:#111}
.leadform button{grid-column:1/-1;background:var(--gold);color:var(--maroon-900);border:0;font-weight:700;padding:.8rem;border-radius:999px;cursor:pointer;font-size:.95rem;transition:.18s}
.leadform button:hover{filter:brightness(1.06);box-shadow:0 10px 22px rgba(201,162,75,.35)}
.leadform .lf-ok{grid-column:1/-1;display:none;color:#fff;font-weight:600;font-size:.9rem}
.leadform .lf-fine{grid-column:1/-1;color:#f0d4dd;font-size:.74rem;margin-top:-.2rem}
.mt-0{margin-top:0}.mt-1{margin-top:.8rem}.mt-2{margin-top:1.6rem}.mb-2{margin-bottom:1.6rem}

/* Premium icon chips */
.tile .ic,.cap-card .ic,.usecase .ic{background:linear-gradient(135deg,#fbeef2,#f3d8e1);box-shadow:inset 0 0 0 1px rgba(119,0,38,.16),0 6px 14px rgba(119,0,38,.08)}
.tile .ic svg,.cap-card .ic svg{stroke-width:1.85}
.tile:hover .ic,.cap-card:hover .ic{background:linear-gradient(135deg,var(--maroon),var(--maroon-900));color:#fff;box-shadow:0 12px 22px rgba(119,0,38,.32)}
.sol .ic,.step::before{box-shadow:0 4px 10px rgba(119,0,38,.10)}

/* Office map cards */
.office-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;transition:.18s;display:flex;flex-direction:column}
.office-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:#e0c4ce}
.office-card .map-embed{width:100%;height:172px;border:0;display:block}
.office-card .oc-body{padding:1.1rem 1.2rem;display:flex;flex-direction:column;flex:1}
.office-card .oc-tag{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--maroon);margin-bottom:.25rem}
.office-card h3{font-size:1.02rem;margin-bottom:.35rem}
.office-card p{font-size:.85rem;color:var(--slate);margin-bottom:.7rem}
.office-card a.dir{margin-top:auto;font-weight:600;color:var(--maroon);font-size:.85rem;display:inline-flex;gap:.3rem;transition:gap .2s}
.office-card a.dir:hover{gap:.55rem}

/* Cross-sector trust band */
.trust-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}
.trust-chips span{font-size:.84rem;font-weight:600;color:var(--maroon);background:var(--maroon-50);border:1px solid #eccfd8;padding:.45rem .95rem;border-radius:999px;transition:.18s}
.trust-chips span:hover{background:#fff;box-shadow:var(--shadow)}

/* Footer social */
.foot-social{display:flex;gap:.6rem;margin-top:1.1rem;flex-wrap:wrap}
.foot-social a{width:34px;height:34px;border:1px solid #2a2f37;border-radius:9px;display:grid;place-items:center;color:#c7ccd6;transition:.18s}
.foot-social a:hover{background:var(--maroon);border-color:var(--maroon);color:#fff;transform:translateY(-2px)}
.foot-social svg{width:17px;height:17px;fill:currentColor}
/* video cards */
.vid-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.18s}
.vid-card:hover{box-shadow:0 14px 30px rgba(61,0,20,.10);transform:translateY(-3px)}
.vid-embed{position:relative;width:100%;padding-top:56.25%;background:#000}
.vid-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vid-card h3{font-size:1.02rem;margin:.9rem 1rem .2rem}
.vid-card p{font-size:.88rem;color:var(--slate);margin:0 1rem 1.1rem}
/* social proof: logos + awards */
.proof-wall{max-width:780px;margin:0 auto}
.proof-logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.1rem}
.proof-logos img{height:88px;width:158px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;transition:.18s}
.proof-logos img:hover{box-shadow:0 10px 24px rgba(61,0,20,.08);transform:translateY(-2px)}
.award-grid{display:flex;flex-wrap:wrap;align-items:stretch;justify-content:center;gap:1.1rem}
.award-grid figure{margin:0;width:172px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.85rem .85rem 1rem;text-align:center;box-shadow:0 6px 18px rgba(61,0,20,.05);transition:.18s;display:flex;flex-direction:column}
.award-grid figure:hover{box-shadow:0 14px 30px rgba(61,0,20,.10);transform:translateY(-3px)}
.award-grid img{height:104px;width:100%;object-fit:contain;display:block;margin:0 auto .6rem;border-radius:6px}
.award-grid figcaption{font-size:.76rem;color:var(--ink);font-weight:600;line-height:1.3;margin-top:auto}
@media(max-width:640px){.proof-logos img{height:64px;width:120px;padding:10px}.award-grid figure{width:44%}.award-grid img{height:80px}}
/* nav weight consistency: dropdown parents match flat links */
.has-drop>a{font-weight:600;font-size:.95rem;color:var(--ink)}
.has-drop:hover>a{color:var(--maroon)}
/* blog */
.post-meta{font-size:.85rem;color:var(--slate);margin-top:.6rem;font-weight:600}
.post-body{max-width:760px;margin:0 auto;font-size:1.06rem;line-height:1.75;color:#2b2f36}
.post-body h2{font-size:1.5rem;color:var(--ink);margin:2rem 0 .6rem;letter-spacing:-.01em}
.post-body p{margin:0 0 1.1rem}
.post-body a{color:var(--maroon);font-weight:600;text-decoration:none;border-bottom:1px solid #e6c2cf}
.post-body a:hover{border-bottom-color:var(--maroon)}
.blog-card{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.18s;text-decoration:none}
.blog-card:hover{box-shadow:0 14px 30px rgba(61,0,20,.10);transform:translateY(-3px)}
.blog-card .bc-body{padding:1.3rem 1.4rem}
.blog-card h3{font-size:1.12rem;color:var(--ink);margin:.5rem 0 .4rem;line-height:1.3}
.blog-card p{font-size:.92rem;color:var(--slate);margin:0 0 .6rem}
.blog-card .bc-meta{font-size:.78rem;color:var(--slate)}
/* case study related links */
.case-links{margin-top:1rem;border-top:1px solid var(--line);padding-top:.9rem;display:flex;flex-direction:column;gap:.35rem}
.case-links div{font-size:.85rem;color:var(--slate)}
.case-links b{color:var(--ink);font-weight:700;margin-right:.3rem}
.case-links a{color:var(--maroon);font-weight:600;text-decoration:none}
.case-links a:hover{text-decoration:underline}
.cat-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}
.cat-chips a{font-size:.86rem;font-weight:600;color:var(--maroon);background:var(--maroon-50);border:1px solid #eccfd8;padding:.5rem 1.1rem;border-radius:999px;text-decoration:none;transition:.18s}
.cat-chips a:hover{background:var(--maroon);color:#fff}

/* usecase icon chip */
.usecase .ic{width:46px;height:46px;border-radius:12px;background:var(--maroon-50);color:var(--maroon);display:grid;place-items:center;margin-bottom:.8rem;box-shadow:inset 0 0 0 1px rgba(119,0,38,.12)}
.usecase .ic svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
/* ---- rich blog ---- */
.post-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--maroon-900),var(--maroon));color:#fff;padding:3rem 0 2.5rem}
.post-hero .wrap{position:relative;z-index:2}
.post-hero .crumbs,.post-hero .crumbs a{color:#f3c9d6}
.post-hero h1{color:#fff;max-width:800px;margin:.5rem 0 .6rem}
.post-hero p{color:#f3dfe6;max-width:740px;font-size:1.05rem}
.post-hero .post-meta{color:#e9c3d0}
.post-hero-wm{position:absolute;right:-26px;bottom:-46px;width:250px;height:250px;opacity:.10;stroke:#fff;fill:none;stroke-width:.9;z-index:1}
.post-cat{display:inline-block;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.32);color:#fff;font-size:.74rem;font-weight:700;padding:.32rem .9rem;border-radius:999px;text-decoration:none;letter-spacing:.05em;text-transform:uppercase;transition:.18s}
.post-cat:hover{background:#fff;color:var(--maroon)}
.post-figure{margin:0 0 1.6rem;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#faf6f7}
.post-figure img{width:100%;display:block;max-height:380px;object-fit:cover}
.post-figure figcaption{font-size:.8rem;color:var(--slate);padding:.55rem .9rem;background:#fff;border-top:1px solid var(--line)}
.post-toc{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:1rem 1.3rem;margin:0 0 1.9rem}
.post-toc b{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--maroon);margin-bottom:.5rem}
.post-toc a{display:block;color:var(--ink);text-decoration:none;padding:.22rem 0;font-size:.95rem}
.post-toc a:hover{color:var(--maroon)}
.post-body h2{scroll-margin-top:90px}
/* index covers + filter */
.blog-card .bc-cover{height:128px;position:relative;background:linear-gradient(135deg,var(--maroon-900),var(--maroon));display:flex;align-items:flex-end;padding:.85rem 1rem;overflow:hidden}
.blog-card .bc-cover .cat{position:relative;z-index:2;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.32);color:#fff;font-size:.7rem;font-weight:700;padding:.24rem .7rem;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}
.blog-card .bc-cover svg{position:absolute;right:-14px;top:-18px;width:128px;height:128px;opacity:.13;stroke:#fff;fill:none;stroke-width:.9}
.blog-filter{display:flex;flex-wrap:wrap;gap:.55rem;justify-content:center;margin-bottom:2rem}
.blog-filter button{font-size:.84rem;font-weight:600;color:var(--maroon);background:var(--maroon-50);border:1px solid #eccfd8;padding:.45rem 1.05rem;border-radius:999px;cursor:pointer;transition:.18s;font-family:inherit}
.blog-filter button.active,.blog-filter button:hover{background:var(--maroon);color:#fff;border-color:var(--maroon)}
/* ---- resource library ---- */
.res-layout{display:grid;grid-template-columns:236px 1fr;gap:2rem;align-items:start}
.res-side{position:sticky;top:90px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.1rem 1.2rem}
.res-side .res-toggle{display:none}
.res-grp{margin-bottom:1.1rem}
.res-grp:last-child{margin-bottom:0}
.res-grp h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--maroon);margin:0 0 .6rem}
.res-grp button{display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;background:none;border:0;font-family:inherit;font-size:.92rem;color:var(--ink);padding:.34rem .5rem;border-radius:8px;cursor:pointer;transition:.15s}
.res-grp button:hover{background:var(--maroon-50)}
.res-grp button.active{background:var(--maroon);color:#fff;font-weight:600}
.res-grp button .ct{font-size:.72rem;opacity:.7}
.res-grp button.active .ct{opacity:.9}
.res-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.18s;text-decoration:none}
.res-card:hover{box-shadow:0 14px 30px rgba(61,0,20,.10);transform:translateY(-3px)}
.res-card .rc-top{display:flex;align-items:center;gap:.6rem;padding:1rem 1.2rem .4rem}
.res-card .rc-ic{width:38px;height:38px;border-radius:10px;background:var(--maroon-50);color:var(--maroon);display:grid;place-items:center;flex:none}
.res-card .rc-ic svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.7}
.res-card .rc-type{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--maroon)}
.res-card h3{font-size:1rem;color:var(--ink);margin:0 1.2rem .3rem;line-height:1.3}
.res-card p{font-size:.86rem;color:var(--slate);margin:0 1.2rem .8rem;flex:1}
.res-card .rc-act{font-size:.85rem;font-weight:600;color:var(--maroon);padding:0 1.2rem 1.1rem}
.res-count{font-size:.85rem;color:var(--slate);margin-bottom:1rem}
@media(max-width:820px){.res-layout{grid-template-columns:1fr}.res-side{position:static}.res-side .res-toggle{display:flex;justify-content:space-between;width:100%;background:none;border:0;font-family:inherit;font-size:.95rem;font-weight:700;color:var(--ink);cursor:pointer;padding:0}.res-side.collapsed .res-body{display:none}}
/* ---- iframe modal (brochure / forms) ---- */
.imodal{position:fixed;inset:0;background:rgba(28,5,15,.62);backdrop-filter:blur(3px);z-index:9999;display:none;align-items:center;justify-content:center;padding:2vh 3vw}
.imodal.open{display:flex}
.imodal-dialog{background:#fff;border-radius:16px;width:min(620px,96vw);max-height:94vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.4);animation:imup .25s ease}
@keyframes imup{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.imodal-head{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;border-bottom:1px solid var(--line)}
.imodal-head b{color:var(--ink);font-size:1rem}
.imodal-close{background:var(--maroon-50);border:0;width:32px;height:32px;border-radius:8px;color:var(--maroon);font-size:1.1rem;cursor:pointer;line-height:1}
.imodal-close:hover{background:var(--maroon);color:#fff}
.imodal-body{flex:1;overflow:auto;background:#faf6f7}
.imodal-body iframe{width:100%;height:72vh;border:0;display:block}
.post-figure--diagram{background:#fff;border:1px solid var(--line);padding:1.2rem}
.post-figure--diagram svg{width:100%;height:auto;display:block}
/* resource toolbar + collapsible groups */
.res-toolbar{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center;margin-bottom:1.1rem}
.res-search{flex:1;min-width:220px;display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:10px;padding:.55rem .85rem}
.res-search svg{width:17px;height:17px;fill:none;stroke:var(--slate);stroke-width:2;flex:none}
.res-search input{border:0;outline:0;font-family:inherit;font-size:.95rem;width:100%;background:none;color:var(--ink)}
.res-sort{background:#fff;border:1px solid var(--line);border-radius:10px;padding:.55rem .7rem;font-family:inherit;font-size:.9rem;color:var(--ink);cursor:pointer}
.res-feat{background:var(--maroon-50);border:1px solid #eccfd8;color:var(--maroon);border-radius:10px;padding:.55rem .95rem;font-weight:600;font-size:.9rem;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:.4rem}
.res-feat.active{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.res-grp h4{cursor:pointer;user-select:none;display:flex;justify-content:space-between;align-items:center}
.res-grp h4 .chev{transition:.18s;font-size:.7rem}
.res-grp.collapsed h4 .chev{transform:rotate(-90deg)}
.res-grp.collapsed .res-grp-body{display:none}
.res-empty{padding:2.5rem 1rem;text-align:center;color:var(--slate);display:none;grid-column:1/-1}
.res-clear{font-size:.82rem;color:var(--maroon);background:none;border:0;cursor:pointer;font-family:inherit;font-weight:600;padding:0;margin-top:.3rem}
/* trusted-by masthead */
.trust-mast{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.1rem 2.6rem}
.trust-mast-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--slate)}
.trust-mast-logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2.6rem}
.trust-mast-logos img{height:38px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.5;transition:.22s}
.trust-mast-logos img:hover{filter:grayscale(0);opacity:1}
@media(max-width:640px){.trust-mast-logos{gap:1.6rem}.trust-mast-logos img{height:30px}}
/* product imagery */
.card-media{display:block;background:#fff;border-bottom:1px solid var(--line);padding:1.1rem;text-align:center;margin:-1.5rem -1.5rem 1rem;border-radius:14px 14px 0 0}
.card-media img{height:128px;width:auto;max-width:100%;object-fit:contain}
.card-media--svg svg{height:96px;width:96px;fill:none;stroke:var(--maroon);stroke-width:1.4;opacity:.85}
.prod-showcase{background:#fff;border:1px solid var(--line);border-radius:18px;padding:2.2rem;text-align:center;display:flex;align-items:center;justify-content:center}
.prod-showcase img{max-height:300px;max-width:100%;width:auto;object-fit:contain}
/* industry photo hero */
.page-hero--photo{background-size:cover;background-position:center;background-repeat:no-repeat}
.page-hero--photo .crumbs,.page-hero--photo .crumbs a{color:#f3c9d6}
.page-hero--photo .eyebrow{color:#f4c9d8}
.page-hero--photo h1{color:#fff}
.page-hero--photo p{color:#f3dfe6}
.page-hero--photo .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
.page-hero--photo .btn-ghost:hover{background:#fff;color:var(--maroon)}
/* net cloud gallery */
.nc-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.nc-shot{border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 12px 28px rgba(61,0,20,.12);background:#0d0d12;transition:.18s}
.nc-shot:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(61,0,20,.18)}
.nc-shot img{width:100%;display:block}
.nc-shot figcaption{font-size:.8rem;color:var(--ink);padding:.55rem .85rem;background:#fff;border-top:1px solid var(--line);font-weight:600}
@media(max-width:760px){.nc-gallery{grid-template-columns:1fr 1fr}}
/* photo hero: lighter, image visible (directional overlay) */
.page-hero--photo{position:relative;background-size:cover;background-position:center}
.page-hero--photo::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(61,0,20,.90) 0%,rgba(61,0,20,.62) 42%,rgba(119,0,38,.34) 100%)}
.page-hero--photo .wrap{position:relative;z-index:2}
/* professional product presentation */
.prod-showcase{background:#fff;border:1px solid var(--line);border-radius:18px;padding:2.4rem 2rem;box-shadow:0 20px 50px rgba(61,0,20,.12);display:flex;align-items:center;justify-content:center;max-width:520px;margin:0 auto}
.prod-showcase img{max-height:280px;max-width:100%;width:auto;object-fit:contain;filter:drop-shadow(0 10px 18px rgba(0,0,0,.10))}
.card-media{background:#fff!important;}
/* net cloud hero split (dark dashboard floats nicely) */
.page-hero--split .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:2.4rem;align-items:center}
.page-hero--split .hero-media img{width:100%;border-radius:14px;border:1px solid var(--line);box-shadow:0 24px 60px rgba(61,0,20,.18)}
@media(max-width:820px){.page-hero--split .wrap{grid-template-columns:1fr}.page-hero--split .hero-media{display:none}}
.case-ic{background:linear-gradient(135deg,var(--maroon-900),var(--maroon))!important;height:84px;display:flex;align-items:center;justify-content:center}
.case-ic svg{height:34px;width:34px;stroke:#fff;opacity:.95}
@media(max-width:820px){.page-hero--split .hero-media{display:block;margin-top:1.2rem}}
/* premium product tile in hero (replaces cheap white box) */
.hero-card.center{background:#fff;border:0;border-radius:22px;box-shadow:0 30px 70px rgba(0,0,0,.34),0 6px 16px rgba(0,0,0,.20);padding:2.4rem 1.8rem;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.hero-card.center::before{content:"";position:absolute;inset:0;background:#ffffff;z-index:0}
.hero-card.center img{position:relative;z-index:1;height:auto!important;max-height:300px!important;width:auto;max-width:100%}
.hero-dash:hover img{box-shadow:0 20px 44px rgba(0,0,0,.42)!important}
/* blog post photo hero */
.post-hero--photo{background-size:cover;background-position:center}
.post-hero--photo::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(61,0,20,.93) 0%,rgba(61,0,20,.72) 46%,rgba(119,0,38,.46) 100%);z-index:0}
.post-hero--photo .post-hero-wm{z-index:1}
/* case-study card photo header */
.case-photo{margin:-1.8rem -1.8rem 1.2rem;height:152px;overflow:hidden;border-radius:14px 14px 0 0}
.case-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* In-article CTA buttons: override .post-body a link styling so buttons stay buttons */
.post-body a.btn{border-bottom:none !important;text-decoration:none}
.post-body a.btn-primary{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.post-body a.btn-primary:hover{background:var(--maroon-900);color:#fff}
.post-body a.btn-ghost{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.post-body a.btn-gold{background:var(--gold);color:var(--maroon-900);border-color:var(--gold)}
.post-body a.btn:hover{color:#fff}

/* In-article stock photos */
.post-figure--photo{margin:2rem 0}
.post-figure--photo img{width:100%;height:auto;max-height:360px;object-fit:cover;border-radius:14px;display:block;box-shadow:0 10px 30px rgba(61,0,20,.10)}
