/* ============================================================
   EPDS.hu — design system
   Anchor: deep navy  ·  Accent: EPDS orange  ·  Flat B2B
   Type: IBM Plex Sans (400/500) + IBM Plex Mono (labels)
   ============================================================ */

:root{
  --navy:#0F2A43;       /* anchor: text, footer, dark surfaces */
  --navy-700:#173653;
  --ink:#17252F;        /* primary text */
  --muted:#5C6B76;      /* secondary text */
  --faint:#65727D;      /* tertiary / captions (AA: ~4.9:1) */
  --accent:#E98F17;     /* the single accent — fills, dashes, arrows only */
  --accent-press:#CC7B0C;
  --accent-text:#9A5A00;/* AA-safe burnt amber for small accent TEXT (5.5:1) */
  --on-accent:#fff;     /* text on orange fills — white on the extracted EPDS orange */
  --accent-tint:#FDF3E4;
  /* secondary / technical label face — tweakable (default: Space Grotesk) */
  --font-label:"Space Grotesk",ui-sans-serif,system-ui,sans-serif;
  --label-tracking:.02em;  /* mono wants tight tracking; sans labels widen this */
  --paper:#FFFFFF;
  --bg:#F5F7F9;
  --line:#E3E8EC;       /* hairline borders */
  --line-strong:#D2DAE0;
  --radius:10px;
  --radius-sm:7px;
  --maxw:1240px;
  --gut:40px;
  --header-h:72px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;}
body{
  font-family:"IBM Plex Sans","Helvetica Neue",Arial,sans-serif;
  font-weight:400;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);}

/* mono technical label */
.mono{
  font-family:var(--font-label);
  font-size:12px;letter-spacing:var(--label-tracking);color:var(--faint);
}
.eyebrow{
  font-family:var(--font-label);
  font-size:12.5px;letter-spacing:calc(var(--label-tracking) + .04em);color:var(--muted);
  display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{
  content:"";width:18px;height:1px;background:var(--accent);display:inline-block;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:46px;padding:0 22px;border-radius:var(--radius-sm);
  font-size:15px;font-weight:500;line-height:1;border:1px solid transparent;
  transition:background .15s ease,border-color .15s ease,color .15s ease,
             box-shadow .2s ease,transform .15s ease,filter .15s ease,text-shadow .15s ease;
  white-space:nowrap;
}
/* Primary = the extracted EPDS orange (#E98F17) with white text. The fill stays
   the same colour on hover — the interaction is an EFFECT, not a darker shade. */
.btn-primary{ background:var(--accent);color:#fff;border-color:var(--accent); }
/* default hover effect: brighten (applies with no attribute) */
.btn-primary:hover{ filter:brightness(1.09) saturate(1.06); box-shadow:0 4px 14px rgba(233,143,23,.4); }
/* tweakable alternatives — each keeps the #E98F17 fill */
body[data-btnhover="glow"] .btn-primary:hover{
  filter:none;
  box-shadow:0 6px 22px rgba(233,143,23,.55), 0 1px 3px rgba(233,143,23,.4);
}
body[data-btnhover="lift"] .btn-primary:hover{
  filter:none;
  transform:translateY(-2px);
  box-shadow:0 10px 24px rgba(233,143,23,.5), 0 2px 6px rgba(31,35,39,.18);
}
body[data-btnhover="brighten"] .btn-primary:hover{
  filter:brightness(1.09) saturate(1.06);
  box-shadow:0 4px 14px rgba(233,143,23,.4);
}
body[data-btnhover="sheen"] .btn-primary:hover{
  filter:none;
  text-shadow:0 1px 7px rgba(31,18,2,.45);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4), 0 4px 16px rgba(233,143,23,.42);
}
.btn-outline{ background:transparent;color:var(--navy);border-color:var(--line-strong); }
.btn-outline:hover{ border-color:var(--navy);background:#fff; }
.btn-sm{height:40px;padding:0 16px;font-size:14px;}
.btn-block{width:100%;}
.btn .arr{font-size:16px;line-height:1;transition:transform .15s ease;}
.btn:hover .arr{transform:translateX(2px);}

/* ===========================================================
   CARD HOVER PROMOTION (tweakable via body[data-cardhover])
   Applies to every promotable card type across all pages.
   `body :is(...)` keeps these ahead of the per-card border-only
   :hover rules in knowledge/services/product.css regardless of
   stylesheet order. Border-colour is left to each card's own
   rule (so .track.is-featured keeps its accent border) except
   in the "glow" option.
   =========================================================== */
body :is(.start-card,.track,.theme-card,.blog-card,.cap,.svc-link,.expert){
  transition:border-color .16s ease, transform .18s ease, box-shadow .18s ease;
}
/* default (= "lift"): raise + soft shadow */
body :is(.start-card,.track,.theme-card,.blog-card,.cap,.svc-link,.expert):hover{
  transform:translateY(-4px);
  box-shadow:0 12px 26px rgba(15,42,67,.10);
}
/* subtle: original flat behaviour (border only) */
body[data-cardhover="subtle"] :is(.start-card,.track,.theme-card,.blog-card,.cap,.svc-link,.expert):hover{
  transform:none;box-shadow:none;
}
/* glow: accent ring + accent border, gentle raise */
body[data-cardhover="glow"] :is(.start-card,.track,.theme-card,.blog-card,.cap,.svc-link,.expert):hover{
  transform:translateY(-2px);
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent), 0 14px 30px rgba(233,143,23,.2);
}
/* edge: accent top bar + raise */
body[data-cardhover="edge"] :is(.start-card,.track,.theme-card,.blog-card,.cap,.svc-link,.expert):hover{
  transform:translateY(-4px);
  box-shadow:inset 0 3px 0 var(--accent), 0 12px 26px rgba(15,42,67,.12);
}

/* ===========================================================
   HEADER
   =========================================================== */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  height:var(--header-h);display:flex;align-items:center;gap:28px;
}
.brand{display:flex;align-items:baseline;gap:1px;flex-shrink:0;}
.brand img{height:21px;width:auto;transform:translateY(3px);}
.brand .tld{font-weight:500;font-size:19px;color:var(--navy);letter-spacing:-.01em;}

