/* ==========================================================
   RIVCO ASSISTANT — "The Editorial Executive"
   Deep Sea & Frost palette · No-Line Rule · Ambient Depth
   Plus Jakarta Sans · Work Sans · Inter
   ========================================================== */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* ── Color: Deep Sea & Frost ── */
  --pri:       #0053A6;
  --pri-ctr:   #046BD2;
  --pri-hover: #034E9A;
  --pri-dim:   rgba(0,83,166,.10);
  --pri-ghost: rgba(0,83,166,.04);
  --accent:    #39D2C0;
  --amber:     #F59E0B;
  --amber-h:   #D97706;
  --green:     #22C55E;
  --red:       #EF4444;

  --sf:       #F5FAFF;          /* surface – page base */
  --sf-low:   #F1F4F8;          /* surface-container-low */
  --sf-card:  #FFFFFF;           /* surface-container-lowest (cards) */
  --on:       #171C20;           /* on-surface */
  --on-m:     #57636C;           /* on-surface-muted */
  --ol:       rgba(224,227,231,.15); /* outline-variant ghost */

  /* ── Signature Texture ── */
  --grad:     linear-gradient(135deg,#0053A6,#046BD2);
  --grad-dark:linear-gradient(135deg,#003D7A,#034E9A);

  /* ── Shadows (blue-tinted, premium depth) ── */
  --sh-xs: 0 1px 3px rgba(0,83,166,.04);
  --sh-sm: 0 2px 8px rgba(0,83,166,.06);
  --sh-md: 0 4px 12px -2px rgba(0,83,166,.08), 0 2px 6px -1px rgba(0,83,166,.04);
  --sh-lg: 0 12px 28px -6px rgba(0,83,166,.10), 0 4px 8px -2px rgba(0,83,166,.05);
  --sh-xl: 0 24px 48px -8px rgba(0,83,166,.09), 0 8px 16px -4px rgba(0,83,166,.04);
  --sh-glow: 0 0 40px rgba(4,107,210,.12);

  /* ── Typography ── */
  --f-d: 'Plus Jakarta Sans',sans-serif;
  --f-b: 'Source Sans 3',sans-serif;
  --f-l: 'Inter',sans-serif;
  --f-q: 'Instrument Serif','Georgia',serif;

  /* ── Spacing (8px) ── */
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s7:28px;
  --s8:32px;--s10:40px;--s12:48px;--s16:64px;--s20:80px;--s24:96px;--s32:128px;

  /* ── Radius ── */
  --r-sm:4px;--r-md:8px;--r-lg:12px;--r-xl:24px;--r-pill:9999px;

  /* ── Motion ── */
  --ease:cubic-bezier(.4,0,.2,1);
  --dur:.3s;

  --cw:1200px;
}
@media(min-width:1440px){:root{--cw:1280px}}
@media(min-width:1600px){:root{--cw:1360px}}
@media(min-width:1920px){:root{--cw:1440px}}

/* ── Base ── */
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--f-b);color:var(--on-m);background:var(--sf);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body.elementor-page{font-family:var(--f-b)!important;color:var(--on-m)!important;background:var(--sf)!important}
body.elementor-page .elementor{background:var(--sf)!important}
.elementor .elementor-widget-rivco-contact-main{margin-bottom:0!important}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--dur) ease-out}
ul,ol{list-style:none}
button{font-family:var(--f-l)}
strong{font-weight:600;color:var(--on)}

/* ── Focus visible (keyboard a11y) ── */
:focus-visible{outline:2px solid var(--pri-ctr);outline-offset:2px;border-radius:var(--r-sm)}

/* ── Container (responsive padding per UX Pro) ── */
.ctr{max-width:var(--cw);margin:0 auto;padding-inline:var(--s4)}
@media(min-width:640px){.ctr{padding-inline:var(--s6)}}
@media(min-width:1024px){.ctr{padding-inline:var(--s8)}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ── Section Shell ── */
.sec{padding:96px 0}
.sec--low{background:var(--sf-low)}
.sec--dark{background:var(--on);color:#fff;position:relative;overflow:hidden}
.sec--dark::before{content:'';position:absolute;top:-30%;right:-20%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(4,107,210,.08) 0%,transparent 70%);pointer-events:none}
.sec--grad{background:var(--grad);color:#fff;position:relative;overflow:hidden}
.sec--grad::before{content:'';position:absolute;top:-40%;left:-15%;width:600px;height:600px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.sec--compact{padding:var(--s16) 0}

/* Section tag — small editorial overline */
.sec__tag{
  display:inline-flex;align-items:center;gap:6px;
  font:700 .625rem/1 var(--f-l);color:var(--pri-ctr);
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:var(--s5);
  background:rgba(0,83,166,.05);padding:6px 14px;border-radius:var(--r-pill);
}
.sec--dark .sec__tag{color:#93C5FD;background:rgba(147,197,253,.08)}
.sec--grad .sec__tag{color:rgba(255,255,255,.8);background:rgba(255,255,255,.1)}

/* Section heading — editorial authority */
.sec__h{
  font:800 clamp(1.625rem,3.2vw,3rem)/1.12 var(--f-d);color:var(--on);
  letter-spacing:-.035em;margin-bottom:var(--s4);
}
.sec--dark .sec__h,.sec--grad .sec__h{color:#fff}
.sec__h em{font-style:normal;color:var(--pri-ctr)}

/* Section paragraph — readable, restrained */
.sec__p{font:400 1.0625rem/1.75 var(--f-b);color:var(--on-m);max-width:560px}
.sec--dark .sec__p{color:rgba(255,255,255,.6)}
.sec--grad .sec__p{color:rgba(255,255,255,.7)}

.sec__top{text-align:center;margin-bottom:64px}
.sec__top .sec__p{margin-inline:auto}

/* ── Reveal (premium eased entrance) ── */
.rv{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.rv.vis{opacity:1;transform:translateY(0)}
.rv-d1{transition-delay:.12s}.rv-d2{transition-delay:.24s}
.rv-d3{transition-delay:.36s}.rv-d4{transition-delay:.48s}

/* ==========================================================
   ANNOUNCEMENT
   ========================================================== */
.ann{
  background:var(--on)!important;color:rgba(255,255,255,.7)!important;text-align:center;
  padding:10px var(--s6)!important;font:500 .75rem/1.4 var(--f-l)!important;letter-spacing:.02em;
  margin:0!important;
}
.ann b{color:#93C5FD!important;font-weight:700}

/* ==========================================================
   HEADER — Glassmorphism
   ========================================================== */
.hdr{
  position:sticky;top:0;z-index:1000;
  background:rgba(245,250,255,.82);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  transition:box-shadow var(--dur) var(--ease);
}
.hdr.scrolled{box-shadow:var(--sh-md)}

.hdr__in{display:flex;align-items:center;justify-content:space-between;height:72px;position:relative}

.hdr__logo{display:flex;align-items:center}
.hdr .hdr__logo-img{height:36px!important;width:auto!important;max-width:none!important;display:block}

.hdr__nav{display:flex;align-items:center;gap:var(--s8);min-width:0}
.hdr__links{display:flex;align-items:center;gap:var(--s6);margin:0!important;padding:0!important;list-style:none!important}
.hdr__links li{margin:0!important;padding:0!important;line-height:1}
.hdr__links a{
  display:inline-flex;align-items:center;white-space:nowrap;
  font:600 .8125rem/1 var(--f-l);color:var(--on-m);text-transform:uppercase;
  letter-spacing:.04em;padding:var(--s1) 0;position:relative;
}
.elementor .hdr__links a{
  font:600 .8125rem/1 var(--f-l)!important;
  color:var(--on-m)!important;
  text-transform:uppercase!important;
  letter-spacing:.04em!important;
}
.hdr__links a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;
  background:var(--pri-ctr);transition:width var(--dur) var(--ease);border-radius:1px;
}
.hdr__links a:hover{color:var(--on)}
.hdr__links a:hover::after,.hdr__links a.on::after{width:100%}
.hdr__links a.on{color:var(--pri-ctr)}
.elementor .hdr__links a:hover{color:var(--on)!important}
.elementor .hdr__links a.on{color:var(--pri-ctr)!important}

/* ── Mega Menu ── */
.hdr__mega-wrap{position:static}
.hdr__chev{width:10px;height:10px;vertical-align:middle;margin-left:3px;transition:transform var(--dur) var(--ease)}
/* Invisible bridge — keeps hover alive while cursor moves from link to dropdown */
.hdr__mega-wrap > a::before{
  content:'';position:absolute;top:100%;left:-30px;right:-30px;height:50px;
}
.hdr__mega-wrap:hover .hdr__chev,
.hdr__mega-wrap:focus-within .hdr__chev{transform:rotate(180deg)}

.mega{
  position:absolute;top:100%;left:0;right:0;
  padding-top:0;
  z-index:100;
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(6px);
  transition:opacity .22s var(--ease), visibility .22s, transform .22s var(--ease);
  filter:drop-shadow(0 16px 48px rgba(0,83,166,.10)) drop-shadow(0 4px 14px rgba(0,83,166,.06));
}
.hdr__mega-wrap:hover .mega,
.hdr__mega-wrap:focus-within .mega{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translateY(0);
}
/* Kill inherited underline from .hdr__links a::after */
.mega a::after{display:none !important}

.mega__grid{
  background:var(--sf-card);
  border-radius:var(--r-lg) var(--r-lg) 0 0;
  padding:var(--s10) var(--s10) var(--s6);
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:var(--s8);position:relative;
}
/* Signature gradient accent stripe */
.mega__grid::before{
  content:'';position:absolute;top:0;left:var(--s8);right:var(--s8);
  height:3px;background:var(--grad);border-radius:0 0 3px 3px;
}

.mega__col{display:flex;flex-direction:column;gap:2px;padding-bottom:var(--s4)}
.mega__cat{
  font:700 .6875rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.06em;
  color:var(--pri);padding-bottom:8px;margin-bottom:4px;
  display:flex;align-items:center;gap:7px;
}
.mega__cat::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--grad);flex-shrink:0;
}

.mega__col > a{
  font:600 .875rem/1.5 var(--f-b);color:var(--on);
  text-decoration:none;padding:6px 10px;margin:0 -10px;border-radius:6px;
  transition:all .12s var(--ease);
  text-transform:none;letter-spacing:0;
}
.mega__col > a:hover{color:var(--pri);background:var(--sf)}
.mega__col > a.mega__more{
  font:600 .75rem/1.5 var(--f-l);color:var(--pri-ctr);margin-top:2px;
}
.mega__col > a.mega__more:hover{color:var(--pri)}

.mega__grid--2cat + .mega__foot{
  background:none;
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  padding:0;text-align:center;
  pointer-events:none;z-index:2;
  border-radius:0;width:auto;
}
.mega__grid--2cat + .mega__foot a{
  display:inline-flex;align-items:center;gap:8px;
  font:700 .75rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.06em;
  color:#fff;background:var(--pri-ctr);
  padding:10px 24px;border-radius:var(--r-pill);
  text-decoration:none;
  box-shadow:0 4px 16px rgba(0,16,40,.4);
  transition:all var(--dur) var(--ease);
  pointer-events:auto;
}
.mega__grid--2cat + .mega__foot a:hover{box-shadow:0 6px 24px rgba(0,16,40,.5);transform:translateY(-1px)}
.mega__foot a svg{width:12px;height:12px}

/* ── Two-category mega menu ── */
.mega__grid--2cat{grid-template-columns:2fr 3fr;gap:0;padding:0;background:none;border-radius:var(--r-lg);overflow:hidden}

/* ========== Netlify-style 2-zone mega (light, gradient stripe, hover pills) ========== */
.mega__grid--netlify{
  background:var(--sf-card);
  border-radius:var(--r-lg) var(--r-lg) 0 0;
  padding:var(--s8) var(--s10) var(--s6);
  display:grid;grid-template-columns:1fr 1.4fr;gap:var(--s10);
  position:relative;
}
.mega__grid--netlify::before{
  content:'';position:absolute;top:0;left:var(--s8);right:var(--s8);
  height:3px;background:var(--grad);border-radius:0 0 3px 3px;
}
.mega__grid--netlify .mega__zone{padding:0;background:none !important;overflow:visible}
.mega__grid--netlify .mega__zone::before,
.mega__grid--netlify .mega__zone::after{display:none}
.mega__grid--netlify .mega__zone-head{
  margin-bottom:var(--s5);padding-bottom:var(--s4);
  border-bottom:1px solid rgba(0,83,166,.10);
}
.mega__grid--netlify .mega__zone-title{font:800 1rem/1.2 var(--f-d);color:var(--on) !important}
.mega__grid--netlify .mega__zone-sub{
  font:500 .6875rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.08em;
  color:var(--on-m) !important;margin-top:6px;
}
.mega__grid--netlify .mega__zone-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
.mega__grid--netlify .mega__col{display:flex;flex-direction:column;gap:2px}
.mega__grid--netlify .mega__cat{
  font:700 .6875rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.06em;
  color:var(--pri) !important;padding-bottom:8px;margin-bottom:4px;
  display:flex;align-items:center;gap:7px;
}
.mega__grid--netlify .mega__cat::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--grad);flex-shrink:0;
}
.mega__grid--netlify .mega__col > a{
  font:400 .8125rem/1.5 var(--f-b);color:var(--on-m) !important;
  background:none !important;padding:5px 10px;margin:0 -10px;
  border-radius:6px;text-decoration:none;
  transition:all .12s var(--ease);
}
.mega__grid--netlify .mega__col > a:hover{
  color:var(--pri) !important;background:var(--sf) !important;
}
.mega__grid--netlify + .mega__foot{
  background:var(--sf);border-radius:0 0 var(--r-lg) var(--r-lg);
  padding:var(--s5) var(--s10);text-align:center;
}
.mega__grid--netlify + .mega__foot a{
  display:inline-flex;align-items:center;gap:8px;
  font:700 .75rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.06em;
  color:#fff !important;background:var(--grad);
  padding:10px 24px;border-radius:var(--r-pill);
  text-decoration:none;
  box-shadow:0 4px 14px rgba(0,83,166,.18);
  transition:all .22s var(--ease);
}
.mega__grid--netlify + .mega__foot a:hover{
  box-shadow:0 6px 20px rgba(0,83,166,.28);transform:translateY(-1px);
}
.mega__grid--2cat::before{display:none}

/* Zones — shared */
.mega__zone{padding:var(--s12) var(--s12) 80px;position:relative;overflow:hidden}

/* Left zone — deep navy gradient */
.mega__zone:first-child{background:linear-gradient(165deg,#001028 0%,#001E50 30%,#003070 65%,#0053A6 100%)}
.mega__zone:first-child::before{content:'';position:absolute;top:-40px;right:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(4,107,210,.20) 0%,transparent 65%);pointer-events:none}
.mega__zone:first-child::after{content:'';position:absolute;bottom:-50px;left:-30px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(100,170,255,.10) 0%,transparent 65%);pointer-events:none}

/* Right zone — site surface with blue glow */
.mega__zone:last-child{background:var(--sf-low)}
.mega__zone:last-child::before{content:'';position:absolute;top:-40px;right:-40px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(4,107,210,.07) 0%,transparent 60%);pointer-events:none}
.mega__zone:last-child::after{content:'';position:absolute;bottom:-40px;left:30px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(0,83,166,.05) 0%,transparent 60%);pointer-events:none}

/* Zone headers */
.mega__zone-head{margin-bottom:var(--s8)}
.mega__zone-title{font:800 1rem/1.2 var(--f-d);color:var(--pri)}
.mega__zone:first-child .mega__zone-title{color:#fff}
.mega__zone-sub{font:500 .625rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.1em;color:var(--on-m);margin-top:8px}
.mega__zone:first-child .mega__zone-sub{color:rgba(255,255,255,.4)}

/* Industry links (left zone, dark bg) */
.mega__zone-links{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mega__zone-links a{
  font:600 .8125rem/1 var(--f-l);color:rgba(255,255,255,.9);
  text-decoration:none;padding:10px 14px;border-radius:8px;
  background:rgba(255,255,255,.06);
  transition:all .18s var(--ease);
  text-transform:none;letter-spacing:0;
}
.mega__zone-links a:hover{color:#fff;background:rgba(255,255,255,.14)}
.mega__zone-links a::after{display:none !important}

/* Specialist columns (right zone) */
.mega__zone-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s8)}
.mega__zone-cols .mega__col{gap:6px}
.mega__zone-cols .mega__cat{font:700 .625rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.08em;color:var(--pri);padding-bottom:10px;margin-bottom:6px}
.mega__zone-cols .mega__col > a{
  font:600 .8125rem/1.5 var(--f-b);color:var(--on);
  padding:8px 14px;margin:0;border-radius:var(--r-md);
  background:var(--sf-card);
  text-transform:none;letter-spacing:0;
  box-shadow:var(--sh-xs);
  transition:all .18s var(--ease);
}
.mega__zone-cols .mega__col > a:hover{
  background:var(--pri-ctr);color:#fff;
  box-shadow:0 4px 12px rgba(0,83,166,.22);
  transform:translateY(-1px);
}

.hdr__ph{
  font:600 .8125rem/1 var(--f-l);color:var(--on);
  display:flex;align-items:center;gap:6px;
  white-space:nowrap;
}
.elementor .hdr__ph{font:600 .8125rem/1 var(--f-l)!important;color:var(--on)!important}
.hdr__ph svg{color:var(--pri);width:15px;height:15px;fill:currentColor}

/* Logo image in mobile drawer inherits same sizing */
.mob-drawer .hdr__logo-img{height:32px!important;width:auto!important;max-width:none!important}

/* ── Mobile Drawer (slide-in, per Kimi pattern) ── */
.mob-overlay{position:fixed;inset:0;background:rgba(23,28,32,.45);z-index:40;opacity:0;visibility:hidden;transition:all .25s ease-out}
.mob-overlay.vis{opacity:1;visibility:visible}
.mob-drawer{position:fixed;top:0;right:0;bottom:0;width:300px;background:var(--sf);z-index:50;padding:var(--s6);display:flex;flex-direction:column;gap:var(--s4);transform:translateX(100%);transition:transform .3s ease-out;overflow-y:auto}
.mob-drawer.open{transform:translateX(0)}
.mob-drawer__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s6)}
.mob-drawer__close{background:none;border:none;font-size:1.75rem;color:var(--on);cursor:pointer;line-height:1;padding:var(--s2)}
.mob-drawer__nav{display:flex;flex-direction:column;gap:0}
.mob-drawer__nav a{font:600 1rem/1 var(--f-d);color:var(--on);padding:var(--s4) 0;box-shadow:0 1px 0 var(--ol)}
.mob-drawer__nav a.on{color:var(--pri-ctr)}
.mob-drawer__ph{font:600 .875rem/1 var(--f-l);color:var(--pri-ctr);display:flex;align-items:center;gap:6px;margin-top:var(--s4)}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--s2);
  font:700 .8125rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.06em;
  border:none;cursor:pointer;border-radius:var(--r-pill);
  transition:all var(--dur) var(--ease);text-decoration:none;
}
.btn svg{width:14px;height:14px;flex-shrink:0}

.btn--pri{
  background:var(--grad);color:#fff;padding:13px 28px;
  box-shadow:0 4px 14px rgba(0,83,166,.2);
  position:relative;overflow:hidden;
}
.btn.btn--pri{color:#fff!important}
.btn--pri::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 50%);
  pointer-events:none;
}
.btn--pri:hover{transform:scale(1.03) translateY(-2px);box-shadow:0 8px 28px rgba(0,83,166,.28),0 0 20px rgba(4,107,210,.1)}
.btn--pri:active{transform:scale(.97)}

.btn--ghost{
  background:transparent;color:var(--pri);padding:12px 27px;
  border:1px solid var(--ol);border-color:rgba(224,227,231,.4);
}
.btn--ghost:hover{background:var(--pri-dim);border-color:rgba(0,83,166,.15)}

