/* ============================================================
   SALERNO CONSULTANCY COMPANY — Global Stylesheet
   Project Control Experts · Bahrain · Sweden
   ============================================================ */

/* ---- RESET & TOKENS ---- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
:root{
  --g:#3CB54A;--gd:#2e9940;--gl:#edfaef;--gm:#c3efc9;
  --bk:#0c0c0c;--wh:#ffffff;--of:#f8f7f4;--lt:#f0efec;
  --gy:#5a5a5a;--gyl:#a8a8a8;--bdr:#e0ddd8;
  --f-head:'Syne',sans-serif;
  --f-serif:Georgia,'Times New Roman',serif;
  --f-mono:'IBM Plex Mono',monospace;
  --f-body:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --wrap:1320px;
}
body{background:var(--wh);color:var(--bk);font-family:var(--f-body);font-weight:500;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}
img{display:block;max-width:100%}
a{color:inherit}
::selection{background:var(--g);color:#fff}

/* ---- SKIP LINK (a11y) ---- */
.skip{position:absolute;left:-9999px;top:0;z-index:9999;background:var(--bk);color:#fff;padding:.8rem 1.4rem;font-family:var(--f-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em}
.skip:focus{left:1rem;top:1rem}

/* ---- NAV ---- */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 3rem;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);border-bottom:1px solid transparent;transition:border-color .3s}
.nav.line{border-color:var(--bdr)}
.nav .logo img{height:32px;width:auto}
.n-mid{display:flex;gap:1.1rem;list-style:none}
.n-mid a{font-family:var(--f-mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.14em;color:var(--gy);text-decoration:none;transition:color .18s}
.n-mid a:hover,.n-mid a[aria-current="page"]{color:var(--g)}
.n-cta{font-family:var(--f-mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.12em;color:var(--bk);border:1px solid var(--bk);padding:.5rem 1.4rem;text-decoration:none;transition:background .2s,color .2s}
.n-cta:hover{background:var(--bk);color:var(--wh)}
.n-burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.n-burger span{width:22px;height:2px;background:var(--bk);display:block;transition:.3s}

/* ---- SHARED LAYOUT ---- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 3rem}
.section{padding:8rem 0}
.eyebrow{font-family:var(--f-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.2em;color:var(--g);display:flex;align-items:center;gap:.7rem;margin-bottom:1.4rem}
.eyebrow::before{content:'';width:22px;height:1px;background:var(--g);display:block}
.sh{font-family:var(--f-head);font-weight:800;font-size:clamp(2rem,4vw,3.8rem);line-height:1.02;letter-spacing:-.03em;text-transform:uppercase}
.sh em{font-family:var(--f-serif);font-style:italic;text-transform:none;color:var(--g);font-weight:400;font-size:.9em}
.lead{font-size:.95rem;font-weight:500;color:var(--gy);line-height:1.85;max-width:540px;margin-top:1rem}
.divider{height:1px;background:var(--bdr)}

/* ---- REVEAL (content visible by default — entrance is a pure enhancement) ---- */
.rv{opacity:1;transform:none}
.rv.vis{opacity:1;transform:none}
@media(min-width:1px){
  /* Only browsers that paint transitions get the entrance; resting state stays visible */
  .rv.anim{opacity:0;transform:translateY(26px);transition:opacity .75s ease,transform .75s ease}
  .rv.anim.d1{transition-delay:.1s}.rv.anim.d2{transition-delay:.22s}.rv.anim.d3{transition-delay:.33s}
  .rv.anim.vis{opacity:1;transform:none}
}
@media(prefers-reduced-motion:reduce){.rv.anim{opacity:1!important;transform:none!important;transition:none!important}*{scroll-behavior:auto!important}}

/* ---- HERO ---- */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 3rem;border-bottom:1px solid var(--bdr);position:relative;overflow:hidden}
.hero-bg-num{position:absolute;right:-2vw;top:50%;transform:translateY(-50%);font-family:var(--f-head);font-size:38vw;font-weight:800;color:rgba(60,181,74,.05);line-height:1;pointer-events:none;user-select:none;white-space:nowrap}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;padding-top:10rem;margin-bottom:auto;gap:2rem}
.hero-index,.hero-loc{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gyl)}
.hero-loc{text-align:right}
.hero-index span,.hero-loc span{color:var(--g);font-weight:500}
.hero-headline{margin:3rem 0 0}
.hero-headline h1{font-family:var(--f-head);font-weight:800;font-size:clamp(3.4rem,11vw,13rem);line-height:.9;letter-spacing:-.04em;text-transform:uppercase}
.hero-headline .itl{display:block;padding-left:8vw;font-family:var(--f-serif);font-weight:400;font-style:italic;font-size:.78em;text-transform:none;color:var(--g)}
.hero-headline .out{display:block;-webkit-text-stroke:2px var(--bk);color:transparent}
.hero-bottom{display:grid;grid-template-columns:1fr 1fr 1fr;border-top:1px solid var(--bdr);margin-top:4rem}
.hb-cell{padding:2rem 2rem 2rem 0;border-right:1px solid var(--bdr);margin-right:2rem}
.hb-cell:last-child{border-right:none;margin-right:0}
.hb-num{font-family:var(--f-head);font-size:2.6rem;font-weight:800;line-height:1}
.hb-num span{color:var(--g)}
.hb-lbl{font-family:var(--f-mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.16em;color:var(--gyl);margin-top:.4rem}
.hb-sub{font-size:.8rem;color:var(--gy);margin-top:.3rem}

/* ---- FULL-SCREEN IMAGE HERO ---- */
.hero-img{justify-content:flex-end;background:#0c0c0c}
.hero-photo{position:absolute;inset:0;z-index:0;background-image:url('../assets/hero-digital-twin.jpg');background-size:cover;background-position:center center;background-repeat:no-repeat}
.hero-scrim{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(8,8,8,.72) 0%,rgba(8,8,8,.30) 22%,rgba(8,8,8,.22) 50%,rgba(8,8,8,.52) 74%,rgba(8,8,8,.90) 100%)}
.hero-3d{position:absolute;inset:0;z-index:1;width:100%;height:100%;display:block}
.hero-img>.hero-top,.hero-img>.hero-headline,.hero-img>.lead,.hero-img>.hero-bottom{position:relative;z-index:3}
.hero-img .hero-index,.hero-img .hero-loc{color:rgba(255,255,255,.80)}
.hero-img .hero-index span,.hero-img .hero-loc span{color:var(--g)}
.hero-img .hero-headline h1{color:#fff}
.hero-img .hero-headline .out{-webkit-text-stroke:1.5px rgba(255,255,255,.88);color:transparent}
.hero-img .lead{color:rgba(255,255,255,.88)}
.hero-img .hero-bottom{border-top-color:rgba(255,255,255,.26)}
.hero-img .hb-cell{border-right-color:rgba(255,255,255,.26)}
.hero-img .hb-num{color:#fff}
.hero-img .hb-lbl{color:rgba(255,255,255,.62)}
.hero-img .hb-sub{color:rgba(255,255,255,.58)}
.hero-img .bh-badge{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.28);color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.hero-img .bh-badge .bh-ar{border-left-color:rgba(255,255,255,.28);color:#fff}
.hero-cta{display:flex;gap:.8rem;margin-top:2.4rem;flex-wrap:wrap}

/* ---- BRAND HEADLINE (Salerno Company) + payoff ---- */
.brandline{line-height:.9;letter-spacing:-.045em;margin:0}
.brandline .bl-word{display:block}
.brandline .w2{font-family:var(--f-serif);font-weight:400;font-style:italic;text-transform:none;font-size:.82em;padding-left:.06em;color:var(--g)}
.hero-img .brandline .w1{color:#fff}
.hero-img .brandline .w2{color:var(--g)}
.payoff{display:flex;flex-wrap:wrap;gap:.55em;margin-top:1.5rem;font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.34em;font-weight:500;font-size:clamp(.72rem,1.5vw,1.08rem);color:rgba(255,255,255,.9)}
.payoff span:nth-child(2){color:var(--g)}
.preanim .brandline .bl-word{opacity:0;transform:translateY(34px)}
.preanim .payoff{opacity:0;transform:translateY(12px)}
@media(max-width:560px){.payoff{letter-spacing:.2em;gap:.45em}}

/* buttons */
.btn{font-family:var(--f-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;padding:.85rem 2rem;text-decoration:none;transition:all .2s;display:inline-block;cursor:pointer;border:none}
.btn-g{background:var(--g);color:#fff}
.btn-g:hover{background:var(--gd);transform:translateY(-2px)}
.btn-o{border:1px solid var(--bdr);color:var(--gy);background:transparent}
.btn-o:hover{border-color:var(--g);color:var(--g)}
.btn-bk{border:1px solid var(--bk);color:var(--bk);background:transparent}
.btn-bk:hover{background:var(--bk);color:#fff}

/* ---- MARQUEE ---- */
.marquee{background:var(--bk);overflow:hidden;padding:.8rem 0;border-top:1px solid #222}
.marquee-track{display:flex;white-space:nowrap;width:max-content;animation:mq 32s linear infinite}
.mq-item{font-family:var(--f-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.72);padding:0 2.6rem;display:inline-flex;align-items:center;gap:.6rem}
.mq-item .dot{width:5px;height:5px;background:var(--g);border-radius:50%}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- SERVICES ---- */
.bg-of{background:var(--of)}
.bg-bk{background:var(--bk);color:#fff}
.srv-intro{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:end;margin-bottom:5rem}
.srv-list{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.sc{background:var(--of);padding:3rem 2.4rem;transition:background .28s}
.sc:hover{background:var(--wh)}
.sc-n{font-family:var(--f-mono);font-size:.55rem;letter-spacing:.15em;color:var(--gyl);margin-bottom:2.4rem;display:block}
.sc-t{font-family:var(--f-head);font-size:1.3rem;font-weight:700;line-height:1.15;letter-spacing:-.02em;margin-bottom:.9rem}
.sc-p{font-size:.85rem;color:var(--gy);line-height:1.8;font-weight:500}
.sc-tags{margin-top:1.6rem;display:flex;flex-wrap:wrap;gap:.4rem}
.stag{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.09em;border:1px solid var(--gm);color:var(--g);padding:.22rem .7rem;background:var(--gl)}

/* ---- TWO-COL ---- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:start}
.two-col.center{align-items:center}

/* ---- EVM ---- */
.formulas{margin-top:2.6rem;display:flex;flex-direction:column;gap:.55rem}
.fr{display:flex;align-items:center;gap:1.4rem;padding:.9rem 1.2rem;background:var(--of);border-left:2px solid transparent;transition:border-color .2s}
.fr:hover{border-color:var(--g)}
.fr-id{font-family:var(--f-mono);font-size:.68rem;font-weight:500;color:var(--g);min-width:38px}
.fr-eq{font-family:var(--f-mono);font-size:.78rem;color:var(--bk);flex:1}
.fr-lbl{font-size:.72rem;color:var(--gyl)}
.evm-metrics{display:flex;flex-direction:column;gap:.8rem}
.em{display:grid;grid-template-columns:70px 1fr;border:1px solid var(--bdr);transition:border-color .2s,transform .2s}
.em:hover{border-color:var(--g);transform:translateX(6px)}
.em-abbr{background:var(--bk);display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-size:.78rem;font-weight:500;color:#fff}
.em-body{padding:1.2rem 1.4rem}
.em-name{font-size:.83rem;font-weight:600;margin-bottom:.35rem}
.em-desc{font-size:.76rem;color:var(--gy);line-height:1.62;font-weight:500}

/* ---- TABLE ---- */
.tw{overflow-x:auto;border:1px solid var(--bdr);margin-top:2.5rem}
table{width:100%;border-collapse:collapse;font-size:.77rem}
thead tr{background:var(--bk);color:#fff}
th{font-family:var(--f-mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.11em;padding:.9rem 1.1rem;text-align:left;font-weight:400;white-space:nowrap}
tbody tr{border-bottom:1px solid var(--bdr);transition:background .14s}
tbody tr:hover{background:var(--lt)}
td{padding:.85rem 1.1rem;color:var(--gy);white-space:nowrap}
td.key{font-weight:600;color:var(--bk);font-family:var(--f-mono);font-size:.7rem}
.ok{color:var(--g);font-weight:700}.wn{color:#d97706;font-weight:700}.bd{color:#dc2626;font-weight:700}
.pill{font-family:var(--f-mono);font-size:.52rem;letter-spacing:.08em;padding:.2rem .75rem;white-space:nowrap}
.pok{background:#dcfce7;color:#166534}.pwn{background:#fef9c3;color:#854d0e}.pbd{background:#fee2e2;color:#991b1b}
tfoot td{background:var(--lt);font-family:var(--f-mono);font-size:.62rem;font-weight:600;padding:.9rem 1.1rem;color:var(--bk);border-top:2px solid var(--bk)}

/* ---- MATRIX ---- */
.mx-quads{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:2.5rem}
.mq{padding:1.8rem 1.6rem}
.mq-t{font-family:var(--f-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;font-weight:500;margin-bottom:.5rem}
.mq-d{font-size:.8rem;line-height:1.65}
.q1{background:#fefce8}.q2{background:#f0fdf4}.q3{background:#fef2f2}.q4{background:#eff6ff}

/* ---- AWP DARK ---- */
.bg-bk .eyebrow{color:var(--g)}
.bg-bk .sh{color:#fff}
.bg-bk .lead{color:rgba(255,255,255,.5)}
.tools-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
.tool{background:var(--bk);padding:1.8rem 1.6rem;transition:background .2s}
.tool:hover{background:#181818}
.tool-l{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.3);margin-bottom:.5rem}
.tool-n{font-family:var(--f-head);font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.3rem}
.tool-s{font-size:.74rem;color:rgba(255,255,255,.38);line-height:1.5}

/* ---- PAGE HEADER (interior pages) ---- */
.phead{padding:11rem 0 4rem;border-bottom:1px solid var(--bdr);position:relative;overflow:hidden}
.phead .wrap{position:relative;z-index:2}
.phead-bg{position:absolute;right:-1vw;top:50%;transform:translateY(-50%);font-family:var(--f-head);font-size:30vw;font-weight:800;color:rgba(60,181,74,.045);line-height:1;pointer-events:none;user-select:none;white-space:nowrap}
.phead h1{font-family:var(--f-head);font-weight:800;font-size:clamp(2.8rem,7vw,6.5rem);line-height:.94;letter-spacing:-.04em;text-transform:uppercase;margin-top:.5rem}
.phead h1 em{font-family:var(--f-serif);font-style:italic;text-transform:none;color:var(--g);font-weight:400;font-size:.84em}
.crumb{font-family:var(--f-mono);font-size:.54rem;text-transform:uppercase;letter-spacing:.14em;color:var(--gyl);margin-bottom:1.4rem}
.crumb a{color:var(--gyl);text-decoration:none}
.crumb a:hover{color:var(--g)}
.crumb span{color:var(--g)}

/* ---- SECTOR ROWS (projects) ---- */
.sr{display:grid;grid-template-columns:1fr 1fr;min-height:560px;border-bottom:1px solid var(--bdr)}
.sr:nth-child(even){direction:rtl}
.sr:nth-child(even)>*{direction:ltr}
.sr-img{position:relative;overflow:hidden;background:#111;min-height:400px}
.sr-img>img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.25,.46,.45,.94);filter:brightness(.88)}
.sr:hover .sr-img>img{transform:scale(1.05);filter:brightness(.78)}
.sr-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6),rgba(0,0,0,.08) 55%,transparent)}
.sr-badge{position:absolute;top:1.5rem;left:1.5rem;font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.14em;background:var(--g);color:#fff;padding:.28rem .85rem;z-index:2}
.sr-live{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;background:rgba(12,12,12,.75);color:#fff;padding:.28rem .85rem;backdrop-filter:blur(6px);display:flex;align-items:center;gap:.45rem;z-index:2}
.sr-live-dot{width:6px;height:6px;background:#ef4444;border-radius:50%;animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}
.sr-photos{width:100%;height:100%;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px}
.sr-photos img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;filter:brightness(.88)}
.sr-photos img:first-child{grid-column:1;grid-row:1/3}
.sr:hover .sr-photos img{transform:scale(1.04);filter:brightness(.78)}
.sr-content{padding:4rem 4.5rem;display:flex;flex-direction:column;justify-content:center;background:var(--wh);position:relative}
.sr-n{position:absolute;top:2rem;right:3rem;font-family:var(--f-head);font-size:5rem;font-weight:800;color:rgba(0,0,0,.05);line-height:1;letter-spacing:-.04em}
.sr-eye{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.2em;color:var(--g);display:flex;align-items:center;gap:.5rem;margin-bottom:1.2rem}
.sr-eye::before{content:'';width:16px;height:1.5px;background:var(--g);display:block}
.sr-title{font-family:var(--f-head);font-size:clamp(1.7rem,2.5vw,2.5rem);font-weight:800;line-height:1.06;letter-spacing:-.03em;text-transform:uppercase;margin-bottom:1rem}
.sr-title em{font-family:var(--f-serif);font-style:italic;text-transform:none;color:var(--g);font-weight:400;font-size:.9em}
.sr-desc{font-size:.88rem;color:var(--gy);line-height:1.85;font-weight:500;max-width:440px;margin-bottom:2rem}
.sr-list{display:flex;flex-direction:column;gap:.55rem;margin-bottom:2rem}
.sp{display:flex;align-items:flex-start;gap:.9rem;padding:.9rem 1.1rem;background:var(--of);border:1px solid var(--bdr);transition:border-color .2s,background .2s}
.sp:hover{border-color:var(--g);background:var(--gl)}
.sp-line{width:1.5px;background:var(--g);align-self:stretch;flex-shrink:0;min-height:32px}
.sp-name{font-size:.83rem;font-weight:600;line-height:1.3;margin-bottom:.18rem}
.sp-meta{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.09em;color:var(--gyl)}
.sp-ref{font-family:var(--f-mono);font-size:.46rem;border:1px solid var(--gm);color:var(--g);padding:.08rem .5rem;margin-left:.5rem;vertical-align:middle}
.sp-cur{font-family:var(--f-mono);font-size:.46rem;background:var(--g);color:#fff;padding:.08rem .5rem;margin-left:.5rem;vertical-align:middle}
.sr-role{font-family:var(--f-mono);font-size:.54rem;text-transform:uppercase;letter-spacing:.12em;color:var(--g);padding-top:1.2rem;border-top:1px solid var(--bdr)}

/* ---- REFERENCES ---- */
.ref-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:4rem}
.rc{background:var(--wh);border:1px solid var(--bdr);padding:2.4rem 2rem;position:relative;overflow:hidden;transition:border-color .25s,transform .2s}
.rc:hover{border-color:var(--g);transform:translateY(-3px)}
.rc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:transparent;transition:background .25s}
.rc:hover::before{background:var(--g)}
.rc-q{font-family:var(--f-serif);font-size:3.5rem;line-height:.5;color:rgba(60,181,74,.18);margin-bottom:.8rem;display:block}
.rc-txt{font-size:.865rem;color:var(--gy);line-height:1.82;font-style:italic;font-family:var(--f-serif);margin-bottom:1.5rem}
.rc-div{height:1px;background:var(--bdr);margin-bottom:1.2rem}
.rc-name{font-family:var(--f-head);font-size:.9rem;font-weight:700;margin-bottom:.2rem}
.rc-role{font-family:var(--f-mono);font-size:.54rem;text-transform:uppercase;letter-spacing:.1em;color:var(--g);margin-bottom:.25rem}
.rc-co{font-size:.78rem;color:var(--gy)}
.rc-proj{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl);margin-top:.35rem}
.rc-badge{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.09em;border:1px solid var(--gm);color:var(--g);padding:.22rem .7rem;background:var(--gl);margin-top:.8rem}

/* ---- ARAMCO CREDENTIAL ---- */
.aramco{background:var(--bk);display:grid;grid-template-columns:1.1fr 1fr;border:1px solid #1e1e1e;overflow:hidden}
.ar-left{padding:3.5rem 4rem}
.ar-sup{font-family:var(--f-mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.3);margin-bottom:1.2rem}
.ar-left h3{font-family:var(--f-head);font-weight:800;font-size:clamp(1.6rem,2.5vw,2.2rem);color:#fff;line-height:1.1;letter-spacing:-.03em;text-transform:uppercase;margin-bottom:1rem}
.ar-left h3 em{font-family:var(--f-serif);font-style:italic;text-transform:none;color:var(--g);font-weight:400}
.ar-left p{font-size:.875rem;color:rgba(255,255,255,.5);line-height:1.82;font-weight:500;max-width:420px;margin-bottom:1rem}
.ar-pill{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em;background:var(--g);color:#fff;padding:.4rem 1.1rem;margin-top:.8rem}
.ar-sub{font-family:var(--f-mono);font-size:.5rem;color:rgba(255,255,255,.22);margin-top:.7rem;letter-spacing:.08em}
.ar-right{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.06)}
.ak{background:#111;padding:2rem;display:flex;flex-direction:column;justify-content:center}
.ak-n{font-family:var(--f-head);font-size:2.4rem;font-weight:800;color:var(--g);line-height:1}
.ak-l{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.3);margin-top:.3rem}

/* ---- ABOUT ---- */
.ab-text p{font-size:.92rem;color:var(--gy);line-height:1.9;margin-bottom:1.1rem;font-weight:500}
.certs{display:flex;flex-direction:column;gap:.6rem;margin-top:2.5rem}
.cert{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.2rem;background:var(--of);border:1px solid var(--bdr)}
.cert-dot{width:6px;height:6px;background:var(--g);margin-top:.4rem;flex-shrink:0}
.cert-txt{font-size:.8rem;color:var(--gy);line-height:1.5}
.cert-txt strong{display:block;font-family:var(--f-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;color:var(--bk);font-weight:500;margin-bottom:.15rem}
.quote{background:var(--bk);padding:3.5rem;position:relative;overflow:hidden}
.q-bg{position:absolute;top:-2rem;left:-1rem;font-family:var(--f-serif);font-size:12rem;line-height:.4;color:rgba(60,181,74,.12);pointer-events:none}
.q-txt{font-family:var(--f-serif);font-style:italic;font-size:1.3rem;line-height:1.55;color:#fff;margin-bottom:1.5rem;position:relative;z-index:1}
.q-attr{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.14em;color:var(--g)}
.stat-row{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:1.2rem}
.sbox{background:var(--wh);padding:1.5rem;text-align:center}
.sn{font-family:var(--f-head);font-size:2.2rem;font-weight:800;color:var(--g);line-height:1}
.sl{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gyl);margin-top:.3rem}

/* ---- PARTNERS ---- */
.tier-wrap{margin-bottom:4.5rem}
.tier-hed{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.2em;background:var(--bk);color:#fff;display:inline-block;padding:.4rem 1.1rem;margin-bottom:1.5rem}
.pg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.pg.g2{grid-template-columns:repeat(2,1fr)}
.pg.g1{grid-template-columns:1fr}
.pcard{background:var(--wh);padding:2.4rem 2rem;position:relative;overflow:hidden;transition:background .22s}
.pcard:hover{background:var(--gl)}
.pcard::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--g);transition:width .35s}
.pcard:hover::after{width:100%}
.pn{font-family:var(--f-head);font-size:1.2rem;font-weight:700;margin-bottom:.35rem;letter-spacing:-.01em}
.pr{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em;color:var(--g);margin-bottom:.9rem}
.pd{font-size:.83rem;color:var(--gy);line-height:1.72;font-weight:500}
.pbadge{margin-top:1.3rem;display:inline-flex;align-items:center;gap:.4rem;font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.1em;border:1px solid var(--gm);color:var(--g);padding:.25rem .75rem;background:var(--gl)}
.pweb{display:inline-block;margin-top:1rem;font-family:var(--f-mono);font-size:.6rem;letter-spacing:.06em;color:var(--g);text-decoration:none;border-bottom:1px solid var(--gm);padding-bottom:1px;transition:border-color .2s}
.pweb:hover{border-color:var(--g)}

/* ---- PROCESS-AT-A-GLANCE FLOW ---- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--bdr);margin-top:2.5rem}
.fstep{padding:1.7rem 1.5rem;border-right:1px solid var(--bdr);position:relative;background:var(--of)}
.fstep:last-child{border-right:none}
.fstep .ph{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.12em;color:var(--g);margin-bottom:.6rem}
.fstep .ft{font-family:var(--f-head);font-size:1.2rem;font-weight:800;margin-bottom:.5rem;letter-spacing:-.01em}
.fstep .fd{font-size:.76rem;color:var(--gy);line-height:1.5;font-weight:500}
.fstep .farrow{position:absolute;right:-10px;top:50%;transform:translateY(-50%);width:20px;height:20px;background:var(--g);border-radius:50%;color:#fff;font-size:.7rem;display:flex;align-items:center;justify-content:center;z-index:2}
.fstep:last-child .farrow{display:none}
.lane{display:grid;grid-template-columns:150px 1fr;border:1px solid var(--bdr);border-top:none}
.lane-h{background:var(--bk);color:#fff;font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.1em;padding:1rem 1.2rem;display:flex;align-items:center}
.lane-items{display:flex;flex-wrap:wrap;gap:.45rem;padding:1rem 1.2rem;align-items:center}
.lchip{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--gm);color:var(--g);background:var(--gl);padding:.28rem .7rem}
.lchip.d{border-color:#222;color:#fff;background:#0c0c0c}
@media(max-width:680px){.flow{grid-template-columns:1fr 1fr}.lane{grid-template-columns:1fr}.lane-h{border-bottom:1px solid var(--bdr)}}

/* ---- HERITAGE / 4D SINCE 2004 ---- */
.herit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);margin-top:2.5rem}
.herit-card{background:#0c0c0c}
.herit-card img{width:100%;height:200px;object-fit:cover;display:block;filter:grayscale(.15)}
.herit-cap{padding:1rem 1.2rem}
.herit-cap .d{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.12em;color:var(--g);margin-bottom:.3rem}
.herit-cap .t{font-family:var(--f-head);font-size:.92rem;font-weight:700;color:#fff}
@media(max-width:680px){.herit-grid{grid-template-columns:1fr}.herit-card img{height:220px}}

/* ---- 8 CONTROL AREAS ---- */
.ctrl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:2.5rem}
.ctrl{background:var(--wh);padding:1.6rem 1.4rem;transition:background .22s;position:relative}
.ctrl:hover{background:var(--gl)}
.ctrl .cn{font-family:var(--f-mono);font-size:.62rem;color:var(--g);font-weight:500;margin-bottom:.7rem}
.ctrl .ct{font-family:var(--f-head);font-size:1rem;font-weight:700;line-height:1.15;letter-spacing:-.01em}
@media(max-width:780px){.ctrl-grid{grid-template-columns:1fr 1fr}}

/* ---- PROGRESS TARGET DIAGRAM ---- */
.target-wrap{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.target-svg{width:100%;max-width:480px;margin:0 auto;display:block}
.target-legend{display:flex;flex-direction:column;gap:.7rem;margin-top:1.5rem}
.tleg{display:flex;align-items:flex-start;gap:1rem;padding:.9rem 1.1rem;background:rgba(255,255,255,.04);border-left:2px solid var(--g)}
.tleg .ti{width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:.2rem}
.tleg .tt{font-family:var(--f-head);font-size:.92rem;font-weight:700;color:#fff;margin-bottom:.15rem}
.tleg .td{font-size:.78rem;color:rgba(255,255,255,.5);line-height:1.5;font-weight:500}
@media(max-width:860px){.target-wrap{grid-template-columns:1fr;gap:2.5rem}}

/* ---- CONFIDENTIALITY NOTE ---- */
.nda-note{display:flex;align-items:flex-start;gap:.8rem;background:var(--of);border:1px solid var(--bdr);border-left:3px solid var(--g);padding:.9rem 1.2rem;margin-top:1.8rem;max-width:760px}
.nda-note .ic{font-family:var(--f-mono);font-size:.7rem;color:var(--g);font-weight:500;flex-shrink:0;letter-spacing:.06em}
.nda-note p{font-size:.76rem;color:var(--gy);line-height:1.6;font-weight:500;margin:0}
.bg-bk .nda-note{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12);border-left-color:var(--g)}
.bg-bk .nda-note p{color:rgba(255,255,255,.55)}

/* ---- PARTNERS MARQUEE (all pages) ---- */
.pmarq{display:flex;align-items:stretch;background:var(--of);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);overflow:hidden}
.pmarq-label{flex-shrink:0;display:flex;align-items:center;gap:.5rem;background:var(--bk);color:#fff;font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.14em;padding:.9rem 1.4rem;text-decoration:none;white-space:nowrap;transition:background .2s}
.pmarq-label:hover{background:var(--gd)}
.pmarq-label .ar{color:var(--g)}
.pmarq-vp{flex:1;overflow:hidden;display:flex;align-items:center;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.pmarq-track{display:flex;align-items:center;white-space:nowrap;width:max-content;animation:mq 30s linear infinite}
.pmarq:hover .pmarq-track{animation-play-state:paused}
.pmarq-item{display:inline-flex;align-items:center;gap:.7rem;padding:0 1.8rem;font-family:var(--f-head);font-weight:700;font-size:.95rem;letter-spacing:-.01em;color:var(--bk)}
.pmarq-item::before{content:'';width:5px;height:5px;background:var(--g);border-radius:50%;flex-shrink:0}
@media(max-width:560px){.pmarq-label{font-size:.5rem;padding:.8rem 1rem}.pmarq-item{font-size:.85rem;padding:0 1.3rem}}
.pcard .pweb + .pbadge{margin-top:.7rem;margin-left:.9rem}

/* ---- FAQ ---- */
.faq{display:flex;flex-direction:column;gap:.7rem;margin-top:2.5rem;max-width:820px}
.faq details{border:1px solid var(--bdr);background:var(--wh);transition:border-color .2s}
.faq details[open]{border-color:var(--g)}
.faq summary{cursor:pointer;list-style:none;padding:1.3rem 1.5rem;font-family:var(--f-head);font-weight:600;font-size:1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-family:var(--f-mono);color:var(--g);font-size:1.3rem;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq-a{padding:0 1.5rem 1.4rem;font-size:.9rem;color:var(--gy);line-height:1.8;font-weight:500}

/* ---- CTA BANNER ---- */
.cta{background:var(--g);padding:5.5rem 3rem;display:flex;align-items:center;justify-content:space-between;gap:3rem}
.cta h2{font-family:var(--f-head);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:800;color:#fff;letter-spacing:-.03em;text-transform:uppercase;line-height:1.08;max-width:560px}
.cta h2 em{font-family:var(--f-serif);font-style:italic;text-transform:none;font-weight:400}
.btn-wh{font-family:var(--f-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.1em;background:#fff;color:var(--g);padding:1rem 2.5rem;text-decoration:none;transition:background .2s;font-weight:500;white-space:nowrap}
.btn-wh:hover{background:var(--gl)}

/* ---- ACADEMY / TRAINING ---- */
.heritage{display:grid;grid-template-columns:1.1fr 1fr;gap:7rem;align-items:center}
.heritage-flow{display:flex;flex-direction:column;gap:0}
.hf-step{display:grid;grid-template-columns:auto 1fr;gap:1.6rem;position:relative;padding-bottom:2.2rem}
.hf-step:last-child{padding-bottom:0}
.hf-rail{display:flex;flex-direction:column;align-items:center}
.hf-dot{width:42px;height:42px;border:1px solid var(--bdr);background:var(--wh);display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-size:.6rem;color:var(--g);flex-shrink:0;z-index:1}
.hf-step:last-child .hf-line{display:none}
.hf-line{width:1px;flex:1;background:var(--bdr);margin:.4rem 0}
.hf-body{padding-top:.5rem}
.hf-k{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.14em;color:var(--gyl);margin-bottom:.4rem}
.hf-t{font-family:var(--f-head);font-size:1.15rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.4rem}
.hf-d{font-size:.84rem;color:var(--gy);line-height:1.7;font-weight:500}
.hf-d strong{color:var(--g);font-weight:500}
.heritage-card{background:var(--bk);padding:3rem;position:relative;overflow:hidden}
.hc-bg{position:absolute;right:-1.5rem;bottom:-3rem;font-family:var(--f-head);font-size:14rem;font-weight:800;color:rgba(60,181,74,.07);line-height:.8;pointer-events:none}
.hc-eyebrow{font-family:var(--f-mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.3);margin-bottom:1.2rem}
.hc-quote{font-family:var(--f-serif);font-style:italic;font-size:1.32rem;line-height:1.55;color:#fff;position:relative;z-index:1;margin-bottom:1.6rem}
.hc-quote em{color:var(--g);font-style:italic}
.hc-attr{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em;color:var(--g);position:relative;z-index:1}
.hc-line{height:1px;background:rgba(255,255,255,.1);margin:1.8rem 0;position:relative;z-index:1}
.hc-stats{display:flex;gap:2.2rem;position:relative;z-index:1}
.hc-stat .n{font-family:var(--f-head);font-size:1.9rem;font-weight:800;color:#fff;line-height:1}
.hc-stat .l{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.35);margin-top:.3rem}

.course-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.course{background:var(--wh);padding:2.8rem 2.6rem;position:relative;transition:background .25s}
.course:hover{background:var(--of)}
.course::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:transparent;transition:background .25s}
.course:hover::before{background:var(--g)}
.course-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.4rem}
.course-n{font-family:var(--f-mono);font-size:.55rem;letter-spacing:.15em;color:var(--gyl)}
.course-lvl{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;padding:.22rem .7rem;border:1px solid var(--bdr);color:var(--gy);white-space:nowrap}
.course-lvl.adv{border-color:var(--gm);color:var(--g);background:var(--gl)}
.course-t{font-family:var(--f-head);font-size:1.4rem;font-weight:700;line-height:1.12;letter-spacing:-.02em;margin-bottom:.5rem}
.course-t em{font-family:var(--f-serif);font-style:italic;color:var(--g);font-weight:400;text-transform:none}
.course-d{font-size:.85rem;color:var(--gy);line-height:1.75;font-weight:500;margin-bottom:1.4rem}
.course-mods{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.6rem}
.cmod{display:flex;align-items:flex-start;gap:.7rem;font-size:.8rem;color:var(--gy);line-height:1.5}
.cmod::before{content:'';width:5px;height:5px;background:var(--g);margin-top:.45rem;flex-shrink:0}
.course-meta{display:flex;gap:1.4rem;padding-top:1.3rem;border-top:1px solid var(--bdr)}
.cm-item{display:flex;flex-direction:column;gap:.2rem}
.cm-item .v{font-family:var(--f-mono);font-size:.74rem;color:var(--bk);font-weight:500}
.cm-item .k{font-family:var(--f-mono);font-size:.48rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl)}

.fmt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
.fmt{background:var(--bk);padding:2.6rem 2.2rem;transition:background .22s}
.fmt:hover{background:#181818}
.fmt-ico{width:38px;height:38px;border:1px solid rgba(60,181,74,.4);display:flex;align-items:center;justify-content:center;margin-bottom:1.4rem}
.fmt-ico svg{width:18px;height:18px;stroke:var(--g);fill:none;stroke-width:1.5}
.fmt-t{font-family:var(--f-head);font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.5rem}
.fmt-d{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.7;font-weight:500}

.aud-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.aud{background:var(--wh);padding:2rem 1.6rem;transition:background .2s}
.aud:hover{background:var(--gl)}
.aud-n{font-family:var(--f-mono);font-size:.5rem;letter-spacing:.12em;color:var(--gyl);margin-bottom:.8rem}
.aud-t{font-family:var(--f-head);font-size:1rem;font-weight:700;margin-bottom:.4rem;line-height:1.15}
.aud-d{font-size:.78rem;color:var(--gy);line-height:1.6;font-weight:500}

.cert-path{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2.5rem;position:relative}
.cp{background:var(--of);border:1px solid var(--bdr);padding:2rem 1.6rem;position:relative;transition:border-color .2s,transform .2s}
.cp:hover{border-color:var(--g);transform:translateY(-3px)}
.cp-step{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.12em;color:var(--g);margin-bottom:1rem}
.cp-t{font-family:var(--f-head);font-size:1.05rem;font-weight:700;margin-bottom:.5rem;line-height:1.15}
.cp-d{font-size:.78rem;color:var(--gy);line-height:1.6;font-weight:500}
.cp-arrow{position:absolute;right:-.85rem;top:50%;transform:translateY(-50%);color:var(--g);font-size:1rem;z-index:2}
@media(max-width:1024px){
  .heritage{grid-template-columns:1fr;gap:3rem}
  .course-grid,.fmt-grid,.aud-grid{grid-template-columns:1fr}
  .cert-path{grid-template-columns:1fr 1fr}
  .cp-arrow{display:none}
  .hc-bg{font-size:9rem}
}
@media(max-width:560px){
  .cert-path{grid-template-columns:1fr}
  .hc-stats{gap:1.4rem;flex-wrap:wrap}
}

/* ---- COURSE DETAIL ---- */
.cdetail{display:grid;grid-template-columns:1fr 380px;gap:4rem;align-items:start}
.cd-main{min-width:0}
.cd-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.6rem}
.cd-tag{font-family:var(--f-mono);font-size:.54rem;text-transform:uppercase;letter-spacing:.1em;padding:.3rem .8rem;border:1px solid var(--bdr);color:var(--gy)}
.cd-tag.g{border-color:var(--gm);color:var(--g);background:var(--gl)}
.cd-h{font-family:var(--f-head);font-weight:800;font-size:clamp(2rem,4vw,3.2rem);line-height:1.02;letter-spacing:-.03em;text-transform:uppercase;margin-bottom:1rem}
.cd-h em{font-family:var(--f-serif);font-style:italic;text-transform:none;color:var(--g);font-weight:400}
.cd-intro{font-size:1rem;color:var(--gy);line-height:1.85;font-weight:500;margin-bottom:2.5rem}
.cd-block{margin-bottom:3rem}
.cd-block h2{font-family:var(--f-head);font-size:1.4rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1.4rem;display:flex;align-items:center;gap:.7rem}
.cd-block h2::before{content:'';width:18px;height:2px;background:var(--g)}
.learn-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.learn{background:var(--wh);padding:1.5rem 1.6rem;display:flex;gap:.9rem;align-items:flex-start}
.learn::before{content:'✓';font-family:var(--f-mono);color:var(--g);font-weight:600;flex-shrink:0}
.learn span{font-size:.86rem;color:var(--gy);line-height:1.55}
.mod-list{display:flex;flex-direction:column;gap:.6rem}
.mod{border:1px solid var(--bdr);background:var(--wh)}
.mod summary{cursor:pointer;list-style:none;padding:1.2rem 1.4rem;display:flex;align-items:center;gap:1rem;font-family:var(--f-head);font-weight:600;font-size:.98rem}
.mod summary::-webkit-details-marker{display:none}
.mod summary::after{content:'+';margin-left:auto;font-family:var(--f-mono);color:var(--g);font-size:1.2rem;transition:transform .2s}
.mod[open]{border-color:var(--g)}
.mod[open] summary::after{transform:rotate(45deg)}
.mod-num{font-family:var(--f-mono);font-size:.62rem;color:var(--gyl)}
.mod-body{padding:0 1.4rem 1.3rem 3.2rem;font-size:.85rem;color:var(--gy);line-height:1.75;font-weight:500}
.cd-buy{position:sticky;top:90px;border:1px solid var(--bdr);background:var(--wh)}
.cd-buy-top{padding:2.2rem 2rem 1.8rem;border-bottom:1px solid var(--bdr)}
.cd-price{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.3rem}
.cd-price .amt{font-family:var(--f-head);font-size:2.6rem;font-weight:800;letter-spacing:-.03em;line-height:1}
.cd-price .per{font-family:var(--f-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl)}
.cd-price-note{font-size:.78rem;color:var(--gy);font-weight:500}
.cd-enroll{display:block;text-align:center;background:var(--g);color:#fff;font-family:var(--f-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;padding:1.1rem;text-decoration:none;margin:1.6rem 0 .7rem;transition:background .2s}
.cd-enroll:hover{background:var(--gd)}
.cd-enroll.sec{background:transparent;color:var(--bk);border:1px solid var(--bk);margin-top:0}
.cd-enroll.sec:hover{background:var(--bk);color:#fff}
.cd-secure{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gyl);text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.4rem}
.cd-secure::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--g)}
.cd-facts{padding:1.6rem 2rem}
.cd-fact{display:flex;justify-content:space-between;align-items:center;padding:.7rem 0;border-bottom:1px solid var(--bdr);font-size:.84rem}
.cd-fact:last-child{border-bottom:none}
.cd-fact .k{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl)}
.cd-fact .v{font-weight:500;color:var(--bk)}
.cd-instr{display:flex;gap:1.4rem;align-items:flex-start;background:var(--of);border:1px solid var(--bdr);padding:2rem}
.cd-instr-badge{width:64px;height:64px;background:var(--bk);color:var(--g);font-family:var(--f-head);font-weight:800;font-size:1.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cd-instr-name{font-family:var(--f-head);font-size:1.1rem;font-weight:700;margin-bottom:.2rem}
.cd-instr-role{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.1em;color:var(--g);margin-bottom:.7rem}
.cd-instr-bio{font-size:.84rem;color:var(--gy);line-height:1.7;font-weight:500}
@media(max-width:980px){
  .cdetail{grid-template-columns:1fr;gap:2.5rem}
  .cd-buy{position:static}
  .learn-grid{grid-template-columns:1fr}
}

/* ---- TAILORED (bespoke) ---- */
.tailor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.tailor{background:var(--wh);padding:1.8rem 1.6rem;transition:background .2s}
.tailor:hover{background:var(--gl)}
.tailor-k{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.12em;color:var(--g);margin-bottom:.7rem}
.tailor-t{font-family:var(--f-head);font-size:1.05rem;font-weight:700;margin-bottom:.4rem;line-height:1.15}
.tailor-d{font-size:.8rem;color:var(--gy);line-height:1.6;font-weight:500}
@media(max-width:760px){.tailor-grid{grid-template-columns:1fr}}

/* ---- REPORTING / DASHBOARD ---- */
.rep-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.rep{background:var(--wh);padding:2rem;display:flex;flex-direction:column;transition:background .2s}
.rep:hover{background:var(--of)}
.rep-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}
.rep-num{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.12em;color:var(--g);border:1px solid var(--gm);background:var(--gl);padding:.24rem .65rem}
.rep-tagn{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl)}
.rep-viz{border:1px solid var(--bdr);background:var(--of);margin-bottom:1.2rem;overflow:hidden}
.rep-viz svg{display:block;width:100%;height:auto}
.rep-t{font-family:var(--f-head);font-size:1.12rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.5rem;line-height:1.18}
.rep-d{font-size:.84rem;color:var(--gy);line-height:1.7;font-weight:500;margin-bottom:1.5rem;flex:1}
.rep-dl{align-self:flex-start;display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.1em;color:var(--bk);border:1px solid var(--bk);padding:.6rem 1.1rem;text-decoration:none;transition:background .2s,color .2s;background:transparent;cursor:pointer}
.rep-dl:hover{background:var(--bk);color:#fff}
.rep-dl svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.6}
@media(max-width:760px){.rep-grid{grid-template-columns:1fr}}

/* ---- BAHRAIN BADGE ---- */
.bh-badge{display:inline-flex;align-items:center;gap:.7rem;border:1px solid var(--bdr);background:var(--wh);padding:.5rem .55rem .5rem .55rem;font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gy);width:max-content;max-width:100%;white-space:nowrap}
.bh-flag{width:26px;height:16px;flex-shrink:0;background:#ce1126;position:relative;overflow:hidden}
.bh-flag::before{content:"";position:absolute;inset:0;background:#fff;clip-path:polygon(0 0,42% 0,58% 10%,42% 20%,58% 30%,42% 40%,58% 50%,42% 60%,58% 70%,42% 80%,58% 90%,42% 100%,0 100%)}
.bh-badge .bh-ar{font-family:var(--f-body);font-size:.82rem;letter-spacing:0;color:var(--g);text-transform:none;padding-left:.6rem;border-left:1px solid var(--bdr)}
@media(max-width:560px){.bh-badge{font-size:.5rem;gap:.5rem}.bh-badge .bh-ar{font-size:.74rem}}

/* ---- BECOME A PARTNER ---- */
.bp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
.bp{background:var(--bk);padding:2.2rem 1.8rem;transition:background .22s}
.bp:hover{background:#181818}
.bp-n{font-family:var(--f-mono);font-size:.5rem;letter-spacing:.12em;color:var(--g);margin-bottom:1rem}
.bp-t{font-family:var(--f-head);font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:.5rem;line-height:1.18}
.bp-d{font-size:.8rem;color:rgba(255,255,255,.45);line-height:1.65;font-weight:500}
.look-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr)}
.look{background:var(--wh);padding:2rem 1.6rem;transition:background .2s}
.look:hover{background:var(--gl)}
.look-i{width:36px;height:36px;border:1px solid var(--gm);background:var(--gl);display:flex;align-items:center;justify-content:center;font-family:var(--f-head);font-weight:800;color:var(--g);font-size:1rem;margin-bottom:1.2rem}
.look-t{font-family:var(--f-head);font-size:1rem;font-weight:700;margin-bottom:.4rem;line-height:1.15}
.look-d{font-size:.78rem;color:var(--gy);line-height:1.6;font-weight:500}
@media(max-width:1024px){.bp-grid,.look-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.bp-grid,.look-grid{grid-template-columns:1fr}}

/* ---- DASHBOARD: live menu cue + interactive intro ---- */
.n-mid a[href="dashboard.html"]{display:inline-flex;align-items:center;gap:.42rem}
.n-mid a[href="dashboard.html"]::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--g);animation:pulse 1.5s infinite}
.dash-cues{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem}
.dash-cue{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em;color:var(--bk);border:1px solid var(--bdr);background:var(--wh);padding:.5rem .9rem}
.dash-cue .ld{width:6px;height:6px;border-radius:50%;background:var(--g);animation:pulse 1.5s infinite}
.dash-see{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:2.5rem;max-width:680px}
.dash-see-i{background:var(--wh);padding:1.5rem 1.6rem}
.dash-see-i .n{font-family:var(--f-head);font-size:1.6rem;font-weight:800;color:var(--g);line-height:1}
.dash-see-i .t{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em;margin-top:.5rem;color:var(--bk)}
.dash-see-i .d{font-size:.76rem;color:var(--gy);line-height:1.55;font-weight:500;margin-top:.3rem}
@media(max-width:560px){.dash-see{grid-template-columns:1fr}}

/* ---- FEATURED PROJECT BAND ---- */
.proj-tag{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em;background:var(--bk);color:#fff;padding:.4rem 1rem;margin-bottom:1.2rem}
.proj-tag .ld{width:6px;height:6px;border-radius:50%;background:var(--g);animation:pulse 1.5s infinite}
.proj-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:2.2rem}
.pk{background:var(--wh);padding:1.7rem 1.5rem}
.pk .v{font-family:var(--f-head);font-size:2rem;font-weight:800;line-height:1;letter-spacing:-.02em}
.pk .v.ok{color:var(--g)}
.pk .v.wn{color:#d97706}
.pk .l{font-family:var(--f-mono);font-size:.54rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gyl);margin-top:.5rem}
.proj-photo{width:100%;height:100%;min-height:320px;border:1px solid var(--bdr);background:#0c0c0c;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.proj-photo>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.proj-photo .ph{position:relative;z-index:2;width:100%;padding:1.4rem;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em}
.proj-photo .ghost{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.25);font-family:var(--f-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;text-align:center;padding:2rem}
@media(max-width:560px){.proj-kpis{grid-template-columns:1fr 1fr}}

/* ---- PRESS / RECORD ---- */
.press{display:grid;grid-template-columns:1fr 1.1fr;gap:0;border:1px solid var(--bdr);background:var(--bk)}
.press-l{padding:3.5rem 3rem;display:flex;flex-direction:column;justify-content:center}
.press-l .sup{font-family:var(--f-mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.32);margin-bottom:1.1rem}
.press-l h3{font-family:var(--f-head);font-weight:800;font-size:clamp(1.5rem,2.3vw,2.1rem);color:#fff;line-height:1.12;letter-spacing:-.03em;text-transform:uppercase;margin-bottom:1rem}
.press-l h3 em{font-family:var(--f-serif);font-style:italic;text-transform:none;color:var(--g);font-weight:400}
.press-l p{font-size:.875rem;color:rgba(255,255,255,.5);line-height:1.8;font-weight:500;margin-bottom:1.6rem}
.rec-stats{display:flex;gap:2.2rem;margin-bottom:1.6rem}
.rec-stats .n{font-family:var(--f-head);font-size:1.9rem;font-weight:800;color:var(--g);line-height:1}
.rec-stats .l{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.35);margin-top:.3rem}
.press-src{font-family:var(--f-mono);font-size:.54rem;text-transform:uppercase;letter-spacing:.12em;color:var(--g)}
.press-r{background:var(--of);display:flex;align-items:center;justify-content:center;padding:1.6rem;border-left:1px solid var(--bdr)}
.press-r img{width:100%;height:auto;border:1px solid var(--bdr);box-shadow:0 8px 30px rgba(0,0,0,.18)}
@media(max-width:860px){.press{grid-template-columns:1fr}.press-r{border-left:none;border-top:1px solid var(--bdr)}}

/* ---- LIVE INTERACTIVE DASHBOARD ---- */
.flt-bar{display:flex;flex-wrap:wrap;gap:1.6rem;align-items:flex-end;padding:1.5rem 1.6rem;border:1px solid var(--bdr);background:var(--wh);margin-bottom:1.6rem}
.flt{display:flex;flex-direction:column;gap:.5rem}
.flt-l{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gyl)}
.seg{display:flex;flex-wrap:wrap;border:1px solid var(--bdr)}
.seg button{font-family:var(--f-mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.08em;padding:.6rem .85rem;background:#fff;border:none;border-right:1px solid var(--bdr);cursor:pointer;color:var(--gy);transition:background .15s,color .15s}
.seg button:last-child{border-right:none}
.seg button:hover{background:var(--of)}
.seg button.on{background:var(--bk);color:#fff}
.flt-reset{margin-left:auto;font-family:var(--f-mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.1em;border:1px solid var(--bdr);background:transparent;padding:.6rem 1.1rem;cursor:pointer;color:var(--gy);transition:border-color .2s,color .2s}
.flt-reset:hover{border-color:var(--g);color:var(--g)}
.flt-scope{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.1em;color:var(--g);margin-bottom:1.4rem;display:flex;align-items:center;gap:.5rem}
.flt-scope .ld{width:6px;height:6px;border-radius:50%;background:var(--g);animation:pulse 1.5s infinite}
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-bottom:1.2rem}
.kpiL{background:#fff;padding:1.5rem 1.4rem}
.kpiL .v{font-family:var(--f-head);font-size:1.7rem;font-weight:800;line-height:1;letter-spacing:-.02em;white-space:nowrap;transition:color .25s}
.kpiL .v.ok{color:var(--g)}.kpiL .v.wn{color:#d97706}.kpiL .v.bd{color:#dc2626}
.kpiL .l{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl);margin-top:.5rem}
.panels{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1.2rem}
.panel{border:1px solid var(--bdr);background:#fff;padding:1.6rem 1.7rem}
.panel-h{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.12em;color:var(--bk);margin-bottom:1.2rem;display:flex;justify-content:space-between;align-items:center}
.panel-h .sub{color:var(--gyl);font-size:.5rem}
.panel svg{width:100%;height:auto;display:block}
.lt-empty{padding:2rem;text-align:center;font-family:var(--f-mono);font-size:.6rem;letter-spacing:.1em;color:var(--gyl);text-transform:uppercase}
@media(max-width:860px){.kpi-row{grid-template-columns:1fr 1fr 1fr}.panels{grid-template-columns:1fr}}
@media(max-width:480px){.kpi-row{grid-template-columns:1fr 1fr}}

/* ---- CLIENT WORDMARKS (per sector) ---- */
.sr-clients{margin-top:1.6rem;padding-top:1.4rem;border-top:1px solid var(--bdr)}
.sr-clients-l{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.16em;color:var(--gyl);margin-bottom:.8rem}
.sr-clients-row{display:flex;flex-wrap:wrap;align-items:center;gap:1.4rem}
.sr-cw{font-family:var(--f-head);font-weight:700;font-size:.95rem;letter-spacing:-.01em;color:#1a1a1a;opacity:.55;transition:opacity .2s,color .2s;white-space:nowrap}
.sr-cw:hover{opacity:1;color:var(--g)}
.sr-cw .tm{font-family:var(--f-mono);font-size:.5rem;vertical-align:super;opacity:.6}

/* ---- METHOD PAGE: signature frameworks ---- */
/* nD dimensional ladder */
.nd-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:2.5rem}
.nd{background:var(--wh);padding:2rem 1.5rem;position:relative;transition:background .25s}
.nd:hover{background:var(--gl)}
.nd-d{font-family:var(--f-head);font-size:2.6rem;font-weight:800;color:var(--g);line-height:.9;letter-spacing:-.03em}
.nd-t{font-family:var(--f-head);font-size:1rem;font-weight:700;margin:.7rem 0 .4rem;line-height:1.15}
.nd-s{font-size:.78rem;color:var(--gy);line-height:1.6;font-weight:500}
.nd-cross{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-top:none}
.ndc{background:var(--bk);color:#fff;padding:1.3rem 1.5rem;display:flex;align-items:center;gap:.8rem}
.ndc .k{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.14em;color:var(--g)}
.ndc .t{font-family:var(--f-head);font-size:1rem;font-weight:700}
/* know-how cycle */
.cyc{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.2rem;margin-top:2.5rem}
.cyc-col{border:1px solid var(--bdr);background:var(--wh)}
.cyc-h{background:var(--bk);color:#fff;padding:1.1rem 1.4rem;display:flex;align-items:center;justify-content:space-between}
.cyc-h .n{font-family:var(--f-head);font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:-.01em}
.cyc-h .a{font-family:var(--f-mono);font-size:1rem;color:var(--g)}
.cyc-b{padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:.7rem}
.cyc-i{padding-left:1rem;border-left:2px solid var(--gm);position:relative}
.cyc-i .t{font-size:.84rem;font-weight:600;line-height:1.3}
.cyc-i .d{font-size:.74rem;color:var(--gy);line-height:1.5;font-weight:500;margin-top:.15rem}
/* schedule levels pyramid */
.lvls{display:flex;flex-direction:column;gap:.6rem;margin-top:2.5rem;max-width:880px}
.lvl{display:grid;grid-template-columns:90px 1fr;border:1px solid var(--bdr);background:var(--wh);transition:border-color .2s,transform .2s}
.lvl:hover{border-color:var(--g);transform:translateX(6px)}
.lvl-n{background:var(--bk);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem}
.lvl-n .l{font-family:var(--f-mono);font-size:.5rem;letter-spacing:.12em;color:var(--g);text-transform:uppercase}
.lvl-n .v{font-family:var(--f-head);font-size:1.8rem;font-weight:800;line-height:1}
.lvl-b{padding:1.2rem 1.5rem}
.lvl-t{font-family:var(--f-head);font-size:1.05rem;font-weight:700;margin-bottom:.3rem}
.lvl-d{font-size:.8rem;color:var(--gy);line-height:1.6;font-weight:500}
.lvl-c{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:var(--g);margin-top:.5rem}
/* certifications */
.certs-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:2.5rem}
.crt{background:var(--wh);padding:2rem 1.6rem;text-align:center;transition:background .2s}
.crt:hover{background:var(--gl)}
.crt-seal{width:48px;height:48px;margin:0 auto 1rem;border:2px solid var(--g);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--f-head);font-weight:800;color:var(--g);font-size:.9rem;background:var(--gl)}
.crt-t{font-family:var(--f-head);font-size:.95rem;font-weight:700;line-height:1.2;margin-bottom:.3rem}
.crt-s{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl)}
@media(max-width:1024px){
  .nd-grid{grid-template-columns:1fr 1fr}
  .nd-cross{grid-template-columns:1fr}
  .cyc{grid-template-columns:1fr}
  .certs-row{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .nd-grid{grid-template-columns:1fr}
  .lvl{grid-template-columns:70px 1fr}
}

/* ---- ORGANIZATION ---- */
.org-lead{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:2.5rem}
.org-x{background:var(--bk);color:#fff;padding:2.2rem 2rem;position:relative}
.org-x .role{font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.14em;color:var(--g);margin-bottom:.7rem}
.org-x .nm{font-family:var(--f-head);font-size:1.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.3rem}
.org-x .ti{font-size:.85rem;color:rgba(255,255,255,.6);font-weight:500;line-height:1.5}
.org-x .loc{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.35);margin-top:.8rem}
.org-units{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-top:none}
.org-u{background:var(--wh);padding:1.6rem 1.3rem;transition:background .2s}
.org-u:hover{background:var(--gl)}
.org-u .n{font-family:var(--f-mono);font-size:.5rem;color:var(--gyl);letter-spacing:.1em;margin-bottom:.7rem}
.org-u .t{font-family:var(--f-head);font-size:.92rem;font-weight:700;line-height:1.2;margin-bottom:.35rem}
.org-u .s{font-size:.74rem;color:var(--gy);line-height:1.5;font-weight:500}
.org-spec{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-top:none}
.org-sp{background:var(--of);padding:1.4rem 1.3rem;display:flex;gap:.8rem;align-items:flex-start}
.org-sp .b{width:5px;height:5px;background:var(--g);margin-top:.5rem;flex-shrink:0}
.org-sp .t{font-size:.8rem;font-weight:600;line-height:1.3}
.org-sp .d{font-size:.72rem;color:var(--gy);font-weight:500;margin-top:.15rem;line-height:1.45}
@media(max-width:1024px){.org-lead{grid-template-columns:1fr}.org-units{grid-template-columns:1fr 1fr}.org-spec{grid-template-columns:1fr}}
@media(max-width:560px){.org-units{grid-template-columns:1fr}}

/* ---- PERFORMANCE MATRIX (HTML, crisp) ---- */
.pmx{display:grid;grid-template-columns:26px 1fr;grid-template-rows:1fr 26px;gap:.6rem;margin-top:.5rem}
.pmx-yaxis{grid-column:1;grid-row:1;display:flex;align-items:center;justify-content:center}
.pmx-yaxis span{writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--f-mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bk);font-weight:500}
.pmx-grid{grid-column:2;grid-row:1;display:grid;grid-template-columns:1fr 1fr;gap:4px}
.pmx-xaxis{grid-column:2;grid-row:2;text-align:center;font-family:var(--f-mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bk);font-weight:500}
.pmq{padding:1.5rem 1.3rem;min-height:150px;display:flex;flex-direction:column;position:relative}
.pmq.q1{background:#fef9c3}.pmq.q2{background:#bbf7d0;outline:3px solid #3CB54A;outline-offset:-3px}
.pmq.q3{background:#fee2e2}.pmq.q4{background:#dbeafe}
.pmq-t{font-family:var(--f-head);font-size:1.05rem;font-weight:800;line-height:1.1;letter-spacing:-.01em}
.pmq-s{font-family:var(--f-head);font-size:.82rem;font-weight:600;margin-top:.15rem}
.pmq-d{font-size:.78rem;line-height:1.4;font-weight:500;margin-top:.5rem}
.pmq-m{margin-top:auto;display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-mono);font-size:.6rem;padding-top:.8rem}
.pmq-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.7rem;flex-shrink:0}
.pmq.q1 .pmq-t,.pmq.q1 .pmq-s,.pmq.q1 .pmq-d,.pmq.q1 .pmq-m{color:#854d0e}
.pmq.q2 .pmq-t,.pmq.q2 .pmq-s,.pmq.q2 .pmq-d,.pmq.q2 .pmq-m{color:#14532d}
.pmq.q3 .pmq-t,.pmq.q3 .pmq-s,.pmq.q3 .pmq-d,.pmq.q3 .pmq-m{color:#7f1d1d}
.pmq.q4 .pmq-t,.pmq.q4 .pmq-s,.pmq.q4 .pmq-d,.pmq.q4 .pmq-m{color:#1e3a8a}
@media(max-width:480px){.pmq{min-height:130px;padding:1.2rem 1rem}.pmq-t{font-size:.95rem}}

/* ---- CASE STUDIES ---- */
.cs-hero{display:grid;grid-template-columns:1.1fr 1fr;gap:0;border:1px solid var(--bdr);margin-top:2.5rem;background:var(--bk)}
.cs-hero-l{padding:3rem 3rem;display:flex;flex-direction:column;justify-content:center}
.cs-hero-l .tag{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-mono);font-size:.52rem;text-transform:uppercase;letter-spacing:.14em;color:var(--g);margin-bottom:1.2rem}
.cs-hero-l h3{font-family:var(--f-head);font-weight:800;font-size:clamp(1.5rem,2.4vw,2.2rem);color:#fff;line-height:1.1;letter-spacing:-.02em;text-transform:uppercase;margin-bottom:1rem}
.cs-hero-l h3 em{font-family:var(--f-serif);font-style:italic;text-transform:none;color:var(--g);font-weight:400}
.cs-hero-l p{font-size:.875rem;color:rgba(255,255,255,.55);line-height:1.8;font-weight:500}
.cs-hero-r{position:relative;overflow:hidden;min-height:300px;background:#111}
.cs-hero-r img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cs-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-top:none}
.csm{background:var(--wh);padding:1.5rem 1.4rem}
.csm .k{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl);margin-bottom:.5rem}
.csm .v{font-family:var(--f-head);font-size:1.05rem;font-weight:700;line-height:1.15}
.cs-body{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1.2rem}
.cs-block{border:1px solid var(--bdr);background:var(--wh);padding:2rem 1.9rem}
.cs-block.full{grid-column:1/-1}
.cs-block h4{font-family:var(--f-head);font-size:1.1rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;gap:.6rem}
.cs-block h4::before{content:'';width:16px;height:2px;background:var(--g)}
.cs-li{display:flex;gap:.8rem;padding:.55rem 0;border-bottom:1px solid #f0efec;font-size:.85rem;color:var(--gy);line-height:1.5;font-weight:500}
.cs-li:last-child{border-bottom:none}
.cs-li::before{content:'';width:5px;height:5px;background:var(--g);margin-top:.5rem;flex-shrink:0}
.cs-li strong{color:var(--bk);font-weight:600}
.cs-num-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:1.2rem}
.cs-num{background:var(--of);padding:1.8rem 1.4rem;text-align:center}
.cs-num .n{font-family:var(--f-head);font-size:2.2rem;font-weight:800;color:var(--g);line-height:1;letter-spacing:-.02em}
.cs-num .l{font-family:var(--f-mono);font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gyl);margin-top:.5rem}
@media(max-width:860px){.cs-hero,.cs-body{grid-template-columns:1fr}.cs-meta,.cs-num-row{grid-template-columns:1fr 1fr}}

/* ---- DELIVERY METHODOLOGY (9 phases) ---- */
.ph-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);margin-top:2.5rem}
.ph{background:var(--wh);padding:1.9rem 1.7rem;transition:background .22s;position:relative}
.ph:hover{background:var(--gl)}
.ph-n{font-family:var(--f-mono);font-size:.56rem;letter-spacing:.12em;color:var(--g);margin-bottom:.9rem}
.ph-t{font-family:var(--f-head);font-size:1.1rem;font-weight:700;line-height:1.12;letter-spacing:-.01em;margin-bottom:.5rem}
.ph-d{font-size:.8rem;color:var(--gy);line-height:1.6;font-weight:500}
@media(max-width:860px){.ph-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ph-grid{grid-template-columns:1fr}}

/* ---- SITE GUIDE ---- */
#guide [style*="grid-template-columns:repeat(5"]{grid-template-columns:repeat(5,1fr)}
@media(max-width:860px){#guide [style*="repeat(5"]{grid-template-columns:1fr 1fr !important}}
@media(max-width:480px){#guide [style*="repeat(5"]{grid-template-columns:1fr !important}}

/* ---- SITE MAP MEGA-MENU / MOBILE NAV ---- */
.n-menu-label{display:none;font-family:var(--f-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.14em;color:var(--bk);cursor:pointer;margin-left:auto;margin-right:.6rem}
.nav .n-cta{margin-left:1.2rem;margin-right:0}
@media(max-width:1180px){
  .n-mid{display:none !important}
  .n-burger{display:flex !important;align-items:center}
  .n-menu-label{display:inline-flex;align-items:center}
  .nav .n-cta{display:none !important}
}
@media(min-width:1181px){
  .n-mid{display:flex !important}
  .n-burger{display:none !important}
  .n-menu-label{display:none !important}
}
.smenu{position:fixed;inset:0;z-index:300;background:#0c0c0c;overflow-y:auto;padding:5.5rem 3rem 3rem;display:none}
.smenu.open{display:block}
.smenu-close{position:absolute;top:1.3rem;right:2rem;background:none;border:1px solid rgba(255,255,255,.25);color:#fff;font-family:var(--f-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;cursor:pointer;padding:.55rem 1rem;transition:background .2s,color .2s}
.smenu-close:hover{background:#3CB54A;border-color:#3CB54A}
.smenu-head{max-width:1320px;margin:0 auto 2.6rem}
.smenu-head .e{font-family:var(--f-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.18em;color:#3CB54A;margin-bottom:.6rem}
.smenu-head h3{font-family:var(--f-head);font-size:clamp(1.6rem,3.5vw,2.6rem);font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:-.03em;line-height:1}
.smenu-head h3 em{font-family:var(--f-serif);font-style:italic;text-transform:none;color:#3CB54A;font-weight:400}
.smenu-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:2.5rem}
.smenu-col h4{font-family:var(--f-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.13em;color:rgba(255,255,255,.85);margin-bottom:1.2rem;padding-bottom:.6rem;border-bottom:1px solid rgba(255,255,255,.12)}
.smenu-col h4 span{color:#3CB54A;font-weight:600}
.smenu-col a{display:block;font-family:var(--f-head);font-size:1.12rem;font-weight:700;color:#fff;text-decoration:none;margin-bottom:.95rem;letter-spacing:-.01em;transition:color .16s,transform .16s}
.smenu-col a:hover{color:#3CB54A;transform:translateX(4px)}
.smenu-col a[aria-current="page"]{color:#3CB54A}
.smenu-col a small{display:block;font-family:var(--f-body);font-size:.74rem;font-weight:400;color:rgba(255,255,255,.72);letter-spacing:0;margin-top:.2rem}
body.smenu-lock{overflow:hidden}
@media(max-width:860px){.smenu-grid{grid-template-columns:1fr 1fr;gap:1.6rem 2rem}.smenu-col a{font-size:1rem}}
@media(max-width:480px){.smenu-grid{grid-template-columns:1fr}.smenu{padding:5rem 1.5rem 2rem}}

/* ---- CONTACT ---- */
.ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:7rem}
.cblock{margin-bottom:2.2rem}
.cblock h4{font-family:var(--f-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.35);margin-bottom:.9rem}
.cblock p,.cblock a{font-size:.875rem;color:rgba(255,255,255,.62);line-height:1.85;text-decoration:none;display:block;font-weight:500}
.cblock a:hover{color:#fff}
.cf{display:flex;flex-direction:column;gap:1rem;margin-top:.5rem}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cf label{font-family:var(--f-mono);font-size:.54rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4);margin-bottom:.4rem;display:block}
.cf input,.cf textarea,.cf select{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:#fff;font-family:var(--f-body);font-size:.875rem;padding:.9rem 1.1rem;outline:none;transition:border-color .2s}
.cf input::placeholder,.cf textarea::placeholder{color:rgba(255,255,255,.28)}
.cf input:focus,.cf textarea:focus,.cf select:focus{border-color:rgba(60,181,74,.5)}
.cf textarea{min-height:120px;resize:vertical}
.cf-note{font-size:.72rem;color:rgba(255,255,255,.4);margin-top:.5rem;display:none}
.cf-note.show{display:block;color:var(--g)}

/* ---- FOOTER ---- */
.footer{background:#080808;padding:3.5rem 3rem 2rem;border-top:1px solid #1a1a1a}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;max-width:var(--wrap);margin:0 auto 3rem}
.footer-brand img{height:30px;width:auto;margin-bottom:1.2rem}
.footer-brand p{font-size:.8rem;color:rgba(255,255,255,.4);line-height:1.7;font-weight:500;max-width:280px}
.footer-col h5{font-family:var(--f-mono);font-size:.54rem;text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.35);margin-bottom:1.1rem}
.footer-col a{display:block;font-size:.82rem;color:rgba(255,255,255,.55);text-decoration:none;margin-bottom:.6rem;transition:color .18s;font-weight:500}
.footer-col a:hover{color:var(--g)}
.footer-bot{max-width:var(--wrap);margin:0 auto;padding-top:1.6rem;border-top:1px solid #1a1a1a;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.ft-b{font-family:var(--f-serif);font-size:.88rem;color:var(--g);font-style:italic}
.ft-c{font-family:var(--f-mono);font-size:.52rem;color:rgba(255,255,255,.22);letter-spacing:.08em}

/* ---- RESPONSIVE ---- */
@media(max-width:1180px){
  .nav{padding:1rem 1.5rem}
  .n-mid,.n-cta{display:none}
  .n-burger{display:flex}
  .nav.open .n-mid{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--wh);border-bottom:1px solid var(--bdr);padding:1.5rem;gap:1.3rem}
  .nav.open .n-mid a{font-size:.75rem}
  .wrap{padding:0 1.5rem}
  .section{padding:5rem 0}
  .hero{padding:7rem 1.5rem 4rem;min-height:auto;justify-content:flex-start}.hero-top{padding-top:0}
  .hero-bg-num,.phead-bg{display:none}
  .two-col,.srv-intro{grid-template-columns:1fr;gap:3rem}
  .srv-list,.tools-grid,.pg,.pg.g2,.ref-grid{grid-template-columns:1fr}
  .hero-bottom{grid-template-columns:1fr 1fr}
  .hb-cell:nth-child(2){border-right:none;margin-right:0}
  .sr,.sr:nth-child(even){grid-template-columns:1fr;direction:ltr}
  .sr-img,.sr-photos{min-height:260px}
  .sr-content{padding:2.5rem 1.5rem}.sr-n{display:none}
  .aramco{grid-template-columns:1fr}
  .cta{flex-direction:column;text-align:center;padding:4rem 1.5rem}
  .ct-grid{grid-template-columns:1fr;gap:3rem}
  .cf-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .phead{padding:9rem 0 3rem}
}
@media(max-width:560px){
  .footer-top{grid-template-columns:1fr}
  .hero-bottom{grid-template-columns:1fr}
  .hb-cell{border-right:none;margin-right:0;padding-right:0}
  .footer-bot{flex-direction:column;text-align:center}
}

/* ---- MOBILE OPTIMISATION PASS ---- */
@media(max-width:1024px){
  /* taller sector imagery so photos (and Marcelo) breathe on phones/tablets */
  .sr-img,.sr-photos{min-height:340px}
  /* generous tap targets */
  .nav.open .n-mid a{padding:.5rem 0;font-size:.8rem}
  .n-burger{padding:10px;min-width:44px;min-height:44px;align-items:center;justify-content:center}
  /* hero headline never overflows */
  .hero-headline h1{font-size:clamp(3rem,14vw,7rem)}
  .hero-headline .itl{padding-left:6vw}
  /* phead headline scale */
  .phead h1{font-size:clamp(2.4rem,9vw,5rem)}
}
@media(max-width:640px){
  .section{padding:4rem 0}
  .wrap{padding:0 1.2rem}
  .hero{padding:6.5rem 1.2rem 3rem}
  .hero-top{flex-direction:column;gap:.6rem}
  .hero-loc{text-align:left}
  .sr-content{padding:2.2rem 1.2rem}
  .sr-title{font-size:clamp(1.6rem,7vw,2.2rem)}
  /* taller chemical/two-up sector splits so faces aren't cropped away */
  .sr-img{min-height:300px}
  /* live dashboard + press + CTA breathing room */
  .cta{padding:3.5rem 1.2rem}
  .cta h2{font-size:clamp(1.6rem,7vw,2.2rem)}
  .press-l{padding:2.5rem 1.5rem}
  .rec-stats{gap:1.4rem;flex-wrap:wrap}
  .flt-bar{gap:1rem;padding:1.2rem}
  .flt-reset{margin-left:0}
  /* contact + buttons full-width friendly */
  .hero-cta{width:100%}
  .hero-cta .btn{flex:1;text-align:center;min-width:0}
  .btn{padding:.85rem 1.4rem}
  /* form inputs at 16px to stop iOS zoom-on-focus */
  .cf input,.cf textarea,.cf select{font-size:16px}
  /* tables scroll hint */
  .tw{position:relative}
}
@media(max-width:420px){
  .kpi-row{grid-template-columns:1fr 1fr}
  .proj-kpis{grid-template-columns:1fr 1fr}
  .sr-clients-row{gap:1rem}
  .sr-cw{font-size:.85rem}
  .hb-num{font-size:2.2rem}
  /* on small phones show only the PROMAN photo (Marcelo prominent) */
  .chem-split{grid-template-columns:1fr!important}
  .chem-split>div:last-child{display:none}
}

/* ---- IMAGE HERO · MOBILE (full screen) ---- */
@media(max-width:980px){
  section.hero-img{min-height:100svh;justify-content:flex-end;padding:6rem 1.5rem 2.2rem}
  section.hero-img .hero-top{padding-top:1.4rem}
  section.hero-img .hero-photo{background-position:center center}
}
/* ---- MOBILE HERO: readable opening on every phone ---- */
@media(max-width:768px){
  /* center the brand block, let it breathe, stronger contrast */
  section.hero-img{min-height:100svh;justify-content:center;padding:6.5rem 1.3rem 2.4rem}
  /* darker, more even scrim so text + brand always read over the animation */
  section.hero-img .hero-scrim{background:linear-gradient(180deg,rgba(8,8,8,.86) 0%,rgba(8,8,8,.62) 34%,rgba(8,8,8,.60) 56%,rgba(8,8,8,.80) 100%)}
  /* hero top labels smaller + stacked tidy */
  section.hero-img .hero-top{font-size:.62rem}
  /* Bahrain badge compact */
  section.hero-img .bh-badge{margin-bottom:1.1rem !important;font-size:.5rem;gap:.5rem}
  /* BRAND — the focal point, must fit width on every phone */
  section.hero-img .hero-headline{margin-top:1.4rem;max-width:100%;overflow:hidden}
  .hero-headline h1.brandline{font-size:clamp(2.2rem,11.2vw,4rem);line-height:.94;letter-spacing:-.055em}
  .brandline .bl-word{white-space:nowrap}
  .brandline .w2{font-size:.82em}
  /* payoff: tight, single clear line */
  .payoff{font-size:.72rem;letter-spacing:.22em;gap:.5em;margin-top:1.1rem}
  /* lead: readable, not cramped */
  section.hero-img .lead{font-size:.92rem;line-height:1.7;margin-top:1.2rem;margin-bottom:1.6rem;color:rgba(255,255,255,.92)}
}
@media(max-width:560px){
  section.hero-img{padding:6rem 1.2rem 2rem}
  section.hero-img .hero-bottom{grid-template-columns:1fr 1fr}
  section.hero-img .hb-cell:nth-child(2){border-right:none}
  section.hero-img .hb-cell{padding:1.1rem 1rem 1.1rem 0;margin-right:1rem}
  section.hero-img .hb-cell:nth-child(3){grid-column:1 / -1;border-top:1px solid rgba(255,255,255,.26);padding-top:1.1rem}
}
@media(max-width:400px){
  .hero-headline h1.brandline{font-size:clamp(2rem,10.6vw,3.2rem);letter-spacing:-.05em}
  .payoff{font-size:.62rem;letter-spacing:.12em}
  section.hero-img .lead{font-size:.88rem}
}


/* ---- SALERNO 2026 OPTIMIZATION PATCH ---- */
:root{--safe-top:env(safe-area-inset-top);--safe-bottom:env(safe-area-inset-bottom)}
.nav{padding-top:calc(1rem + var(--safe-top));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}
.nav .logo img{height:46px;width:auto;object-fit:contain}
@media(min-width:1181px){.nav .logo img{height:52px}.nav{gap:1.4rem}.n-mid{flex:1;justify-content:center}.n-mid a{font-weight:500}.n-cta{font-weight:500}}
@media(max-width:1180px){.nav .logo img{height:44px}.nav{padding-left:max(1.2rem,env(safe-area-inset-left));padding-right:max(1.2rem,env(safe-area-inset-right))}}
@media(max-width:480px){.nav .logo img{height:40px}.n-menu-label{font-size:.56rem}.n-burger span{width:24px;height:2px}.smenu{padding-bottom:calc(2rem + var(--safe-bottom))}}

/* More readable paragraph-size text */
p,.lead,.sc-p,.em-desc,.sr-desc,.ab-text p,.pd,.fd,.course-d,.fmt-d,.aud-d,.tailor-d,.rep-d,.bp-d,.look-d,.hf-d,.cf input,.cf textarea,.cf select,.footer-brand p,.footer-col a{font-weight:500}

/* Mobile-only hamburger menu state */
@media(min-width:1181px){body.smenu-lock{overflow:auto}.smenu.open{display:none}}
@media(max-width:1180px){.smenu.open{display:block}.smenu-col a small{font-weight:500}.smenu-close{font-weight:500}}

/* ---- COOKIE CONSENT + PRIVACY PREFERENCES ---- */
.cookie-consent{position:fixed;left:max(1rem,env(safe-area-inset-left));right:max(1rem,env(safe-area-inset-right));bottom:calc(1rem + env(safe-area-inset-bottom));z-index:9999;display:none;align-items:flex-end;justify-content:space-between;gap:1rem;max-width:1120px;margin:0 auto;padding:1rem 1.1rem;background:rgba(12,12,12,.94);color:#fff;border:1px solid rgba(255,255,255,.16);box-shadow:0 28px 80px rgba(0,0,0,.38);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}
.cookie-consent.show{display:flex}
.cookie-consent h3{margin:0 0 .35rem;font-family:'Syne',sans-serif;font-size:.88rem;letter-spacing:.02em;font-weight:700}
.cookie-consent p{margin:0;max-width:760px;font-size:.78rem;line-height:1.6;color:rgba(255,255,255,.74);font-weight:500}
.cookie-actions{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-end;min-width:310px}
.cookie-btn{appearance:none;border:1px solid rgba(255,255,255,.28);background:transparent;color:#fff;padding:.72rem .9rem;font-family:'IBM Plex Mono',monospace;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;font-weight:500;transition:background .2s ease,border-color .2s ease,color .2s ease}
.cookie-btn:hover{border-color:#3CB54A}.cookie-btn.primary{background:#3CB54A;border-color:#3CB54A;color:#07120b}.cookie-btn.dark{background:#fff;color:#0c0c0c;border-color:#fff}
.cookie-preferences-link{display:inline-flex;align-items:center;gap:.35rem;background:none;border:0;color:inherit;padding:0;margin:0;font:inherit;text-decoration:underline;text-underline-offset:.22em;cursor:pointer}
.cookie-modal{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:1.2rem;background:rgba(0,0,0,.58)}
.cookie-modal.show{display:flex}.cookie-panel{width:min(620px,100%);max-height:calc(100svh - 2.4rem);overflow:auto;background:#101010;color:#fff;border:1px solid rgba(255,255,255,.16);box-shadow:0 34px 90px rgba(0,0,0,.55);padding:1.4rem}
.cookie-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:1rem;margin-bottom:1rem}.cookie-panel h2{margin:0;font-family:'Syne',sans-serif;font-size:1.35rem;letter-spacing:-.03em}.cookie-panel p{font-size:.82rem;line-height:1.65;color:rgba(255,255,255,.72);font-weight:500}.cookie-close{background:none;border:1px solid rgba(255,255,255,.22);color:#fff;width:38px;height:38px;cursor:pointer}
.cookie-row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.cookie-row h4{margin:0 0 .25rem;font-size:.82rem;font-family:'Syne',sans-serif}.cookie-row p{margin:0;font-size:.75rem}.cookie-switch{position:relative;display:inline-block;width:52px;height:28px}.cookie-switch input{opacity:0;width:0;height:0}.cookie-slider{position:absolute;cursor:pointer;inset:0;background:rgba(255,255,255,.18);transition:.2s;border:1px solid rgba(255,255,255,.18)}.cookie-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background:#fff;transition:.2s}.cookie-switch input:checked+.cookie-slider{background:#3CB54A}.cookie-switch input:checked+.cookie-slider:before{transform:translateX(24px)}.cookie-switch input:disabled+.cookie-slider{opacity:.7;cursor:not-allowed}.cookie-panel-actions{display:flex;justify-content:flex-end;gap:.6rem;flex-wrap:wrap;padding-top:1rem}.cookie-footnote{margin-top:.9rem;font-size:.68rem!important;color:rgba(255,255,255,.52)!important}
@media(max-width:760px){.cookie-consent{display:none;flex-direction:column;align-items:stretch;padding:1rem}.cookie-consent.show{display:flex}.cookie-actions{min-width:0;display:grid;grid-template-columns:1fr}.cookie-btn{width:100%;text-align:center}.cookie-panel{padding:1.1rem}.cookie-row{grid-template-columns:1fr;gap:.8rem}.cookie-panel-actions{display:grid;grid-template-columns:1fr}.cookie-consent p{font-size:.75rem}}