/* primary nav */
.nav{display:flex;align-items:center;gap:2px;margin-left:6px;}
.nav-item{position:relative;}
.nav-link{
  display:inline-flex;align-items:center;gap:5px;
  height:var(--header-h);padding:0 13px;font-size:15px;color:var(--ink);
  position:relative;
}
.nav-link .caret{
  width:7px;height:7px;border-right:1.5px solid var(--faint);
  border-bottom:1.5px solid var(--faint);transform:rotate(45deg) translateY(-2px);
  transition:transform .2s ease,border-color .2s ease;
}
.nav-link:hover{color:var(--accent-press);}
.nav-link:hover .caret{border-color:var(--accent-press);}
.nav-item:hover .nav-link::after{
  content:"";position:absolute;left:13px;right:13px;bottom:-1px;height:2px;background:var(--accent);
}

/* dropdown */
.dropdown{
  position:absolute;top:calc(var(--header-h) - 10px);left:6px;min-width:268px;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .16s ease,transform .16s ease,visibility .16s;
  box-shadow:0 1px 0 rgba(15,42,67,.04);
}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.dd-link{
  display:block;padding:10px 12px;border-radius:var(--radius-sm);
  font-size:14.5px;color:var(--ink);
}
.dd-link span{display:block;font-size:12.5px;color:var(--faint);margin-top:2px;}
.dd-link:hover{background:var(--bg);}

.header-cta{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0;}

/* hamburger */
.burger{display:none;width:44px;height:44px;border:1px solid var(--line-strong);
  border-radius:var(--radius-sm);background:#fff;align-items:center;justify-content:center;
  flex-direction:column;gap:4px;margin-left:auto;}
.burger span{width:18px;height:1.6px;background:var(--navy);display:block;transition:.2s;}

/* ===========================================================
   HERO
   =========================================================== */