.btn--amber{background:var(--amber);color:#fff;padding:13px 28px;box-shadow:0 4px 12px rgba(245,158,11,.2)}
.btn.btn--amber{color:#fff!important}
.btn--amber:hover{background:var(--amber-h);transform:scale(1.02) translateY(-1px)}

.btn--lg{padding:15px 34px;font-size:.875rem}
.btn--sm{padding:9px 20px;font-size:.75rem}
.hdr .btn--nav{padding:10px 22px;white-space:nowrap}
.btn--full{width:100%;justify-content:center}

/* ── Mobile Toggle ── */
.mob{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px;flex-direction:column;justify-content:center;align-items:center;z-index:1001;position:relative}
.mob span{display:block;width:20px;height:2px;background:var(--on);transition:all var(--dur) var(--ease)}
.mob span+span{margin-top:5px}
.mob.on span:nth-child(1){transform:rotate(45deg) translate(3px,4px)}
.mob.on span:nth-child(2){opacity:0}
.mob.on span:nth-child(3){transform:rotate(-45deg) translate(4px,-5px)}

.mob-menu{
  display:none;position:fixed;inset:0;background:var(--sf);
  z-index:999;padding:100px var(--s6) var(--s6);flex-direction:column;gap:var(--s2);
}
.mob-menu.open{display:flex}
.mob-menu a{font:600 1.0625rem/1 var(--f-d);color:var(--on);padding:var(--s4) 0}
.mob-menu a+a{box-shadow:0 -1px 0 var(--ol)}
.mob-menu .btn{margin-top:var(--s4)}

/* ==========================================================
   HERO
   ========================================================== */
.hero{padding:96px 0 104px;position:relative;overflow:hidden}.hero--home{
  background:linear-gradient(160deg,var(--sf) 0%,#EBF3FF 35%,#F0F5FF 60%,var(--sf) 100%);
}
.hero--home::before{
  content:'';position:absolute;top:-25%;left:-10%;width:500px;height:500px;
  border-radius:50%;background:radial-gradient(circle,rgba(4,107,210,.05) 0%,transparent 70%);
  pointer-events:none;
}
.hero--home::after{
  content:'';position:absolute;top:-20%;right:-10%;width:650px;height:650px;
  border-radius:50%;background:radial-gradient(circle,rgba(4,107,210,.07) 0%,transparent 65%);
  pointer-events:none;
}
.hero--home .hero__h{font-size:clamp(1.75rem,3.4vw,3rem);line-height:1.12}
.hero--pg{background:var(--sf-low);padding:var(--s16) 0 var(--s20)}

/* Services hero — dark dramatic */
.hero--srv{
  background:linear-gradient(170deg,#001028 0%,#001E50 35%,#003070 65%,#004A99 100%);
  position:relative;overflow:hidden;
}
.hero--srv::before{
  content:'';position:absolute;top:45%;left:50%;
  transform:translate(-50%,-50%);
  width:900px;height:550px;
  background:radial-gradient(ellipse,rgba(4,107,210,.18) 0%,transparent 60%);
  pointer-events:none;
}
.hero--srv::after{
  content:'';position:absolute;top:-25%;right:-8%;
  width:550px;height:550px;border-radius:50%;
  background:rgba(255,255,255,.025);pointer-events:none;
}
.hero--srv .hero__label{color:#93C5FD;background:rgba(147,197,253,.1)}
.hero--srv .hero__h{color:#fff}
.hero--srv .hero__h em{color:#93C5FD}
.hero--srv .hero__p{color:rgba(255,255,255,.55)}
.hero--srv .hero__ghost{border-color:rgba(255,255,255,.18);color:#fff}
.hero--srv .hero__ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3)}

/* Metric strip */
.hero__metrics{
  display:flex;justify-content:center;gap:var(--s10);flex-wrap:wrap;
}
.hero__metric{display:flex;flex-direction:column;align-items:center;gap:4px}
.hero__metric strong{font:800 1.5rem/1 var(--f-d);color:#fff;letter-spacing:-.02em}
.hero__metric span{font:500 .6875rem/1 var(--f-l);color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.04em}
@media(max-width:600px){.hero__metrics{gap:var(--s6)}.hero__metric strong{font-size:1.25rem}}

.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s16);align-items:center}
.hero__grid--c{grid-template-columns:1fr;text-align:center;max-width:740px;margin:0 auto}
.hero__grid--c .hero__p{margin-inline:auto}

.hero__badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(0,83,166,.08);color:var(--pri-ctr);
  padding:7px 16px;border-radius:var(--r-pill);
  font:600 .75rem/1 var(--f-l);letter-spacing:.03em;margin-bottom:var(--s6);
}
.hero__badge svg{width:13px;height:13px}

.hero__h{
  font:800 clamp(2rem,4.5vw,4rem)/1.08 var(--f-d);color:var(--on);
  letter-spacing:-.035em;margin-bottom:var(--s6);
}
.hero__h em{font-style:normal;color:var(--pri-ctr)}

.hero__p{font:400 1.0625rem/1.75 var(--f-b);color:var(--on-m);margin-bottom:var(--s10);max-width:500px}
.hero__p strong{color:var(--on)}

.elementor .hero__h{
  font:800 clamp(2rem,4.5vw,4rem)/1.08 var(--f-d)!important;
  letter-spacing:-.035em!important;
  margin-bottom:var(--s6)!important;
}
.elementor .hero--home .hero__h{
  font-size:clamp(1.75rem,3.4vw,3rem)!important;
  line-height:1.12!important;
}
.elementor .hero__p{
  font:400 1.0625rem/1.75 var(--f-b)!important;
  margin-bottom:var(--s10)!important;
}
.elementor .sec__h{
  font:800 clamp(1.625rem,3.2vw,3rem)/1.12 var(--f-d)!important;
  letter-spacing:-.035em!important;
  margin-bottom:var(--s4)!important;
}
.elementor .sec__p{font:400 1.0625rem/1.75 var(--f-b)!important}

.hero__acts{display:flex;gap:var(--s3);margin-bottom:var(--s10);flex-wrap:wrap}

.hero__trust{display:flex;gap:var(--s4) var(--s8);flex-wrap:wrap}
.hero__trust span{display:flex;align-items:center;gap:6px;font:500 .8125rem/1 var(--f-l);color:var(--on-m)}
.hero__trust-break{flex-basis:100%;height:0;padding:0;margin:0}
.hero__trust svg{color:var(--green);width:15px;height:15px;flex-shrink:0}

/* Hero visual */
.hero__vis{position:relative;display:flex;justify-content:center}
.hero__img{
  width:100%;max-width:520px;aspect-ratio:4/3;
  background:linear-gradient(135deg,#E0ECFF,#C7DBFF);
  border-radius:var(--r-xl);display:grid;place-items:center;
  position:relative;overflow:hidden;
  box-shadow:var(--sh-xl),var(--sh-glow);
  transition:transform .6s ease-out;
}
.hero__img:hover{transform:translateY(-4px) scale(1.005)}
.hero__img img{width:100%;height:100%;object-fit:cover;object-position:center 30%;border-radius:var(--r-xl)}
.hero__img-ph{color:var(--pri);font:600 .875rem/1.4 var(--f-b);text-align:center;padding:var(--s8);opacity:.45}

/* Hero label — base pill style, used on inner pages (services, role pages). */
.hero__label{
  display:inline-block;font:700 .625rem/1 var(--f-l);color:var(--pri-ctr);
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--s5);
  background:rgba(0,83,166,.05);padding:7px 16px;border-radius:var(--r-pill);
}
/* Hero kicker pill — same shape and tint as .sec__tag (used on "All of These. One Person."),
   but with the em emphasis pattern for the question-answer split. */
.hero__kicker{
  display:inline-block;
  font:700 .875rem/1 var(--f-d);color:var(--on);
  letter-spacing:.005em;margin-bottom:var(--s5);
  background:rgba(0,83,166,.05);padding:10px 20px;border-radius:var(--r-pill);
}
.hero__kicker em{font-style:normal;color:var(--pri-ctr)}

/* ── INLINE HERO BOOKING FORM ── */
.hero__book{
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .6s cubic-bezier(.16,1,.3,1),
             opacity .4s ease,
             margin .6s cubic-bezier(.16,1,.3,1);
  margin-top:0;
}
.hero__book.open{
  max-height:600px;opacity:1;margin-top:var(--s8);
}

.hero__book-inner{
  background:var(--sf-card);border-radius:var(--r-lg);
  padding:var(--s8);
  box-shadow:var(--sh-xl),var(--sh-glow);
  position:relative;
  animation:book-glow 3s ease-in-out infinite alternate;
}
@keyframes book-glow{
  0%{box-shadow:var(--sh-xl),0 0 30px rgba(4,107,210,.06)}
  100%{box-shadow:var(--sh-xl),0 0 50px rgba(4,107,210,.12)}
}

.hero__book-head{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--s4);margin-bottom:var(--s6)}
.hero__book-head h3{font:700 1.25rem/1.2 var(--f-d);color:var(--on);margin-bottom:var(--s1)}
.hero__book-head p{font:400 .875rem/1.5 var(--f-b);color:var(--on-m)}
.hero__book-close{
  background:none;border:none;font-size:1.5rem;color:var(--on-m);
  cursor:pointer;line-height:1;padding:var(--s1);border-radius:var(--r-sm);
  transition:color .2s ease,background .2s ease;
}
.hero__book-close:hover{color:var(--on);background:var(--sf-low)}

.hero__book-form{display:flex;flex-direction:column;gap:var(--s4)}
.hero__book-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}
.hero__book-field{display:flex;flex-direction:column;gap:5px}
.hero__book-field label{font:600 .75rem/1 var(--f-l);color:var(--on);text-transform:uppercase;letter-spacing:.03em}
.hero__book-field input,
.hero__book-field select{
  padding:12px 14px;border:none;border-radius:var(--r-md);
  font:400 .9375rem/1.4 var(--f-b);color:var(--on);
  background:var(--sf-low);width:100%;
  transition:all .2s ease;
}
.hero__book-field input:focus,
.hero__book-field select:focus{
  outline:none;background:var(--sf);
  box-shadow:0 0 0 2px rgba(4,107,210,.15),inset 0 -2px 0 var(--pri-ctr);
}
.hero__book-field input::placeholder{color:rgba(87,99,108,.5)}

.hero__book-submit{width:100%;margin-top:var(--s2)}
.hero__book-trust{
  text-align:center;font:500 .75rem/1.4 var(--f-l);color:var(--on-m);
  display:flex;align-items:center;justify-content:center;gap:6px;margin-top:var(--s2);
}
.hero__book-trust svg{color:var(--green)}

/* Success state */
.hero__book-success{
  display:none;text-align:center;padding:var(--s10) var(--s6);
}
.hero__book-success.show{display:block}
.hero__book-success-icon{
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,#DCFCE7,#BBF7D0);
  display:grid;place-items:center;margin:0 auto var(--s5);
  color:#16A34A;
  animation:success-pop .5s cubic-bezier(.16,1,.3,1);
}
@keyframes success-pop{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}
.hero__book-success h3{font:700 1.5rem/1.2 var(--f-d);color:var(--on);margin-bottom:var(--s2)}
.hero__book-success p{font:400 .9375rem/1.6 var(--f-b);color:var(--on-m)}

@media(max-width:640px){
  .hero__book-row{grid-template-columns:1fr}
  .hero__book-inner{padding:var(--s6)}
}

.hero__fl{
  position:absolute;
  background:rgba(255,255,255,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-radius:16px;
  box-shadow:
    0 8px 32px rgba(0,83,166,.10),
    0 2px 8px rgba(0,83,166,.06),
    inset 0 1px 0 rgba(255,255,255,.8),
    0 0 0 1px rgba(0,83,166,.03);
  padding:18px 22px;
  display:flex;align-items:center;gap:14px;
  animation:hfl 4s ease-out 0.5s both;
}
.hero__fl--a{top:8%;right:-8%}
.hero__fl--b{bottom:14%;left:-6%;animation-delay:1s}
.hero__fl-ic{
  width:48px;height:48px;border-radius:14px;
  display:grid;place-items:center;
  position:relative;overflow:hidden;
}
.hero__fl-ic--bl{
  background:var(--grad);color:#fff;
  box-shadow:0 4px 14px rgba(0,83,166,.25),0 0 0 3px rgba(0,83,166,.08);
}
.hero__fl-ic--bl::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 50%);
  border-radius:inherit;pointer-events:none;
}
.hero__fl-ic--am{
  background:linear-gradient(135deg,#F59E0B,#D97706);color:#fff;
  box-shadow:0 4px 14px rgba(245,158,11,.3),0 0 0 3px rgba(245,158,11,.1);
}
.hero__fl-ic--am::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.22) 0%,transparent 50%);
  border-radius:inherit;pointer-events:none;
}
.hero__fl-ic svg{width:24px;height:24px;position:relative;z-index:1}
.hero__fl-tx small{display:block;font:500 .625rem/1.2 var(--f-l);color:var(--on-m);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.hero__fl-tx strong{display:block;font:800 1.0625rem/1.2 var(--f-d);color:var(--on);letter-spacing:-.02em}
@keyframes hfl{0%{opacity:0;transform:translateY(20px) scale(.92)}100%{opacity:1;transform:translateY(0) scale(1)}}

/* ==========================================================
   LOGO MARQUEE
   ========================================================== */
.logos{padding:var(--s12) 0;overflow:hidden}
.logos__lbl{text-align:center;font:500 .75rem/1 var(--f-l);color:var(--on-m);letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--s8);opacity:.6}
.logos__track{display:flex;gap:var(--s16);animation:marq 35s linear infinite;width:max-content}
.logos__track:hover{animation-play-state:paused}
.logos__item{flex-shrink:0;height:28px;display:flex;align-items:center;font:700 .9375rem/1 var(--f-d);color:var(--on);white-space:nowrap;user-select:none;opacity:.18}
.logos__item--img{opacity:1;height:32px}
.logos__item--img img{height:100%;width:auto;max-width:120px;object-fit:contain;filter:grayscale(1);opacity:.35}
@keyframes marq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ==========================================================
   AUDIENCE CARDS
   ========================================================== */
.aud__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}

.aud__card{
  background:var(--sf-card);border-radius:var(--r-lg);padding:var(--s8) var(--s6);
  box-shadow:var(--sh-sm);transition:all var(--dur) ease-out;position:relative;cursor:pointer;
}
.aud__card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r-lg) var(--r-lg) 0 0;
  background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);
}
.aud__card:hover{box-shadow:var(--sh-lg),var(--sh-glow);transform:translateY(-8px)}
.aud__card:hover::after{transform:scaleX(1)}

.aud__ic{
  width:52px;height:52px;border-radius:var(--r-md);
  display:grid;place-items:center;margin-bottom:var(--s5);
}
.aud__ic--1{background:rgba(0,83,166,.07);color:var(--pri-ctr)}
.aud__ic--2{background:rgba(245,158,11,.08);color:var(--amber)}
.aud__ic--3{background:rgba(57,210,192,.1);color:#0D9488}
.aud__ic svg{width:26px;height:26px}

.aud__card h3{font:700 1.1875rem/1.25 var(--f-d);color:var(--on);margin-bottom:var(--s2);letter-spacing:-.015em}
.aud__card>p{font:400 .9375rem/1.65 var(--f-b);color:var(--on-m);margin-bottom:var(--s5)}

.aud__list{display:flex;flex-direction:column;gap:10px}
.aud__list li{display:flex;align-items:flex-start;gap:10px;font:400 .9375rem/1.5 var(--f-b);color:var(--on-m)}
.aud__list svg{flex-shrink:0;color:var(--pri-ctr);margin-top:3px;width:15px;height:15px}

.aud__link{
  display:inline-flex;align-items:center;gap:6px;font:600 .875rem/1 var(--f-l);
  color:var(--pri-ctr);margin-top:var(--s5);letter-spacing:.02em;transition:gap var(--dur) var(--ease);
}
.aud__link:hover{gap:10px}
.aud__link svg{width:14px;height:14px}

/* ==========================================================
   PROCESS (How It Works)
   ========================================================== */
.proc__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s8);position:relative}
.proc__grid::before{
  content:'';position:absolute;top:28px;
  left:calc(16.66% + 28px);right:calc(16.66% + 28px);
  height:2px;background:linear-gradient(90deg,var(--pri-ctr),var(--pri));opacity:.12;
}
.proc__step{text-align:center;position:relative;z-index:1}
.proc__num{
  width:56px;height:56px;border-radius:50%;background:var(--grad);color:#fff;
  display:grid;place-items:center;font:800 1.25rem/1 var(--f-d);
  margin:0 auto var(--s3);
  box-shadow:0 6px 20px rgba(0,83,166,.18),0 0 0 6px rgba(4,107,210,.06);
}
.proc__time{
  display:block;
  font:600 .6875rem/1 var(--f-l);color:var(--pri-ctr);
  text-transform:uppercase;letter-spacing:.06em;
  margin-bottom:var(--s4);
}
.proc__step h3{font:700 1.0625rem/1.35 var(--f-d);color:var(--on);margin-bottom:var(--s2);letter-spacing:-.01em}
.proc__step p{font:400 .8125rem/1.65 var(--f-b);color:var(--on-m);max-width:280px;margin:0 auto}
.proc__cta{text-align:center;margin-top:var(--s10)}

/* ==========================================================
   SERVICES GRID
   ========================================================== */
.srv__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s5)}

.srv__card{
  background:var(--sf-card);border-radius:var(--r-lg);padding:var(--s6);
  text-align:center;box-shadow:var(--sh-xs);transition:all var(--dur) ease-out;cursor:pointer;
}
.srv__card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.srv__ic{
  width:48px;height:48px;border-radius:var(--r-md);background:rgba(0,83,166,.06);
  color:var(--pri-ctr);display:grid;place-items:center;margin:0 auto var(--s3);
}
.srv__ic svg{width:24px;height:24px}
.srv__card h3{font:600 .9375rem/1.3 var(--f-d);color:var(--on);margin-bottom:var(--s1)}
.srv__card p{font:400 .8125rem/1.5 var(--f-b);color:var(--on-m)}

/* ==========================================================
   WHY RIVCO (Dark section)
   ========================================================== */
.why__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
/* Ambient light — blue-tinted per brand bible */
.sec--heavenly::before{
  content:'';position:absolute;top:-20%;left:50%;transform:translateX(-50%);
  width:100%;height:120%;
  background:
    radial-gradient(ellipse 600px 700px at 50% 10%,rgba(4,107,210,.1) 0%,rgba(4,107,210,.03) 40%,transparent 60%),
    radial-gradient(ellipse 200px 400px at 25% 15%,rgba(4,107,210,.06) 0%,transparent 55%),
    radial-gradient(ellipse 200px 400px at 75% 15%,rgba(4,107,210,.06) 0%,transparent 55%);
  pointer-events:none;
}

.why__card{
  background:rgba(0,0,0,.02);border-radius:var(--r-lg);padding:var(--s8);
  transition:all var(--dur) cubic-bezier(.25,.46,.45,.94);cursor:default;
  position:relative;border:none;
  box-shadow:0 4px 12px rgba(245,158,11,.03),0 0 16px rgba(245,158,11,.02);
}
.why__card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(135deg,#171C20,#B45309 20%,#F59E0B 40%,#FDE68A 55%,#F59E0B 70%,#B45309 85%,#171C20);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;opacity:.35;transition:opacity var(--dur) ease;
}
.why__card:hover{
  background:rgba(0,12,32,.45);transform:translateY(-4px);
  box-shadow:0 12px 36px rgba(245,158,11,.08),0 0 40px rgba(245,158,11,.05);
}
.why__card:hover::before{opacity:.8}
.why__q{font:700 1.0625rem/1.4 var(--f-d);color:#fff;margin-bottom:var(--s3);display:flex;align-items:flex-start;gap:10px}
.why__q svg{flex-shrink:0;color:var(--amber);margin-top:2px;width:16px;height:16px}
.why__a{font:400 .9375rem/1.65 var(--f-b);color:rgba(255,255,255,.55);padding-left:26px}

/* ==========================================================
   STATS
   ========================================================== */
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s8);text-align:center}
.stats__num{font:800 3rem/1 var(--f-d);margin-bottom:var(--s2);letter-spacing:-.03em;text-shadow:0 2px 4px rgba(0,0,0,.1)}
.stats__lbl{font:500 .6875rem/1 var(--f-l);opacity:.7;text-transform:uppercase;letter-spacing:.06em}

/* ==========================================================
   COMPARISON — Card-based "vs" layout
   ========================================================== */
.vs__grid{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:var(--s4);align-items:start}

.vs__card{
  background:var(--sf-card);border-radius:var(--r-lg);padding:var(--s8) var(--s6);
  box-shadow:var(--sh-md);transition:all .5s cubic-bezier(.25,.46,.45,.94);
  position:relative;overflow:hidden;
  border:1px solid rgba(0,83,166,.04);
}
.vs__card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--sf-low);border-radius:var(--r-lg) var(--r-lg) 0 0;
}
.vs__card:hover{box-shadow:var(--sh-lg),var(--sh-glow);transform:translateY(-4px)}

/* Hero card (Rivco — center, dark gradient) */
.vs__card--hero{
  background:linear-gradient(165deg,#001E50 0%,#003070 50%,#0053A6 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 16px 48px rgba(4,107,210,.2),0 0 40px rgba(4,107,210,.06);
  padding:var(--s10) var(--s6);z-index:2;
  overflow:visible;
}
.vs__card--hero::before{display:none}
.vs__card--hero:hover{
  box-shadow:0 24px 64px rgba(4,107,210,.28),0 0 50px rgba(4,107,210,.1);
  transform:translateY(-6px);
}

.vs__card-badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--amber);color:#fff;padding:6px 20px;border-radius:var(--r-pill);
  font:700 .6875rem/1 var(--f-l);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;
  box-shadow:0 4px 16px rgba(245,158,11,.3);
}

.vs__card-head{margin-bottom:var(--s5);padding-bottom:var(--s5);border-bottom:1px solid var(--ol)}
.vs__card--hero .vs__card-head{border-bottom-color:rgba(255,255,255,.07)}
.vs__card-label{font:600 .625rem/1 var(--f-l);color:var(--on-m);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--s2)}
.vs__card--hero .vs__card-label{color:rgba(255,255,255,.45)}
.vs__card-head h3{font:800 1.25rem/1.2 var(--f-d);color:var(--on);margin-bottom:var(--s2);letter-spacing:-.02em}
.vs__card--hero .vs__card-head h3{color:#fff}
.vs__card-price{font:800 1.125rem/1 var(--f-d);color:var(--on)}
.vs__card-price span{font:400 .75rem/1 var(--f-b);color:var(--on-m);margin-left:4px}
.vs__card--hero .vs__card-price{color:#fff}
.vs__card--hero .vs__card-price span{color:rgba(255,255,255,.4)}

/* Feature list */
.vs__list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:var(--s6)}
.vs__list li{display:flex;align-items:center;gap:var(--s2);font:400 .8125rem/1.4 var(--f-b);color:var(--on-m)}

.vs__list-y svg{color:var(--pri-ctr);flex-shrink:0;width:14px;height:14px}
.vs__list-n{opacity:.45;text-decoration:line-through;text-decoration-color:rgba(0,0,0,.15)}
.vs__list-n svg{color:var(--on-m);flex-shrink:0;opacity:.4;width:14px;height:14px}
.vs__list-m{opacity:.5;font-style:italic}

/* Rivco list — on dark */
.vs__card--hero .vs__list li{font-weight:500;color:rgba(255,255,255,.75)}
.vs__card--hero .vs__list-y svg{color:#60A5FA}

/* Verdict bar */
.vs__verdict{
  font:600 .6875rem/1 var(--f-l);text-align:center;padding:10px var(--s4);
  border-radius:var(--r-md);letter-spacing:.03em;text-transform:uppercase;
}
.vs__verdict--warn{background:var(--sf-low);color:var(--on-m)}

/* CTA in hero card */
.vs__cta{width:100%;margin-top:auto}

/* Responsive */
@media(max-width:768px){
  .vs__grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .vs__card--hero{order:-1}
}

/* ==========================================================
   PRICING
   ========================================================== */
.price__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s6);max-width:880px;margin:0 auto}

.price__card{
  background:var(--sf-card);border-radius:var(--r-lg);padding:var(--s12) var(--s8);
  position:relative;box-shadow:var(--sh-md);transition:all .4s ease-out;
  border:1px solid rgba(0,83,166,.04);
}
.price__card:hover{box-shadow:var(--sh-xl),var(--sh-glow);transform:translateY(-6px)}

