/* ============================================================
   RifeX design system
   Warm off-white · charcoal · restrained gold accents
   See DESIGN_SYSTEM.md before changing section styles.
   ============================================================ */

/* ---------- tokens ---------- */
:root{
  --maxw:1220px;
  --gut:clamp(20px,5vw,56px);
  --ease:cubic-bezier(.22,.61,.36,1);

  /* brand — warm gold / charcoal */
  --brand:#b8962e;
  --brand-deep:#8d721f;
  --brand-bright:#d4ae4a;
  --brand-ink:#111111;
  --brand-soft:#f6efd8;
  --brand-soft-2:#eadfbd;
  --brand-line:rgba(184,150,46,.28);
  --accent:#8a806e;
  --accent-soft:#f2f0ec;
  --gold:#c7912f;

  /* neutrals */
  --bg:#f8f7f4;
  --bg-2:#f2f0ec;
  --bg-3:#ebe7df;
  --surface:#ffffff;
  --line:#e0ddd8;
  --line-2:#d4d0c8;
  --ink:#111111;
  --ink-2:#4d4a43;
  --ink-3:#8a867d;
  --on-brand:#ffffff;

  --shadow-sm:0 1px 2px rgba(17,17,17,.06), 0 2px 6px rgba(17,17,17,.05);
  --shadow:0 8px 24px -10px rgba(17,17,17,.18);
  --shadow-lg:0 40px 80px -36px rgba(17,17,17,.36);
  --img-bg:#e9e4da;

  --r-sm:2px;
  --r:4px;
  --r-lg:6px;

  --font-display:"Playfair Display",Georgia,serif;
  --font-ui:"DM Sans",system-ui,-apple-system,sans-serif;
}

/* ---------- reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-ui);background:var(--bg);color:var(--ink);
  line-height:1.62;font-size:16.5px;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
::selection{background:var(--brand);color:#fff}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);width:100%}
.sec{padding:clamp(72px,9vw,132px) 0;position:relative}
.sec-tight{padding:clamp(48px,6.5vw,88px) 0}
.bg-2{background:var(--bg-2)}
.bg-ink{background:var(--brand-ink);color:#fff}
@supports (content-visibility:auto){
  main > .sec,
  .footer{content-visibility:auto;contain-intrinsic-size:auto 900px}
}

/* ---------- type ---------- */
.kicker{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--font-ui);
  font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand);margin-bottom:20px;
}
.kicker::before{content:"";width:22px;height:2px;border-radius:2px;background:var(--brand);opacity:.55}
.kicker.center{justify-content:center}
.bg-ink .kicker{color:var(--brand-bright)}
.bg-ink .kicker::before{background:var(--brand-bright)}

h1,h2{font-family:var(--font-display);font-weight:600;letter-spacing:-.03em;line-height:1.02;color:var(--ink)}
h3,h4{font-family:var(--font-ui);font-weight:800;letter-spacing:-.02em;line-height:1.16;color:var(--ink)}
h1{font-size:clamp(48px,6.4vw,86px)}
h2{font-size:clamp(30px,3.15vw,46px);line-height:1.08;letter-spacing:-.024em}
h3{font-size:clamp(19px,1.7vw,23px)}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:#fff}
em{font-style:normal;color:var(--brand)}
.bg-ink em{color:var(--brand-bright)}

.lead{font-size:clamp(17px,1.5vw,20px);color:var(--ink-2);max-width:56ch;line-height:1.6}
.bg-ink .lead{color:rgba(255,255,255,.74)}