.hero{padding:74px 0 64px;border-bottom:1px solid var(--line);background:var(--paper);}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;}
.hero h1{
  font-size:51px;line-height:1.06;font-weight:500;letter-spacing:-.018em;
  color:var(--navy);margin:22px 0 0;text-wrap:balance;
}
.hero .lede{font-size:18.5px;color:var(--muted);margin-top:22px;max-width:34em;text-wrap:pretty;}
.hero-cta{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap;}
.hero-trust{display:flex;align-items:center;gap:18px;margin-top:34px;padding-top:22px;border-top:1px solid var(--line);}
.hero-trust .mono{white-space:nowrap;}
.trust-names{display:flex;flex-wrap:wrap;gap:8px 18px;}
.trust-names span{font-size:13.5px;color:var(--faint);font-weight:500;}

/* hero visual */
.hero-visual{position:relative;}
.ph{
  position:relative;border:1px solid var(--line);border-radius:var(--radius);
  background:
    repeating-linear-gradient(135deg,rgba(15,42,67,.035) 0 1px,transparent 1px 11px),
    #EDF1F4;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.ph .ph-label{
  font-family:var(--font-label);font-size:12px;color:#9aa7b1;letter-spacing:var(--label-tracking);
  border:1px solid var(--line-strong);background:rgba(255,255,255,.7);
  padding:5px 10px;border-radius:5px;
}
.hero-visual .ph{aspect-ratio:4/5;}
.hero-float{
  position:absolute;left:20px;bottom:20px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:16px 18px;width:300px;max-width:calc(100% - 40px);
}
.hero-float .ttl{font-size:12px;font-family:var(--font-label);color:var(--faint);letter-spacing:var(--label-tracking);}
.hero-float .val{font-size:15px;color:var(--ink);margin-top:8px;font-weight:500;line-height:1.4;text-wrap:pretty;}
.hero-float .row{display:flex;align-items:center;gap:9px;margin-top:14px;padding-top:13px;border-top:1px solid var(--line);}
.dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;}

/* ===========================================================
   SECTION SHELL
   =========================================================== */
.section{padding:80px 0;}
.section + .section{border-top:1px solid var(--line);}
.section-head{max-width:680px;margin-bottom:44px;}
.section-head h2{
  font-size:34px;line-height:1.12;font-weight:500;letter-spacing:-.015em;
  color:var(--navy);margin-top:16px;text-wrap:balance;
}
.section-head p{font-size:17px;color:var(--muted);margin-top:14px;text-wrap:pretty;}