/* Popular — dark gradient card */
.price__card--pop{
  background:linear-gradient(165deg,#001E50 0%,#003070 50%,#0053A6 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 16px 48px rgba(4,107,210,.2),0 0 40px rgba(4,107,210,.06);
  transform:translateY(-6px);
}
.price__card--pop:hover{
  box-shadow:0 24px 64px rgba(4,107,210,.28),0 0 50px rgba(4,107,210,.1);
  transform:translateY(-10px);
}
.price__card--pop::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,rgba(57,210,192,.5) 30%,rgba(4,107,210,.6) 70%,transparent);
  border-radius:var(--r-lg) var(--r-lg) 0 0;
}
.price__card--pop .price__name{color:rgba(255,255,255,.55)}
.price__card--pop .price__desc{color:rgba(255,255,255,.4)}
.price__card--pop .price__amt strong{color:#fff}
.price__card--pop .price__amt span{color:rgba(255,255,255,.45)}
.price__card--pop .price__rate{color:#93C5FD}
.price__card--pop .price__sep{background:rgba(255,255,255,.07)}
.price__card--pop .price__list li{color:rgba(255,255,255,.55)}
.price__card--pop .price__list li strong{color:#fff}
.price__card--pop .price__list svg{color:#60A5FA}

.price__badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--amber);
  color:#fff;padding:6px 20px;border-radius:var(--r-pill);
  font:700 .6875rem/1 var(--f-l);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;
  box-shadow:0 4px 16px rgba(245,158,11,.3);
}
.price__name{font:700 .9375rem/1 var(--f-l);color:var(--on);margin-bottom:var(--s1);text-transform:uppercase;letter-spacing:.06em}
.price__desc{font:400 .8125rem/1.5 var(--f-b);color:var(--on-m);margin-bottom:var(--s5)}
.price__amt{display:flex;align-items:baseline;gap:4px;margin-bottom:var(--s1)}
.price__amt strong{font:800 2.75rem/1 var(--f-d);color:var(--on);letter-spacing:-.03em}
.price__amt span{font:500 .9375rem/1 var(--f-b);color:var(--on-m)}
.price__rate{
  font:600 .75rem/1 var(--f-l);color:var(--pri-ctr);
  letter-spacing:.02em;margin-bottom:var(--s8);
}

.price__sep{height:1px;background:var(--ol);margin-bottom:var(--s6)}

.price__list{display:flex;flex-direction:column;gap:14px;margin-bottom:var(--s10)}
.price__list li{display:flex;align-items:flex-start;gap:10px;font:400 .875rem/1.5 var(--f-b);color:var(--on-m)}
.price__list li strong{font-weight:600;color:var(--on)}
.price__list svg{flex-shrink:0;color:var(--pri-ctr);margin-top:2px;width:15px;height:15px}
.price__list .price__list-head{
  font:700 .6875rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.14em;
  padding-bottom:12px;margin-bottom:4px;border-bottom:1px solid rgba(255,255,255,.1);
  justify-content:flex-start;gap:8px;
}
.price__card--pop .price__list .price__list-head span{color:#FBBF24}
.price__list .price__list-head::before{
  content:'';display:inline-block;width:14px;height:2px;background:#FBBF24;margin-right:4px;
  align-self:center;border-radius:2px;
}

.price__guar{
  text-align:center;margin-top:var(--s10);font:500 .8125rem/1.4 var(--f-l);
  color:var(--on-m);display:flex;align-items:center;justify-content:center;gap:var(--s2);
  background:rgba(34,197,94,.04);padding:var(--s3) var(--s5);
  border-radius:var(--r-pill);max-width:max-content;margin-inline:auto;
}
.price__guar svg{color:var(--green);width:15px;height:15px}

/* Part-Time anchor styling (de-emphasized but readable) */
.price__card--anchor{background:var(--sf-low)}
.price__card--anchor .price__list li{font-size:.8125rem}
.price__list-n{color:rgba(87,99,108,.65);text-decoration:line-through}
.price__list-n svg{color:rgba(87,99,108,.55)}
.price__cta--anchor{opacity:.85}
.price__note{
  text-align:center;font:400 italic .75rem/1.4 var(--f-b);color:var(--on-m);
  margin-top:var(--s3);
}

/* Full-Time: added savings callout */
.price__save{
  background:rgba(34,197,94,.08);
  color:var(--on);border:1px solid rgba(34,197,94,.2);
  padding:8px 12px;border-radius:6px;
  font:500 .75rem/1.4 var(--f-b);text-align:center;
  margin:var(--s3) 0;
}
.price__save strong{font-weight:700;color:#15803D}
.price__card--pop .price__save{
  background:rgba(46,213,115,.14);
  color:#fff;border-color:rgba(46,213,115,.35);
}
.price__card--pop .price__save strong{color:#2ED573}

/* Promoted 3-column guarantee row */
.price__guar-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4);
  margin-top:var(--s10);padding:var(--s5) var(--s6);
  background:linear-gradient(135deg,rgba(0,83,166,.03),rgba(34,197,94,.03));
  border-radius:var(--r-lg);border:1px solid rgba(0,83,166,.06);
}
.price__guar-item{display:flex;align-items:flex-start;gap:var(--s3);padding:0 var(--s2)}
.price__guar-item svg{color:var(--pri-ctr);flex-shrink:0;margin-top:3px;width:18px;height:18px}
.price__guar-item strong{
  display:block;font:700 .875rem/1.3 var(--f-d);color:var(--on);letter-spacing:-.01em;margin-bottom:2px;
}
.price__guar-item span{font:400 .75rem/1.4 var(--f-b);color:var(--on-m)}
@media(max-width:720px){
  .price__guar-row{grid-template-columns:1fr;gap:var(--s3);padding:var(--s4)}
}

/* ==========================================================
   VIDEO TESTIMONIALS
   ========================================================== */

/* ── Floating pill capsules background ── */
.sec--pills{position:relative;overflow:hidden}
.sec--pills .ctr{position:relative;z-index:1}
.sec--pills::before,.sec--pills::after{
  content:'';position:absolute;border-radius:9999px;
  background:linear-gradient(135deg,rgba(4,107,210,.06),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.03);
  pointer-events:none;
  animation:pillFloat 20s ease-in-out infinite;
}
.sec--pills::before{
  width:220px;height:70px;top:12%;left:-40px;
  transform:rotate(-15deg);
  animation-delay:0s;
}
.sec--pills::after{
  width:160px;height:50px;bottom:18%;right:-30px;
  transform:rotate(20deg);
  animation-delay:-7s;
}
.sec--pills .sec__top::before,.sec--pills .sec__top::after{
  content:'';position:absolute;border-radius:9999px;
  background:linear-gradient(135deg,rgba(4,107,210,.04),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.02);
  pointer-events:none;
  animation:pillFloat 20s ease-in-out infinite;
}
.sec--pills .sec__top::before{
  width:120px;height:38px;top:-60px;right:15%;
  transform:rotate(35deg);
  animation-delay:-4s;
}
.sec--pills .sec__top::after{
  width:180px;height:55px;bottom:-100px;left:8%;
  transform:rotate(-25deg);
  animation-delay:-11s;
}
.sec--pills .vtm__row::before,.sec--pills .vtm__row::after{
  content:'';position:absolute;border-radius:9999px;
  background:linear-gradient(135deg,rgba(4,107,210,.05),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.02);
  pointer-events:none;
  animation:pillFloat 20s ease-in-out infinite;
}
.sec--pills .vtm__row::before{
  width:140px;height:44px;top:-80px;right:5%;
  transform:rotate(-10deg);
  animation-delay:-15s;
}
.sec--pills .vtm__row::after{
  width:100px;height:32px;bottom:-50px;left:20%;
  transform:rotate(45deg);
  animation-delay:-9s;
}
@keyframes pillFloat{
  0%,100%{transform:rotate(var(--pill-r,0deg)) translateY(0)}
  50%{transform:rotate(var(--pill-r,0deg)) translateY(-15px)}
}

/* ── Shared play button ── */
.vtm__play{
  position:absolute;top:50%;left:50%;z-index:2;
  transform:translate(-50%,-50%);
  width:64px;height:64px;border-radius:50%;
  background:rgba(255,255,255,.12);backdrop-filter:blur(16px);
  border:2px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all .5s cubic-bezier(.16,1,.3,1);
}
.vtm__play svg{margin-left:3px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}
.vtm__play::before{
  content:'';position:absolute;inset:-8px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.15);
  animation:vtm-pulse 3s ease-out infinite;
}
.vtm__play::after{
  content:'';position:absolute;inset:-16px;border-radius:50%;
  border:1px solid rgba(255,255,255,.06);
  animation:vtm-pulse 3s ease-out .8s infinite;
}
@keyframes vtm-pulse{
  0%{transform:scale(1);opacity:.5}
  70%{transform:scale(1.25);opacity:0}
  100%{transform:scale(1.25);opacity:0}
}
/* Shared duration pill */
.vtm__dur{
  position:absolute;bottom:14px;right:16px;z-index:2;
  font:600 .6875rem/1 var(--f-l);color:rgba(255,255,255,.85);
  background:rgba(0,0,0,.45);backdrop-filter:blur(8px);
  padding:5px 12px;border-radius:9999px;letter-spacing:.04em;
}
.vtm__name{font:600 .875rem/1.3 var(--f-d);color:#fff}
.vtm__role{font:400 .75rem/1.3 var(--f-b);color:rgba(255,255,255,.35)}

/* ── Cinematic hero video ── */
.vtm__hero{margin-bottom:var(--s8);position:relative}
.vtm__hero::after{
  content:'';position:absolute;inset:0;border-radius:var(--r-xl);padding:2px;
  background:linear-gradient(135deg,#171C20,#0053A6 25%,#046BD2 45%,#93C5FD 55%,#046BD2 75%,#171C20);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;opacity:.2;transition:opacity .5s ease;z-index:2;
}
.vtm__hero:hover::after{opacity:.5}
.vtm__hero-media{
  position:relative;overflow:hidden;
  border-radius:var(--r-xl);cursor:pointer;
}
.vtm__hero-media img{
  width:100%;display:block;object-fit:cover;
  aspect-ratio:2.35/1;filter:brightness(.75);
  transition:transform 1.2s cubic-bezier(.16,1,.3,1),filter .8s ease;
}
.vtm__hero-media:hover img{transform:scale(1.03);filter:brightness(.85)}
/* Cinematic gradient — heavy bottom + left fade */
.vtm__hero-media::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg,transparent 20%,rgba(0,0,0,.75) 100%),
    linear-gradient(90deg,rgba(0,0,0,.4) 0%,transparent 50%);
}
.vtm__hero-media .vtm__play{width:80px;height:80px}
.vtm__hero-media .vtm__play svg{width:28px;height:28px}
.vtm__hero-media:hover .vtm__play{
  background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.4);
  transform:translate(-50%,-50%) scale(1.06);
  box-shadow:0 0 0 16px rgba(255,255,255,.04),0 16px 48px rgba(0,0,0,.4);
}
.vtm__hero-media:hover .vtm__play::before,
.vtm__hero-media:hover .vtm__play::after{animation:none;opacity:0}
/* Overlay text on the image */
.vtm__hero-overlay{
  position:absolute;bottom:0;left:0;right:40%;z-index:2;
  padding:0 40px 36px;
}
.vtm__hero-met{
  font:500 .8125rem/1.4 var(--f-l);color:rgba(255,255,255,.5);
  display:flex;align-items:baseline;gap:6px;margin-bottom:10px;
}
.vtm__hero-met strong{
  font:800 2.25rem/1 var(--f-d);color:#93C5FD;letter-spacing:-.03em;
}
.vtm__hero-quote{
  font:italic 400 1.0625rem/1.7 var(--f-q);color:rgba(255,255,255,.8);
  margin:0 0 16px;position:relative;padding-left:20px;
}
.vtm__hero-quote::before{
  content:'';position:absolute;left:0;top:4px;bottom:4px;
  width:3px;border-radius:3px;background:#93C5FD;opacity:.4;
}
.vtm__hero-who{display:flex;align-items:center;gap:8px}
.vtm__hero-who .vtm__name{font-size:.8125rem}
.vtm__hero-who .vtm__role{color:rgba(255,255,255,.4)}
.vtm__hero-who .vtm__name::after{
  content:'\00B7';margin-left:8px;color:rgba(255,255,255,.2);
}

/* ── Three-card row below ── */
.vtm__row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);
}
.vtm__card{
  border-radius:var(--r-xl);overflow:hidden;
  background:rgba(0,0,0,.15);
  border:none;
  transition:all .5s cubic-bezier(.16,1,.3,1);
  display:flex;flex-direction:column;
  position:relative;
  box-shadow:0 4px 12px rgba(0,83,166,.03),0 0 16px rgba(4,107,210,.02);
}
.vtm__card::after{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(135deg,#171C20,#0053A6 25%,#046BD2 45%,#93C5FD 55%,#046BD2 75%,#171C20);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;opacity:.35;transition:opacity .5s ease;z-index:1;
}
.vtm__card:hover{
  transform:translateY(-6px);
  box-shadow:0 12px 36px rgba(0,83,166,.12),0 0 50px rgba(4,107,210,.1);
}
.vtm__card:hover::after{opacity:.8}
.vtm__card .vtm__thumb{
  position:relative;overflow:hidden;cursor:pointer;
}
.vtm__card .vtm__thumb img{
  width:100%;display:block;object-fit:cover;aspect-ratio:16/9;
  filter:brightness(.75);
  transition:transform .8s cubic-bezier(.16,1,.3,1),filter .5s ease;
}
.vtm__card:hover .vtm__thumb img{transform:scale(1.06);filter:brightness(.9)}
.vtm__card .vtm__thumb::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.5));
}
.vtm__card .vtm__play{width:52px;height:52px}
.vtm__card .vtm__play::after{display:none}
.vtm__card:hover .vtm__play{
  background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.4);
  transform:translate(-50%,-50%) scale(1.1);
}
.vtm__card:hover .vtm__play::before{animation:none;opacity:0}
/* Card body */
.vtm__card-body{
  padding:20px 22px 22px;flex:1;
  display:flex;flex-direction:column;gap:8px;
}
/* Industry tag */
.vtm__card-tag{
  font:600 .625rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.1em;
  color:rgba(147,197,253,.8);
}
/* Stat line — the hero of the card */
.vtm__card-quote{
  font:400 italic .9375rem/1.45 var(--f-q);color:rgba(255,255,255,.92);
  margin:2px 0 4px;letter-spacing:-.005em;
}
.vtm__card-stat{
  font:400 .8125rem/1.4 var(--f-b);color:rgba(255,255,255,.5);
}
.vtm__card-stat strong{
  font:800 1.5rem/1 var(--f-d);color:#93C5FD;
  display:inline-block;margin-right:3px;letter-spacing:-.02em;
}
.vtm__card-body .vtm__name{margin-top:auto;padding-top:12px;border-top:1px solid rgba(255,255,255,.06)}

@media(max-width:768px){
  .vtm__hero-media img{aspect-ratio:16/9}
  .vtm__hero-overlay{right:10%;padding:0 24px 24px}
  .vtm__hero-met strong{font-size:1.5rem}
  .vtm__row{grid-template-columns:1fr}
}
@media(max-width:540px){
  .vtm__hero-overlay{right:0}
  .vtm__hero-quote{font-size:.9375rem}
}

/* ==========================================================
   TESTIMONIALS — commanding, dominant cards
   ========================================================== */
.test__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}

.test__card{
  background:linear-gradient(170deg,#00102E 0%,#001845 40%,#002D6B 100%);
  border-radius:var(--r-lg);
  padding:var(--s10) var(--s8);
  box-shadow:0 16px 48px rgba(0,20,60,.35),0 0 40px rgba(4,107,210,.08);
  border:1px solid rgba(255,255,255,.05);
  transition:all .6s cubic-bezier(.25,.46,.45,.94);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.test__card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 0%,rgba(4,107,210,.12),transparent 60%);
  pointer-events:none;
}
.test__card:hover{
  box-shadow:0 32px 80px rgba(0,20,60,.4),0 0 60px rgba(4,107,210,.12);
  transform:translateY(-8px) scale(1.01);
}
.test__card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,rgba(57,210,192,.6) 30%,rgba(4,107,210,.7) 70%,transparent);
}

/* Metric hero — MASSIVE number at top */
.test__met{
  display:flex;align-items:baseline;gap:var(--s3);
  margin-bottom:var(--s6);padding-bottom:var(--s6);
  border-bottom:1px solid rgba(255,255,255,.06);
  position:relative;
}
.test__met strong{
  font:800 3rem/1 var(--f-d);color:#fff;letter-spacing:-.04em;
  text-shadow:0 0 40px rgba(4,107,210,.3);
}
.test__met span{font:400 .8125rem/1.4 var(--f-b);color:rgba(255,255,255,.5)}

.test__stars{display:flex;gap:3px;margin-bottom:var(--s3)}
.test__stars svg{width:12px;height:12px;flex-shrink:0}

.test__txt{
  font:400 1rem/1.8 var(--f-b);
  color:rgba(255,255,255,.75);
  margin-bottom:var(--s6);flex:1;
}

.test__who{display:flex;align-items:center;gap:var(--s3)}
.test__av{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.12);
  display:grid;place-items:center;font:700 .6875rem/1 var(--f-l);color:#fff;
  flex-shrink:0;letter-spacing:.02em;
}
.test__name{font:600 .875rem/1.3 var(--f-d);color:#fff}
.test__role{font:400 .75rem/1.3 var(--f-b);color:rgba(255,255,255,.45);letter-spacing:.01em}

.test__foot{
  text-align:center;margin-top:var(--s8);
  display:flex;align-items:center;justify-content:center;gap:var(--s2);
  font:500 .75rem/1.4 var(--f-l);color:var(--on-m);letter-spacing:.01em;
}
.test__foot svg{color:var(--pri-ctr);flex-shrink:0}

/* ==========================================================
   FAQ
   ========================================================== */
.faq__list{display:flex;flex-direction:column;gap:0;flex:1;min-width:0}

/* FAQ split layout (questions + sidebar) */
.faq__split{
  display:grid;grid-template-columns:1fr 340px;gap:var(--s10);align-items:start;
}
.faq__side{position:sticky;top:120px}
.faq__side-card{
  background:var(--sf-card);border-radius:var(--r-xl);
  padding:var(--s8);box-shadow:var(--sh-lg),var(--sh-glow);
  display:flex;flex-direction:column;gap:var(--s4);
}
.faq__side-card h3{
  font:700 1.25rem/1.3 var(--f-d);color:var(--on);margin:0;
}
.faq__side-card p{
  font:400 .875rem/1.65 var(--f-b);color:var(--on-m);margin:0;
}
.faq__side-stats{
  display:flex;gap:var(--s4);padding:var(--s4) 0;
  border-top:1px solid var(--ol);border-bottom:1px solid var(--ol);
}
.faq__side-stats>div{
  flex:1;display:flex;flex-direction:column;gap:2px;
}
.faq__side-stats strong{font:800 1.25rem/1 var(--f-d);color:var(--pri)}
.faq__side-stats span{font:500 .6875rem/1.2 var(--f-l);color:var(--on-m);text-transform:uppercase;letter-spacing:.04em}
.faq__side-phone{
  font:600 .8125rem/1 var(--f-l);color:var(--pri-ctr);
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding-top:var(--s2);
  transition:color var(--dur) ease;
}
.faq__side-phone:hover{color:var(--pri)}

@media(max-width:900px){
  .faq__split{grid-template-columns:1fr}
  .faq__side{position:static}
}

.faq__list{counter-reset:faq}
.faq__item{
  transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;
  border-radius:var(--r-lg);
  margin-bottom:6px;
  overflow:hidden;
}
.faq__item:hover{background:rgba(0,83,166,.02)}
.faq__item.on{
  background:var(--sf-card);
  box-shadow:var(--sh-sm);
}
/* Left accent bar on active */
.faq__item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:3px;border-radius:0 3px 3px 0;background:var(--grad);
  transform:scaleY(0);transition:transform .35s cubic-bezier(.16,1,.3,1);
}
.faq__item.on::before{transform:scaleY(1)}

.faq__q{
  display:flex;align-items:center;
  width:100%;padding:16px 18px;background:none;border:none;cursor:pointer;
  text-align:left;font:600 .9375rem/1.4 var(--f-d);color:var(--on);gap:var(--s3);
  letter-spacing:-.01em;transition:color var(--dur) ease;
  counter-increment:faq;
}
.faq__q::before{
  content:counter(faq,decimal-leading-zero);
  font:700 .6875rem/1 var(--f-l);color:var(--pri-ctr);opacity:.25;
  flex-shrink:0;min-width:22px;
  transition:opacity var(--dur) ease;
}
.faq__item.on .faq__q::before{opacity:.7}
.faq__q:hover{color:var(--pri-ctr)}

.faq__chev{
  flex-shrink:0;width:24px;height:24px;margin-left:auto;
  color:var(--pri-ctr);opacity:.2;
  transition:all .4s cubic-bezier(.16,1,.3,1);
}
.faq__q:hover .faq__chev{opacity:.5}
.faq__item.on .faq__chev{
  transform:rotate(180deg);opacity:1;
  color:var(--pri);
}

.faq__a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq__a-in{
  padding:0 18px 18px 45px;
  font:400 .875rem/1.75 var(--f-b);color:var(--on-m);
}

/* ==========================================================
   FINAL CTA
   ========================================================== */
.fcta{
  padding:96px 0;background:linear-gradient(150deg,#003D7A 0%,#0053A6 30%,#046BD2 70%,#0A7BF0 100%);
  color:#fff;text-align:center;position:relative;overflow:hidden;
}
.fcta::before{content:'';position:absolute;top:-30%;right:-10%;width:600px;height:600px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.fcta::after{content:'';position:absolute;bottom:-35%;left:-8%;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,.03);pointer-events:none}

.fcta__form{
  max-width:560px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);
  position:relative;z-index:1;
}
.fcta__input{
  padding:14px 18px;border-radius:var(--r-lg);
  border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.08);
  color:#fff;font:400 .875rem/1.4 var(--f-b);width:100%;
  transition:all var(--dur) var(--ease);
}
.fcta__input::placeholder{color:rgba(255,255,255,.4)}
.fcta__input:focus{outline:none;background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.25)}
.fcta__input--full{grid-column:1/-1}

/* Custom select dropdown */
.fcta__select{position:relative}
.fcta__select-btn{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:14px 18px;border-radius:var(--r-lg);
  border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.08);
  color:#fff;font:400 .875rem/1.4 var(--f-b);cursor:pointer;
  transition:all var(--dur) var(--ease);text-align:left;
}
.fcta__select-btn:hover{background:rgba(255,255,255,.12)}
.fcta__select.open .fcta__select-btn{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.25)}
.fcta__select-val{opacity:.4}
.fcta__select-val.chosen{opacity:1}
.fcta__select-chev{
  flex-shrink:0;opacity:.4;
  transition:transform var(--dur) var(--ease),opacity var(--dur) var(--ease);
}
.fcta__select.open .fcta__select-chev{transform:rotate(180deg);opacity:.7}

.fcta__select-list{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:rgba(0,30,80,.85);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-lg);padding:var(--s1) 0;
  list-style:none;z-index:10;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:all .2s var(--ease);
  box-shadow:0 12px 32px rgba(0,0,0,.3);
}
.fcta__select.open .fcta__select-list{opacity:1;visibility:visible;transform:translateY(0)}
.fcta__select-list li{
  padding:11px 18px;font:600 .875rem/1.4 var(--f-d);
  color:#fff;cursor:pointer;letter-spacing:-.01em;
  transition:all .15s ease;
  text-shadow:0 1px 2px rgba(0,0,0,.3);
}
.fcta__select-list li:hover{background:var(--pri-ctr);color:#fff}

.fcta__submit{
  grid-column:1/-1;background:var(--amber);color:#fff;border:none;
  padding:16px 32px;border-radius:var(--r-pill);font:700 .8125rem/1 var(--f-l);
  text-transform:uppercase;letter-spacing:.06em;cursor:pointer;
  transition:all var(--dur) var(--ease);
}
.fcta__submit:hover{background:var(--amber-h);transform:scale(1.02) translateY(-2px);box-shadow:0 8px 24px rgba(245,158,11,.35),0 0 20px rgba(245,158,11,.15)}

.fcta__trust{
  margin-top:var(--s5);font:500 .6875rem/1 var(--f-l);
  color:rgba(255,255,255,.45);letter-spacing:.02em;
  display:flex;justify-content:center;gap:var(--s6);flex-wrap:wrap;position:relative;z-index:1;
}

.fcta__phone{
  display:block;margin-top:var(--s4);text-align:center;
  font:500 .8125rem/1 var(--f-l);color:rgba(255,255,255,.5);
  letter-spacing:.01em;transition:color var(--dur) ease;
  position:relative;z-index:1;
}
.fcta__phone:hover{color:rgba(255,255,255,.85)}

/* ==========================================================
   FOOTER
   ========================================================== */
.ftr{background:var(--on);color:rgba(255,255,255,.55);padding:var(--s16) 0 var(--s8)}

.ftr__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--s12);margin-bottom:var(--s12)}

.ftr__brand p{font:400 .9375rem/1.65 var(--f-b);margin-top:var(--s3);margin-bottom:0!important;max-width:280px}
.ftr__logo{display:flex;align-items:center;max-width:220px;overflow:hidden}
.ftr__logo-img{height:32px!important;width:auto!important;max-width:180px!important;display:block!important;object-fit:contain!important;filter:brightness(0) invert(1)}
.elementor .ftr .ftr__logo-img{height:32px!important;width:auto!important;max-width:180px!important}

.ftr__heading{font:700 .6875rem/1 var(--f-l);color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--s5)}
.ftr__links{display:flex;flex-direction:column;gap:10px;margin:0!important;padding-left:0!important;list-style:none!important}
.ftr__links a{font:400 .9375rem/1 var(--f-b);color:rgba(255,255,255,.5);transition:color var(--dur) var(--ease)}
.ftr__links a:hover{color:#fff}

.ftr__ci{display:flex;align-items:flex-start;gap:10px;font:400 .9375rem/1.4 var(--f-b);margin-bottom:var(--s4)}
.ftr__ci svg{flex-shrink:0;color:var(--pri-ctr);margin-top:2px;width:15px;height:15px}

.ftr__bot{padding-top:var(--s8);display:flex;justify-content:space-between;align-items:center;font:400 .75rem/1 var(--f-l);color:rgba(255,255,255,.25);box-shadow:0 -1px 0 rgba(255,255,255,.06)}
.ftr__bot strong{color:rgba(255,255,255,.5)}
.ftr__soc{display:flex;gap:var(--s3)}
.ftr__soc a{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.06);display:grid;place-items:center;color:rgba(255,255,255,.4);transition:all var(--dur) var(--ease)}
.ftr__soc a:hover{background:var(--pri-ctr);color:#fff}
.ftr__soc svg{width:14px;height:14px}

/* ==========================================================
   BENTO GRID — "Six Roles. One Person."
   Apple-style modular cards, varied sizes, premium depth
   ========================================================== */
.bento{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.bento__card{
  background:var(--sf-card);border-radius:var(--r-xl);padding:var(--s8);
  box-shadow:var(--sh-sm);transition:all .35s ease-out;cursor:pointer;
  position:relative;overflow:hidden;
}
.bento__card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(0,83,166,.02) 0%,transparent 60%);
  pointer-events:none;transition:opacity .3s ease;opacity:0;
}
.bento__card:hover{box-shadow:var(--sh-lg),var(--sh-glow);transform:translateY(-5px)}
.bento__card:hover::before{opacity:1}

/* Wide card — spans 2 columns */
.bento__card--wide{grid-column:span 2}
.bento__inner{display:flex;gap:var(--s5);align-items:flex-start}

/* Accent variant for the differentiator card */
.bento__card--accent{
  background:linear-gradient(160deg,#EFF6FF 0%,#F8FBFF 40%,var(--sf-card) 100%);
}
.bento__card--accent::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad);border-radius:var(--r-xl) var(--r-xl) 0 0;
}
.bento__card--accent .bento__tags li{background:rgba(0,83,166,.06);color:var(--pri)}

/* Faded number watermark */
.bento__card-num{
  font:800 4.5rem/1 var(--f-d);color:rgba(0,83,166,.035);
  position:absolute;top:12px;right:18px;letter-spacing:-.05em;
  pointer-events:none;
}