.sec-head{max-width:820px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{margin-bottom:18px}
.sec-head p{color:#6b6b6b;font-size:clamp(16px,1.35vw,18px);font-weight:300;line-height:1.75;max-width:62ch}
.sec-head.center p{margin-inline:auto}
.bg-ink .sec-head p{color:rgba(255,255,255,.72)}
.bg-ink .pstep h3,
.bg-ink .download-card h3,
.bg-ink .program-strip h3{color:var(--ink)}
.bg-ink .download-card p,
.bg-ink .program-strip p{color:var(--ink-2)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:52px;
  padding:0 26px;border-radius:var(--r-sm);font-family:var(--font-ui);font-weight:700;
  font-size:15px;letter-spacing:-.01em;border:1.5px solid transparent;
  transition:.28s var(--ease);white-space:nowrap}
.btn svg{width:17px;height:17px;transition:transform .28s var(--ease)}
.btn-icon{width:46px;height:46px;padding:0;flex:0 0 46px}
.btn-icon svg{width:19px;height:19px}
.btn-primary{background:var(--brand-ink);color:#fff;border-color:var(--brand-ink);box-shadow:0 10px 22px -10px rgba(17,17,17,.42)}
.btn-primary:hover{background:#000;border-color:#000;transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(17,17,17,.58)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand);transform:translateY(-2px)}
.bg-ink .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
.bg-ink .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}
.btn-dark{background:var(--brand-ink);color:#fff;border-color:var(--brand-ink)}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 16px 30px -16px rgba(0,0,0,.45)}
.btn-white{background:#fff;color:var(--brand-ink)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(0,0,0,.4)}
.btn-white:hover svg{transform:translateX(4px)}
.btn-block{width:100%}
.btn-lg{height:56px;padding:0 30px}

.txtlink{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--brand);
  font-size:15px;transition:.24s var(--ease)}
.txtlink svg{width:16px;height:16px;transition:transform .24s var(--ease)}
.txtlink:hover svg{transform:translateX(4px)}

/* ---------- header / topbar ---------- */
.topbar{background:var(--brand-ink);color:rgba(255,255,255,.82);font-size:13.5px;
  font-weight:500;letter-spacing:.01em}
.topbar-in{display:flex;align-items:center;justify-content:space-between;height:42px;gap:20px}
.topbar a{display:inline-flex;align-items:center;gap:7px;color:rgba(255,255,255,.82);transition:.2s}
.topbar a:hover{color:#fff}
.topbar svg{width:14px;height:14px}
.topbar-l{display:flex;align-items:center;gap:22px}
.topbar-r{display:flex;align-items:center;gap:18px}
.topbar .tb-loc{display:inline-flex;align-items:center;gap:7px;color:rgba(255,255,255,.6)}

.hdr{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px) saturate(1.5);-webkit-backdrop-filter:blur(14px) saturate(1.5);
  border-bottom:1px solid var(--line);transition:box-shadow .3s,border-color .3s}
.hdr.scrolled{box-shadow:0 6px 24px -16px rgba(13,28,66,.3)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}

.brand{display:inline-flex;align-items:center;gap:11px}
.brand-mark{width:38px;height:38px;flex:0 0 auto}
.brand-mark rect{fill:var(--brand)}
.brand-mark circle:first-of-type{fill:#fff}
.brand-mark circle:last-of-type{fill:var(--brand-bright)}
.brand-mark path:last-of-type{stroke:var(--brand-bright)}
.brand-logo{width:auto;height:auto;max-height:40px;object-fit:contain;flex:0 0 auto}
.brand-wordmark{width:132px;height:auto;display:block;flex:0 0 auto}
.brand-txt{display:flex;flex-direction:column;line-height:1}
.brand-txt b{font-family:var(--font-ui);font-weight:800;font-size:21px;letter-spacing:-.03em;color:var(--ink)}
.brand-txt span{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-top:4px}

.nav{display:flex;align-items:center;gap:4px;margin-inline:auto}
.nav a{padding:9px 15px;border-radius:8px;font-size:15px;font-weight:600;color:var(--ink-2);transition:.2s}
.nav a:hover{color:var(--ink);background:var(--bg-2)}
.nav a.active{color:var(--brand)}

.hdr-cta{display:flex;align-items:center;gap:12px}
.hdr-cta .btn{height:46px;padding:0 22px}
.lang-switch{position:relative;direction:ltr;flex:0 0 auto}
.lang-toggle{
  height:46px;min-width:66px;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding-inline:14px;border:1px solid var(--line-2);border-radius:var(--r-sm);background:#fff;color:var(--ink);
  font-size:13px;font-weight:800;letter-spacing:.08em;transition:.2s var(--ease);
}
.lang-toggle:hover{border-color:rgba(199,145,47,.45);color:var(--gold)}
.lang-toggle svg{width:14px;height:14px}
.lang-menu{
  position:absolute;inset-inline-end:0;top:calc(100% + 8px);min-width:142px;padding-block:6px;
  background:#fff;border:1px solid var(--line);box-shadow:0 18px 42px -30px rgba(17,17,17,.45);
  opacity:0;transform:translateY(6px);pointer-events:none;transition:.2s var(--ease);z-index:70;
}
.lang-switch.open .lang-menu{opacity:1;transform:none;pointer-events:auto}
.lang-option{
  display:flex;align-items:center;justify-content:space-between;gap:12px;padding-block:9px;padding-inline:12px;
  color:var(--ink-2);font-size:13.5px;font-weight:800;line-height:1.2;
}
.lang-option:hover,.lang-option.active{color:var(--ink);background:var(--bg-2)}
.lang-option.active::after{content:"";width:7px;height:7px;background:var(--gold)}
.burger{display:none;width:46px;height:46px;align-items:center;justify-content:center;
  border-radius:10px;border:1px solid var(--line-2);color:var(--ink)}
.burger svg{width:22px;height:22px}

/* ---------- mobile menu ---------- */
.mmenu{
  position:fixed;inset:0;z-index:80;background:#fff;display:flex;flex-direction:column;
  padding:20px var(--gut) 32px;visibility:hidden;opacity:0;pointer-events:none;
  transform:translateY(-14px);transition:opacity .28s var(--ease),transform .34s var(--ease),visibility 0s linear .34s;
}
.mmenu.open{visibility:visible;opacity:1;pointer-events:auto;transform:none;transition-delay:0s}
.mm-top{display:flex;align-items:center;justify-content:space-between;height:54px}
.mm-x{width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--line-2)}
.mm-x svg{width:22px;height:22px}
.mmenu nav{display:flex;flex-direction:column;gap:2px;margin-top:28px}
.mmenu nav a{
  font-family:var(--font-display);font-size:26px;font-weight:700;letter-spacing:-.02em;padding:14px 0;border-bottom:1px solid var(--line);
  opacity:0;transform:translateY(10px);transition:opacity .26s var(--ease),transform .32s var(--ease);
}
.mmenu.open nav a{opacity:1;transform:none}
.mmenu.open nav a:nth-child(1){transition-delay:.06s}
.mmenu.open nav a:nth-child(2){transition-delay:.1s}
.mmenu.open nav a:nth-child(3){transition-delay:.14s}
.mmenu.open nav a:nth-child(4){transition-delay:.18s}
.mmenu.open nav a:nth-child(5){transition-delay:.22s}
.mm-foot{
  margin-top:auto;display:flex;flex-direction:column;gap:12px;opacity:0;transform:translateY(10px);
  transition:opacity .26s var(--ease),transform .32s var(--ease);
}
.mmenu.open .mm-foot{opacity:1;transform:none;transition-delay:.24s}
.mm-foot .lang-switch{width:100%}
.mm-foot .lang-toggle{width:100%;height:48px}
.mm-foot .lang-menu{position:static;margin-block-start:8px;opacity:1;transform:none;pointer-events:auto;display:none;box-shadow:none}
.mm-foot .lang-switch.open .lang-menu{display:block}

/* ---------- language direction ---------- */
html[dir="rtl"]{
  --font-display:"Cairo",system-ui,sans-serif;
  --font-ui:"Cairo",system-ui,sans-serif;
}
html[dir="rtl"] body{text-align:right}
html[dir="rtl"] .brand,
html[dir="rtl"] .brand-mark,
html[dir="rtl"] .brand-txt,
html[dir="rtl"] .lang-switch,
html[dir="rtl"] a[href^="tel"],
html[dir="rtl"] a[href^="mailto"]{direction:ltr;unicode-bidi:isolate}
html[dir="rtl"] h1,
html[dir="rtl"] h2,
html[dir="rtl"] h3,
html[dir="rtl"] h4{letter-spacing:0;line-height:1.16}
html[dir="rtl"] em{font-style:normal}
html[dir="rtl"] .kicker,
html[dir="rtl"] .hero-eyebrow{flex-direction:row-reverse}
html[dir="rtl"] .flist li,
html[dir="rtl"] .cert-list li,
html[dir="rtl"] .aud-card li,
html[dir="rtl"] .hero-feat li{flex-direction:row}
html[dir="rtl"] .flist li,
html[dir="rtl"] .cert-list li,
html[dir="rtl"] .aud-card li,
html[dir="rtl"] .hero-feat li{direction:rtl}
html[dir="rtl"] .flist .chk,
html[dir="rtl"] .cert-list .chk,
html[dir="rtl"] .aud-card .chk,
html[dir="rtl"] .hero-feat .chk{margin-inline-start:0;margin-inline-end:0}
html[dir="rtl"] .hero-actions,
html[dir="rtl"] .bigcta-actions{justify-content:center}
html[dir="rtl"] .hero-badge{left:auto;right:clamp(28px,4vw,56px);border-left:1px solid rgba(255,255,255,.62);border-right:4px solid var(--gold)}
html[dir="rtl"] .hero-flag{right:auto;left:clamp(24px,4vw,54px)}
html[dir="rtl"] .split-media::before,
html[dir="rtl"] .phero::before,
html[dir="rtl"] .phero-media::before{left:auto;right:0}
html[dir="rtl"] .phero-card{left:auto;right:18px;border-left:1px solid rgba(255,255,255,.62);border-right:4px solid var(--gold)}
html[dir="rtl"] .field-card::after,
html[dir="rtl"] .download-card::after{transform-origin:right}
html[dir="rtl"] .proc-line,
html[dir="rtl"] .bento-process .proc-line{left:auto;right:38px}
html[dir="rtl"] .pstep:not(:last-child)::after,
html[dir="rtl"] .bento-process .pstep:not(:last-child)::after{left:auto;right:63px}

/* ---------- hero ---------- */
.hero{position:relative;padding:0;overflow:hidden;background:var(--bg)}
.hero::before{content:none}
.hero-grid{
  position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(44%,.92fr);
  gap:0;align-items:stretch;min-height:clamp(680px,calc(100vh - 42px),860px);
  max-width:none;padding-inline:0;
}
.hero-copy{
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:clamp(72px,9vw,132px) clamp(32px,7vw,96px) clamp(54px,7vw,96px);
  background:var(--bg);
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;background:transparent;color:var(--brand-deep);
  font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  padding:0;border-radius:0;margin-bottom:34px;border:0;
}
.hero-eyebrow::before{content:"";width:48px;height:1px;background:var(--gold)}
.hero-eyebrow .dot{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 6px rgba(199,145,47,.12)}
.hero h1{max-width:720px;margin-bottom:28px;text-wrap:balance;color:var(--ink)}
.hero h1 em{font-family:var(--font-display);font-style:italic;font-weight:500;color:var(--gold)}
.hero-lead{
  margin-bottom:34px;max-width:56ch;font-size:17px;line-height:1.78;
  color:#6b6b6b;font-weight:300;
}
.hero-feat{display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;margin-bottom:34px;max-width:560px}
.hero-feat li{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:500;color:#6b6b6b}
.hero-feat .chk{width:18px;height:18px;flex:0 0 auto;border-radius:50%;background:rgba(199,145,47,.14);
  display:flex;align-items:center;justify-content:center;color:var(--gold)}
.hero-feat .chk svg{width:10px;height:10px;stroke-width:3}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero-actions .btn{
  height:58px;border-radius:0;padding:0 30px;text-transform:uppercase;
  letter-spacing:.1em;font-size:12px;font-weight:800;
}
.hero-actions .btn-ghost{background:transparent;border-color:var(--line-2);box-shadow:inset 0 0 0 1px rgba(17,17,17,.02)}

.hero-visual{position:relative;min-height:100%;overflow:hidden}
.hero-frame{position:absolute;inset:0;border-radius:0;overflow:hidden;background:var(--img-bg);
  aspect-ratio:auto;box-shadow:none;border:0}
.hero-frame image-slot{width:100%;height:100%}
.hero-frame::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg,rgba(17,17,17,.12),transparent 26%),linear-gradient(0deg,rgba(17,17,17,.18),transparent 38%)}
.hero-badge{
  position:absolute;left:clamp(28px,4vw,56px);bottom:clamp(28px,5vw,66px);background:rgba(248,247,244,.94);
  border-radius:0;box-shadow:0 24px 52px -30px rgba(0,0,0,.45);
  padding:22px 26px 22px 28px;display:flex;align-items:center;gap:14px;border:1px solid rgba(255,255,255,.62);
  border-left:4px solid var(--gold);
}
.hero-badge .hb-ic{width:42px;height:42px;border-radius:0;background:rgba(199,145,47,.12);color:var(--gold);
  display:flex;align-items:center;justify-content:center}
.hero-badge .hb-ic svg{width:21px;height:21px}
.hero-badge b{font-family:var(--font-ui);font-size:17px;display:block;letter-spacing:-.01em;color:var(--ink)}
.hero-badge span{font-size:12px;color:var(--ink-3);font-weight:500;letter-spacing:.08em;text-transform:uppercase}
.hero-flag{
  position:absolute;right:clamp(24px,4vw,54px);top:clamp(28px,5vw,58px);background:rgba(248,247,244,.92);
  border-radius:0;padding:12px 17px 12px 12px;display:flex;align-items:center;gap:10px;
  box-shadow:0 18px 40px -28px rgba(0,0,0,.46);border:1px solid rgba(255,255,255,.58);
  font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
}
.hero-flag .dots{display:flex}
.hero-flag .dots span{width:22px;height:22px;border-radius:50%;border:2px solid #fff;margin-left:-8px;font-size:11px;
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.hero-flag .dots span:first-child{margin-left:0}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:clamp(30px,3.2vw,46px) clamp(20px,2.4vw,34px);border-left:1px solid var(--line);position:relative}
.stat:first-child{border-left:none}
.stat::before{content:"";position:absolute;left:clamp(20px,2.4vw,34px);top:0;width:42px;height:2px;background:var(--gold)}
.stat b{font-family:var(--font-display);font-weight:600;font-size:clamp(38px,4.6vw,58px);
  letter-spacing:-.035em;color:var(--ink);display:block;line-height:1}
.stat p{margin-top:12px;font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);line-height:1.45}
.bg-ink .stat{border-color:rgba(255,255,255,.14)}
.bg-ink .stat b{color:#fff}
.bg-ink .stat p{color:rgba(255,255,255,.66)}

/* ---------- logo strip / trust ---------- */
.trust-head{text-align:center;max-width:760px;margin:0 auto 48px}
.logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(28px,5vw,68px)}
.logos .lg{height:38px;display:flex;align-items:center;color:var(--ink-3);font-family:var(--font-ui);
  font-weight:700;font-size:21px;letter-spacing:-.01em;opacity:.8;filter:grayscale(1)}
.logos .lg img{height:100%;width:auto;object-fit:contain}
.logos .partner-tile{height:auto;min-height:58px;padding:0 24px;border-radius:var(--r);background:#fff;border:1px solid var(--line);
  border-bottom-color:rgba(199,145,47,.35);color:var(--ink);font-family:var(--font-ui);font-size:13px;font-weight:800;letter-spacing:.09em;
  text-transform:uppercase;box-shadow:none;filter:none;opacity:1}
.logos .partner-tile span{display:block;white-space:nowrap}

/* ---------- split / feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,6vw,92px);align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--img-bg);
  aspect-ratio:5/4;box-shadow:0 24px 58px -42px rgba(17,17,17,.55);border:1px solid var(--line)}
.split-media::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);z-index:2}
.split-media image-slot{width:100%;height:100%}
.tag-soon{position:absolute;top:18px;left:18px;z-index:3;background:var(--brand-ink);color:#fff;font-size:11px;
  font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:10px 16px;border-radius:var(--r-sm);
  box-shadow:0 12px 26px -14px rgba(17,17,17,.7)}
.flist{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.flist li{display:flex;align-items:flex-start;gap:13px;font-size:15.5px;font-weight:500;color:var(--ink)}
.flist .chk{width:23px;height:23px;flex:0 0 auto;border-radius:var(--r-sm);background:rgba(199,145,47,.14);color:var(--gold);
  display:flex;align-items:center;justify-content:center;margin-top:1px}
.flist .chk svg{width:14px;height:14px;stroke-width:3}
.bg-ink .flist li{color:#fff}
.bg-ink .flist .chk{background:#fff;color:var(--brand-ink)}

.locrow{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.loc-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--r-sm);
  background:#fff;border:1px solid var(--line);font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink)}
.loc-pill .fl{font-size:15px}
.bg-ink .loc-pill{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#fff}

/* ---------- fields grid ---------- */
.fields{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.field-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:34px 32px;transition:.28s var(--ease);position:relative;overflow:hidden;box-shadow:none}
.field-card::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:rgba(199,145,47,.34);transform:scaleX(0);transform-origin:left;transition:.28s var(--ease)}
.field-card:hover{transform:translateY(-4px);box-shadow:0 22px 44px -34px rgba(17,17,17,.48);border-color:rgba(199,145,47,.35)}
.field-card:hover::after{transform:scaleX(1)}
.field-card .fc-ic{width:52px;height:52px;border-radius:var(--r);background:rgba(199,145,47,.12);color:var(--gold);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.field-card .fc-ic svg{width:26px;height:26px}
.field-card h3{margin-bottom:7px}
.field-card p{color:#6b6b6b;font-size:15px;font-weight:300;line-height:1.7}

/* ---------- process ---------- */
.proc{position:relative;margin-top:52px}
.proc-line{
  position:absolute;left:38px;top:42px;bottom:42px;width:2px;
  background:linear-gradient(var(--gold),rgba(199,145,47,.18));opacity:.45;z-index:0;
}
.proc-grid{display:grid;grid-template-columns:1fr;gap:16px;position:relative;z-index:1;max-width:920px}
.pstep{
  position:relative;display:grid;grid-template-columns:76px minmax(0,1fr);align-items:center;gap:22px;
  min-height:112px;background:var(--surface);border:1px solid var(--line);border-radius:0;
  padding:22px 26px;transition:.28s var(--ease);box-shadow:0 12px 30px -20px rgba(13,28,66,.22);overflow:visible;
}
.pstep:hover{box-shadow:0 18px 36px -22px rgba(199,145,47,.28);border-color:rgba(199,145,47,.32);transform:translateY(-2px)}
.bg-ink .pstep{background:#fff;border-color:rgba(255,255,255,.16)}
.bg-ink .proc-line{background:rgba(255,255,255,.16)}
.pstep:not(:last-child)::after{
  content:"";position:absolute;left:63px;top:calc(50% + 30px);bottom:-32px;width:2px;
  background:linear-gradient(rgba(199,145,47,.28),rgba(199,145,47,.12));z-index:0;
}
.pstep .pn{
  position:relative;z-index:1;width:58px;height:58px;flex:0 0 auto;border-radius:0;background:#000;color:var(--gold);
  box-shadow:0 10px 22px -12px rgba(199,145,47,.62);font-family:var(--font-display);font-weight:700;font-size:23px;
  display:flex;align-items:center;justify-content:center;letter-spacing:0;
}
.pstep h3{font-size:clamp(20px,1.7vw,24px);line-height:1.16;letter-spacing:0;margin-bottom:6px;color:var(--ink);overflow-wrap:anywhere}
.pstep p{color:var(--ink-2);font-size:16.5px;line-height:1.45}

.bento-process{background:var(--bg-2);border-block:1px solid var(--line)}
.bento-process .wrap{max-width:var(--maxw)}
.bento-process .kicker{color:var(--gold)}
.bento-process .kicker::before{background:var(--gold)}
.bento-process .sec-head h2{color:var(--ink)}
.bento-process .sec-head p{color:var(--ink-2)}
.bento-process .proc{
  max-width:920px;margin:clamp(42px,5vw,64px) auto 0;position:relative;
}
.bento-process .proc-line{
  display:block;left:38px;top:42px;bottom:42px;width:2px;
  background:linear-gradient(var(--gold),rgba(199,145,47,.18));opacity:.45;z-index:0;
}
.bento-process .proc-grid{
  display:grid;grid-template-columns:1fr;gap:16px;position:relative;z-index:1;
}
.bento-process .pstep{
  position:relative;display:grid;grid-template-columns:76px minmax(0,1fr);
  align-items:center;gap:22px;min-height:112px;border-radius:0;
  padding:22px 26px;background:#fff;border:1px solid var(--line);
  box-shadow:0 12px 30px -20px rgba(13,28,66,.28);overflow:visible;
}
.bento-process .pstep:hover{box-shadow:0 18px 36px -22px rgba(199,145,47,.28);border-color:rgba(199,145,47,.32);transform:translateY(-2px)}
.bento-process .pstep:not(:last-child)::after{
  content:"";position:absolute;left:63px;top:calc(50% + 30px);bottom:-32px;width:2px;
  background:linear-gradient(rgba(199,145,47,.28),rgba(199,145,47,.12));z-index:0;
}
.bento-process .pstep .pn{
  position:relative;z-index:1;width:58px;height:58px;border-radius:0;background:#000;color:var(--gold);
  box-shadow:0 10px 22px -12px rgba(199,145,47,.62);font-size:23px;letter-spacing:0;
}
.bento-process .pstep h3{
  font-size:clamp(20px,1.7vw,24px);line-height:1.16;letter-spacing:0;margin-bottom:6px;color:var(--ink);
  overflow-wrap:anywhere;
}
.bento-process .pstep p{
  font-size:16.5px;line-height:1.45;color:var(--ink-2);
}

/* ---------- two audiences ---------- */
.aud{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.aud-card{border-radius:var(--r-lg);padding:clamp(34px,3.8vw,54px);position:relative;overflow:hidden;border:1px solid var(--line)}
.aud-emp{background:var(--brand-ink);color:#fff}
.aud-emp::after{content:none}
.aud-wrk{background:#fff;border:1px solid var(--line)}
.aud-card .aud-k{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;position:relative;z-index:1}
.aud-emp .aud-k{color:var(--gold)}
.aud-wrk .aud-k{color:var(--gold)}
.aud-card h3{font-size:clamp(24px,2.4vw,32px);margin-bottom:24px;position:relative;z-index:1;font-family:var(--font-ui)}
.aud-emp h3{color:#fff}
.aud-card ul{display:flex;flex-direction:column;gap:13px;margin-bottom:30px;position:relative;z-index:1}
.aud-card li{display:flex;align-items:flex-start;gap:12px;font-size:15.5px;font-weight:500}
.aud-emp li{color:rgba(255,255,255,.82)}
.aud-wrk li{color:var(--ink)}
.aud-card .chk{width:23px;height:23px;flex:0 0 auto;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;margin-top:1px}
.aud-card .chk svg{width:13px;height:13px;stroke-width:3}
.aud-emp .chk{background:rgba(199,145,47,.18);color:var(--gold)}
.aud-wrk .chk{background:rgba(199,145,47,.14);color:var(--gold)}
.aud-card .btn{position:relative;z-index:1}

/* ---------- locations / schools ---------- */
.schools{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px;margin-top:52px}
.school{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  transition:.28s var(--ease);box-shadow:none}
.school:hover{box-shadow:0 28px 58px -42px rgba(17,17,17,.52);transform:translateY(-5px);border-color:rgba(199,145,47,.3)}
.school-img{aspect-ratio:5/3;background:var(--img-bg);position:relative}
.school-img image-slot{width:100%;height:100%}
.school-flag{position:absolute;top:16px;left:16px;background:rgba(248,247,244,.94);border-radius:var(--r-sm);padding:9px 14px;
  font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-sm);border-left:3px solid var(--gold)}
.school-body{padding:30px 32px 36px}
.school-body h3{margin-bottom:6px}
.school-body>p{color:#6b6b6b;font-size:16px;font-weight:300;margin-bottom:20px;line-height:1.7}
.school-cities{display:flex;flex-wrap:wrap;gap:8px}
.school-cities span{font-size:13px;font-weight:700;color:var(--ink);background:rgba(199,145,47,.12);
  padding:7px 13px;border-radius:var(--r-sm);border:1px solid rgba(199,145,47,.16)}

/* ---------- certifications ---------- */
.cert-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(36px,5vw,72px);align-items:center}
.cert-list{display:flex;flex-direction:column;gap:16px;margin-top:28px}
.cert-list li{display:flex;align-items:flex-start;gap:13px;font-size:16px;font-weight:500;color:var(--ink)}
.cert-list .chk{width:25px;height:25px;flex:0 0 auto;border-radius:var(--r-sm);background:rgba(199,145,47,.14);color:var(--gold);
  display:flex;align-items:center;justify-content:center;margin-top:1px}
.cert-list .chk svg{width:15px;height:15px;stroke-width:3}
.seals{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.seal{width:132px;height:132px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;
  padding:14px;box-shadow:none}
.seal .seal-ic{width:42px;height:42px;border-radius:var(--r);background:rgba(199,145,47,.12);color:var(--gold);
  display:flex;align-items:center;justify-content:center}
.seal .seal-ic svg{width:22px;height:22px}
.seal b{font-family:var(--font-ui);font-size:14px;font-weight:800}
.seal span{font-size:11px;color:var(--ink-3);font-weight:500;line-height:1.3}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(36px,5vw,72px);align-items:start}
.crows{display:flex;flex-direction:column;gap:16px;margin-top:34px}
.crow{display:flex;align-items:center;gap:16px;padding:18px 20px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);transition:.24s}
.crow:hover{border-color:rgba(199,145,47,.35);box-shadow:0 18px 38px -30px rgba(17,17,17,.42)}
.crow .ic{width:46px;height:46px;flex:0 0 auto;border-radius:var(--r);background:rgba(199,145,47,.12);color:var(--gold);
  display:flex;align-items:center;justify-content:center}
.crow .ic svg{width:22px;height:22px}
.crow .l{font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.crow .v{font-size:17px;font-weight:700;color:var(--ink);margin-top:2px}

.form{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(28px,3.2vw,44px);box-shadow:0 24px 52px -42px rgba(17,17,17,.5)}
.form h3{margin-bottom:6px}
.form .fl{color:var(--ink-2);font-size:14.5px;margin-bottom:24px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;font-weight:700;color:var(--ink);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;height:52px;padding:0 16px;border-radius:var(--r-sm);
  border:1.5px solid var(--line-2);background:var(--bg);font-family:inherit;font-size:15px;color:var(--ink);
  transition:.2s}
.field textarea{height:auto;padding:14px 16px;min-height:120px;resize:vertical;line-height:1.6}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 4px rgba(199,145,47,.12)}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-consent{display:flex;align-items:flex-start;gap:11px;margin:6px 0 20px;font-size:13px;color:var(--ink-2);line-height:1.5}
.form-consent input{width:18px;height:18px;margin-top:2px;flex:0 0 auto;accent-color:var(--gold)}
.form-consent a{color:var(--gold);font-weight:700}
.form-note{margin-top:14px;font-size:12.5px;color:var(--ink-3);text-align:center}
.form-ok{display:none;margin-top:16px;padding:14px 18px;border-radius:var(--r-sm);background:rgba(199,145,47,.12);
  color:var(--brand-deep);font-weight:700;font-size:14.5px;text-align:center}
.form-ok.show{display:block}

/* ---------- theme settings ---------- */
.theme-settings{position:fixed;right:20px;bottom:20px;z-index:90}
.theme-settings-toggle{
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;
  background:var(--brand-ink);color:#fff;border:1px solid rgba(255,255,255,.14);
  box-shadow:0 18px 38px -22px rgba(0,0,0,.55);transition:.24s var(--ease);
}
.theme-settings-toggle:hover{transform:translateY(-2px);box-shadow:0 22px 44px -24px rgba(0,0,0,.62)}
.theme-settings-toggle svg{width:21px;height:21px}
.theme-settings-panel{
  position:absolute;right:0;bottom:60px;width:430px;padding:18px;background:#fff;
  border:1px solid var(--line);border-radius:var(--r);box-shadow:0 26px 60px -38px rgba(17,17,17,.58);
  opacity:0;transform:translateY(8px);pointer-events:none;transition:.22s var(--ease);
}
.theme-settings.open .theme-settings-panel{opacity:1;transform:none;pointer-events:auto}
.theme-settings-group+.theme-settings-group{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.theme-settings-title{
  display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;
  font-size:12px;font-weight:800;letter-spacing:.11em;text-transform:uppercase;color:var(--ink);
}
.theme-settings-title::after{content:"";height:1px;flex:1;background:rgba(199,145,47,.35)}
.theme-swatches,.theme-ink-swatches{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.theme-swatches{grid-template-columns:repeat(8,1fr)}
.theme-ink-swatches{grid-template-columns:repeat(8,1fr)}
.theme-palette-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.theme-palette{
  min-height:86px;padding:12px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:var(--bg);display:grid;grid-template-columns:48px minmax(0,1fr);align-items:center;gap:12px;
  text-align:left;transition:.2s var(--ease);position:relative;
}
.theme-palette:hover{transform:translateY(-2px);border-color:rgba(199,145,47,.36);box-shadow:0 14px 28px -24px rgba(17,17,17,.52)}
.theme-palette.is-active{border-color:rgba(199,145,47,.62);box-shadow:0 0 0 3px rgba(199,145,47,.14)}
.theme-palette.is-active::after{content:"";position:absolute;right:12px;top:12px;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.theme-palette-preview{width:48px;height:48px;border-radius:var(--r-sm);overflow:hidden;border:1px solid rgba(17,17,17,.12);display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}
.theme-palette-preview span:first-child{grid-row:1/3;background:var(--palette-dark)}
.theme-palette-preview span:nth-child(2){background:var(--palette-primary)}
.theme-palette-preview span:nth-child(3){background:var(--palette-soft)}
.theme-palette-copy{min-width:0;display:flex;flex-direction:column;gap:3px}
.theme-palette-copy b{font-size:13.5px;font-weight:800;color:var(--ink);line-height:1.15}
.theme-palette-copy small{font-size:11.5px;font-weight:500;color:var(--ink-3);line-height:1.35}
.theme-icon-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.theme-icon-option{
  min-height:74px;padding:12px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:var(--bg);display:grid;grid-template-columns:58px minmax(0,1fr);align-items:center;gap:12px;
  text-align:left;transition:.2s var(--ease);position:relative;
}
.theme-icon-option:hover{transform:translateY(-2px);border-color:rgba(199,145,47,.36);box-shadow:0 14px 28px -24px rgba(17,17,17,.52)}
.theme-icon-option.is-active{border-color:rgba(199,145,47,.62);box-shadow:0 0 0 3px rgba(199,145,47,.14)}
.theme-icon-option.is-active::after{content:"";position:absolute;right:12px;top:12px;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.theme-icon-preview{
  width:58px;height:40px;border-radius:var(--r-sm);border:1px solid rgba(17,17,17,.12);
  background:#fff;display:flex;align-items:center;justify-content:center;padding:5px;overflow:hidden;
}
.theme-icon-preview img{max-width:100%;max-height:100%;object-fit:contain}
.theme-icon-copy{min-width:0;display:flex;flex-direction:column;gap:3px}
.theme-icon-copy b{font-size:13.5px;font-weight:800;color:var(--ink);line-height:1.15}
.theme-icon-copy small{font-size:11.5px;font-weight:500;color:var(--ink-3);line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.theme-swatch{
  height:30px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--swatch);
  display:grid;place-items:center;transition:.2s var(--ease);position:relative;
}
.theme-swatch:hover{transform:translateY(-2px);border-color:rgba(199,145,47,.36);box-shadow:0 12px 24px -20px rgba(17,17,17,.45)}
.theme-swatch.is-active{border-color:rgba(199,145,47,.62);box-shadow:0 0 0 3px rgba(199,145,47,.14)}
.theme-swatch.is-active::after{content:"";width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 0 1px rgba(17,17,17,.18)}
.theme-reset{
  margin-top:14px;width:100%;height:38px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:var(--bg);color:var(--ink);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  transition:.2s var(--ease);
}
.theme-reset:hover{border-color:rgba(199,145,47,.34);color:var(--gold)}

/* ---------- download center ---------- */
.download-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.download-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:32px 30px;display:flex;flex-direction:column;min-height:270px;transition:.28s var(--ease);
  position:relative;overflow:hidden}
.download-card::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--gold)}
.download-card:hover{transform:translateY(-4px);box-shadow:0 22px 46px -34px rgba(0,0,0,.5);border-color:rgba(199,145,47,.35)}
.download-ic{width:52px;height:52px;border-radius:var(--r);background:rgba(199,145,47,.12);color:var(--gold);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.download-card:nth-child(2) .download-ic,
.download-card:nth-child(3) .download-ic{background:rgba(199,145,47,.12);color:var(--gold)}
.download-ic svg{width:26px;height:26px}
.download-k{font-size:12.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:10px}
.download-card h3{margin-bottom:10px}
.download-card p{color:#6b6b6b;font-size:14.5px;font-weight:300;line-height:1.65}
.program-strip{margin-top:20px;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;
  padding:clamp(26px,3vw,38px);display:grid;grid-template-columns:1.25fr .75fr;gap:28px;align-items:center}
.program-strip .kicker{margin-bottom:14px}
.program-strip h3{font-size:clamp(22px,2.1vw,30px);margin-bottom:8px}
.program-strip p{color:var(--ink-2);font-size:15px;max-width:66ch}
.program-links{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
.program-links a{display:inline-flex;align-items:center;justify-content:center;height:42px;padding:0 16px;
  border-radius:var(--r-sm);background:rgba(199,145,47,.12);border:1px solid rgba(199,145,47,.22);
  color:var(--ink);font-size:13px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;transition:.24s var(--ease)}
.program-links a:hover{background:var(--gold);border-color:var(--gold);color:#fff;transform:translateY(-2px)}

/* ---------- legal pages ---------- */
.legal-page{background:var(--bg);border-top:1px solid var(--line)}
.legal-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:clamp(32px,5vw,72px);align-items:start}
.legal-main{
  max-width:860px;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(26px,4vw,48px);box-shadow:0 18px 42px -36px rgba(17,17,17,.35);
}
.legal-main h2{font-family:var(--font-ui);font-size:clamp(20px,1.8vw,25px);line-height:1.2;letter-spacing:-.02em;margin:34px 0 10px}
.legal-main h2:first-child{margin-top:0}
.legal-main h3{font-size:17px;margin:24px 0 8px}
.legal-main p,.legal-main li{color:#5f5b53;font-size:15.5px;line-height:1.75}
.legal-main p+p{margin-top:10px}
.legal-main ul{list-style:disc;padding-inline-start:22px;margin:10px 0}
.legal-main a{color:var(--brand-deep);font-weight:700;text-decoration:underline;text-underline-offset:3px}
.legal-note{padding:14px 16px;border-left:3px solid var(--gold);background:rgba(199,145,47,.1);margin:18px 0;color:var(--ink)}
.legal-side{display:flex;flex-direction:column;gap:16px;position:sticky;top:96px}
.legal-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px}
.legal-card h3{font-size:16px;margin-bottom:10px}
.legal-card a{display:block;color:var(--ink-2);font-size:14.5px;margin-top:8px}
.legal-card a:hover{color:var(--brand)}

/* ---------- big cta ---------- */
.bigcta{position:relative;overflow:hidden;background:var(--brand-ink)}
.bigcta-in{position:relative;z-index:1;text-align:center;max-width:820px;margin:0 auto}
.bigcta h2{margin-bottom:20px;text-wrap:balance}
.bigcta .lead{margin:0 auto 32px}
.bigcta-actions{display:flex;flex-wrap:wrap;gap:13px;justify-content:center}
.bigcta::before{content:none}

/* ---------- RifeX brand CTA ---------- */
.rifex-brand-cta{background:#f8f7f4}
.rifex-bridge-card{
  color:var(--ink);padding:clamp(22px,3vw,38px) 0;text-align:center;
}
.rifex-bridge-logo{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;margin-bottom:24px}
.rifex-bridge-mark{width:clamp(250px,35vw,520px);height:auto;display:block}
.rifex-bridge-wordmark{width:min(360px,78vw);height:auto;display:block}
.rifex-bridge-flags{display:flex;align-items:center;justify-content:center;gap:14px;margin:18px auto 14px}
.rifex-bridge-line{width:min(112px,16vw);height:1px;background:var(--gold)}
.rifex-flag{width:38px;height:25px;box-shadow:0 1px 2px rgba(0,0,0,.12);overflow:hidden}
.rifex-flag-ma{display:grid;place-items:center;background:#d31f2a;color:#087a3a;font-size:16px;line-height:1}
.rifex-flag-de{display:grid;grid-template-rows:1fr 1fr 1fr}
.rifex-flag-de span:nth-child(1){background:#111}
.rifex-flag-de span:nth-child(2){background:#dd0000}
.rifex-flag-de span:nth-child(3){background:#ffce00}
.rifex-flag-separator{height:28px;width:2px;background:rgba(17,17,17,.2)}
.rifex-bridge-copy{
  margin:0;font-family:var(--font-ui);font-size:clamp(11px,1vw,13px);font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;color:#303030;
}
.rifex-bridge-copy strong:first-of-type{color:#d31f2a}
.rifex-bridge-copy strong:last-of-type{color:var(--gold)}
.rifex-bridge-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:22px}

/* ---------- footer ---------- */
.footer{position:relative;background:var(--brand-ink);color:rgba(255,255,255,.66);padding:clamp(56px,7vw,88px) 0 32px}
.footer::before{
  content:"";position:absolute;top:0;left:var(--gut);right:var(--gut);height:1px;
  max-width:var(--maxw);margin-inline:auto;background:rgba(255,255,255,.12);
}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .brand-txt b{color:#fff}
.footer .brand-txt span{color:rgba(255,255,255,.45)}
.footer .brand-logo,.footer .brand-wordmark{filter:brightness(0) invert(1);opacity:.92}
.footer .footer-logo-white{filter:none;opacity:1}
.footer-brand .brand-wordmark{width:clamp(262px,76vw,310px);min-width:262px}
.footer-blurb{margin:20px 0 22px;font-size:14.5px;max-width:34ch;line-height:1.6}
.footer-socials{display:flex;gap:10px}
.footer-socials a{width:40px;height:40px;border-radius:var(--r);background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:#fff;transition:.24s}
.footer-socials a:hover{background:var(--gold);transform:translateY(-2px)}
.footer-socials svg{width:18px;height:18px}
.footer-col h4{font-family:var(--font-ui);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;margin-bottom:18px}
.footer-col ul{display:flex;flex-direction:column;gap:11px}
.footer-col a{font-size:14.5px;color:rgba(255,255,255,.66);transition:.2s}
.footer-col a:hover{color:#fff}
.footer-col p{font-size:14.5px;line-height:1.7}
.footer-col p a{color:rgba(255,255,255,.66)}
.footer-bridge{
  margin:34px 0 0;
  padding:clamp(14px,2vw,22px) 0;
  background:transparent;color:#fff;text-align:center;border-radius:0;
  border:0;box-shadow:none;
}
.footer-bridge-logo{display:flex;align-items:center;justify-content:center;margin-bottom:0}
.footer-bridge-wordmark{width:min(380px,72vw);height:auto;display:block;filter:brightness(0) invert(1);opacity:.96}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:26px;
  font-size:13px;flex-wrap:wrap}
.footer-bottom .legal{display:flex;gap:20px}
.footer-bottom a:hover{color:#fff}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.scroll-drive.in{transform:translate3d(0,var(--scroll-y,0px),0) scale(var(--scroll-scale,1))}
.scroll-card.in{transform:translate3d(0,var(--scroll-card-y,0px),0)}
.scroll-parallax image-slot{transform:translate3d(0,var(--scroll-media-y,0px),0) scale(1.06);transition:transform .12s linear}
.hero-frame.scroll-parallax image-slot{scale:1.04}
.scroll-line{--scroll-line:0}
.scroll-line::after{opacity:calc(.45 + (var(--scroll-line) * .55))}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .scroll-drive.in,.scroll-card.in,.scroll-parallax image-slot{transform:none}
}

/* ---------- page hero (subpages) ---------- */
.phero{
  background:var(--bg);color:var(--ink);padding:clamp(58px,7vw,106px) 0 clamp(58px,7vw,100px);
  position:relative;overflow:hidden;border-bottom:1px solid var(--line);
}
.phero::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);opacity:.9}
.phero-in{position:relative;z-index:1;max-width:720px}
.phero .crumbs{
  display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;color:var(--ink-3);
  margin-bottom:26px;letter-spacing:.06em;text-transform:uppercase;
}
.phero .crumbs a:hover{color:var(--ink)}
.phero .crumbs span:last-child{color:var(--ink)}
.phero .kicker{color:var(--gold)}
.phero .kicker::before{background:var(--gold)}
.phero h1{
  margin-bottom:22px;color:var(--ink);max-width:640px;
  font-size:clamp(40px,4.35vw,62px);line-height:1.03;letter-spacing:-.026em;
}
.phero h1 em{font-family:var(--font-display);font-style:italic;font-weight:500;color:var(--gold)}
.phero p{font-size:clamp(16.5px,1.35vw,18px);line-height:1.68;color:#6b6b6b;font-weight:300;max-width:52ch}
.phero .btn-ghost{background:transparent}
.phero-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.78fr);gap:clamp(40px,6vw,88px);align-items:center}
.phero-grid>*{min-width:0}
.phero-media{
  position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--img-bg);
  min-height:clamp(460px,42vw,620px);border:1px solid var(--line);box-shadow:0 24px 58px -42px rgba(17,17,17,.55);
}
.phero-media image-slot{position:absolute;inset:0;width:100%;height:100%}
.phero-media::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);z-index:2}
.phero-media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(0deg,rgba(17,17,17,.28),transparent 44%)}
.phero-card{
  position:absolute;left:18px;bottom:18px;background:rgba(248,247,244,.94);color:var(--ink);border-radius:0;
  border:1px solid rgba(255,255,255,.62);border-left:4px solid var(--gold);
  box-shadow:0 24px 52px -30px rgba(0,0,0,.45);padding:14px 18px;min-width:190px;z-index:3;
}
.phero-card b{display:block;font-family:var(--font-ui);font-size:17px;line-height:1.1;color:var(--ink)}
.phero-card span{display:block;margin-top:5px;font-size:11.5px;font-weight:800;color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase}

/* ---------- responsive ---------- */
@media (max-width:1020px){
  .topbar-in{justify-content:center}
  .topbar-r{display:none}
  .topbar-l{min-width:0;gap:18px}
  .topbar-l a{min-width:0;white-space:nowrap}
  .nav{display:none}
  .burger{display:flex;position:relative}
  .burger svg{display:none}
  .burger::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;box-shadow:9px 0 0 currentColor,-9px 0 0 currentColor}
  .hdr-in{gap:12px}
  .hdr-cta{margin-inline-start:auto;gap:10px}
  .hdr-cta .btn-primary{display:none}
  .hdr-cta .btn-ghost{display:none}
}
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:0;min-height:auto}
  .hero-copy{padding:clamp(56px,10vw,86px) 32px 44px}
  .hero h1{max-width:680px}
  .hero-visual{max-width:none;min-height:460px}
  .hero-frame{position:absolute;inset:0}
  .split{grid-template-columns:1fr;gap:36px}
  .split.rev .split-media{order:0}
  .phero-grid{grid-template-columns:1fr;gap:36px}
  .phero-media{max-width:620px;min-height:440px}
  .cert-grid{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr}
  .aud{grid-template-columns:1fr}
  .proc{max-width:720px}
  .proc-line{display:block;left:34px;top:36px;bottom:36px}
  .proc-grid{grid-template-columns:1fr;gap:14px}
  .pstep{grid-template-columns:68px minmax(0,1fr);min-height:104px;padding:20px;gap:18px}
  .pstep:not(:last-child)::after{left:53px;bottom:-28px}
  .pstep .pn{width:52px;height:52px;border-radius:0;font-size:21px}
  .pstep h3{font-size:21px}
  .pstep p{font-size:16px}
  .bento-process .wrap{max-width:100%}
  .bento-process .proc{max-width:720px;margin-top:38px}
  .bento-process .proc-line{display:block;left:34px;top:36px;bottom:36px}
  .bento-process .proc-grid{grid-template-columns:1fr;gap:14px}
  .bento-process .pstep{grid-template-columns:68px minmax(0,1fr);min-height:104px;padding:20px;gap:18px}
  .bento-process .pstep:not(:last-child)::after{left:53px;bottom:-28px}
  .bento-process .pstep .pn{width:52px;height:52px;border-radius:0;font-size:21px}
  .bento-process .pstep h3{font-size:21px}
  .bento-process .pstep p{font-size:16px}
  .stats{grid-template-columns:1fr 1fr}
  .stat{border-left:none;border-top:1px solid var(--line)}
  .bg-ink .stat{border-top-color:rgba(255,255,255,.14)}
  .stat:first-child,.stat:nth-child(2){border-top:none}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
  .fields{grid-template-columns:1fr 1fr}
  .download-grid{grid-template-columns:1fr}
  .program-strip{grid-template-columns:1fr}
  .program-links{justify-content:flex-start}
  .schools{grid-template-columns:1fr}
  .legal-layout{grid-template-columns:1fr}
  .legal-side{position:static}
}
@media (max-width:620px){
  .wrap{max-width:100%;width:100%;margin-inline:auto;padding-inline:24px}
  .topbar-in{justify-content:center}
  .topbar-r{display:none}
  .topbar-l a:first-child{display:none}
  .hdr-in{gap:12px}
  .hdr-cta .btn-primary{display:none}
  .hero-copy{padding:46px 24px 38px}
  .hero-eyebrow{gap:10px;margin-bottom:24px;font-size:10.5px;letter-spacing:.14em}
  .hero-eyebrow::before{width:30px}
  .hero h1{font-size:clamp(44px,13vw,62px);line-height:1.02;margin-bottom:22px}
  .hero-lead{font-size:16px;line-height:1.7;margin-bottom:28px}
  .hero-visual{min-height:420px}
  .hero-badge{left:24px;right:24px;bottom:24px;padding:18px 18px 18px 20px}
  .hero-flag{right:20px;top:20px}
  .phero{padding:48px 0 60px}
  .phero-grid{gap:30px}
  .phero .crumbs{font-size:13px;margin-bottom:18px;flex-wrap:wrap}
  .phero .kicker{font-size:12px;letter-spacing:.12em;margin-bottom:18px}
  .phero-in,.phero h1,.phero p,.phero .bigcta-actions,.phero-media{width:100%;max-width:calc(100vw - 48px)}
  .phero h1{font-size:clamp(32px,8.8vw,40px);line-height:1.06;margin-bottom:16px;text-wrap:balance}
  .phero p{font-size:15.5px;line-height:1.56;overflow-wrap:break-word}
  .phero .bigcta-actions{gap:12px;align-items:stretch}
  .phero .bigcta-actions .btn{width:min(100%,260px)}
  .rifex-bridge-flags{gap:12px}
  .rifex-bridge-line{width:16vw}
  .rifex-bridge-copy{line-height:1.7;letter-spacing:.1em}
  .rifex-bridge-actions{align-items:stretch}
  .rifex-bridge-actions .btn{width:min(100%,260px)}
  .phero-media{border-radius:var(--r-lg);max-width:none;min-height:360px}
  .phero-card{left:12px;bottom:12px;min-width:160px;padding:12px 14px}
  .hero-feat{grid-template-columns:1fr}
  .proc-line{left:28px}
  .pstep{grid-template-columns:58px minmax(0,1fr);min-height:96px;padding:16px;gap:14px;border-radius:0}
  .pstep:not(:last-child)::after{left:44px;top:calc(50% + 26px)}
  .pstep .pn{width:46px;height:46px;border-radius:0;font-size:19px}
  .pstep h3{font-size:19px;line-height:1.2}
  .pstep p{font-size:15px;line-height:1.42}
  .bento-process .proc-line{left:28px}
  .bento-process .pstep{grid-template-columns:58px minmax(0,1fr);min-height:96px;padding:16px;gap:14px;border-radius:0}
  .bento-process .pstep:not(:last-child)::after{left:44px;top:calc(50% + 26px)}
  .bento-process .pstep .pn{width:46px;height:46px;border-radius:0;font-size:19px}
  .bento-process .pstep h3{font-size:19px;line-height:1.2}
  .bento-process .pstep p{font-size:15px;line-height:1.42}
  .hero-actions .btn{width:100%}
  .fields{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bridge-wordmark{width:min(330px,86vw)}
  .stats{grid-template-columns:1fr 1fr}
  .seals{gap:12px}
  .seal{width:108px;height:108px}
  .hero-badge{left:0}
  .topbar-l{gap:14px}
  .theme-settings{right:16px;bottom:16px}
  .theme-settings-panel{width:min(342px,calc(100vw - 32px));right:0}
  .theme-palette-grid{grid-template-columns:1fr}
  .theme-icon-grid{grid-template-columns:1fr}
  .theme-swatches{grid-template-columns:repeat(6,1fr)}
  .theme-ink-swatches{grid-template-columns:repeat(6,1fr)}
}
@media (max-width:430px){
  .phero-in,.phero h1,.phero p,.phero .bigcta-actions,.phero-media{max-width:342px}
  .phero h1{font-size:clamp(32px,10vw,40px)}
}

html[dir="rtl"] .hero-badge{left:auto;right:clamp(28px,4vw,56px)}
html[dir="rtl"] .phero-card{left:auto;right:18px}
@media (max-width:900px){
  html[dir="rtl"] .proc-line,
  html[dir="rtl"] .bento-process .proc-line{left:auto;right:34px}
  html[dir="rtl"] .pstep:not(:last-child)::after,
  html[dir="rtl"] .bento-process .pstep:not(:last-child)::after{left:auto;right:53px}
}
@media (max-width:620px){
  html[dir="rtl"] .hero-badge{left:24px;right:24px}
  html[dir="rtl"] .phero-card{left:12px;right:12px}
  html[dir="rtl"] .proc-line,
  html[dir="rtl"] .bento-process .proc-line{left:auto;right:28px}
  html[dir="rtl"] .pstep:not(:last-child)::after,
  html[dir="rtl"] .bento-process .pstep:not(:last-child)::after{left:auto;right:44px}
}