/* ---- three tracks ---- */
.tracks{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.track{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 24px 24px;display:flex;flex-direction:column;min-height:264px;
  transition:border-color .15s ease;
}
.track:hover{border-color:var(--line-strong);}
.track .idx{font-family:var(--font-label);font-size:12.5px;color:var(--navy);font-weight:500;letter-spacing:var(--label-tracking);}
.track .stage{font-family:var(--font-label);font-size:11px;color:var(--faint);letter-spacing:var(--label-tracking);
  border:1px solid var(--line);border-radius:20px;padding:3px 10px;}
.track-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.track h3{font-size:20px;font-weight:500;color:var(--navy);letter-spacing:-.01em;}
.track p{font-size:14.5px;color:var(--muted);margin-top:10px;text-wrap:pretty;}
.track .go{
  margin-top:auto;padding-top:20px;display:inline-flex;align-items:center;gap:7px;
  font-size:14.5px;font-weight:500;color:var(--navy);
}
.track .go .arr{color:var(--accent);font-size:16px;transition:transform .15s ease;}
.track:hover .go .arr{transform:translateX(3px);}

/* ---- experts + references ---- */
.experts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.expert{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.expert .portrait{aspect-ratio:1/1;border-bottom:1px solid var(--line);}
.expert img.portrait{display:block;width:100%;height:auto;object-fit:cover;
  object-position:center top;background:#EDF1F4;}
.expert .meta{padding:18px 20px 20px;}
.expert .name{font-size:17px;font-weight:500;color:var(--navy);}
.expert .role{font-size:13.5px;color:var(--muted);margin-top:4px;}
.expert .cred{font-family:var(--font-label);font-size:11.5px;color:var(--faint);margin-top:12px;letter-spacing:var(--label-tracking);
  padding-top:12px;border-top:1px solid var(--line);}

.refs{margin-top:40px;border-top:1px solid var(--line);padding-top:28px;}
.refs .mono{display:block;margin-bottom:18px;}
.ref-row{display:flex;align-items:center;flex-wrap:wrap;gap:14px;}
.ref-cell{
  flex:1 1 0;min-width:150px;height:62px;border:1px solid var(--line);border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;background:#fff;
  font-size:14px;color:var(--faint);font-weight:500;letter-spacing:.01em;text-align:center;padding:0 12px;
}

/* ===========================================================
   FOOTER
   =========================================================== */
.site-footer{background:var(--navy);color:#C6D2DC;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding:60px 0 48px;}
.footer-news .flogo{display:flex;align-items:baseline;gap:1px;margin-bottom:18px;}
.footer-news .flogo img{height:20px;transform:translateY(3px);}
.footer-news .flogo .tld{color:#fff;font-weight:500;font-size:18px;}
.footer-news p{font-size:14px;color:#9DB0BD;max-width:30ch;margin-bottom:16px;}
.news-form{display:flex;gap:8px;max-width:360px;}
.news-form input{
  flex:1;height:44px;border-radius:var(--radius-sm);border:1px solid var(--navy-700);
  background:#0B2236;color:#fff;padding:0 14px;font-family:inherit;font-size:14px;
}
.news-form input::placeholder{color:#6E8493;}
.news-form input:focus{outline:none;border-color:var(--accent);}
.fcol h4{font-size:13px;font-weight:500;color:#fff;margin-bottom:16px;letter-spacing:.01em;}
.fcol a{display:block;font-size:14px;color:#9DB0BD;padding:6px 0;}
.fcol a:hover{color:#fff;}
.footer-bottom{
  border-top:1px solid var(--navy-700);padding:22px 0;
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
}
.footer-bottom .legal{display:flex;gap:22px;flex-wrap:wrap;}
.footer-bottom a,.footer-bottom span{font-size:13px;color:#8DA1AF;}
.footer-bottom a:hover{color:#fff;}
.fsocial{display:flex;gap:18px;}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1080px){
  :root{--gut:28px;}
  .hero h1{font-size:44px;}
  .nav-link{padding:0 10px;font-size:14.5px;}
  .header-inner{gap:16px;}
}
@media (max-width:900px){
  .nav{display:none;}
  .header-cta .btn-try{display:none;}
  .burger{display:flex;}
  .header-cta{margin-left:0;}
  .hero-grid{grid-template-columns:1fr;gap:40px;}
  .hero-visual{order:-1;}
  .hero-visual .ph{aspect-ratio:16/10;}
  .hero-float{left:16px;right:16px;bottom:16px;width:auto;max-width:none;}
  .tracks{grid-template-columns:1fr;}
  .experts{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}
  .footer-news{grid-column:1 / -1;}
}
@media (max-width:560px){
  :root{--gut:20px;--header-h:62px;}
  .hero{padding:44px 0 48px;}
  .hero h1{font-size:34px;}
  .hero .lede{font-size:16.5px;}
  .hero-cta{flex-direction:column;}
  .hero-cta .btn{width:100%;}
  .hero-trust{flex-direction:column;align-items:flex-start;gap:12px;}
  .section{padding:56px 0;}
  .section-head h2{font-size:27px;}
  .ref-row{gap:10px;}
  .ref-cell{flex:1 1 44%;min-width:0;}
  .footer-top{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .news-form{max-width:none;}
}

/* ===========================================================
   MOBILE MENU (panel)
   =========================================================== */
.mobile-menu{
  position:fixed;inset:0;z-index:80;background:#fff;display:none;flex-direction:column;
  padding:18px var(--gut) 40px;overflow-y:auto;
}
.mobile-menu.open{display:flex;}
.mm-head{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);
  border-bottom:1px solid var(--line);margin-bottom:8px;}
.mm-close{width:44px;height:44px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);
  background:#fff;font-size:22px;color:var(--navy);line-height:1;}
.mm-group{border-bottom:1px solid var(--line);}
.mm-row{width:100%;display:flex;align-items:center;justify-content:space-between;
  background:none;border:none;padding:16px 2px;font-size:17px;color:var(--ink);text-align:left;}
.mm-row .caret{width:8px;height:8px;border-right:1.6px solid var(--faint);
  border-bottom:1.6px solid var(--faint);transform:rotate(45deg);transition:transform .2s;}
.mm-row[aria-expanded="true"] .caret{transform:rotate(-135deg);}
.mm-sub{display:none;padding:0 2px 14px;}
.mm-sub.open{display:block;}
.mm-sub a{display:block;padding:9px 0;font-size:15px;color:var(--muted);}
.mm-cta{display:flex;flex-direction:column;gap:12px;margin-top:26px;}
body.menu-open{overflow:hidden;}

/* ===========================================================
   HERO — PHOTOGRAPHIC BACKGROUND (tweakable; default off = white hero)
   Activated by body[data-herobg="<key>"]; --hero-img set from JS.
   =========================================================== */
body[data-herobg]:not([data-herobg="none"]) .hero{
  position:relative;isolation:isolate;overflow:hidden;color:#fff;
  background:var(--navy);border-bottom:none;
}
.hero-bg{display:none;}
body[data-herobg]:not([data-herobg="none"]) .hero-bg{
  display:block;position:absolute;left:0;top:-50%;z-index:0;
  width:100%;height:160%;object-fit:cover;object-position:center;
  will-change:transform;
}
/* left-weighted scrim keeps the copy legible, photo breathes on the right.
   Real element (not ::after) so DOM paint order is unambiguous. */
.hero-scrim{display:none;}
body[data-herobg]:not([data-herobg="none"]) .hero-scrim{
  display:block;position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(7,19,31,.96) 0%, rgba(7,19,31,.9) 42%, rgba(7,19,31,.55) 64%, rgba(7,19,31,.3) 100%),
    linear-gradient(0deg, rgba(7,19,31,.5) 0%, rgba(7,19,31,0) 62%);
}
body[data-herobg]:not([data-herobg="none"]) .hero > .wrap{position:relative;z-index:2;}

/* light type over the photo */
body[data-herobg]:not([data-herobg="none"]) .hero h1{color:#fff;}
body[data-herobg]:not([data-herobg="none"]) .hero .lede{color:rgba(233,240,246,.86);}
body[data-herobg]:not([data-herobg="none"]) .hero .eyebrow{color:rgba(233,240,246,.82);}
body[data-herobg]:not([data-herobg="none"]) .hero .hero-trust{border-top-color:rgba(255,255,255,.18);}
body[data-herobg]:not([data-herobg="none"]) .hero .hero-trust .mono{color:rgba(233,240,246,.62);}
body[data-herobg]:not([data-herobg="none"]) .hero .trust-names span{color:rgba(233,240,246,.88);}
body[data-herobg]:not([data-herobg="none"]) .hero .btn-outline{
  color:#fff;border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.05);
}
body[data-herobg]:not([data-herobg="none"]) .hero .btn-outline:hover{
  border-color:#fff;background:rgba(255,255,255,.13);
}

/* photo replaces the placeholder; spec card turns to glass */
body[data-herobg]:not([data-herobg="none"]) .hero .hero-visual .ph{display:none;}
body[data-herobg]:not([data-herobg="none"]) .hero .hero-float{
  position:static;width:auto;max-width:360px;margin-left:auto;
  background:rgba(11,25,40,.42);border-color:rgba(255,255,255,.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);
}
body[data-herobg]:not([data-herobg="none"]) .hero .hero-float .ttl{color:rgba(233,240,246,.72);}
body[data-herobg]:not([data-herobg="none"]) .hero .hero-float .val{color:#fff;}
body[data-herobg]:not([data-herobg="none"]) .hero .hero-float .row{border-top-color:rgba(255,255,255,.16);}
body[data-herobg]:not([data-herobg="none"]) .hero .hero-float .mono{color:rgba(233,240,246,.72)!important;}

/* -----------------------------------------------------------
   HERO TEXT TREATMENTS (tweakable via body[data-herostyle])
   Goal: let the photo read while keeping the copy legible.
   ----------------------------------------------------------- */
/* shared: give the copy column room to become a contained surface */
body[data-herobg]:not([data-herobg="none"])[data-herostyle="glass"] .hero-copy,
body[data-herobg]:not([data-herobg="none"])[data-herostyle="panel"] .hero-copy{
  border-radius:var(--radius);padding:34px 36px;
  align-self:start;
}

/* A) GLASS — frosted translucent card; photo shows through and around it */
body[data-herobg]:not([data-herobg="none"])[data-herostyle="glass"] .hero-scrim{
  background:linear-gradient(0deg, rgba(7,19,31,.34) 0%, rgba(7,19,31,.14) 60%, rgba(7,19,31,.06) 100%);
}
body[data-herobg]:not([data-herobg="none"])[data-herostyle="glass"] .hero-copy{
  background:rgba(11,25,40,.46);
  -webkit-backdrop-filter:blur(13px) saturate(1.25);backdrop-filter:blur(13px) saturate(1.25);
  border:1px solid rgba(255,255,255,.16);
}

/* B) PANEL — near-solid navy card; crispest text, photo breathes on the right */
body[data-herobg]:not([data-herobg="none"])[data-herostyle="panel"] .hero-scrim{
  background:linear-gradient(90deg, rgba(7,19,31,.42) 0%, rgba(7,19,31,.18) 45%, rgba(7,19,31,0) 72%);
}
body[data-herobg]:not([data-herobg="none"])[data-herostyle="panel"] .hero-copy{
  background:rgba(13,34,53,.93);border:1px solid rgba(255,255,255,.1);
}

/* C) LIGHT SCRIM — current approach, much lighter, with a text-shadow safety net */
body[data-herobg]:not([data-herobg="none"])[data-herostyle="scrim"] .hero-scrim{
  background:
    linear-gradient(90deg, rgba(7,19,31,.8) 0%, rgba(7,19,31,.58) 38%, rgba(7,19,31,.22) 68%, rgba(7,19,31,.05) 100%),
    linear-gradient(0deg, rgba(7,19,31,.34) 0%, rgba(7,19,31,0) 56%);
}
body[data-herobg]:not([data-herobg="none"])[data-herostyle="scrim"] .hero h1,
body[data-herobg]:not([data-herobg="none"])[data-herostyle="scrim"] .hero .lede{
  text-shadow:0 1px 14px rgba(4,12,20,.5);
}

/* D) PHOTO-FORWARD — minimal scrim, legibility from text-shadow only */
body[data-herobg]:not([data-herobg="none"])[data-herostyle="minimal"] .hero-scrim{
  background:
    linear-gradient(90deg, rgba(7,19,31,.5) 0%, rgba(7,19,31,.22) 42%, rgba(7,19,31,0) 70%),
    linear-gradient(0deg, rgba(7,19,31,.32) 0%, rgba(7,19,31,0) 46%);
}
body[data-herobg]:not([data-herobg="none"])[data-herostyle="minimal"] .hero h1,
body[data-herobg]:not([data-herobg="none"])[data-herostyle="minimal"] .hero .lede,
body[data-herobg]:not([data-herobg="none"])[data-herostyle="minimal"] .hero .eyebrow,
body[data-herobg]:not([data-herobg="none"])[data-herostyle="minimal"] .hero .trust-names span{
  text-shadow:0 2px 18px rgba(4,12,20,.7), 0 1px 3px rgba(4,12,20,.6);
}

/* mobile: single column, photo as full backdrop, uniform scrim, hide spec card */
@media (max-width:900px){
  body[data-herobg]:not([data-herobg="none"]) .hero .hero-visual{display:none;}
  body[data-herobg]:not([data-herobg="none"]) .hero-grid{gap:0;}
  body[data-herobg]:not([data-herobg="none"]) .hero-scrim{
    background:linear-gradient(180deg, rgba(7,19,31,.86) 0%, rgba(7,19,31,.72) 50%, rgba(7,19,31,.82) 100%);
  }
  /* contained-card treatments: tighter padding on phones */
  body[data-herobg]:not([data-herobg="none"])[data-herostyle="glass"] .hero-copy,
  body[data-herobg]:not([data-herobg="none"])[data-herostyle="panel"] .hero-copy{
    padding:26px 22px;
  }
  /* glass/panel: very light backdrop on mobile, the card carries legibility */
  body[data-herobg]:not([data-herobg="none"])[data-herostyle="glass"] .hero-scrim,
  body[data-herobg]:not([data-herobg="none"])[data-herostyle="panel"] .hero-scrim{
    background:linear-gradient(180deg, rgba(7,19,31,.5) 0%, rgba(7,19,31,.32) 60%, rgba(7,19,31,.4) 100%);
  }
  /* scrim/photo-forward: vertical scrim that actually sits under the stacked copy */
  body[data-herobg]:not([data-herobg="none"])[data-herostyle="scrim"] .hero-scrim,
  body[data-herobg]:not([data-herobg="none"])[data-herostyle="minimal"] .hero-scrim{
    background:linear-gradient(180deg, rgba(7,19,31,.78) 0%, rgba(7,19,31,.58) 50%, rgba(7,19,31,.72) 100%);
  }
}

/* -----------------------------------------------------------
   HERO IMAGE LAYOUT — "side" (tweakable via body[data-herolayout])
   Default "full" = photo as full-bleed backdrop (the dark-hero rules above).
   "side" = light hero again, with the chosen photo contained in the right-hand
   visual column — exactly where the white-hero placeholder sits. The extra
   [data-herolayout="side"] attribute outranks every dark-hero rule, so this
   block alone flips the section back to light without touching them.
   The photo URL comes from --hero-img, set on <body> by tweaks-app.jsx.
   ----------------------------------------------------------- */
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero{
  color:var(--ink);background:var(--paper);border-bottom:1px solid var(--line);
}
/* drop the full-bleed photo + scrim */
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero-bg,
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero-scrim{display:none;}

/* restore dark-on-light copy */
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero h1{color:var(--navy);text-shadow:none;}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .lede{color:var(--muted);text-shadow:none;}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .eyebrow{color:var(--muted);text-shadow:none;}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-trust{border-top-color:var(--line);}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-trust .mono{color:var(--faint);}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .trust-names span{color:var(--faint);text-shadow:none;}

/* outline button back to the light variant */
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .btn-outline{
  color:var(--navy);border-color:var(--line);background:transparent;
}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .btn-outline:hover{
  border-color:var(--navy);background:transparent;
}

/* copy column: no glass/panel surface, sit at the grid's vertical centre */
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero-copy{
  background:none;border:none;padding:0;align-self:center;
  -webkit-backdrop-filter:none;backdrop-filter:none;
}

/* show the placeholder frame, now filled with the chosen photo */
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-visual{display:block;}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-visual .ph{
  display:block;background-image:var(--hero-img);
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
/* the photo overflows the frame top & bottom so it can drift (parallax via nav.js) */
.ph-photo{display:none;}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-visual .ph .ph-photo{
  display:block;position:absolute;left:0;top:-20%;width:100%;height:140%;
  object-fit:cover;object-position:center;will-change:transform;z-index:0;
}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-visual .ph .ph-label{display:none;}

/* spec card back to the light floating treatment over the photo */
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-float{
  position:absolute;left:20px;bottom:20px;width:300px;max-width:calc(100% - 40px);margin-left:0;
  background:#fff;border-color:var(--line);
  -webkit-backdrop-filter:none;backdrop-filter:none;
}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-float .ttl{color:var(--faint);}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-float .val{color:var(--ink);}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-float .row{border-top-color:var(--line);}
body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-float .mono{color:var(--muted)!important;}

@media (max-width:900px){
  /* on phones the photo stacks above the copy, like the white hero does */
  body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-visual{display:block;order:-1;}
  body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero-grid{gap:40px;}
  body[data-herobg]:not([data-herobg="none"])[data-herolayout="side"] .hero .hero-visual .ph{aspect-ratio:16/10;}
}