/* Icon */
.bento__ic{
  width:52px;height:52px;border-radius:var(--r-lg);
  display:grid;place-items:center;margin-bottom:var(--s4);flex-shrink:0;
}
.bento__inner .bento__ic{margin-bottom:0}
.bento__ic svg{width:26px;height:26px}
.bento__ic--1{background:rgba(0,83,166,.06);color:var(--pri-ctr)}
.bento__ic--2{background:rgba(245,158,11,.06);color:#D97706}
.bento__ic--3{background:rgba(57,210,192,.07);color:#0D9488}
.bento__ic--4{background:rgba(99,102,241,.06);color:#6366F1}
.bento__ic--5{background:rgba(34,197,94,.06);color:#16A34A}
.bento__ic--6{background:rgba(0,83,166,.06);color:var(--pri-ctr)}

.bento__card h3{font:700 1.125rem/1.25 var(--f-d);color:var(--on);margin-bottom:6px;letter-spacing:-.015em}
.bento__card--wide h3{font-size:1.25rem}
.bento__card p{font:400 .875rem/1.65 var(--f-b);color:var(--on-m);margin-bottom:var(--s4)}
.bento__card--wide p{font-size:.9375rem}

/* Skill tags (pill chips) */
.bento__tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto}.bento__tags li{
  font:500 .625rem/1 var(--f-l);color:var(--on-m);
  background:var(--sf-low);padding:5px 10px;border-radius:var(--r-pill);
  letter-spacing:.03em;text-transform:uppercase;
}
.bento__card--accent .bento__tags li{background:rgba(0,83,166,.05);color:var(--pri)}

/* Differentiator callout strip */
.svc__diff{
  margin-top:32px;padding:36px 40px;
  background:linear-gradient(160deg,#EEF4FF 0%,var(--sf-card) 100%);
  border-radius:var(--r-xl);box-shadow:var(--sh-md);
  position:relative;overflow:hidden;
}
.svc__diff::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad);
}
.svc__diff-badge{
  display:inline-flex;align-items:center;gap:6px;
  font:700 .625rem/1 var(--f-l);color:var(--pri);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;
}
.svc__diff-badge svg{color:var(--pri-ctr)}
.svc__diff h3{font:700 1.375rem/1.25 var(--f-d);color:var(--on);margin-bottom:10px;letter-spacing:-.02em}
.svc__diff h3 em{font-style:normal;color:var(--pri-ctr)}
.svc__diff p{font:400 .9375rem/1.7 var(--f-b);color:var(--on-m);max-width:640px}

/* Cost comparison bar */
.svc__cost{
  display:flex;align-items:center;justify-content:center;
  gap:var(--s6);margin-top:28px;padding:20px 28px;
  background:var(--sf-card);border-radius:var(--r-xl);
  box-shadow:var(--sh-sm);flex-wrap:wrap;
}
.svc__cost-vs{font:400 .9375rem/1.4 var(--f-b);color:var(--on-m)}
.svc__cost-vs strong{color:var(--on-m);font-weight:700;text-decoration:line-through;text-decoration-color:var(--red);text-decoration-thickness:2px}
.svc__cost-divider{width:1px;height:28px;background:var(--ol)}
.svc__cost-rivco{font:500 .9375rem/1.4 var(--f-b);color:var(--on)}
.svc__cost-rivco strong{font:800 1.25rem/1 var(--f-d);color:var(--pri-ctr)}

@media(max-width:768px){
  .svc__diff{padding:28px 24px}
  .svc__cost{flex-direction:column;gap:var(--s3);text-align:center}
  .svc__cost-divider{width:40px;height:1px}
}

/* Legacy feat__grid kept for other pages */
/* ==========================================================
   ROLES — dark showcase on homepage
   ========================================================== */
.sec--roles{
  background:linear-gradient(165deg,#001028 0%,#001E50 30%,#003070 65%,#0053A6 100%);
  position:relative;overflow:hidden;
}
.sec--roles::before{
  content:'';position:absolute;top:30%;left:50%;
  transform:translate(-50%,-50%);
  width:1000px;height:600px;
  background:radial-gradient(ellipse,rgba(4,107,210,.15) 0%,transparent 60%);
  pointer-events:none;
}
.sec--roles::after{
  content:'';position:absolute;bottom:-15%;right:-5%;
  width:450px;height:450px;border-radius:50%;
  background:rgba(255,255,255,.02);pointer-events:none;
}

/* 3-col grid */
.roles__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s4);position:relative;z-index:1;
}

/* Card */
.roles__card{
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:var(--r-md);padding:var(--s6) var(--s5);
  border:none;
  box-shadow:0 4px 24px rgba(0,0,0,.12);
  position:relative;
  transition:all .4s cubic-bezier(.25,.46,.45,.94);
  display:flex;flex-direction:column;
}
.roles__card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(135deg,#0053A6,#046BD2 40%,#93C5FD 70%,#046BD2);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;
  opacity:.25;transition:opacity .4s ease;
}
.roles__card:hover::before{opacity:.7}
.roles__card:hover{
  background:rgba(255,255,255,.07);
  box-shadow:0 16px 48px rgba(4,107,210,.25),0 0 40px rgba(4,107,210,.1);
  transform:translateY(-4px);
}

/* Header row: number + title inline */
.roles__head{
  display:flex;align-items:center;gap:var(--s3);
  margin-bottom:var(--s2);
}
.roles__num{
  font:800 1.5rem/1 var(--f-d);color:#fff;opacity:.15;
  letter-spacing:-.04em;flex-shrink:0;
  transition:opacity .4s ease;
}
.roles__card:hover .roles__num{opacity:.35}

.roles__card h3{
  font:600 .875rem/1.35 var(--f-d);color:#fff;
  letter-spacing:-.01em;
  transition:color .4s ease;
}
.roles__card:hover h3{color:#93C5FD}
.roles__card>p{
  font:400 .75rem/1.6 var(--f-b);
  color:rgba(255,255,255,.45);
  transition:color .4s ease;flex:1;
}
.roles__card:hover>p{color:rgba(255,255,255,.65)}

/* Tool tags */
.roles__tools{
  font:500 .5625rem/1 var(--f-l);color:rgba(255,255,255,.25);
  letter-spacing:.03em;text-transform:uppercase;
  padding-top:var(--s3);margin-top:var(--s3);
  border-top:1px solid rgba(255,255,255,.05);
  transition:color .4s ease;
}
.roles__card:hover .roles__tools{color:rgba(255,255,255,.4)}

/* Industry specialization strip */
.roles__diff{
  margin-top:var(--s8);position:relative;z-index:1;
}
.roles__diff-inner{
  background:rgba(255,255,255,.03);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--r-lg);padding:var(--s6) var(--s8);
  text-align:center;
}
.roles__diff-badge{
  display:inline-flex;align-items:center;gap:6px;
  font:600 .6875rem/1 var(--f-l);color:#93C5FD;
  text-transform:uppercase;letter-spacing:.06em;
  margin-bottom:var(--s3);
}
.roles__diff-badge svg{color:#60A5FA}
.roles__diff h3{
  font:700 1.25rem/1.25 var(--f-d);color:#fff;
  letter-spacing:-.02em;margin-bottom:var(--s4);
}
.roles__diff h3 em{font-style:normal;color:#93C5FD}
.roles__tags{display:flex;justify-content:center;gap:var(--s2);flex-wrap:wrap}
.roles__tags span{
  padding:6px 14px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  font:500 .6875rem/1 var(--f-l);color:rgba(255,255,255,.55);
  letter-spacing:.02em;transition:all .3s ease;
}
.roles__tags span:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.15)}

/* Cost comparison */
.roles__cost{
  margin-top:var(--s10);display:inline-flex;align-items:center;
  gap:0;flex-wrap:wrap;position:relative;z-index:1;
  background:rgba(0,0,0,.25);border-radius:var(--r-xl);
  border:1px solid rgba(0,83,166,.06);
  margin-left:auto;margin-right:auto;
}
.roles__cost-vs,.roles__cost-rivco{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:var(--s5) var(--s8);
}
.roles__cost-vs small,.roles__cost-rivco small{
  font:600 .6875rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.1em;
}
.roles__cost-vs small{color:rgba(255,255,255,.5)}
.roles__cost-rivco small{color:rgba(147,197,253,.8)}
.roles__cost-vs strong{
  font:800 1.75rem/1 var(--f-d);color:rgba(255,255,255,.5);text-decoration:line-through;
  text-decoration-color:#D97706;text-decoration-thickness:2px;
}
.roles__cost-line{width:1px;align-self:stretch;background:rgba(255,255,255,.08)}
.roles__cost-rivco strong{font:800 1.75rem/1 var(--f-d);color:#fff}
.roles__cost .btn{margin:0 var(--s5) 0 var(--s2)}

@media(max-width:900px){.roles__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){
  .roles__grid{grid-template-columns:1fr}
  .roles__cost{flex-direction:column;padding:var(--s5);gap:0;width:100%;max-width:320px}
  .roles__cost-vs,.roles__cost-rivco{padding:var(--s4) var(--s5)}
  .roles__cost-line{width:100%;height:1px;align-self:auto}
  .roles__cost .btn{margin:var(--s4) var(--s5) var(--s5)}
}

/* ==========================================================
   SPLIT LAYOUT (text + image, matching original site sections)
   ========================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--s16);align-items:center}
.split--rev{direction:rtl}
.split--rev>*{direction:ltr}
.split__text{display:flex;flex-direction:column}
.split:not(.split--exp) .split__text>.sec__h{position:relative;padding-left:20px}
.split:not(.split--exp) .split__text>.sec__h::before{
  content:'';position:absolute;left:0;top:.15em;bottom:.15em;
  width:3px;border-radius:3px;background:var(--grad);
}
.sec--grad .split__text>.sec__h::before,.sec--dark .split__text>.sec__h::before{
  background:rgba(255,255,255,.25);
}
.split__img{display:flex;justify-content:center;align-items:center}
.split__img img{max-width:100%;height:auto;border-radius:var(--r-xl);box-shadow:var(--sh-xl),var(--sh-glow);transition:transform .5s ease-out}
.split__img img:hover{transform:translateY(-4px) scale(1.005)}

/* ── Expertise Section ── */
.split--exp{align-items:flex-start}
.split--exp .split__img{position:sticky;top:120px;align-self:flex-start}

/* 2×3 card grid within split text */
.exp__cards{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}

.exp__card{
  background:var(--sf-card);border-radius:var(--r-lg);
  padding:var(--s5) var(--s4);box-shadow:var(--sh-sm);
  border:1px solid rgba(0,83,166,.03);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:all .35s ease-out;
}
.exp__card:hover{
  box-shadow:var(--sh-lg),var(--sh-glow);
  transform:translateY(-3px);
  border-color:rgba(0,83,166,.06);
}

/* Gradient top accent on hover */
.exp__card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--pri) 0%,var(--pri-ctr) 100%);
  opacity:0;transition:opacity .35s ease;
}
.exp__card:hover::after{opacity:1}

.exp__card-head{
  display:flex;align-items:baseline;gap:var(--s2);
  margin-bottom:6px;
}
.exp__card-head span{
  font:800 1.125rem/1 var(--f-d);color:var(--pri);opacity:.2;
  letter-spacing:-.03em;flex-shrink:0;
  transition:opacity .35s ease;
}
.exp__card:hover .exp__card-head span{opacity:.45}
.exp__card-head h4{
  font:700 .8125rem/1.3 var(--f-d);color:var(--on);
  letter-spacing:-.01em;transition:color .35s ease;margin:0;
}
.exp__card:hover .exp__card-head h4{color:var(--pri)}

.exp__card>p{
  font:400 .6875rem/1.55 var(--f-b);color:var(--on-m);
  flex:1;margin:0 0 var(--s2);
}

.exp__card-tools{
  font:500 .5rem/1.3 var(--f-l);color:var(--on-m);opacity:.35;
  text-transform:uppercase;letter-spacing:.04em;
  padding-top:6px;
  border-top:1px solid var(--ol);
  transition:opacity .35s ease;
}
.exp__card:hover .exp__card-tools{opacity:.65}

@media(max-width:480px){.exp__cards{grid-template-columns:1fr}}

/* Footer: proof + CTA */
.exp__foot{
  display:flex;align-items:center;gap:var(--s6);flex-wrap:wrap;
  margin-top:var(--s8);
}
.exp__proof{
  display:flex;align-items:center;gap:var(--s2);
  padding:var(--s2) var(--s4);
  background:rgba(0,83,166,.04);border-radius:var(--r-pill);
  font:500 .75rem/1.4 var(--f-l);color:var(--on-m);
  letter-spacing:.01em;
}
.exp__proof svg{color:var(--pri-ctr);flex-shrink:0}
.exp__cta{
  display:inline-flex;align-items:center;gap:6px;
  font:600 .8125rem/1 var(--f-l);color:var(--pri);
  text-decoration:none;letter-spacing:.02em;text-transform:uppercase;
  transition:all .25s ease;
}
.exp__cta:hover{gap:10px;color:var(--pri-ctr)}
.exp__cta svg{transition:transform .25s ease}
.exp__cta:hover svg{transform:translateX(3px)}

/* Visual wrapper — image with floating badges */
.exp__visual{position:relative;display:flex;justify-content:center}
.exp__visual img{
  width:100%;max-width:400px;aspect-ratio:6/7;object-fit:cover;
  border-radius:var(--r-xl);box-shadow:var(--sh-xl),var(--sh-glow);
}
/* Landscape variant for split sections (mail center, realtors) */
.split:not(.split--exp) .exp__visual img{aspect-ratio:4/3;max-width:100%}
/* Decorative accent behind image in industry splits */
.split:not(.split--exp) .exp__visual::before{
  content:'';position:absolute;inset:-12px;
  border-radius:calc(var(--r-xl) + 4px);
  background:var(--grad);opacity:.07;z-index:-1;
  transform:rotate(-2deg);
}
.split--rev .exp__visual::before{transform:rotate(2deg)}

.exp__badge{
  position:absolute;
  background:var(--sf-card);color:var(--on);
  font:600 .6875rem/1 var(--f-l);letter-spacing:.02em;
  padding:7px 14px;border-radius:var(--r-pill);
  box-shadow:var(--sh-md);white-space:nowrap;
  display:flex;align-items:center;gap:6px;
  opacity:0;animation:badge-in .7s cubic-bezier(.16,1,.3,1) forwards;
}
.exp__badge-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--pri-ctr);flex-shrink:0;
}
.exp__badge img{
  width:14px;height:14px;flex-shrink:0;
}
.exp__visual--vid{cursor:pointer}
.exp__visual--vid::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.25) 100%);
  border-radius:inherit;
  transition:background .4s ease;
}
.exp__visual--vid:hover::before{
  background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.35) 100%);
}
.exp__visual--vid .vtm__play{
  width:68px;height:68px;z-index:2;
}
.exp__visual--vid:hover .vtm__play{
  transform:translate(-50%,-50%) scale(1.1);
  background:rgba(255,255,255,.2);
  border-color:rgba(255,255,255,.35);
}
.exp__badge--1{top:6%;left:-8%;animation-delay:.4s}
.exp__badge--2{top:20%;right:-10%;animation-delay:.6s}
.exp__badge--3{top:38%;left:-12%;animation-delay:.5s}
.exp__badge--4{top:56%;right:-8%;animation-delay:.7s}
.exp__badge--5{top:73%;left:-6%;animation-delay:.8s}
.exp__badge--6{bottom:6%;right:-5%;animation-delay:.9s}
@keyframes badge-in{
  0%{opacity:0;transform:scale(.8) translateY(10px)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}

@media(max-width:768px){
  .exp__visual{margin-bottom:var(--s8)}
  .exp__badge{display:none}
  .exp__num{display:none}
  .exp__item+.exp__item::before{left:0}
  .exp__foot{flex-direction:column;align-items:flex-start;gap:var(--s3)}
}

/* Check list (for split sections — mirrors exp__item structure) */
.check-list{display:flex;flex-direction:column;gap:var(--s2)}
.check-list__item{
  display:flex;align-items:flex-start;gap:var(--s4);
  padding:14px 16px;position:relative;border-radius:var(--r-lg);
  transition:all var(--dur) var(--ease);
  background:transparent;
}
.check-list__item:hover{background:var(--sf)}
.check-list__item svg{
  flex-shrink:0;margin-top:3px;
  width:20px;height:20px;
  color:#fff;background:var(--grad);border-radius:50%;padding:3px;
  box-shadow:0 2px 8px rgba(0,83,166,.2);
  transition:transform var(--dur) ease;
}
.check-list__item:hover svg{transform:scale(1.15)}
.check-list__body{flex:1;min-width:0}
.check-list__body strong{
  display:block;font:600 .9375rem/1.35 var(--f-d);color:var(--on);
  margin-bottom:3px;letter-spacing:-.01em;
  transition:color var(--dur) ease;
}
.check-list__item:hover .check-list__body strong{color:var(--pri)}
.check-list__body span{
  display:block;font:400 .8125rem/1.6 var(--f-b);color:var(--on-m);
}

/* ==========================================================
   INDUSTRY SPLIT COMPONENTS (mailbox, real estate)
   ========================================================== */

/* Blue Ocean callout */
.ind__callout{
  color:var(--on-m);font:400 .9375rem/1.7 var(--f-b);
  padding:20px 24px;border-radius:0 var(--r-lg) var(--r-lg) 0;margin-bottom:var(--s6);
  background:rgba(0,83,166,.04);border-left:4px solid var(--pri-ctr);
  box-shadow:var(--sh-sm);
}
.ind__callout strong{
  display:inline;font:700 1rem/1.7 var(--f-d);color:var(--pri);
}

/* 2×2 feature grid */
.ind__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:var(--s6);
}
.ind__card{
  background:var(--sf-card);border-radius:var(--r-lg);padding:16px 18px;
  box-shadow:var(--sh-sm);transition:all var(--dur) var(--ease);
  position:relative;overflow:hidden;
}
.ind__card::before{
  content:'';position:absolute;top:0;left:0;width:3px;height:100%;
  background:var(--grad);opacity:0;transition:opacity var(--dur) ease;
}
.ind__card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.ind__card:hover::before{opacity:1}
.ind__card-num{
  font:800 1.5rem/1 var(--f-d);color:var(--pri);opacity:.12;
  position:absolute;top:10px;right:14px;
}
.ind__card strong{
  display:block;font:600 .8125rem/1.3 var(--f-d);color:var(--on);
  margin-bottom:4px;letter-spacing:-.01em;
}
.ind__card span{
  display:block;font:400 .75rem/1.55 var(--f-b);color:var(--on-m);
}

/* Stats row (real estate) */
.ind__stats{
  display:flex;gap:var(--s5);margin-bottom:var(--s6);
}
.ind__stat{
  display:flex;flex-direction:column;gap:2px;
}
.ind__stat strong{font:800 1.5rem/1 var(--f-d);color:var(--pri);letter-spacing:-.02em}
.ind__stat span{font:500 .6875rem/1.2 var(--f-l);color:var(--on-m);text-transform:uppercase;letter-spacing:.06em}

/* Tool pills row */
.ind__tools{
  display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--s5);
}
.ind__tools span{
  font:500 .6875rem/1 var(--f-l);color:var(--pri-ctr);letter-spacing:.02em;
  background:rgba(0,83,166,.06);padding:5px 12px;border-radius:9999px;
}

/* CTA link */
.ind__cta{
  font:600 .8125rem/1 var(--f-l);color:var(--pri-ctr);
  display:inline-flex;align-items:center;gap:6px;
  transition:gap var(--dur) ease;
}
.ind__cta:hover{gap:10px;color:var(--pri)}

/* Vertical flow (real estate journey) */
.vflow{
  display:flex;flex-direction:column;gap:0;
  margin-bottom:var(--s8);position:relative;
}
/* Progress bar on the left */
.vflow::before{
  content:'';position:absolute;
  left:19px;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,rgba(0,83,166,.08),var(--pri-ctr),var(--pri));
}
.vflow__step{
  display:flex;align-items:flex-start;gap:var(--s5);
  padding:16px 0;position:relative;
  transition:all var(--dur) ease;
}
.vflow__num{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:var(--sf-card);color:var(--pri-ctr);
  font:800 .8125rem var(--f-d);
  display:flex;align-items:center;justify-content:center;
  border:2px solid rgba(0,83,166,.12);
  position:relative;z-index:1;
  transition:all .35s cubic-bezier(.16,1,.3,1);
}
.vflow__step:hover .vflow__num{
  background:var(--pri-ctr);color:#fff;border-color:transparent;
  box-shadow:0 0 0 6px rgba(4,107,210,.1),0 4px 12px rgba(0,83,166,.2);
  transform:scale(1.1);
}
.vflow__step--end .vflow__num{
  background:var(--grad);color:#fff;border-color:transparent;
  box-shadow:0 0 0 6px rgba(4,107,210,.08),0 4px 12px rgba(0,83,166,.2);
}
.vflow__body{
  padding-top:6px;flex:1;min-width:0;
}
.vflow__body strong{
  display:block;font:700 .9375rem/1.3 var(--f-d);color:var(--on);
  margin-bottom:2px;transition:color var(--dur) ease;
}
.vflow__step:hover .vflow__body strong{color:var(--pri)}
.vflow__body p{
  margin:0;font:400 .8125rem/1.6 var(--f-b);color:var(--on-m);
}

/* Footer row (stat + cta inline) */
.ind__foot{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:var(--s4);border-top:1px solid var(--ol);
}
.ind__stat-inline{
  font:400 .8125rem/1.4 var(--f-b);color:var(--on-m);
}
.ind__stat-inline strong{font:800 1.125rem/1 var(--f-d);color:var(--pri);margin-right:4px}

/* Dark section variants */
.ind__callout--dark{
  background:linear-gradient(135deg,rgba(245,158,11,.14),rgba(245,158,11,.06));
  border-left:4px solid #F59E0B;
  color:#fff;
  box-shadow:0 4px 20px rgba(245,158,11,.15),inset 0 1px 0 rgba(255,255,255,.08);
}
.ind__callout--dark strong{color:#FBBF24;font-weight:700}
.ind__grid--dark .ind__card{
  background:rgba(255,255,255,.05);box-shadow:none;
  border:1px solid rgba(255,255,255,.06);
}
.ind__grid--dark .ind__card:hover{
  background:rgba(255,255,255,.08);box-shadow:none;
  transform:translateY(-2px);
}
.ind__grid--dark .ind__card strong{color:#fff}
.ind__grid--dark .ind__card span{color:rgba(255,255,255,.5)}
.ind__grid--dark .ind__card-num{color:#fff;opacity:.06}
.ind__grid--dark .ind__card::before{background:linear-gradient(180deg,#F59E0B,#D97706)}
.ind__tools--dark span{
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);
}
.ind__cta--dark{color:#93C5FD}
.ind__cta--dark:hover{color:#fff}

/* Compliance badges (healthcare) */
.ind__badges{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:var(--s6);
}
.ind__badge-item{
  display:inline-flex;align-items:center;gap:6px;
  font:600 .75rem/1 var(--f-l);color:var(--pri-ctr);
  background:rgba(0,83,166,.06);
  padding:8px 16px;border-radius:9999px;
  border:1px solid rgba(0,83,166,.1);
}
.ind__badge-item svg{width:14px;height:14px;flex-shrink:0}

@media(max-width:540px){
  .ind__grid{grid-template-columns:1fr}
  .ind__stats{flex-wrap:wrap;gap:var(--s4)}
  .vflow__step{gap:var(--s4)}
  .vflow__num{width:34px;height:34px;line-height:34px;font-size:.75rem}
  .ind__foot{flex-direction:column;gap:var(--s3);align-items:flex-start}
  .ind__badges{flex-direction:column}
}

/* ==========================================================
   DIFFERENTIATORS (editorial split — quote card + stacked list)
   ========================================================== */
.diff{display:grid;grid-template-columns:5fr 7fr;gap:var(--s16);align-items:start}

/* ── Left: editorial card ── */
.diff__left{position:sticky;top:120px}
.diff__card{
  background:var(--sf-card);border-radius:var(--r-lg);
  padding:var(--s12) var(--s10);
  box-shadow:var(--sh-lg);
}

.diff__intro{
  font:400 1rem/1.75 var(--f-b);color:var(--on-m);
  margin:var(--s4) 0 var(--s8);max-width:520px;
}

.diff__quote{
  font:300 1.25rem/1.6 var(--f-b);font-style:italic;
  color:var(--on);margin:0 0 var(--s3);
  padding-left:var(--s6);position:relative;
  border-left:3px solid var(--pri-ctr);
}
.diff__quote::before{
  content:'\201C';position:absolute;top:-28px;left:var(--s6);
  font:800 4.5rem/1 var(--f-q);color:var(--pri-ctr);opacity:.07;
  pointer-events:none;
}

.diff__attr{
  font:500 .6875rem/1 var(--f-l);color:var(--on-m);
  text-transform:uppercase;letter-spacing:.06em;
  padding-left:var(--s6);margin-bottom:var(--s10);
}

.diff__stats{
  display:flex;gap:var(--s3);
  padding-top:var(--s6);
}
.diff__stat{
  flex:1;display:flex;flex-direction:column;gap:6px;
  padding:14px 16px;
  background:var(--sf);border-radius:var(--r-lg);
  text-align:center;
}
.diff__stat strong{
  font:800 1.5rem/1 var(--f-d);color:var(--pri);
  letter-spacing:-.02em;
}
.diff__stat span{
  font:500 .6875rem/1.3 var(--f-l);color:var(--on-m);
  letter-spacing:.02em;
}

/* Proof footer (mirrors exp__foot exactly) */
.diff__foot{
  display:flex;align-items:center;gap:var(--s6);flex-wrap:wrap;
  margin-top:var(--s8);
}
.diff__proof{
  display:flex;align-items:center;gap:var(--s2);
  padding:var(--s2) var(--s4);
  background:rgba(0,83,166,.04);border-radius:var(--r-pill);
  font:500 .75rem/1.4 var(--f-l);color:var(--on-m);
  letter-spacing:.01em;
}
.diff__proof svg{color:var(--pri-ctr);flex-shrink:0}
.diff__cta{
  display:inline-flex;align-items:center;gap:6px;
  font:600 .8125rem/1 var(--f-l);color:var(--pri);
  text-decoration:none;letter-spacing:.02em;text-transform:uppercase;
  transition:all .25s ease;
}
.diff__cta:hover{gap:10px;color:var(--pri-ctr)}
.diff__cta svg{transition:transform .25s ease}
.diff__cta:hover svg{transform:translateX(3px)}

/* ── Right: 2×2 card grid ── */
.diff__right{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);
}

.diff__item{
  background:var(--sf-card);border-radius:var(--r-lg);
  padding:var(--s8) var(--s6);
  box-shadow:var(--sh-md);
  position:relative;overflow:hidden;
  transition:all .5s cubic-bezier(.25,.46,.45,.94);
}
.diff__item:hover{
  box-shadow:var(--sh-xl),var(--sh-glow);
  transform:translateY(-6px) scale(1.01);
}

/* Left accent bar */
.diff__item::before{
  content:'';position:absolute;top:var(--s5);bottom:var(--s5);left:0;width:4px;
  background:var(--pri);border-radius:0 4px 4px 0;
  transition:background .5s ease;
}
.diff__item:hover::before{background:var(--pri-ctr)}

.diff__num{
  font:800 3rem/1 var(--f-d);color:var(--pri);
  opacity:.2;letter-spacing:-.06em;margin-bottom:var(--s3);display:block;
  transition:opacity .5s ease;
}
.diff__item:hover .diff__num{opacity:.4}

.diff__item>strong{
  display:block;font:800 1rem/1.3 var(--f-d);color:var(--on);
  margin-bottom:var(--s2);letter-spacing:-.02em;
  transition:color .5s ease;
}
.diff__item:hover>strong{color:var(--pri)}

.diff__item>span{
  display:block;font:400 .8125rem/1.65 var(--f-b);color:var(--on-m);
}

@media(max-width:1024px){
  .diff{grid-template-columns:1fr;gap:var(--s10)}
  .diff__left{position:static}
  .diff__card{padding:var(--s8) var(--s6)}
}
@media(max-width:768px){
  .diff__stats{flex-direction:column;gap:var(--s3)}
  .diff__stat{text-align:left;flex-direction:row;align-items:center;gap:var(--s3)}
  .diff__quote{font-size:1.125rem}
  .diff__quote::before{font-size:3rem;top:-16px}
  .diff__foot{flex-direction:column;align-items:flex-start;gap:var(--s3)}
  .diff__right{grid-template-columns:1fr}
}

/* ==========================================================
   THE RIVCO STANDARD — compact feature-strip (services.html)
   ========================================================== */
.std-strip{padding:var(--s10) 0;background:var(--sf);position:relative}
.std-strip::before,
.std-strip::after{
  content:'';position:absolute;left:50%;transform:translateX(-50%);
  width:min(960px,92%);height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,83,166,.12),transparent);
}
.std-strip::before{top:0}
.std-strip::after{bottom:0}
.std-strip__items{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s6);
  align-items:center;
}
.std-strip__items li{
  display:flex;align-items:flex-start;gap:12px;
  padding:0 var(--s4);position:relative;
}
.std-strip__items li + li::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;width:1px;
  background:linear-gradient(180deg,transparent,rgba(0,83,166,.12),transparent);
}
.std-strip__items svg{
  flex-shrink:0;width:20px;height:20px;
  color:#10B981;margin-top:1px;
}
.std-strip__items strong{
  display:block;
  font:700 .9375rem/1.3 var(--f-d);color:var(--on);
  letter-spacing:-.015em;margin-bottom:3px;
}
.std-strip__items span{
  display:block;
  font:400 .8125rem/1.4 var(--f-b);color:var(--on-m);
}

@media(max-width:1024px){
  .std-strip__items{grid-template-columns:repeat(2,1fr);gap:var(--s4) var(--s2)}
  .std-strip__items li{padding:0 var(--s2)}
  .std-strip__items li + li::before{display:none}
}
@media(max-width:540px){
  .std-strip__items{grid-template-columns:1fr}
  .std-strip__items li{padding:0}
}

/* Concern callout banner */
.srv__concern{
  display:flex;align-items:flex-start;gap:var(--s5);
  background:var(--sf-card);border-radius:var(--r-xl);padding:var(--s8);
  box-shadow:var(--sh-md),var(--sh-glow);
}
.srv__concern-ic{
  width:52px;height:52px;border-radius:var(--r-lg);flex-shrink:0;
  background:rgba(0,83,166,.06);color:var(--pri-ctr);
  display:grid;place-items:center;
}
.srv__concern h3{font:700 1.125rem/1.3 var(--f-d);color:var(--on);margin-bottom:4px}
.srv__concern h3 em{font-style:normal;color:var(--pri-ctr)}
.srv__concern p{font:400 .9375rem/1.65 var(--f-b);color:var(--on-m)}

@media(max-width:640px){
  .srv__concern{flex-direction:column;text-align:center;align-items:center}
  .srv__concern-ic{margin-bottom:var(--s2)}
}

/* ==========================================================
   PAGE: Services detail
   ========================================================== */
/* ==========================================================
   SHOWCASE — dark bento with glassmorphic cards
   ========================================================== */
.sec--showcase{
  background:linear-gradient(160deg,#001028 0%,#001E50 30%,#003070 60%,#0053A6 100%);
  position:relative;overflow:hidden;
}
.sec--showcase::before{
  content:'';position:absolute;top:35%;left:50%;
  transform:translate(-50%,-50%);
  width:1000px;height:700px;
  background:radial-gradient(ellipse,rgba(4,107,210,.14) 0%,transparent 65%);
  pointer-events:none;
}
.sec--showcase::after{
  content:'';position:absolute;bottom:-20%;right:-5%;
  width:500px;height:500px;border-radius:50%;
  background:rgba(255,255,255,.02);pointer-events:none;
}

/* Bento grid — asymmetric Z-pattern */
.srvd__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:repeat(4,auto);
  gap:var(--s6);
  position:relative;z-index:1;
}
@media(min-width:769px){
  .srvd__card:nth-child(1){grid-column:1;grid-row:1/3}
  .srvd__card:nth-child(6){grid-column:2;grid-row:3/5}
}

/* Card — glassmorphic on dark */
.srvd__card{
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:var(--r-lg);
  padding:var(--s8);
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 4px 24px rgba(0,0,0,.12);
  transition:all .4s cubic-bezier(.25,.46,.45,.94);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.srvd__card:hover{
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.14);
  box-shadow:0 16px 48px rgba(4,107,210,.2),0 0 40px rgba(4,107,210,.06);
  transform:translateY(-6px);
}

/* Gradient accent line — appears on hover */
.srvd__card::after{
  content:'';position:absolute;top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg,transparent 5%,rgba(4,107,210,.6) 30%,rgba(57,210,192,.4) 70%,transparent 95%);
  opacity:0;transition:opacity .4s ease;
}
.srvd__card:hover::after{opacity:1}

/* Watermark numbers — huge, absolute, decorative */
.srvd__num{
  position:absolute;top:var(--s3);right:var(--s5);
  font:800 4.5rem/1 var(--f-d);color:#fff;
  opacity:.03;letter-spacing:-.06em;
  margin:0;display:block;pointer-events:none;
  transition:opacity .4s ease;
}
.srvd__card:hover .srvd__num{opacity:.07}

/* Featured tall cards */
@media(min-width:769px){
  .srvd__card:nth-child(1),
  .srvd__card:nth-child(6){padding:var(--s10) var(--s8) var(--s8)}
  .srvd__card:nth-child(1) .srvd__num,
  .srvd__card:nth-child(6) .srvd__num{font-size:6.5rem;top:var(--s4)}
  .srvd__card:nth-child(1) h3,
  .srvd__card:nth-child(6) h3{font-size:1.0625rem}
  .srvd__card:nth-child(1)>p,
  .srvd__card:nth-child(6)>p{font-size:.875rem;line-height:1.7}
}

/* Title — white on dark */
.srvd__card h3{
  font:600 .9375rem/1.35 var(--f-d);color:#fff;
  margin-bottom:var(--s3);letter-spacing:-.01em;
  transition:color .4s ease;position:relative;
}
.srvd__card:hover h3{color:#93C5FD}

/* Description */
.srvd__card>p{
  font:400 .8125rem/1.65 var(--f-b);
  color:rgba(255,255,255,.5);margin-bottom:var(--s5);
  position:relative;
}

/* Checklist */
.srvd__card ul{
  display:flex;flex-direction:column;gap:10px;
  padding-top:var(--s5);
  border-top:1px solid rgba(255,255,255,.06);
  position:relative;
}
.srvd__card li{
  display:flex;align-items:flex-start;gap:8px;
  font:400 .8125rem/1.5 var(--f-b);
  color:rgba(255,255,255,.4);
  transition:color .4s ease;
}
.srvd__card:hover li{color:rgba(255,255,255,.7)}
.srvd__card li svg{flex-shrink:0;color:#60A5FA;margin-top:2px;width:14px;height:14px}

/* ==========================================================
   PAGE: About — Premium Redesign
   ========================================================== */

/* Story: text + image */
.abt__story{display:grid;grid-template-columns:1fr 1fr;gap:var(--s16);align-items:start}
.abt__story-text h2{margin-bottom:var(--s6)}
.abt__lead{font:400 1.0625rem/1.75 var(--f-b);color:var(--on);margin-bottom:var(--s5)}
.abt__story-text p{font:400 1rem/1.75 var(--f-b);color:var(--on-m);margin-bottom:var(--s4)}
.abt__story-text p:last-child{margin-bottom:0;font-style:italic;color:var(--on);font-family:var(--f-q)}
.abt__story-img{display:flex;justify-content:center;position:sticky;top:120px}
.abt__story-img img{width:100%;max-width:480px;aspect-ratio:1/1;object-fit:cover;border-radius:var(--r-xl);box-shadow:var(--sh-xl),var(--sh-glow)}

/* Origin story — editorial timeline */
.origin{display:flex;flex-direction:column;gap:var(--s12)}
.origin__block{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s10);align-items:center;
}
.origin__block--rev{direction:rtl}
.origin__block--rev>*{direction:ltr}
.origin__img{position:relative;overflow:hidden;border-radius:var(--r-xl)}
.origin__img img{
  width:100%;display:block;object-fit:cover;aspect-ratio:2/1;
  border-radius:var(--r-xl);box-shadow:var(--sh-xl),var(--sh-glow);
  transition:transform .6s cubic-bezier(.16,1,.3,1);
}
.origin__img:hover img{transform:scale(1.02)}
.origin__img-badge{
  position:absolute;bottom:14px;left:16px;
  font:600 .6875rem/1 var(--f-l);color:#fff;letter-spacing:.04em;
  background:rgba(0,0,0,.45);backdrop-filter:blur(8px);
  padding:6px 14px;border-radius:9999px;
}
.origin__content{display:flex;flex-direction:column;gap:var(--s3)}
.origin__tag{
  font:600 .6875rem/1 var(--f-l);text-transform:uppercase;letter-spacing:.1em;
  color:var(--pri-ctr);
}
.origin__h{
  font:800 1.75rem/1.25 var(--f-d);color:var(--on);letter-spacing:-.03em;
  margin:0;position:relative;padding-left:20px;
}
.origin__h::before{
  content:'';position:absolute;left:0;top:.15em;bottom:.15em;
  width:4px;border-radius:4px;background:var(--grad);
}
.origin__content p{
  font:400 1rem/1.75 var(--f-b);color:var(--on-m);margin:0;
}
.origin__content p strong{color:var(--on)}
.origin__closer{
  font:italic 400 1.0625rem/1.6 var(--f-q);color:var(--on);
  padding-left:16px;border-left:3px solid var(--pri-ctr);
  margin-top:var(--s2);
}
/* Growth metrics strip */
.origin__metrics{
  display:flex;align-items:center;justify-content:center;gap:var(--s6);
  padding:var(--s8) 0;
}
.origin__metric{
  text-align:center;display:flex;flex-direction:column;gap:4px;
}
.origin__metric strong{
  font:800 2.25rem/1 var(--f-d);color:var(--pri);letter-spacing:-.03em;
}
.origin__metric--hl strong{
  color:#fff;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  font-size:2.75rem;
}
.origin__metric span{
  font:500 .75rem/1.3 var(--f-l);color:var(--on-m);text-transform:uppercase;letter-spacing:.06em;
}
.origin__metric-arrow{
  color:var(--pri-ctr);opacity:.2;flex-shrink:0;
}
@media(max-width:768px){
  .origin__block{grid-template-columns:1fr}
  .origin__block--rev{direction:ltr}
  .origin__metrics{flex-wrap:wrap;gap:var(--s4)}
  .origin__metric-arrow{display:none}
  .origin__metric strong{font-size:1.75rem}
  .origin__metric--hl strong{font-size:2rem}
}

/* Mission & Vision — editorial quote cards */
.abt__mv{display:grid;grid-template-columns:1fr 1fr;gap:var(--s6)}
.abt__mv-card{
  background:var(--sf-card);border-radius:var(--r-lg);
  padding:var(--s10) var(--s8);
  box-shadow:var(--sh-md);transition:all var(--dur) ease-out;
  border:1px solid rgba(0,83,166,.03);
  position:relative;overflow:hidden;
}
.abt__mv-card:hover{box-shadow:var(--sh-lg),var(--sh-glow);transform:translateY(-4px)}

.abt__mv-num{
  position:absolute;top:var(--s4);right:var(--s5);
  font:800 3.5rem/1 var(--f-d);color:var(--pri-ctr);opacity:.05;
  letter-spacing:-.04em;pointer-events:none;
  transition:opacity var(--dur) ease;
}
.abt__mv-card:hover .abt__mv-num{opacity:.1}

.abt__mv-label{
  display:inline-block;font:700 .625rem/1 var(--f-l);color:var(--pri-ctr);
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:var(--s4);
}
.abt__mv-quote{
  font:600 1.25rem/1.4 var(--f-d);color:var(--on);
  margin:0 0 var(--s4);padding-left:var(--s5);
  border-left:3px solid var(--pri-ctr);letter-spacing:-.02em;
}
.abt__mv-card p{font:400 .8125rem/1.65 var(--f-b);color:var(--on-m)}

/* Values: numbered list */
.abt__vals{display:grid;grid-template-columns:1fr 1fr;gap:var(--s6)}

.abt__val{
  background:var(--sf-card);border-radius:var(--r-lg);padding:var(--s8);
  box-shadow:var(--sh-sm);transition:all var(--dur) ease-out;
  position:relative;overflow:hidden;
  border:1px solid rgba(0,83,166,.03);
}
.abt__val:hover{box-shadow:var(--sh-lg),var(--sh-glow);transform:translateY(-4px);border-color:rgba(0,83,166,.06)}

.abt__val-num{
  position:absolute;top:var(--s3);right:var(--s4);
  font:800 3rem/1 var(--f-d);color:var(--pri-ctr);opacity:.06;
  letter-spacing:-.04em;pointer-events:none;
  transition:opacity var(--dur) ease;
}
.abt__val:hover .abt__val-num{opacity:.12}
.abt__val h3{font:600 .9375rem/1.35 var(--f-d);color:var(--on);margin-bottom:var(--s2);letter-spacing:-.01em;transition:color var(--dur) ease}
.abt__val:hover h3{color:var(--pri)}
.abt__val p{font:400 .8125rem/1.65 var(--f-b);color:var(--on-m)}

/* Structure section — light editorial split */
.struct{
  display:grid;grid-template-columns:5fr 7fr;gap:var(--s16);
  align-items:start;
}
.struct__left{position:sticky;top:120px}

.struct__stats{
  display:flex;gap:0;padding-top:var(--s6);
  border-top:1px solid var(--ol);
}
.struct__stat{
  flex:1;display:flex;flex-direction:column;gap:4px;
  padding:0 var(--s5);
}
.struct__stat:first-child{padding-left:0}
.struct__stat:last-child{padding-right:0}
.struct__stat+.struct__stat{border-left:1px solid var(--ol)}
.struct__stat strong{font:800 1.5rem/1 var(--f-d);color:var(--pri);letter-spacing:-.02em}
.struct__stat span{font:500 .6875rem/1.3 var(--f-l);color:var(--on-m);text-transform:uppercase;letter-spacing:.04em}

.struct__right{display:flex;flex-direction:column;gap:var(--s4)}

.struct__card{
  background:var(--sf-card);
  border:1px solid rgba(0,83,166,.03);
  border-radius:var(--r-lg);padding:var(--s8);
  box-shadow:var(--sh-sm);
  position:relative;overflow:hidden;
  transition:all var(--dur) ease-out;
}
.struct__card:hover{
  box-shadow:var(--sh-lg),var(--sh-glow);
  transform:translateY(-4px);
  border-color:rgba(0,83,166,.06);
}

.struct__num{
  position:absolute;top:var(--s3);right:var(--s5);
  font:800 3.5rem/1 var(--f-d);color:var(--pri-ctr);opacity:.06;
  letter-spacing:-.06em;pointer-events:none;
  transition:opacity var(--dur) ease;
}
.struct__card:hover .struct__num{opacity:.12}

.struct__card h3{
  font:600 .9375rem/1.35 var(--f-d);color:var(--on);
  margin-bottom:var(--s2);letter-spacing:-.01em;
  transition:color var(--dur) ease;
}
.struct__card:hover h3{color:var(--pri)}
.struct__card p{font:400 .8125rem/1.65 var(--f-b);color:var(--on-m);margin:0}

@media(max-width:1024px){
  .struct{grid-template-columns:1fr;gap:var(--s10)}
  .struct__left{position:static}
}
@media(max-width:768px){
  .struct__stats{flex-direction:column;gap:var(--s4)}
  .struct__stat{padding:0!important}
  .struct__stat+.struct__stat{border-left:none;border-top:1px solid var(--ol);padding-top:var(--s3)!important}
}

/* Responsive */
@media(max-width:768px){
  .abt__story{grid-template-columns:1fr}
  .abt__story-img{order:-1;position:static}
  .abt__mv{grid-template-columns:1fr}
  .abt__vals{grid-template-columns:1fr}
  .struct{grid-template-columns:1fr}
}

/* ==========================================================
   PAGE: Contact — Premium Redesign
   ========================================================== */

/* Grid: info left, form right */
.ct__grid{display:grid;grid-template-columns:5fr 7fr;gap:var(--s12);align-items:start}

/* ── Left: Contact Info Card ── */
.ct__info-card{
  background:var(--on);color:#fff;border-radius:var(--r-xl);
  padding:var(--s10) var(--s8);position:relative;overflow:hidden;
}
.ct__info-card::before{
  content:'';position:absolute;top:-40%;right:-30%;width:300px;height:300px;
  border-radius:50%;background:rgba(4,107,210,.15);pointer-events:none;
}
.ct__info-card::after{
  content:'';position:absolute;bottom:-30%;left:-20%;width:250px;height:250px;
  border-radius:50%;background:rgba(57,210,192,.08);pointer-events:none;
}

.ct__info-card .ct__info-title{font:800 1.75rem/1.2 var(--f-d)!important;color:#fff!important;margin:0 0 var(--s3)!important;position:relative;z-index:1}
.ct__info-sub{font:400 .9375rem/1.65 var(--f-b);color:rgba(255,255,255,.6);margin-bottom:var(--s8);position:relative;z-index:1}

/* Channel items */
.ct__channels{display:flex;flex-direction:column;gap:var(--s5);position:relative;z-index:1;margin-bottom:var(--s8)}

.ct__channel{
  display:flex;align-items:flex-start;gap:var(--s4);
  padding:var(--s4);border-radius:var(--r-lg);
  background:rgba(255,255,255,.05);
  transition:all .25s ease-out;cursor:pointer;
  text-decoration:none;color:inherit;
}
.ct__channel:hover{background:rgba(255,255,255,.1);transform:translateX(4px)}

.ct__channel-ic{
  width:48px;height:48px;border-radius:var(--r-md);flex-shrink:0;
  display:grid;place-items:center;
}
.ct__channel-ic--pri{background:rgba(4,107,210,.2);color:#60A5FA}
.ct__channel-ic--am{background:rgba(245,158,11,.15);color:#FBBF24}
.ct__channel-ic--gr{background:rgba(57,210,192,.15);color:#5EEAD4}
.ct__channel-ic svg{width:22px;height:22px;fill:currentColor}

.ct__channel-label{font:600 .6875rem/1 var(--f-l);color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.ct__channel-value{font:600 1rem/1.3 var(--f-d);color:#fff}
.ct__channel-note{font:400 .75rem/1.3 var(--f-b);color:rgba(255,255,255,.4);margin-top:2px}

/* Promise bar */
.ct__promise{
  display:flex;align-items:flex-start;gap:var(--s3);
  padding:var(--s4);border-radius:var(--r-md);
  background:rgba(255,255,255,.04);
  font:400 .8125rem/1.5 var(--f-b);color:rgba(255,255,255,.5);
  position:relative;z-index:1;
}
.ct__promise svg{flex-shrink:0;color:#60A5FA;fill:currentColor;margin-top:2px}
.ct__promise svg{flex-shrink:0;color:#5EEAD4;margin-top:1px}
.ct__promise strong{color:rgba(255,255,255,.8);font-weight:600}

/* ── Right: Form Card ── */
.ct__form-card{
  background:var(--sf-card);border-radius:var(--r-lg);
  padding:var(--s12) var(--s10);
  box-shadow:var(--sh-xl),var(--sh-glow);
  border:1px solid rgba(0,83,166,.03);
}

.ct__form-head{margin-bottom:var(--s8)}
.ct__form-head h3{font:800 1.375rem/1.2 var(--f-d);color:var(--on);margin-bottom:var(--s2);letter-spacing:-.02em}
.ct__form-head p{font:400 .875rem/1.5 var(--f-b);color:var(--on-m)}

.ct__form{display:flex;flex-direction:column;gap:var(--s5)}
.ct__cf7 .wpcf7,
.ct__cf7 .wpcf7 form{margin:0}
.ct__cf7 .ct__form{margin:0!important}
.ct__cf7 .ct__form p{margin:0!important}
.ct__cf7 .ct__field p{display:flex;flex-direction:column;gap:6px}
.ct__cf7 .ct__form>p:not(.ct__fine){display:contents!important}
.ct__cf7 .ct__form>p:not(.ct__fine) .ct__submit{display:flex!important}
.ct__cf7 .ct__field br{display:none}
.ct__cf7 .wpcf7-form-control-wrap{display:block;width:100%;line-height:0}
.ct__cf7 .wpcf7-spinner{position:absolute;margin:13px 0 0 var(--s3)}
.ct__cf7 .wpcf7-not-valid-tip{font:400 .75rem/1.35 var(--f-b);color:var(--red);margin-top:6px}
.ct__cf7 .wpcf7-response-output{
  margin:var(--s4) 0 0!important;padding:var(--s4)!important;border:0!important;
  border-radius:var(--r-md);background:rgba(0,83,166,.06);
  font:600 .875rem/1.45 var(--f-b);color:var(--on);
}
.ct__cf7 form.init .wpcf7-response-output,
.ct__cf7 .wpcf7-response-output[aria-hidden="true"]{
  display:none!important;margin:0!important;padding:0!important;
}
.ct__cf7 form.sent{display:none}
.ct__cf7 .wpcf7:has(form.sent) + .ct__success{display:block}

.ct__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}

.ct__field{display:flex;flex-direction:column;gap:6px}
.ct__field label{font:600 .6875rem/1 var(--f-l);color:var(--on);text-transform:uppercase;letter-spacing:.04em}
.ct__req{color:var(--pri-ctr)}

.ct__field input,
.ct__field textarea,
.ct__field select{
  padding:14px 18px;border:1px solid rgba(0,83,166,.06);border-radius:var(--r-lg);
  font:400 .875rem/1.5 var(--f-b);color:var(--on);
  background:var(--sf);width:100%;
  transition:all .3s ease-out;
}
.ct__cf7 .ct__field input.wpcf7-form-control,
.ct__cf7 .ct__field textarea.wpcf7-form-control,
.ct__cf7 .ct__field select.wpcf7-form-control{
  display:block!important;
  height:auto!important;
  min-height:auto!important;
  padding:14px 18px!important;
  border:1px solid rgba(0,83,166,.06)!important;
  border-radius:var(--r-lg)!important;
  box-shadow:none!important;
  font:400 .875rem/1.5 var(--f-b)!important;
  color:var(--on)!important;
  background:var(--sf)!important;
}
.ct__cf7 .ct__field textarea.wpcf7-form-control{min-height:120px!important}
.ct__field input::placeholder,
.ct__field textarea::placeholder{color:rgba(87,99,108,.35)}

.ct__field input:focus,
.ct__field textarea:focus,
.ct__field select:focus{
  outline:none;background:var(--sf-card);
  border-color:var(--pri-ctr);
  box-shadow:0 0 0 3px rgba(4,107,210,.08);
}
.ct__field textarea{min-height:120px;resize:vertical}

/* Validation */
.ct__field input:invalid:not(:placeholder-shown){border-color:var(--red);box-shadow:0 0 0 3px rgba(239,68,68,.06)}

.ct__submit{width:100%;margin-top:var(--s3)}

.ct__fine{font:400 .6875rem/1.4 var(--f-l);color:var(--on-m);text-align:center;margin-top:var(--s2)}
.ct__cf7 .ct__form p.ct__fine{margin-top:var(--s2)!important;margin-bottom:0!important}

/* Success state */
.ct__success{display:none;text-align:center;padding:var(--s12) var(--s6)}
.ct__success.show{display:block}
.ct__success-ic{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,#DCFCE7,#BBF7D0);
  display:grid;place-items:center;margin:0 auto var(--s6);color:#16A34A;
  animation:success-pop .5s cubic-bezier(.16,1,.3,1);
}
@keyframes success-pop{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}
.ct__success h3{font:700 1.75rem/1.2 var(--f-d);color:var(--on);margin-bottom:var(--s3)}
.ct__success p{font:400 1rem/1.65 var(--f-b);color:var(--on-m);max-width:400px;margin:0 auto}

/* Responsive */
@media(max-width:768px){
  .ct__grid{grid-template-columns:1fr}
  .ct__row{grid-template-columns:1fr}
  .ct__info-card{padding:var(--s8) var(--s6)}
  .ct__form-card{padding:var(--s8) var(--s6)}
}

/* Legacy contact classes (keep for other pages) */
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s12)}
.contact__info h3{font:700 1.25rem/1.3 var(--f-d);color:var(--on);margin-bottom:var(--s5)}
.contact__form{display:flex;flex-direction:column;gap:var(--s4)}
.contact__field{display:flex;flex-direction:column;gap:6px}
.contact__field label{font:600 .8125rem/1 var(--f-l);color:var(--on);text-transform:uppercase;letter-spacing:.03em}
.contact__field input,.contact__field textarea,.contact__field select{padding:14px 16px;border:none;border-radius:var(--r-md);font:400 .9375rem/1.5 var(--f-b);color:var(--on);background:var(--sf-low);width:100%;transition:all var(--dur) var(--ease)}
.contact__field input:focus,.contact__field textarea:focus,.contact__field select:focus{outline:none;background:var(--sf-card);box-shadow:0 0 0 2px rgba(4,107,210,.12),inset 0 -2px 0 var(--pri-ctr)}
.contact__field textarea{min-height:120px;resize:vertical}

/* ==========================================================
   BROWSE BY ROLE — interactive command-center (services.html)
   ========================================================== */
.roles-x{padding:var(--s16) 0 var(--s20)}

/* ── Hero ── */
.rx__hero{margin-bottom:var(--s7)}
.rx__hero-top{
  display:flex;justify-content:space-between;align-items:center;gap:var(--s5);
  flex-wrap:wrap;margin-bottom:var(--s5);
}
.rx__kicker{
  display:inline-block;padding:7px 16px;border-radius:var(--r-pill);
  background:rgba(147,197,253,.1);color:#93C5FD;
  font:700 .6875rem/1 var(--f-l);letter-spacing:.14em;text-transform:uppercase;
}
.rx__metrics{
  display:flex;gap:var(--s3);flex-wrap:wrap;align-items:center;
  font:500 .8125rem/1.2 var(--f-b);color:rgba(255,255,255,.55);
}
.rx__metrics span{display:inline-flex;align-items:baseline;gap:6px}
.rx__metrics strong{
  font-family:var(--f-d);font-weight:800;font-size:1.0625rem;
  letter-spacing:-.02em;
  background:linear-gradient(135deg,#93C5FD,#60A5FA);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.rx__dot{
  width:4px;height:4px;border-radius:50%;
  background:rgba(255,255,255,.18);
}
.rx__h{
  font:800 clamp(2rem,3.5vw,2.875rem)/1.1 var(--f-d);
  color:#fff;letter-spacing:-.025em;
  margin:0 0 var(--s3);
}
.rx__h em{
  font-style:normal;
  background:linear-gradient(135deg,#93C5FD 0%,#60A5FA 50%,#93C5FD 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.rx__sub{
  font:400 1.0625rem/1.55 var(--f-b);color:rgba(255,255,255,.6);
  margin:0;max-width:740px;
}

/* ── Search (top, full-width) ── */
.rx__search{
  display:flex;align-items:center;gap:var(--s3);
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-radius:var(--r-pill);
  padding:14px 18px 14px 22px;
  margin-bottom:var(--s6);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
  transition:box-shadow var(--dur) var(--ease),background .3s ease;
}
.rx__search:focus-within{
  background:rgba(255,255,255,.08);
  box-shadow:0 10px 32px rgba(4,107,210,.2),inset 0 0 0 1.5px #93C5FD;
}
.rx__search > svg{color:#93C5FD;flex-shrink:0}
.rx__search input{
  flex:1;border:none;background:none;outline:none;min-width:0;
  font:400 .9375rem/1 var(--f-b);color:#fff;
}
.rx__search input::placeholder{color:rgba(255,255,255,.4)}
.rx__kbd{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:26px;height:26px;padding:0 8px;border-radius:6px;
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);
  font:700 .75rem/1 var(--f-l);
  box-shadow:inset 0 -1px 0 rgba(0,0,0,.2);
  flex-shrink:0;
}

/* ── Layout: fixed-height sidebar + scrollable grid ── */
.rx__layout{
  display:grid;grid-template-columns:260px 1fr;gap:var(--s6);
  height:780px;
}

.rx__sidebar{
  height:100%;
  overflow-y:auto;
  padding-right:var(--s3);
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.15) transparent;
}
.rx__sidebar::-webkit-scrollbar{width:4px}
.rx__sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}
.rx__sidebar::-webkit-scrollbar-track{background:transparent}
.rx__sidebar-head{
  font:700 .6875rem/1 var(--f-l);color:rgba(255,255,255,.45);
  letter-spacing:.14em;text-transform:uppercase;
  padding:0 var(--s3) var(--s3);
  margin-bottom:var(--s2);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.rx__tabs{
  display:flex;flex-direction:column;gap:4px;
}
.rx__tab{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:10px 14px;border-radius:10px;
  background:transparent;color:rgba(255,255,255,.65);
  font:600 .8125rem/1.2 var(--f-l);letter-spacing:.01em;
  border:none;cursor:pointer;text-align:left;
  transition:all .25s cubic-bezier(.16,1,.3,1);
}
/* All tabs same color — brand light-blue dot, regardless of state */
.rx__tab-dot{
  width:7px;height:7px;border-radius:50%;flex-shrink:0;
  background:#93C5FD;
  transition:transform .3s ease,box-shadow .3s ease;
}
.rx__tab em{
  font-style:normal;font-weight:700;
  color:rgba(255,255,255,.35);font-family:var(--f-d);font-size:.6875rem;
  padding:2px 7px;border-radius:6px;background:rgba(255,255,255,.05);
  margin-left:auto;letter-spacing:.02em;flex-shrink:0;
}
.rx__tab:hover{
  background:rgba(255,255,255,.05);color:#fff;
}
.rx__tab:hover .rx__tab-dot{
  transform:scale(1.3);
  box-shadow:0 0 0 4px rgba(147,197,253,.18);
}
.rx__tab:hover em{color:rgba(255,255,255,.6);background:rgba(255,255,255,.08)}
.rx__tab.on{
  background:linear-gradient(135deg,rgba(0,83,166,.35),rgba(4,107,210,.25));
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(147,197,253,.25);
}
.rx__tab.on .rx__tab-dot{
  transform:scale(1.4);
  box-shadow:0 0 0 4px rgba(147,197,253,.25);
}
.rx__tab.on em{color:#fff;background:rgba(255,255,255,.15)}

/* ── Grid of tiles (inside right pane, own scroll) ── */
.rx__grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4);
  height:100%;overflow-y:auto;
  padding:4px var(--s3) 4px 4px;
  scrollbar-width:thin;
  scrollbar-color:rgba(147,197,253,.3) rgba(255,255,255,.05);
}
.rx__grid::-webkit-scrollbar{width:8px}
.rx__grid::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:8px}
.rx__grid::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,rgba(147,197,253,.35),rgba(4,107,210,.35));
  border-radius:8px;border:1px solid rgba(255,255,255,.05);
}
.rx__grid::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,rgba(147,197,253,.55),rgba(4,107,210,.55));
}
/* Tile — horizontal split, vertical image left + dark blue content right, homepage-style gradient ring */
.rx__tile{
  position:relative;display:grid;
  grid-template-columns:40% 1fr;
  border-radius:var(--r-md);overflow:hidden;
  text-decoration:none;color:inherit;
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:none;
  box-shadow:0 4px 24px rgba(0,0,0,.12);
  transition:
    transform .4s cubic-bezier(.25,.46,.45,.94),
    box-shadow .4s cubic-bezier(.25,.46,.45,.94),
    background .4s ease;
  animation:rxPop .5s cubic-bezier(.16,1,.3,1) backwards;
  isolation:isolate;height:340px;
}
@keyframes rxPop{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}
.rx__tile:nth-child(1){animation-delay:.02s}
.rx__tile:nth-child(2){animation-delay:.04s}
.rx__tile:nth-child(3){animation-delay:.06s}
.rx__tile:nth-child(4){animation-delay:.08s}
.rx__tile:nth-child(5){animation-delay:.10s}
.rx__tile:nth-child(6){animation-delay:.12s}

/* Gradient ring — dim by default, brightens on hover (matches homepage .roles__card) */
.rx__tile::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg,#0053A6,#046BD2 40%,#93C5FD 70%,#046BD2);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;z-index:3;
  opacity:.22;transition:opacity .45s cubic-bezier(.16,1,.3,1);
}
.rx__tile:hover::before{opacity:.85}

.rx__tile:hover{
  background:rgba(255,255,255,.07);
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(4,107,210,.25),0 0 40px rgba(4,107,210,.1);
}

/* Left: vertical image panel */
.rx__tile-img{
  position:relative;overflow:hidden;z-index:1;
}
.rx__tile-img img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
  transition:transform .7s cubic-bezier(.16,1,.3,1),filter .5s ease;
  filter:saturate(.9) brightness(.92);
}
.rx__tile:hover .rx__tile-img img{
  transform:scale(1.08);
  filter:saturate(1.05) brightness(1);
}
/* Subtle tint on image to unify with dark body */
.rx__tile-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 60%,rgba(0,30,80,.6) 100%);
  pointer-events:none;z-index:2;
  transition:opacity .4s ease;
}
.rx__tile:hover .rx__tile-img::after{opacity:.7}

/* Right: dark blue content panel */
.rx__tile-body{
  position:relative;z-index:2;
  padding:var(--s6) var(--s5) var(--s5);
  display:flex;flex-direction:column;gap:10px;
  color:#fff;
}
.rx__tile-body h3{
  font:700 1.0625rem/1.25 var(--f-d);color:#fff;
  letter-spacing:-.015em;margin:0;
  transition:color .4s ease;
}
.rx__tile:hover .rx__tile-body h3{color:#93C5FD}
.rx__tile-body p{
  font:400 .8125rem/1.5 var(--f-b);
  color:rgba(255,255,255,.55);margin:0;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  transition:color .4s ease;
}
.rx__tile:hover .rx__tile-body p{color:rgba(255,255,255,.75)}

/* Skill tags — small pills showing key competencies */
.rx__tile-skills{
  display:flex;flex-wrap:wrap;gap:4px 5px;margin-top:2px;
}
.rx__tile-skills span{
  font:500 .6rem/1 var(--f-l);
  padding:3px 7px;border-radius:4px;
  background:rgba(147,197,253,.08);
  color:rgba(255,255,255,.45);
  letter-spacing:.02em;
  transition:background .3s ease,color .3s ease;
}
.rx__tile:hover .rx__tile-skills span{
  background:rgba(147,197,253,.14);
  color:rgba(255,255,255,.7);
}

/* Bonus section — visually separated callout block */
.rx__tile-bonus{
  display:flex;flex-wrap:wrap;align-items:center;gap:5px 6px;
  background:rgba(147,197,253,.05);
  border-left:2px solid rgba(147,197,253,.35);
  padding:6px 8px;
  border-radius:0 5px 5px 0;
}
.rx__tile-bonus::before{
  content:'BONUS';
  display:block;width:100%;
  font:700 .5rem/1 var(--f-l);
  color:rgba(147,197,253,.7);
  letter-spacing:.1em;
  margin-bottom:2px;
}
.rx__tile-bonus span{
  font:500 .6rem/1 var(--f-l);
  padding:3px 7px;border-radius:4px;
  background:rgba(147,197,253,.08);
  color:rgba(255,255,255,.6);
  letter-spacing:.02em;
  transition:background .3s ease,color .3s ease;
}
.rx__tile:hover .rx__tile-bonus{
  background:rgba(147,197,253,.09);
  border-left-color:rgba(147,197,253,.55);
}
.rx__tile:hover .rx__tile-bonus span{
  background:rgba(147,197,253,.15);
  color:rgba(255,255,255,.85);
}

/* Salary anchor — anchoring bias: shows what in-house costs */
.rx__tile-save{
  font:600 .65rem/1 var(--f-l);
  color:rgba(147,197,253,.6);
  letter-spacing:.01em;
}
.rx__tile-save strong{
  color:rgba(255,255,255,.7);
  text-decoration:line-through;
  text-decoration-color:rgba(255,100,100,.5);
}

/* Popularity / demand badges — social proof */
.rx__tile-badge{
  position:absolute;top:10px;left:10px;z-index:4;
  font:700 .55rem/1 var(--f-l);
  padding:5px 10px;border-radius:var(--r-pill);
  letter-spacing:.08em;
  text-transform:uppercase;
  pointer-events:none;
}
.rx__tile-badge--popular{
  background:linear-gradient(135deg,#0053A6,#046BD2);
  color:#fff;
  box-shadow:0 2px 12px rgba(4,107,210,.4);
}
.rx__tile-badge--demand{
  background:rgba(147,197,253,.12);
  color:#93C5FD;
  border:1px solid rgba(147,197,253,.25);
  backdrop-filter:blur(8px);
}

/* Tool logos row — subtle glyphs + "+N more" chip */
.rx__tile-logos{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin-top:6px;
}
.rx__tile-logos img{
  width:18px;height:18px;flex-shrink:0;
  opacity:.5;filter:brightness(.85);
  transition:opacity .35s ease,filter .35s ease,transform .35s cubic-bezier(.16,1,.3,1);
}
.rx__tile:hover .rx__tile-logos img{
  opacity:1;filter:brightness(1);
}
.rx__tile:hover .rx__tile-logos img:nth-child(1){transform:translateY(-2px);transition-delay:.05s}
.rx__tile:hover .rx__tile-logos img:nth-child(2){transform:translateY(-2px);transition-delay:.1s}
.rx__tile:hover .rx__tile-logos img:nth-child(3){transform:translateY(-2px);transition-delay:.15s}
.rx__tile:hover .rx__tile-logos img:nth-child(4){transform:translateY(-2px);transition-delay:.2s}

/* "+N more" chip — signals the VA works with more tools than shown */
.rx__tile-more{
  display:inline-flex;align-items:center;
  padding:3px 9px;border-radius:var(--r-pill);
  background:rgba(147,197,253,.08);color:rgba(147,197,253,.7);
  font:700 .625rem/1 var(--f-l);letter-spacing:.06em;
  text-transform:uppercase;
  transition:background .3s ease,color .3s ease,transform .35s cubic-bezier(.16,1,.3,1);
}
.rx__tile:hover .rx__tile-more{
  background:rgba(147,197,253,.16);color:#93C5FD;
  transform:translateY(-2px);transition-delay:.25s;
}

/* Category label — subtle uppercase footer */
.rx__tile-cat{
  font:700 .625rem/1 var(--f-l);
  color:rgba(255,255,255,.35);
  letter-spacing:.14em;text-transform:uppercase;
  padding-top:var(--s3);margin-top:auto;
  border-top:1px solid rgba(255,255,255,.06);
  transition:color .4s ease,border-color .4s ease;
}
.rx__tile:hover .rx__tile-cat{
  color:#93C5FD;
  border-top-color:rgba(147,197,253,.2);
}

/* Filter states */
.rx__tile.hide{display:none}
.rx__empty{
  grid-column:1/-1;text-align:center;padding:var(--s12) var(--s4);
  display:none;
}
.rx__empty.show{display:flex;flex-direction:column;align-items:center;gap:var(--s3)}
.rx__empty-ic{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,rgba(0,83,166,.1),rgba(4,107,210,.05));
  color:var(--pri-ctr);display:grid;place-items:center;
}
.rx__empty p{font:500 1rem/1.5 var(--f-b);color:var(--on-m);margin:0}
.rx__empty strong{color:var(--on);font-family:var(--f-d);font-weight:700}
.rx__empty a{color:var(--pri-ctr);font-weight:600}

/* Responsive */
@media(max-width:1100px){
  .rx__layout{grid-template-columns:1fr;gap:var(--s5);height:auto}
  .rx__sidebar{height:auto;overflow:visible;padding-right:0}
  .rx__sidebar-head{display:none}
  .rx__tabs{flex-direction:row;flex-wrap:wrap;gap:6px}
  .rx__tab{width:auto;padding:8px 14px;border-radius:var(--r-pill)}
  .rx__tab em{margin-left:6px}
  .rx__grid{grid-template-columns:repeat(2,1fr);height:auto;overflow:visible;padding:0}
}
@media(max-width:540px){
  .rx__grid{grid-template-columns:1fr}
  .rx__tile{height:320px}
  .rx__h{font-size:1.75rem}
  .rx__sub{font-size:.9375rem}
  .rx__hero-top{flex-direction:column;align-items:flex-start;gap:var(--s3)}
  .rx__metrics{font-size:.75rem;gap:var(--s2)}
  .rx__metrics strong{font-size:.9375rem}
  .rx__kbd{display:none}
  .rx__search{padding:12px 14px 12px 18px}
  .rx__tab{font-size:.75rem;padding:7px 12px 7px 10px}
  .rx__tab em{font-size:.625rem}
}

/* ==========================================================
   TOOLS TRUST BAR — scrolling logo marquee
   ========================================================== */
.tbar{
  padding:var(--s10) 0;
  overflow:hidden;
  background:var(--sf-low);
  position:relative;
}
.tbar::before,
.tbar::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.tbar::before{left:0;background:linear-gradient(90deg,var(--sf-low),transparent)}
.tbar::after{right:0;background:linear-gradient(270deg,var(--sf-low),transparent)}
.tbar__lbl{
  text-align:center;
  font:500 .75rem/1 var(--f-l);
  color:var(--on-m);
  letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:var(--s6);
  opacity:.6;
}
.tbar__track{
  display:flex;gap:var(--s12);
  animation:marq 25s linear infinite;
  width:max-content;
}
.tbar__track:hover{animation-play-state:paused}
.tbar__item{
  flex-shrink:0;
  display:flex;align-items:center;gap:10px;
  user-select:none;
}
.tbar__item img{
  width:28px;height:28px;
  flex-shrink:0;
}
.tbar__item span{
  font:700 .875rem/1 var(--f-d);
  color:var(--on);
  white-space:nowrap;
  opacity:.35;
}

/* ==========================================================
   HIDDEN LEDGER — pain section as a balance-sheet card
   Brand-aligned: white sf-card, light-blue dotted leaders,
   navy amounts, gradient rule above total, gradient total.
   ========================================================== */
.ledger{
  background:
    radial-gradient(ellipse 700px 500px at 80% 20%,rgba(4,107,210,.08),transparent),
    radial-gradient(ellipse 600px 400px at 15% 80%,rgba(147,197,253,.1),transparent),
    var(--sf);
  position:relative;
}
.ledger__sheet{
  position:relative;
  max-width:780px;margin:var(--s12) auto 0;
  padding:var(--s10);
  background:var(--sf-card);
  border-radius:var(--r-lg);
  box-shadow:var(--sh-lg);
}
.ledger__binder{display:none}

/* Header row, gradient rule below */
.ledger__head{
  display:flex;justify-content:space-between;align-items:baseline;
  padding-bottom:var(--s4);
  margin-bottom:var(--s2);
  position:relative;
}
.ledger__head::after{
  content:'';position:absolute;left:0;right:0;bottom:0;
  height:2px;border-radius:1px;
  background:linear-gradient(90deg,var(--pri),var(--pri-ctr));
}
.ledger__head span{
  font:800 .75rem/1 var(--f-l);
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--on);
}

/* Rows: light-blue dotted leader rule */
.ledger__row{
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:baseline;column-gap:var(--s4);
  padding:var(--s4) 0;
  position:relative;
}
.ledger__row::before{
  content:'';position:absolute;left:0;right:0;bottom:calc(var(--s4) + 2px);
  border-bottom:1.5px dotted rgba(4,107,210,.22);
  z-index:0;
}
.ledger__row > *{position:relative;z-index:1;background:var(--sf-card)}
.ledger__row > .ledger__label{padding:0 8px 0 4px}
.ledger__row > .ledger__amt{padding-left:10px}
.ledger__row > .ledger__no{padding-right:8px}
.ledger__no{
  font:700 .8125rem/1 var(--f-l);
  color:var(--pri-ctr);
  letter-spacing:.06em;
  font-variant-numeric:tabular-nums;
  opacity:.55;
}
.ledger__label{
  font:500 1rem/1.4 var(--f-b);
  color:var(--on);
}
.ledger__amt{
  font:800 1.5rem/1 var(--f-d);
  color:var(--on);
  letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;
}
.ledger__amt--p{
  font:600 1.25rem/1 var(--f-q,'Instrument Serif',serif);
  font-style:italic;
  color:var(--on-m);
  letter-spacing:0;
}

/* Total — gradient rule above, gradient total amount */
.ledger__total{
  display:grid;grid-template-columns:1fr auto;
  align-items:baseline;column-gap:var(--s4);
  padding:var(--s5) 0 var(--s2);
  margin-top:var(--s3);
  position:relative;
}
.ledger__total::before{
  content:'';position:absolute;left:0;right:0;top:0;
  height:3px;border-radius:2px;
  background:linear-gradient(90deg,var(--pri),var(--pri-ctr));
}
.ledger__total-lbl{
  font:800 .9375rem/1 var(--f-l);
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--on);
}
.ledger__total-amt{
  font:800 2.75rem/1 var(--f-d);
  letter-spacing:-.03em;
  font-variant-numeric:tabular-nums;
  display:flex;align-items:baseline;gap:8px;
  background:linear-gradient(135deg,var(--pri),var(--pri-ctr));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  text-shadow:0 0 50px rgba(4,107,210,.15);
}
.ledger__total-amt small{
  font:600 .9375rem/1 var(--f-q,'Instrument Serif',serif);
  font-style:italic;
  color:var(--on-m);
  letter-spacing:0;text-transform:none;
  -webkit-text-fill-color:var(--on-m);
}

/* DEBIT — small restrained pill badge with the brand's accent red */
.ledger__stamp{
  position:absolute;top:-12px;right:var(--s7);
  background:var(--sf-card);
  color:#C53030;
  padding:7px 16px;
  font:800 .6875rem/1 var(--f-l);
  letter-spacing:.22em;text-transform:uppercase;
  border-radius:var(--r-pill);
  box-shadow:
    inset 0 0 0 1.5px rgba(197,48,48,.4),
    0 6px 18px rgba(197,48,48,.12);
  pointer-events:none;
  user-select:none;
  z-index:2;
}

@media(max-width:760px){
  .ledger__sheet{padding:var(--s7) var(--s5);margin-inline:8px}
  .ledger__row{grid-template-columns:auto 1fr;row-gap:4px}
  .ledger__row > .ledger__amt{grid-column:2;justify-self:end}
  .ledger__row > .ledger__label{grid-column:2}
  .ledger__row > .ledger__no{grid-row:1 / span 2;align-self:center}
  .ledger__row::before{display:none}
  .ledger__total-amt{font-size:2rem}
  .ledger__stamp{font-size:.625rem;padding:6px 14px;right:var(--s4)}
}

/* ==========================================================
   VIDEO PROOF BLOCK — "See It Live" between audit & offer
   Reuses .exp__visual--vid + .vtm__play + .exp__badge--N.
   ========================================================== */
.vidblk__wrap{
  display:flex;justify-content:center;
  margin-top:var(--s12);
  padding:0 var(--s8);
}
.vidblk__wrap .exp__visual{margin:0}
.vidblk__wrap .exp__visual img{
  max-width:440px;
  border-radius:var(--r-xl);
  box-shadow:var(--sh-xl),var(--sh-glow);
}
@media(max-width:640px){
  .vidblk__wrap{padding:0}
  .vidblk__wrap .exp__visual img{max-width:90vw;aspect-ratio:4/3}
  .vidblk__wrap .exp__badge{display:none}
}

/* ==========================================================
   THE DAILY JOURNAL — six entries off your plate
   Brand-aligned: white card + 4px navy left bar + faded
   numeral in corner + pill category badge + tools strip.
   ========================================================== */
.jrn__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s5);margin-top:var(--s12);
}
.jrn__entry{
  position:relative;
  display:flex;flex-direction:column;
  background:var(--sf-card);
  border-radius:var(--r-lg);
  padding:var(--s8) var(--s7) var(--s7);
  box-shadow:var(--sh-md);
  overflow:hidden;
  transition:transform .5s cubic-bezier(.25,.46,.45,.94),box-shadow .5s ease;
}
.jrn__entry::before{
  /* Rivco signature: 4px left accent bar */
  content:'';position:absolute;
  top:var(--s5);bottom:var(--s5);left:0;width:4px;
  background:var(--pri);border-radius:0 4px 4px 0;
  transition:background .5s ease;
}
.jrn__entry:hover{
  box-shadow:var(--sh-xl),var(--sh-glow);
  transform:translateY(-6px) scale(1.01);
}
.jrn__entry:hover::before{background:var(--pri-ctr)}

/* Large faded numeral as design element (Rivco diff__num pattern) */
.jrn__num{
  position:absolute;top:var(--s5);right:var(--s7);
  font:800 3rem/1 var(--f-d);
  color:var(--pri);
  opacity:.14;
  letter-spacing:-.06em;
  font-variant-numeric:tabular-nums;
  pointer-events:none;user-select:none;
  transition:opacity .5s ease;
}
.jrn__entry:hover .jrn__num{opacity:.28}

/* Pill category badge */
.jrn__cat{
  display:inline-block;align-self:flex-start;
  font:700 .65rem/1 var(--f-l);
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--pri);
  padding:6px 12px;
  background:rgba(4,107,210,.06);
  border-radius:var(--r-pill);
  margin-bottom:var(--s4);
}
.jrn__h{
  font:800 1.125rem/1.3 var(--f-d);
  color:var(--on);
  letter-spacing:-.02em;
  margin:0 0 var(--s3);
  max-width:78%;
  transition:color .5s ease;
}
.jrn__entry:hover .jrn__h{color:var(--pri)}
.jrn__p{
  font:400 .9375rem/1.65 var(--f-b);
  color:var(--on-m);
  margin:0 0 var(--s5);
  flex:1;
}

/* Footer with light-blue gradient rule */
.jrn__foot{
  display:flex;flex-direction:column;gap:8px;
  padding-top:var(--s4);
  position:relative;
}
.jrn__foot::before{
  content:'';position:absolute;left:0;right:0;top:0;
  height:1px;
  background:linear-gradient(90deg,rgba(4,107,210,.18),rgba(147,197,253,.04));
}
.jrn__foot-lbl{
  font:700 .625rem/1 var(--f-l);
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--on-m);
}
.jrn__tools{
  display:flex;flex-wrap:wrap;gap:6px;
}
.jrn__tool{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 11px 5px 7px;
  background:rgba(4,107,210,.06);
  border-radius:var(--r-pill);
  transition:background .3s ease;
}
.jrn__entry:hover .jrn__tool{background:rgba(4,107,210,.1)}
.jrn__tool img{width:15px;height:15px;flex-shrink:0}
.jrn__tool span{
  font:700 .6875rem/1 var(--f-l);
  color:var(--on);
  white-space:nowrap;
}
.jrn__note{
  text-align:center;
  font:500 1rem/1.5 var(--f-q,'Instrument Serif',serif);
  font-style:italic;
  color:var(--pri);
  margin-top:var(--s10);
  opacity:.85;
}
@media(max-width:980px){
  .jrn__grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .jrn__grid{grid-template-columns:1fr}
}

/* ==========================================================
   AUDIT TRAIL — supervision as a Rivco statement card
   Brand-aligned: white doc, gradient rule, 3 ringed tier
   cards (gradient mask-composite ring), gradient YOU sig.
   ========================================================== */
.audit{
  background:
    radial-gradient(ellipse 700px 500px at 80% 30%,rgba(4,107,210,.08),transparent),
    radial-gradient(ellipse 500px 400px at 10% 80%,rgba(147,197,253,.1),transparent),
    var(--sf);
  position:relative;overflow:hidden;
}
.audit__doc{
  position:relative;
  max-width:920px;margin:var(--s12) auto 0;
  padding:var(--s10);
  background:var(--sf-card);
  border-radius:var(--r-lg);
  box-shadow:var(--sh-lg);
  overflow:hidden;
}
.audit__doc::before{
  /* faint diagonal watermark */
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:repeating-linear-gradient(
    135deg,
    transparent 0 28px,
    rgba(4,107,210,.025) 28px 29px
  );
  pointer-events:none;
}
.audit__doc-h{
  display:flex;justify-content:space-between;align-items:baseline;
  padding-bottom:var(--s4);
  margin-bottom:var(--s9);
  position:relative;
}
.audit__doc-h::after{
  content:'';position:absolute;left:0;right:0;bottom:0;
  height:2px;border-radius:1px;
  background:linear-gradient(90deg,var(--pri),var(--pri-ctr));
}
.audit__doc-title{
  font:800 .9375rem/1 var(--f-d);
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--on);
}
.audit__doc-meta{
  font:500 .8125rem/1 var(--f-l);
  color:var(--on-m);
  letter-spacing:.02em;
}

/* Three tier cards with gradient mask-composite ring */
.audit__stamps{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s5);
  margin-bottom:var(--s9);
  position:relative;
}
.audit__stamps::before{
  /* gradient connector behind tier cards */
  content:'';position:absolute;left:8%;right:8%;top:50%;
  height:1.5px;border-radius:1px;
  background:linear-gradient(90deg,
    rgba(4,107,210,0) 0%,
    rgba(4,107,210,.4) 12%,
    rgba(147,197,253,.55) 50%,
    rgba(4,107,210,.4) 88%,
    rgba(4,107,210,0) 100%);
  z-index:0;
}
.audit__stamp{
  position:relative;z-index:1;
  padding:var(--s7) var(--s5);
  background:var(--sf-card);
  border-radius:var(--r-lg);
  box-shadow:var(--sh-md);
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  overflow:hidden;
  transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s ease;
}
.audit__stamp::before{
  /* gradient ring like bonus cards */
  content:'';position:absolute;inset:0;
  border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg,var(--pri),var(--pri-ctr) 50%,#93C5FD);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;
  opacity:.55;
  transition:opacity .4s ease;
}
.audit__stamp:hover{
  transform:translateY(-4px);
  box-shadow:var(--sh-xl),var(--sh-glow);
}
.audit__stamp:hover::before{opacity:1}
.audit__stamp-tier{
  display:inline-flex;align-items:center;justify-content:center;
  font:800 .625rem/1 var(--f-l);
  letter-spacing:.14em;text-transform:uppercase;
  color:#fff;
  padding:6px 14px;
  background:linear-gradient(135deg,var(--pri),var(--pri-ctr));
  border-radius:var(--r-pill);
  box-shadow:0 4px 12px rgba(4,107,210,.28);
  margin-bottom:6px;
}
.audit__stamp-role{
  font:800 1.25rem/1.15 var(--f-d);
  color:var(--on);
  letter-spacing:-.01em;
  margin:6px 0 4px;
}
.audit__stamp-detail{
  font:400 .8125rem/1.5 var(--f-b);
  color:var(--on-m);
  max-width:200px;
}

/* Signature block with gradient YOU */
.audit__sig{
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  position:relative;
  padding-top:var(--s5);
}
.audit__sig::before{
  content:'';position:absolute;left:50%;top:0;
  width:300px;height:2px;border-radius:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,var(--pri),var(--pri-ctr),transparent);
}
.audit__sig-line{
  font:400 1rem/1.4 var(--f-q,'Instrument Serif',serif);
  font-style:italic;
  color:var(--on-m);
  margin-top:var(--s4);
}
.audit__sig-name{
  font:800 4.25rem/1 var(--f-d);
  background:linear-gradient(135deg,var(--pri),var(--pri-ctr));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  letter-spacing:.04em;
  margin:6px 0 var(--s3);
  text-shadow:0 0 50px rgba(4,107,210,.2);
}
.audit__sig-foot{
  display:flex;gap:var(--s2);flex-wrap:wrap;justify-content:center;
  margin-top:var(--s2);
}
.audit__sig-foot span{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 16px;
  background:rgba(4,107,210,.05);
  border-radius:var(--r-pill);
  font:700 .6875rem/1 var(--f-l);
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--pri);
}
@media(max-width:880px){
  .audit__doc{padding:var(--s8) var(--s5);margin-inline:8px}
  .audit__doc-h{flex-direction:column;gap:6px;align-items:flex-start}
  .audit__stamps{grid-template-columns:1fr;gap:var(--s4)}
  .audit__stamps::before{display:none}
  .audit__sig-name{font-size:3rem}
}

/* ==========================================================
   SERPENTINE PIPE — classy winding tube with stops
   ========================================================== */
.road-s{
  position:relative;
  padding:var(--s6) 0 0;
}

/* Central vertical pipe */
.road-s::before{
  content:'';position:absolute;
  top:24px;bottom:24px;
  left:22px;
  width:8px;
  background:linear-gradient(180deg,#046BD2 0%,#93C5FD 50%,#046BD2 100%);
  border-radius:8px;
  z-index:0;
  box-shadow:
    0 0 24px rgba(4,107,210,.2),
    0 0 8px rgba(147,197,253,.15),
    inset 0 1px 2px rgba(255,255,255,.2);
}

/* Glossy highlight on pipe */
.road-s::after{
  content:'';position:absolute;
  top:24px;bottom:24px;
  left:23px;
  width:3px;
  background:linear-gradient(180deg,rgba(255,255,255,.25),rgba(255,255,255,.05),rgba(255,255,255,.2));
  border-radius:3px;
  z-index:0;
}

.road-s__line{display:none}

.road-s__stop{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:14px;
  margin-bottom:var(--s4);
}
.road-s__stop:last-child{margin-bottom:0}

/* Horizontal arm from pipe to card */
.road-s__stop::before{
  content:'';position:absolute;
  top:50%;height:4px;
  left:26px;
  background:linear-gradient(90deg,#046BD2 0%,rgba(147,197,253,.3) 40%,rgba(147,197,253,.05) 100%);
  border-radius:4px;
  z-index:0;
  box-shadow:0 1px 4px rgba(4,107,210,.1);
}

/* Flush with pipe */
.road-s__stop--r{padding-left:0}
.road-s__stop--r::before{width:28px}

/* Indented zigzag - dramatic stagger */
.road-s__stop--l{padding-left:80px}
.road-s__stop--l::before{width:84px}

.road-s__dot{
  flex-shrink:0;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:linear-gradient(145deg,#0053A6,#046BD2);
  box-shadow:
    0 4px 20px rgba(4,107,210,.35),
    inset 0 2px 4px rgba(255,255,255,.15),
    inset 0 -1px 2px rgba(0,0,0,.1);
  font:800 .9rem/1 var(--f-l);
  color:#fff;
  border:3px solid #fff;
  position:relative;z-index:2;
}

.road-s__info{
  flex:1;
  background:var(--sf-card);
  padding:16px 20px;
  border-radius:var(--r-lg);
  box-shadow:0 2px 10px rgba(0,83,166,.06);
  border:1px solid rgba(0,83,166,.05);
  transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s ease;
  position:relative;z-index:1;
}
.road-s__info:hover{
  transform:translateY(-3px);
  box-shadow:var(--sh-md);
}
.road-s__info strong{
  display:block;
  font:700 .9375rem/1.3 var(--f-d);
  color:var(--on);
  margin-bottom:5px;
}
.road-s__info span{
  font:400 .8125rem/1.55 var(--f-b);
  color:var(--on-m);
}
.road-s__tools{
  display:flex;flex-wrap:wrap;gap:5px;margin-top:8px;
}
.road-s__tool-chip{
  display:flex;align-items:center;gap:4px;
  padding:2px 7px 2px 3px;
  background:rgba(0,83,166,.04);
  border-radius:5px;
  transition:background .3s ease;
}
.road-s__info:hover .road-s__tool-chip{
  background:rgba(0,83,166,.08);
}
.road-s__tools img{
  width:14px;height:14px;
  flex-shrink:0;
}
.road-s__tools span{
  font:600 .6rem/1 var(--f-l);
  color:var(--on-m);
  white-space:nowrap;
}
.road-s__note{
  margin-top:var(--s5);
  font:500 .8125rem/1.5 var(--f-l);
  color:var(--pri-ctr);
  padding-left:50px;
}

@media(max-width:768px){
  .road-s::before{left:18px;width:6px}
  .road-s::after{left:19px;width:2px}
  .road-s__stop--l{padding-left:0}
  .road-s__stop--l::before{width:32px}
  .road-s__dot{width:38px;height:38px;font-size:.8rem}
}

/* ==========================================================
   VALUE STACK — role detail pages (skills + bonus + anchor)
   ========================================================== */

/* Core skills section — premium glass cards on gradient mesh */
.vs{padding:var(--s16) 0}
.vs--skills{
  background:
    radial-gradient(ellipse 500px 350px at 10% 60%,rgba(4,107,210,.12),transparent),
    radial-gradient(ellipse 450px 400px at 90% 40%,rgba(147,197,253,.14),transparent),
    radial-gradient(ellipse 350px 250px at 50% 90%,rgba(0,83,166,.08),transparent),
    linear-gradient(160deg,#E8F0FB 0%,#F2F7FD 50%,#E5EDFA 100%);
  position:relative;overflow:hidden;
}

.vs__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:auto;
  gap:var(--s5);margin-top:var(--s10);
  position:relative;
}
.vs__skill--wide{grid-column:span 2}
.vs__skill{
  display:flex;flex-direction:column;
  padding:var(--s7) var(--s7);
  background:
    linear-gradient(145deg,rgba(255,255,255,.55),rgba(255,255,255,.2));
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-radius:20px;
  border:1px solid rgba(255,255,255,.45);
  box-shadow:
    0 8px 32px rgba(0,83,166,.06),
    0 1px 0 rgba(255,255,255,.6) inset;
  transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s ease,border-color .4s ease;
  position:relative;overflow:hidden;
}
.vs__skill::before{
  content:'';position:absolute;inset:0;
  border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg,rgba(147,197,253,.3),rgba(4,107,210,.1),rgba(147,197,253,.2));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;
  opacity:0;transition:opacity .4s ease;
}
.vs__skill:hover{
  transform:translateY(-6px);
  box-shadow:
    0 20px 48px rgba(0,83,166,.1),
    0 1px 0 rgba(255,255,255,.9) inset;
  border-color:rgba(147,197,253,.4);
}
.vs__skill:hover::before{opacity:1}
.vs__skill-icon{
  flex-shrink:0;width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,#0053A6,#046BD2);
  border-radius:16px;
  box-shadow:
    0 6px 20px rgba(4,107,210,.3),
    inset 0 1px 1px rgba(255,255,255,.2);
  margin-bottom:var(--s5);
}
.vs__skill-icon svg{color:#fff;width:24px;height:24px}

/* Tool logos cluster (replaces checkmark on pages with tool mapping) */
.vs__skill-logos{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-bottom:var(--s5);
}
.vs__skill-tool{
  display:flex;align-items:center;gap:5px;
  padding:3px 8px 3px 4px;
  background:rgba(0,83,166,.04);
  border-radius:6px;
  transition:background .3s ease;
}
.vs__skill:hover .vs__skill-tool{
  background:rgba(0,83,166,.08);
}
.vs__skill-logos img{
  width:18px;height:18px;
  flex-shrink:0;
}
.vs__skill-logos span{
  font:600 .65rem/1 var(--f-l);
  color:var(--on-m);
  white-space:nowrap;
}
.vs__skill-name{
  font:700 1.125rem/1.3 var(--f-d);
  color:var(--on);
  margin-bottom:6px;
}
.vs__skill-desc{
  font:400 .8125rem/1.65 var(--f-b);
  color:var(--on-m);
  flex:1;
}

/* Bonus section — dark glassmorphism with ambient light leaks */
.vs--bonus{
  background:#060e1a;
  position:relative;overflow:hidden;
}
.vs--bonus::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 500px at 10% 80%,rgba(4,107,210,.2),transparent),
    radial-gradient(ellipse 500px 400px at 90% 15%,rgba(147,197,253,.12),transparent),
    radial-gradient(ellipse 400px 350px at 50% 50%,rgba(0,83,166,.08),transparent);
  pointer-events:none;
}
.vs--bonus::after{
  content:'';position:absolute;
  top:-200px;right:-150px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(4,107,210,.1),transparent 60%);
  border-radius:50%;
  pointer-events:none;
  filter:blur(40px);
}
.vs__bonus{
  position:relative;
  padding:0;background:none;border:none;border-radius:0;
  text-align:center;
}
.vs__bonus::before{display:none}

.vs__bonus-badge{
  display:inline-flex;align-items:center;gap:6px;
  font:700 .75rem/1 var(--f-l);
  letter-spacing:.14em;text-transform:uppercase;
  color:#fff;
  background:linear-gradient(135deg,#0053A6,#046BD2);
  padding:10px 24px;border-radius:var(--r-pill);
  margin-bottom:var(--s5);
  box-shadow:
    0 4px 24px rgba(4,107,210,.5),
    0 0 80px rgba(4,107,210,.2);
}

.vs__bonus-h{
  font:800 2.25rem/1.15 var(--f-d);
  color:#fff;margin:0 auto var(--s2);
  letter-spacing:-.03em;
  max-width:700px;
}
.vs__bonus-h em{
  color:#93C5FD;font-style:normal;
}

.vs__bonus-sub{
  font:400 .9375rem/1.6 var(--f-b);
  color:rgba(255,255,255,.4);
  margin:0 auto var(--s7);max-width:580px;
}

.vs__bonus-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s6);text-align:left;
  margin-bottom:var(--s8);
}
.vs__bonus-card{
  padding:var(--s7) var(--s6);
  background:
    linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 8px 32px rgba(0,0,0,.2);
  position:relative;overflow:hidden;
  transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .35s ease,box-shadow .35s ease;
}
.vs__bonus-card::before{
  content:'';position:absolute;inset:0;
  border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg,#0053A6,#046BD2 40%,#93C5FD 70%,#046BD2);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;
  opacity:.8;transition:opacity .45s cubic-bezier(.16,1,.3,1);
}
.vs__bonus-card:hover{
  transform:translateY(-6px);
  box-shadow:
    0 20px 48px rgba(0,0,0,.3),
    0 0 40px rgba(4,107,210,.15),
    0 0 60px rgba(147,197,253,.08);
}
.vs__bonus-card:hover::before{
  opacity:1;
  padding:2.5px;
  filter:brightness(1.3);
}
.vs__bonus-card h4{
  font:700 1.0625rem/1.3 var(--f-d);
  color:#fff;margin:0 0 10px;
}
.vs__bonus-card p{
  font:400 .875rem/1.65 var(--f-b);
  color:rgba(255,255,255,.4);margin:0;
}

/* Price showdown */
.vs__showdown{
  max-width:640px;margin:0 auto var(--s6);
  text-align:center;
  padding:var(--s7) 0;
  border-top:1px solid rgba(147,197,253,.08);
}
.vs__showdown-row{
  display:flex;align-items:center;justify-content:center;
  gap:var(--s8);margin-bottom:var(--s2);
}
.vs__showdown-side{text-align:center}
.vs__showdown-label{
  font:700 .6rem/1 var(--f-l);
  letter-spacing:.12em;text-transform:uppercase;
  display:block;margin-bottom:10px;
}
.vs__showdown-price{
  font:800 3.5rem/1 var(--f-d);
  letter-spacing:-.04em;display:block;
}
.vs__showdown-price small{font-weight:600;font-size:.3em;letter-spacing:0;vertical-align:middle}

/* The loser */
.vs__showdown-old .vs__showdown-label{color:rgba(255,120,120,.4)}
.vs__showdown-old .vs__showdown-price{
  color:rgba(255,255,255,.18);
}
.vs__showdown-old .vs__showdown-num{
  text-decoration:line-through;
  text-decoration-color:rgba(255,80,80,.7);
  text-decoration-thickness:4px;
}
.vs__showdown-old .vs__showdown-price small{
  color:rgba(255,255,255,.12);
}

/* Arrow */
.vs__showdown-arrow{
  font-size:2rem;color:rgba(147,197,253,.3);
  flex-shrink:0;
}

/* The winner */
.vs__showdown-new .vs__showdown-label{color:#93C5FD}
.vs__showdown-new .vs__showdown-price{
  color:#fff;
  text-shadow:0 0 50px rgba(147,197,253,.35),0 0 100px rgba(4,107,210,.15);
}

/* Save badge */
.vs__showdown-save{
  margin-top:var(--s6);
  display:flex;align-items:center;justify-content:center;gap:var(--s5);
}
.vs__showdown-pct{
  display:inline-flex;align-items:center;justify-content:center;
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,#0053A6,#046BD2);
  box-shadow:0 4px 30px rgba(4,107,210,.5),0 0 60px rgba(4,107,210,.15);
  font:800 1.25rem/1 var(--f-d);
  color:#fff;letter-spacing:-.02em;
}
.vs__showdown-text{text-align:left}
.vs__showdown-text span{
  display:block;
  font:500 .7rem/1 var(--f-l);
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.35);
  margin-bottom:6px;
}
.vs__showdown-text strong{
  display:block;
  font:800 1.625rem/1.2 var(--f-d);
  color:#fff;letter-spacing:-.02em;
  margin-bottom:10px;
}
.vs__showdown-text em{
  display:block;
  font:600 1.0625rem/1 var(--f-l);
  color:#93C5FD;font-style:normal;
}

.vs__bonus-cta{
  text-align:center;margin-top:var(--s7);
}

@media(max-width:768px){
  .vs__grid{grid-template-columns:1fr}
  .vs__skill--wide{grid-column:span 1}
  .vs__bonus-h{font-size:1.75rem}
  .vs__bonus-grid{grid-template-columns:1fr}
  .vs__showdown-row{flex-direction:column;gap:var(--s4)}
  .vs__showdown-price{font-size:2.5rem}
  .vs__showdown-arrow{transform:rotate(90deg)}
  .vs__showdown-save{flex-direction:column;text-align:center}
  .vs__showdown-text{text-align:center}
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media(max-width:1024px){
  .sec{padding:var(--s24) 0}
  .hero{padding:var(--s24) 0}
  .hero__h{font-size:2.75rem}
  .sec__h{font-size:2.125rem}
  .srv__grid{grid-template-columns:repeat(2,1fr)}
  .mega,.hdr__chev{display:none}
  .roles-mod__grid{grid-template-columns:repeat(3,1fr)}
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento__card--wide{grid-column:span 2}
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:var(--s10)}
  .stats__num{font-size:2.5rem}
  .fcta{padding:var(--s24) 0}
}

@media(min-width:769px) and (max-width:1024px){
  .hdr__links,
  .hdr__ph,
  .hdr__nav .btn--nav,
  .mega,
  .hdr__chev{display:none!important}
  .hdr__nav{margin-left:auto!important;gap:0!important;width:auto!important;max-width:none!important;min-width:0!important;flex:0 0 auto!important}
  .mob{display:flex!important}
}

@media(max-width:768px){
  html,
  body{
    max-width:100%;
    overflow-x:hidden;
  }

  .elementor,
  .elementor-section-wrap,
  .elementor-widget-container,
  .site,
  .site-content{
    max-width:100%;
    overflow-x:hidden;
  }

  .sec{padding:var(--s16) 0}
  .hdr__links,.hdr__ph{display:none}
  .hdr__nav .btn--nav{display:none}
  .mob{display:flex}

  .ann{
    white-space:normal!important;
    padding-inline:var(--s4)!important;
  }

  .hero{padding:var(--s16) 0 var(--s20)}
  .hero__grid{grid-template-columns:minmax(0,1fr);gap:var(--s10);width:100%;min-width:0;max-width:100%}
  .ctr,
  .hero__content,
  .hero__vis{
    min-width:0;
    max-width:100%;
  }
  .hdr__in,
  .hdr__nav,
  .hero__grid > *,
  .hero__content{
    width:100%;
    min-width:0;
    max-width:calc(100vw - (var(--s4) * 2));
    box-sizing:border-box;
  }
  .hdr__in,
  .hdr__nav{
    max-width:100%;
  }
  .hero__grid--c{
    max-width:calc(100vw - (var(--s4) * 2));
  }
  .hero__img{max-width:100%}
  .hero__h{font-size:2.125rem}
  .hero__h,
  .hero__p{
    width:calc(100vw - (var(--s4) * 2))!important;
    max-width:100%;
    overflow-wrap:break-word;
  }
  .elementor .hero__h,
  .elementor .hero--home .hero__h{
    font-size:2.125rem!important;
  }
  .hero__vis{order:-1}
  .hero__fl{display:none}

  .aud__grid,.proc__grid,.why__grid,.test__grid,.vals__grid{grid-template-columns:1fr}
  .feat__grid{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr}
  .bento__card--wide{grid-column:span 1}
  .bento__inner{flex-direction:column}
  .split{grid-template-columns:1fr;gap:var(--s8)}
  .split--rev{direction:ltr}
  .proc__grid::before{display:none}
  .price__grid{grid-template-columns:1fr;max-width:420px}
  .sec__h{font-size:1.625rem}

  .cmp__wrap{margin:0 -24px;padding:0 24px}
  .cmp{min-width:560px}

  .fcta__form{grid-template-columns:1fr}

  .ftr__grid{grid-template-columns:1fr 1fr;gap:var(--s8)}
  .ftr__bot{flex-direction:column;gap:var(--s4);text-align:center}

  .about__grid,.contact__grid,.srvd__grid{grid-template-columns:1fr}
  .roles-mod__grid{grid-template-columns:1fr}
  .roles-hero{padding:var(--s8) var(--s6) var(--s7)}
  .roles-hero__stats{grid-template-columns:repeat(2,1fr);gap:var(--s5) var(--s4)}
  .roles-hero__stat + .roles-hero__stat{padding-left:0}
  .roles-hero__stat + .roles-hero__stat::before{display:none}
  .roles-hero__stats .roles-hero__stat:nth-child(2)::before,
  .roles-hero__stats .roles-hero__stat:nth-child(4)::before{display:none}
  .roles-hero__h{font-size:1.375rem}
  .roles-hero__finder{padding:12px 16px 12px 20px}
  .roles-hero__finder input{font-size:.875rem}
  .roles-hero__kbd{display:none}
  .roles-nav{gap:6px}
  .roles-nav__chip{font-size:.6875rem;padding:6px 10px 6px 8px}
  .roles-mod__head{grid-template-columns:1fr;gap:var(--s3)}
  .roles-mod__num{font-size:1.625rem}
  .roles-mod__title{font-size:1.125rem}
  .roles-mod__count{margin-left:0}
}

@media(max-width:480px){
  .hero__h{font-size:1.625rem}
  .elementor .hero__h,
  .elementor .hero--home .hero__h{
    font-size:1.4375rem!important;
    line-height:1.14!important;
  }
  .hero__h em{
    display:block;
  }
  .hero__p{
    font-size:1rem!important;
  }
  .ann{
    font-size:.625rem!important;
    line-height:1.35!important;
    padding-inline:8px!important;
  }
  .hero__acts{flex-direction:column}
  .hero__acts .btn{width:100%;justify-content:center}
  .hero__trust{flex-direction:column;gap:var(--s2)}
  .srv__grid{grid-template-columns:1fr}
  .ftr__grid{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:1fr 1fr}
  .stats__num{font-size:2rem}
}

@media(max-width:640px){
  .elementor .hero__h,
  .elementor .hero--home .hero__h{
    font-size:1.4375rem!important;
    line-height:1.14!important;
  }

  .hero__h em{
    display:block;
  }

  .hero__p{
    width:auto!important;
    max-width:280px!important;
    font-size:1rem!important;
  }

  .ann{
    white-space:normal!important;
    padding-inline:var(--s6)!important;
    font:500 .75rem/1.4 var(--f-l)!important;
    letter-spacing:.02em!important;
    overflow-wrap:normal;
    word-break:normal;
  }

  .hero__grid--c .hero__p{
    margin-inline:auto;
  }

  .hero__metrics{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:var(--s5) var(--s6);
    max-width:280px;
    margin-inline:auto;
  }

  .sec__h{
    max-width:320px;
    margin-inline:auto;
    overflow-wrap:break-word;
  }
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .rv{opacity:1;transform:none}
  .logos__track{animation:none;flex-wrap:wrap;justify-content:center}
}

body.elementor-editor-active .rv,
body.elementor-editor-preview .rv,
.elementor-editor-active .rv,
.elementor-editor-preview .rv,
.e-editor-active .rv{
  opacity:1!important;
  transform:none!important;
  transition:none!important;
}

.elementor-widget-rivco-announcement-bar,
.elementor-widget-rivco-header,
.elementor-widget-rivco-about-hero,
.elementor-widget-rivco-about-origin,
.elementor-widget-rivco-about-mission-vision,
.elementor-widget-rivco-about-values,
.elementor-widget-rivco-about-stats,
.elementor-widget-rivco-about-parent-company,
.elementor-widget-rivco-about-structure,
.elementor-widget-rivco-final-cta,
.elementor-widget-rivco-footer{
  margin-bottom:0!important;
}

.elementor-widget-rivco-announcement-bar>.elementor-widget-container,
.elementor-widget-rivco-header>.elementor-widget-container,
.elementor-widget-rivco-about-hero>.elementor-widget-container,
.elementor-widget-rivco-about-origin>.elementor-widget-container,
.elementor-widget-rivco-about-mission-vision>.elementor-widget-container,
.elementor-widget-rivco-about-values>.elementor-widget-container,
.elementor-widget-rivco-about-stats>.elementor-widget-container,
.elementor-widget-rivco-about-parent-company>.elementor-widget-container,
.elementor-widget-rivco-about-structure>.elementor-widget-container,
.elementor-widget-rivco-final-cta>.elementor-widget-container,
.elementor-widget-rivco-footer>.elementor-widget-container{
  margin:0!important;
  padding:0!important;
}

/* ==========================================================
   BLOG PAGE
   ========================================================== */

/* Hero */
.blog__hero{
  background:linear-gradient(165deg,#000A18 0%,#001230 25%,#001E50 50%,#003070 75%,#0053A6 100%);
  padding:120px 0 80px;position:relative;overflow:hidden;color:#fff;
}
.blog__hero::before{
  content:'';position:absolute;top:-20%;left:50%;transform:translateX(-50%);
  width:1000px;height:600px;
  background:radial-gradient(ellipse,rgba(4,107,210,.2) 0%,transparent 60%);
  pointer-events:none;
}
.blog__hero .ctr{position:relative;z-index:1;text-align:center}
.blog__hero-tag{
  display:inline-block;padding:8px 18px;border-radius:var(--r-pill);
  background:rgba(4,107,210,.15);color:#93C5FD;
  font:700 .6875rem/1 var(--f-l);letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:var(--s5);border:1px solid rgba(147,197,253,.15);
}
.blog__hero-h{
  font:800 3.5rem/1.05 var(--f-d);color:#fff;letter-spacing:-.04em;
  margin-bottom:var(--s5);max-width:820px;margin-left:auto;margin-right:auto;
}
.blog__hero-h em{
  font-style:normal;
  background:linear-gradient(135deg,#4A9AE8,#93C5FD);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.blog__hero-p{
  font:400 1.125rem/1.65 var(--f-b);color:rgba(255,255,255,.65);
  max-width:620px;margin-inline:auto;margin-bottom:var(--s7);
  text-align:center;
}
.blog__hero-meta{
  display:flex;justify-content:center;gap:var(--s6);flex-wrap:wrap;margin-bottom:var(--s8);
}
.blog__hero-meta span{
  display:inline-flex;align-items:center;gap:6px;
  font:500 .8125rem/1 var(--f-l);color:rgba(255,255,255,.7);
  text-transform:uppercase;letter-spacing:.05em;
}
.blog__hero-meta span svg{color:#2ED573}
.blog__search{
  display:flex;align-items:center;gap:12px;max-width:540px;margin:0 auto;
  background:rgba(255,255,255,.06);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:var(--r-pill);padding:4px 4px 4px 22px;
  border:1px solid rgba(255,255,255,.1);
  transition:all .3s ease;
}
.blog__search:focus-within{
  background:rgba(255,255,255,.1);
  border-color:rgba(147,197,253,.35);
  box-shadow:0 0 0 4px rgba(4,107,210,.15);
}
.blog__search svg{color:rgba(255,255,255,.5);flex-shrink:0}
.blog__search input{
  flex:1;background:transparent;border:none;outline:none;
  font:400 .9375rem/1 var(--f-b);color:#fff;padding:14px 0;
}
.blog__search input::placeholder{color:rgba(255,255,255,.35)}

/* Category filter bar */
.blog__filter{
  position:sticky;top:72px;z-index:30;
  background:rgba(245,250,255,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:0 2px 8px rgba(0,83,166,.06);
  padding:var(--s4) 0;
}
.blog__cats{
  display:flex;gap:var(--s2);justify-content:center;flex-wrap:wrap;
}
.blog__cat{
  background:rgba(4,107,210,.04);border:2px solid transparent;
  padding:10px 20px;border-radius:var(--r-pill);
  font:600 .75rem/1 var(--f-l);color:var(--on);
  letter-spacing:.05em;text-transform:uppercase;
  cursor:pointer;transition:all .3s ease;position:relative;
}
.blog__cat::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(135deg,#0053A6,#046BD2 40%,#93C5FD 70%,#046BD2);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;opacity:0;transition:opacity .3s ease;
}
.blog__cat:hover{color:var(--pri)}
.blog__cat:hover::before{opacity:.4}
.blog__cat.on{
  background:var(--grad);color:#fff;
  box-shadow:0 4px 16px rgba(4,107,210,.2);
}
.blog__cat.on::before{opacity:0}

.blog__featured-sec{padding-top:var(--s10)}

/* Featured post */
.blog__featured{
  display:grid;grid-template-columns:1fr 1.1fr;gap:0;
  background:var(--sf-card);border-radius:var(--r-xl);overflow:hidden;
  box-shadow:0 12px 40px rgba(0,83,166,.1);
  transition:all .5s cubic-bezier(.25,.46,.45,.94);
  text-decoration:none;color:inherit;
  position:relative;
}
.blog__featured::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(135deg,#0053A6,#046BD2 40%,#93C5FD 70%,#046BD2);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;opacity:.25;transition:opacity .4s ease;z-index:3;
}
.blog__featured:hover::before{opacity:.6}
.blog__featured:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 60px rgba(0,83,166,.18),0 0 40px rgba(4,107,210,.1);
}
.blog__featured-media{
  position:relative;overflow:hidden;min-height:380px;
}
.blog__featured-media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s ease;
}
.blog__featured:hover .blog__featured-media img{transform:scale(1.04)}
.blog__featured-cat{
  position:absolute;top:var(--s4);left:var(--s4);
  background:var(--grad);color:#fff;
  padding:6px 14px;border-radius:var(--r-pill);
  font:700 .625rem/1 var(--f-l);letter-spacing:.1em;text-transform:uppercase;
  box-shadow:0 4px 16px rgba(4,107,210,.25);
}
.blog__featured-body{
  padding:var(--s8);display:flex;flex-direction:column;justify-content:center;
}
.blog__featured-meta{
  display:flex;gap:var(--s4);margin-bottom:var(--s4);
  font:500 .75rem/1 var(--f-l);color:var(--on-m);
  text-transform:uppercase;letter-spacing:.06em;
}
.blog__featured-meta span{display:inline-flex;align-items:center;gap:6px}
.blog__featured-meta span svg{color:var(--pri-ctr)}
.blog__featured-h{
  font:800 1.875rem/1.15 var(--f-d);color:var(--on);
  letter-spacing:-.02em;margin-bottom:var(--s4);
}
.blog__featured-h em{font-style:normal;color:var(--pri-ctr)}
.blog__featured-excerpt{
  font:400 1rem/1.65 var(--f-b);color:var(--on-m);
  margin-bottom:var(--s5);
}
.blog__featured-cta{
  display:inline-flex;align-items:center;gap:8px;
  font:700 .8125rem/1 var(--f-l);color:var(--pri-ctr);
  text-transform:uppercase;letter-spacing:.06em;
  transition:gap .3s ease;
}
.blog__featured:hover .blog__featured-cta{gap:14px}

/* Article grid */
.blog__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);
}
.blog__card{
  background:var(--sf-card);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:0 4px 20px rgba(0,83,166,.05);
  transition:all .5s cubic-bezier(.25,.46,.45,.94);
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
  position:relative;
}
.blog__card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(135deg,#0053A6,#046BD2 40%,#93C5FD 70%,#046BD2);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;opacity:0;transition:opacity .4s ease;z-index:3;
}
.blog__card:hover::before{opacity:.8}
.blog__card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 48px rgba(0,83,166,.15),0 0 40px rgba(4,107,210,.1);
}
.blog__card-media{
  position:relative;overflow:hidden;aspect-ratio:16/10;
}
.blog__card-media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s ease;
}
.blog__card:hover .blog__card-media img{transform:scale(1.06)}
.blog__card-cat{
  position:absolute;top:12px;left:12px;
  background:rgba(0,83,166,.92);color:#fff;backdrop-filter:blur(8px);
  padding:5px 12px;border-radius:var(--r-pill);
  font:700 .5625rem/1 var(--f-l);letter-spacing:.1em;text-transform:uppercase;
}
.blog__card-body{
  padding:var(--s5) var(--s5) var(--s5);display:flex;flex-direction:column;flex:1;
}
.blog__card h3{
  font:700 1.0625rem/1.3 var(--f-d);color:var(--on);
  letter-spacing:-.01em;margin-bottom:var(--s3);
}
.blog__card h3 em{font-style:normal;color:var(--pri-ctr)}
.blog__card p{
  font:400 .875rem/1.55 var(--f-b);color:var(--on-m);
  margin-bottom:var(--s4);flex:1;
}
.blog__card-meta{
  display:flex;gap:var(--s4);margin-top:auto;
  font:500 .6875rem/1 var(--f-l);color:var(--on-m);
  text-transform:uppercase;letter-spacing:.06em;
  padding-top:var(--s3);
}
.blog__card-meta span{display:inline-flex;align-items:center;gap:4px}
.blog__card-meta svg{color:var(--pri-ctr)}

/* Empty state */
.blog__empty{
  display:none;text-align:center;padding:var(--s12) var(--s4);
}
.blog__empty.on{display:block}
.blog__empty h3{
  font:700 1.5rem/1.3 var(--f-d);color:var(--on);margin-bottom:var(--s3);
}
.blog__empty p{
  font:400 1rem/1.6 var(--f-b);color:var(--on-m);
  margin-bottom:var(--s5);max-width:420px;margin-left:auto;margin-right:auto;
}

/* Pagination */
.blog__pag{
  display:flex;align-items:center;justify-content:center;gap:var(--s2);
  margin-top:var(--s12);
}
.blog__pag-num,.blog__pag-btn{
  display:flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:var(--r-lg);
  font:600 .875rem/1 var(--f-l);color:var(--on-m);
  text-decoration:none;transition:all .2s ease;
}
.blog__pag-num:hover,.blog__pag-btn:hover:not([aria-disabled="true"]){
  background:var(--sf-low);color:var(--on);
}
.blog__pag-num.active{
  background:var(--grad);color:#fff;
  box-shadow:0 4px 12px rgba(0,83,166,.25);
}
.blog__pag-btn{color:var(--pri-ctr)}
.blog__pag-btn[aria-disabled="true"]{
  opacity:.3;pointer-events:none;
}
.blog__pag-dots{
  font:600 .875rem/1 var(--f-l);color:var(--on-m);
  width:44px;text-align:center;letter-spacing:2px;
}

/* Newsletter */
.blog__newsletter{
  background:linear-gradient(165deg,#000D1F 0%,#001230 20%,#002660 50%,#003A8C 80%,#0053A6 100%);
  color:#fff;position:relative;overflow:hidden;
}
.blog__newsletter::after{
  content:'';position:absolute;top:35%;right:12%;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(96,165,250,.04) 0%,transparent 55%);
  pointer-events:none;
}
.blog__news-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:var(--s16);align-items:center;
  position:relative;z-index:1;
}
.blog__news-tag{
  display:inline-block;padding:8px 18px;border-radius:var(--r-pill);
  background:rgba(96,165,250,.1);color:#93C5FD;border:1px solid rgba(96,165,250,.18);
  font:700 .6875rem/1 var(--f-l);letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:var(--s5);
}
.blog__news-text h2{
  font:800 2.75rem/1.05 var(--f-d);color:#fff;letter-spacing:-.03em;
  margin-bottom:var(--s5);
}
.blog__news-text h2 em{
  font-style:normal;
  background:linear-gradient(135deg,#60A5FA,#93C5FD);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.blog__news-text>p{
  font:400 1.0625rem/1.7 var(--f-b);color:rgba(255,255,255,.65);
  margin-bottom:var(--s6);max-width:480px;
}
.blog__news-list{
  list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s3);
}
.blog__news-list li{
  display:flex;align-items:center;gap:10px;
  font:500 .9375rem/1.4 var(--f-b);color:rgba(255,255,255,.75);
}
.blog__news-list svg{color:#2ED573;flex-shrink:0}
.blog__news-proof{
  display:flex;align-items:baseline;gap:8px;margin-top:var(--s8);
  font:400 .9375rem/1.4 var(--f-b);color:rgba(255,255,255,.45);
}
.blog__news-proof strong{
  font:800 1.375rem/1 var(--f-d);letter-spacing:-.02em;
  background:linear-gradient(135deg,#60A5FA,#93C5FD);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* Newsletter form card */
.blog__news-form{
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-radius:var(--r-xl);padding:var(--s8);
  position:relative;
  box-shadow:0 16px 48px rgba(0,83,166,.18),0 0 80px rgba(4,107,210,.06);
}
.blog__news-form::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(160deg,rgba(251,191,36,.5),rgba(245,158,11,.15) 30%,rgba(253,230,138,.4) 50%,rgba(245,158,11,.1) 70%,rgba(251,191,36,.3));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;
}
.blog__news-form-top{
  display:flex;align-items:center;gap:10px;
  font:600 .75rem/1 var(--f-l);color:rgba(255,255,255,.45);
  text-transform:uppercase;letter-spacing:.12em;
  margin-bottom:var(--s6);
}
.blog__news-form-top svg{color:rgba(251,191,36,.55)}
.blog__news-combo{
  display:flex;align-items:stretch;
  background:rgba(0,0,0,.3);
  border-radius:var(--r-pill);
  padding:6px 6px 6px 24px;
  margin-bottom:var(--s4);
  border:1px solid rgba(255,255,255,.08);
  transition:border-color .3s ease,box-shadow .3s ease;
}
.blog__news-combo:focus-within{
  border-color:rgba(251,191,36,.25);
  box-shadow:0 0 0 4px rgba(251,191,36,.06);
}
.blog__news-combo input{
  flex:1;background:transparent;border:none;outline:none;
  font:400 .9375rem/1 var(--f-b);color:#fff;
  padding:0 12px 0 0;min-width:0;
}
.blog__news-combo input::placeholder{color:rgba(255,255,255,.3)}
.blog__news-combo .btn{
  flex-shrink:0;white-space:nowrap;
  padding:14px 28px;border-radius:var(--r-pill);
}
.blog__news-foot{
  font:400 .75rem/1.4 var(--f-b);color:rgba(255,255,255,.35);
  text-align:center;margin-top:var(--s2);
}
.blog__news-success{
  display:none;margin-top:var(--s4);padding:var(--s4);
  background:rgba(46,213,115,.1);border:1px solid rgba(46,213,115,.25);
  border-radius:var(--r-md);
  font:500 .875rem/1.5 var(--f-b);color:#2ED573;
  align-items:center;gap:10px;
}
.blog__news-success.on{display:flex}
.blog__news-success strong{color:#fff;font-weight:700;margin-right:4px}

/* Author / behind the blog */
.blog__author-card{
  background:var(--sf-card);border-radius:var(--r-xl);
  padding:var(--s10);
  display:grid;grid-template-columns:1fr 1.3fr;gap:var(--s10);
  box-shadow:0 8px 32px rgba(0,83,166,.06);
  position:relative;
}
.blog__author-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;
  background:linear-gradient(135deg,#0053A6,#046BD2 40%,#93C5FD 70%,#046BD2);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask-composite:exclude;
  pointer-events:none;opacity:.3;
}
.blog__author-h{
  font:800 2rem/1.15 var(--f-d);color:var(--on);
  letter-spacing:-.03em;margin-top:var(--s4);
}
.blog__author-h em{font-style:normal;color:var(--pri-ctr)}
.blog__author-body p{
  font:400 1rem/1.75 var(--f-b);color:var(--on-m);
  margin-bottom:var(--s4);
}
.blog__author-body p:last-child{margin-bottom:0}
.blog__author-sig{
  font:italic 500 1.125rem/1.55 var(--f-q)!important;
  color:var(--pri)!important;
  letter-spacing:-.005em;
  margin-top:var(--s5);
}

/* Blog CTA overrides */
.blog__cta .sec__tag{color:rgba(255,255,255,.7);background:rgba(255,255,255,.06)}
.blog__cta .sec__h{color:#fff;font-size:2.75rem;margin-top:var(--s5)}
.blog__cta .sec__h em{color:#93C5FD}
.blog__cta .sec__p{color:rgba(255,255,255,.7);margin:0 auto var(--s10)}

/* Responsive */
@media(max-width:900px){
  .blog__hero-h{font-size:2.5rem}
  .blog__featured{grid-template-columns:1fr}
  .blog__featured-media{min-height:240px}
  .blog__featured-body{padding:var(--s6)}
  .blog__featured-h{font-size:1.5rem}
  .blog__grid{grid-template-columns:repeat(2,1fr);gap:var(--s4)}
  .blog__news-grid{grid-template-columns:1fr;gap:var(--s8)}
  .blog__news-text h2{font-size:2rem}
  .blog__author-card{grid-template-columns:1fr;gap:var(--s5);padding:var(--s7)}
  .blog__author-h{font-size:1.625rem}
}
@media(max-width:600px){
  .blog__hero{padding:80px 0 60px}
  .blog__hero-h{font-size:2rem}
  .blog__hero-p{font-size:1rem}
  .blog__hero-meta{gap:var(--s4);font-size:.6875rem}
  .blog__search{margin:0 var(--s2)}
  .blog__filter{top:72px}
  .blog__grid{grid-template-columns:1fr}
  .blog__cats{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding:0 var(--s4);margin:0 calc(var(--s4)*-1)}
  .blog__cat{flex-shrink:0}
  .blog__news-text h2{font-size:1.625rem}
  .blog__news-combo{
    flex-direction:column;padding:var(--s3);gap:var(--s2);
    border-radius:var(--r-xl);
  }
  .blog__news-combo input{padding:14px 16px;text-align:center}
  .blog__news-combo .btn{width:100%;justify-content:center;padding:14px 24px}
  .blog__news-form{padding:var(--s6)}
  .blog__news-proof{flex-direction:column;gap:4px;align-items:flex-start}
  .blog__cta .sec__h{font-size:2rem}
  .blog__author-card{padding:var(--s5)}
  .blog__author-h{font-size:1.375rem}
}
