/* ============================================================
   PREGASUS ENTERPRISES — Brand stylesheet
   Brand: Red #E80011 · Black #111 · White · Grey #595959
   ============================================================ */

:root{
  --red:#e80011;
  --red-dark:#c00010;
  --red-soft:#fde7e4;
  --ink:#111114;
  --ink-2:#1a1a1a;
  --grey:#595959;
  --muted:#6b7280;
  --line:#e8e8ea;
  --line-2:#ededf0;
  --bg:#ffffff;
  --bg-soft:#f6f6f8;
  --bg-soft-2:#f1f1f4;
  --dark:#0c0c0f;
  --dark-2:#141418;
  --dark-3:#1d1d23;
  --white:#ffffff;

  --maxw:1200px;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(17,17,20,.06), 0 1px 3px rgba(17,17,20,.05);
  --shadow:0 10px 30px -12px rgba(17,17,20,.18);
  --shadow-lg:0 30px 60px -20px rgba(17,17,20,.28);
  --ease:cubic-bezier(.22,.61,.36,1);

  --font:"Inter","Segoe UI",-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;
  --display:"Space Grotesk","Inter","Segoe UI",-apple-system,Helvetica,Arial,sans-serif;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin:0}
p{margin:0}
button{font-family:inherit}
:focus-visible{outline:3px solid rgba(232,0,17,.5);outline-offset:3px;border-radius:6px}
::selection{background:var(--red);color:#fff}

/* ---------- layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.section{padding:104px 0}
.section--soft{background:var(--bg-soft)}
.section--dark{background:var(--dark);color:#e9e9ee}
.section--tight{padding:72px 0}

.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--red);margin-bottom:18px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);border-radius:2px}
.section--dark .eyebrow{color:#ff5660}
.section--dark .eyebrow::before{background:#ff5660}

.section-head{max-width:720px;margin-bottom:56px}
.section-head.center{margin-inline:auto;text-align:center}
.section-head.center .eyebrow::before{display:none}
.h-xl{font-size:clamp(2.4rem,5vw,3.7rem)}
.h-lg{font-size:clamp(2rem,3.6vw,2.9rem)}
.h-md{font-size:clamp(1.5rem,2.4vw,2rem)}
.lead{font-size:clamp(1.05rem,1.4vw,1.22rem);color:var(--grey);margin-top:18px}
.section--dark .lead{color:#b7b7c2}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:14px 26px;border-radius:999px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease),color .2s,border-color .2s;
  white-space:nowrap;
}
.btn svg{width:17px;height:17px}
.btn--primary{background:var(--red);color:#fff;box-shadow:0 10px 24px -10px rgba(232,0,17,.7)}
.btn--primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(232,0,17,.75)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--light{background:#fff;color:var(--ink)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--on-dark{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
.btn--on-dark:hover{border-color:#fff;background:rgba(255,255,255,.07);transform:translateY(-2px)}
.btn--lg{padding:17px 34px;font-size:16px}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px -18px rgba(0,0,0,.4)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.brand{display:flex;align-items:center;gap:0;flex-shrink:0}
.brand img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{
  font-family:var(--display);font-weight:500;font-size:15px;color:var(--ink-2);
  position:relative;padding:6px 0;transition:color .2s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--red);
  transition:width .28s var(--ease);
}
.nav-links a:hover{color:var(--red)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--ink)}
.nav-links .btn{display:none}      /* duplicate CTA: shown only inside mobile menu */
.nav-links .btn::after{display:none}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;position:relative}
.nav-toggle span{position:absolute;left:10px;right:10px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
.nav-toggle span:nth-child(1){top:15px}
.nav-toggle span:nth-child(2){top:21px}
.nav-toggle span:nth-child(3){top:27px}
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:var(--dark);color:#fff;overflow:hidden;isolation:isolate}
.hero__stripe{position:absolute;top:0;left:0;height:100%;width:18px;display:flex;z-index:2}
.hero__stripe i{height:100%}
.hero__stripe i:nth-child(1){width:7px;background:var(--red)}
.hero__stripe i:nth-child(2){width:5px;background:#000}
.hero__bg{position:absolute;inset:0;z-index:0;opacity:.9}
.hero__bg::before{
  content:"";position:absolute;width:640px;height:640px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,0,17,.32),transparent 62%);
  top:-180px;right:-120px;filter:blur(10px);
}
.hero__bg::after{
  content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,0,17,.14),transparent 60%);
  bottom:-220px;left:-80px;
}
.hero__grid{
  position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 70% at 60% 30%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 60% 30%,#000 30%,transparent 80%);
}
.hero__inner{position:relative;z-index:3;padding:118px 0 124px;max-width:860px}
.hero__tag{
  display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  font-family:var(--display);font-size:13px;letter-spacing:.04em;color:#d9d9e2;margin-bottom:26px;
}
.hero__tag .dot{width:7px;height:7px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px rgba(232,0,17,.25)}
.hero h1{font-size:clamp(2.7rem,6vw,4.6rem);letter-spacing:-.03em;line-height:1.03}
.hero h1 .accent{color:var(--red)}
.hero__sub{font-size:clamp(1.08rem,1.7vw,1.34rem);color:#bfbfca;margin-top:24px;max-width:660px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.hero__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:46px}
.hero__chips span{
  font-family:var(--display);font-size:13.5px;font-weight:500;color:#cfcfd8;
  padding:8px 15px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);
}

/* ---------- trust / stats bar ---------- */
.stripbar{background:var(--ink);color:#fff;border-top:3px solid var(--red)}
.stripbar .container{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding-block:40px}
.stat{display:flex;flex-direction:column;gap:4px}
.stat__num{font-family:var(--display);font-weight:700;font-size:clamp(2rem,3.4vw,2.7rem);letter-spacing:-.02em;line-height:1}
.stat__num em{color:var(--red);font-style:normal}
.stat__label{font-size:14px;color:#b9b9c4;letter-spacing:.01em}

/* ============================================================
   GENERIC PIECES
   ============================================================ */
.grid{display:grid;gap:24px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

/* division / feature cards */
.card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:32px 28px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  overflow:hidden;
}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card__icon{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:20px;
  background:var(--red-soft);color:var(--red);
}
.card__icon svg{width:26px;height:26px}
.card h3{font-size:1.28rem;margin-bottom:10px}
.card__num{position:absolute;top:24px;right:26px;font-family:var(--display);font-weight:700;font-size:14px;color:var(--line-2);letter-spacing:.05em}
.card p{color:var(--grey);font-size:15.5px}
.card__list{margin-top:16px;display:flex;flex-wrap:wrap;gap:7px}
.card__list li{font-size:12.5px;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--line);padding:4px 11px;border-radius:999px}

/* section--dark variant of cards */
.section--dark .card{background:var(--dark-2);border-color:rgba(255,255,255,.08)}
.section--dark .card:hover{box-shadow:0 30px 60px -25px rgba(0,0,0,.8)}
.section--dark .card h3{color:#fff}
.section--dark .card p{color:#aeaeba}
.section--dark .card__icon{background:rgba(232,0,17,.16);color:#ff5660}
.section--dark .card__list li{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1);color:#cfcfd8}
.section--dark .card__num{color:rgba(255,255,255,.12)}

/* split content */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.split--reverse .split__media{order:2}
.prose p+p{margin-top:18px}
.prose .lead{margin-top:0;margin-bottom:22px}
.ticks{margin-top:26px;display:grid;gap:14px}
.ticks li{display:flex;gap:13px;align-items:flex-start;font-size:15.5px;color:var(--ink-2)}
.ticks li svg{flex-shrink:0;width:22px;height:22px;color:var(--red);margin-top:1px}

/* brand identity card (about/story media) */
.brandcard{position:relative;background:var(--dark);border-radius:var(--radius-lg);padding:40px 34px 32px 44px;overflow:hidden;color:#fff;box-shadow:var(--shadow-lg)}
.brandcard::after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;top:-160px;right:-120px;background:radial-gradient(circle,rgba(232,0,17,.28),transparent 62%)}
.brandcard__stripe{position:absolute;top:0;left:0;bottom:0;width:16px;display:flex;z-index:2}
.brandcard__stripe i:nth-child(1){width:9px;background:var(--red)}
.brandcard__stripe i:nth-child(2){width:7px;background:#000}
.brandcard__inner{position:relative;z-index:3}
.brandcard__logo{height:40px;width:auto;margin-bottom:16px}
.brandcard__tag{color:#b7b7c2;font-size:14.5px;line-height:1.5;margin-bottom:24px;max-width:330px}
.brandcard__label{font-family:var(--display);font-size:11.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#7c7c8a;margin-bottom:11px}
.brandcard__sheet{border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 14px 30px -14px rgba(0,0,0,.7);margin-bottom:26px;border:1px solid rgba(255,255,255,.08)}
.brandcard__sheet img{display:block;width:100%}
.swatches{display:flex;gap:10px}
.swatch{flex:1;border-radius:11px;padding:12px 12px 11px;border:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:6px}
.swatch .chip{height:30px;border-radius:7px}
.swatch b{font-family:var(--display);font-size:12px}
.swatch span{font-size:10.5px;color:#8a8a98;letter-spacing:.02em}

/* media frame */
.frame{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);
  background:#fff;box-shadow:var(--shadow);
}
.frame--pad{padding:26px;background:var(--bg-soft)}
.frame img{border-radius:8px;margin-inline:auto;box-shadow:var(--shadow)}
.media-badge{
  position:absolute;left:22px;bottom:22px;background:#fff;border-radius:12px;padding:14px 18px;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;font-size:14px;
}
.media-badge b{font-family:var(--display)}

/* industries */
.tag-grid{display:flex;flex-wrap:wrap;gap:12px}
.tag-grid .tag{
  display:flex;align-items:center;gap:10px;padding:13px 20px;border-radius:12px;
  background:#fff;border:1px solid var(--line);font-family:var(--display);font-weight:500;font-size:15px;
  transition:transform .25s var(--ease),border-color .25s,box-shadow .25s;
}
.tag-grid .tag:hover{transform:translateY(-3px);border-color:var(--red);box-shadow:var(--shadow-sm)}
.tag-grid .tag svg{width:18px;height:18px;color:var(--red)}

/* steps / models */
.steps{counter-reset:step;display:grid;gap:0}
.step{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:28px 0;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:0}
.step__n{counter-increment:step;width:48px;height:48px;border-radius:50%;border:2px solid var(--red);color:var(--red);
  font-family:var(--display);font-weight:700;display:grid;place-items:center;font-size:18px}
.step__n::before{content:counter(step,decimal-leading-zero)}
.step h3{font-size:1.2rem;margin-bottom:6px}
.step p{color:var(--grey);font-size:15.5px}

/* certifications */
.cert-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cert{
  display:flex;gap:18px;align-items:center;padding:26px;border-radius:var(--radius);
  background:#fff;border:1px solid var(--line);
}
.section--dark .cert{background:var(--dark-2);border-color:rgba(255,255,255,.08)}
.cert__seal{width:56px;height:56px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;
  background:conic-gradient(from 0deg,var(--red),var(--red-dark),var(--red));color:#fff}
.cert__seal svg{width:26px;height:26px}
.cert b{font-family:var(--display);font-size:16px;display:block}
.cert span{font-size:13.5px;color:var(--muted)}
.section--dark .cert span{color:#9b9ba6}
.section--dark .cert b{color:#fff}

/* logos / partners */
.logo-cloud{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.logo-cloud .lc{
  display:flex;flex-direction:column;gap:4px;justify-content:center;align-items:center;text-align:center;
  padding:26px 18px;border-radius:var(--radius);border:1px solid var(--line);background:#fff;
  transition:transform .25s var(--ease),box-shadow .25s;min-height:104px;
}
.logo-cloud .lc:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.logo-cloud .lc b{font-family:var(--display);font-size:17px;letter-spacing:-.01em}
.logo-cloud .lc span{font-size:12.5px;color:var(--muted)}

/* CTA band */
.cta-band{position:relative;background:var(--red);color:#fff;overflow:hidden;isolation:isolate}
.cta-band::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 85% 20%,rgba(255,255,255,.18),transparent 45%),
  radial-gradient(circle at 10% 90%,rgba(0,0,0,.18),transparent 40%);z-index:0}
.cta-band .container{position:relative;z-index:1;text-align:center;padding-block:84px}
.cta-band h2{font-size:clamp(2rem,4vw,3rem);color:#fff}
.cta-band p{color:rgba(255,255,255,.92);font-size:1.15rem;margin-top:16px;max-width:600px;margin-inline:auto}
.cta-band .hero__cta{justify-content:center;margin-top:34px}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.contact-card{display:grid;gap:14px}
.contact-item{display:flex;gap:16px;align-items:flex-start;padding:20px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;transition:border-color .25s,box-shadow .25s}
.contact-item:hover{border-color:var(--red);box-shadow:var(--shadow-sm)}
.contact-item__ic{width:46px;height:46px;border-radius:12px;flex-shrink:0;display:grid;place-items:center;background:var(--red-soft);color:var(--red)}
.contact-item__ic svg{width:22px;height:22px}
.contact-item h4{font-family:var(--display);font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:4px;font-weight:600}
.contact-item p,.contact-item a{font-size:15.5px;color:var(--ink-2);word-break:break-word}
.contact-item a:hover{color:var(--red)}

.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--display);font-size:13.5px;font-weight:600;margin-bottom:7px;color:var(--ink-2)}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:15px;
  background:var(--bg-soft);color:var(--ink);transition:border-color .2s,background .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red);background:#fff;box-shadow:0 0 0 4px rgba(232,0,17,.1)}
.field textarea{resize:vertical;min-height:130px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form__note{font-size:13px;color:var(--muted);margin-top:6px}
.form-success{display:none;align-items:center;gap:12px;background:#e8f6ec;border:1px solid #b6e2c3;color:#1a7f37;padding:14px 18px;border-radius:12px;font-size:15px;margin-bottom:18px}
.form-success.show{display:flex}
.form-error{display:none;align-items:center;gap:12px;background:#fdecea;border:1px solid #f3c6c1;color:var(--red-dark);padding:14px 18px;border-radius:12px;font-size:15px;margin-bottom:18px}
.form-error.show{display:flex}
/* anti-spam honeypot: kept in the DOM but hidden from real users & screen readers */
.hp-field{position:absolute!important;left:-9999px!important;top:-9999px!important;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--dark);color:#b6b6c2;padding-top:74px;position:relative}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),var(--red-dark))}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.09)}
.footer__brand img{height:34px;margin-bottom:18px}
.footer__brand p{font-size:14.5px;color:#9696a4;max-width:300px}
.footer__brand .socials{display:flex;gap:10px;margin-top:20px}
.footer__brand .socials a{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);transition:background .2s,transform .2s,border-color .2s}
.footer__brand .socials a:hover{background:var(--red);border-color:var(--red);transform:translateY(-2px);color:#fff}
.footer__brand .socials svg{width:18px;height:18px}
.footer h5{font-family:var(--display);color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px}
.footer__col a,.footer__col li{display:block;font-size:14.5px;color:#9696a4;padding:6px 0;transition:color .2s}
.footer__col a:hover{color:#fff}
.footer__contact li{display:flex;gap:10px;font-size:14.5px;color:#9696a4;padding:7px 0;align-items:flex-start}
.footer__contact svg{width:17px;height:17px;color:var(--red);flex-shrink:0;margin-top:3px}
.footer__contact a:hover{color:#fff}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;padding:26px 0;font-size:13.5px;color:#7c7c8a}
.footer__bottom .badges{display:flex;gap:8px;flex-wrap:wrap}
.footer__bottom .badges span{border:1px solid rgba(255,255,255,.12);padding:4px 11px;border-radius:999px;font-size:12px}

/* ============================================================
   PAGE HERO (interior pages)
   ============================================================ */
.page-hero{position:relative;background:var(--dark);color:#fff;overflow:hidden;isolation:isolate}
.page-hero .hero__stripe{width:14px}
.page-hero__inner{position:relative;z-index:3;padding:84px 0 78px;max-width:760px}
.page-hero h1{font-size:clamp(2.3rem,4.6vw,3.5rem)}
.page-hero p{color:#bfbfca;font-size:1.18rem;margin-top:18px;max-width:600px}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:13.5px;color:#8a8a98;margin-bottom:22px;font-family:var(--display)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:var(--red)}

/* values / leadership */
.people{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.person{display:flex;gap:20px;align-items:center;padding:26px;border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff;transition:transform .3s var(--ease),box-shadow .3s}
.person:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.person__avatar{width:74px;height:74px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;
  font-family:var(--display);font-weight:700;font-size:24px;color:#fff;background:linear-gradient(135deg,var(--ink),var(--red))}
.person h3{font-size:1.18rem}
.person .role{font-family:var(--display);font-size:13.5px;color:var(--red);font-weight:600;margin:3px 0 8px}
.person p{font-size:14px;color:var(--grey)}

/* timeline */
.timeline{position:relative;margin-top:20px;padding-left:34px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl{position:relative;padding-bottom:34px}
.tl:last-child{padding-bottom:0}
.tl::before{content:"";position:absolute;left:-34px;top:3px;width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--red)}
.tl .yr{font-family:var(--display);font-weight:700;color:var(--red);font-size:15px}
.tl h4{font-size:1.1rem;margin:4px 0 6px}
.tl p{color:var(--grey);font-size:15px}

/* value cards small */
.val{padding:28px;border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.val:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.val__ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--ink);color:#fff;margin-bottom:18px}
.val__ic svg{width:23px;height:23px}
.val h3{font-size:1.16rem;margin-bottom:8px}
.val p{color:var(--grey);font-size:15px}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- whatsapp float ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:90;width:58px;height:58px;border-radius:50%;
  background:#25d366;display:grid;place-items:center;box-shadow:0 12px 28px -8px rgba(37,211,102,.6);
  transition:transform .25s var(--ease)}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;color:#fff}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .split{gap:42px}
  .footer__top{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
}
@media (max-width:900px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:block}
  .nav-links{
    position:fixed;inset:74px 0 auto 0;background:#fff;flex-direction:column;align-items:flex-start;
    gap:0;padding:14px 24px 26px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .4s var(--ease);display:flex;
  }
  .site-header.open .nav-links{transform:none}
  .nav-links a{width:100%;padding:15px 0;border-bottom:1px solid var(--line-2);font-size:17px}
  .nav-links .btn{display:inline-flex;margin-top:16px;width:100%}
  .stripbar .container{grid-template-columns:repeat(2,1fr);gap:30px}
  .cols-3,.cols-4,.logo-cloud,.cert-row{grid-template-columns:repeat(2,1fr)}
  .split,.contact-grid,.people{grid-template-columns:1fr}
  .split--reverse .split__media{order:0}
  .section{padding:76px 0}
}
@media (max-width:560px){
  body{font-size:16px}
  .container{padding-inline:20px}
  .hero__inner{padding:84px 0 88px}
  .cols-2,.cols-3,.cols-4,.logo-cloud,.cert-row,.field-row{grid-template-columns:1fr}
  .stripbar .container{grid-template-columns:1fr 1fr}
  .nav .btn{display:none}
  .card,.form{padding:26px 22px}
  .section{padding:64px 0}
  .section-head{margin-bottom:40px}
}

/* ============================================================
   NEXT-GEN ADDITIONS — animations, i18n switcher, models, orbit
   ============================================================ */
[id]{scroll-margin-top:88px}

/* ---- language switcher ---- */
.lang{display:flex;align-items:center;gap:2px;border:1.5px solid var(--line);border-radius:999px;padding:3px;background:#fff}
.lang button{border:0;background:none;cursor:pointer;font-family:var(--display);font-weight:600;font-size:12px;padding:6px 10px;border-radius:999px;color:var(--grey);transition:background .2s,color .2s;white-space:nowrap}
.lang button.active{background:var(--ink);color:#fff}
.lang button:hover:not(.active){color:var(--red)}

/* ---- scroll progress bar ---- */
.progress-bar{position:fixed;top:0;left:0;height:3px;width:100%;transform-origin:0 0;transform:scaleX(0);background:linear-gradient(90deg,var(--red),#ff6b74);z-index:300;pointer-events:none}

/* ---- marquee strip ---- */
.marquee{background:var(--dark);border-top:1px solid rgba(255,255,255,.07);padding:16px 0;overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee__track{display:flex;width:max-content;animation:marquee 38s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__group{display:flex;align-items:center;gap:36px;padding-right:36px}
.marquee__group span{font-family:var(--display);font-size:12.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#83838f;white-space:nowrap}
.marquee__group i{width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---- hero flourishes ---- */
.hero .orb,.page-hero .orb{position:absolute;border-radius:50%;filter:blur(70px);z-index:1;pointer-events:none;will-change:transform}
.orb--1{width:420px;height:420px;background:rgba(232,0,17,.24);top:-120px;right:6%;animation:orb-float 11s ease-in-out infinite}
.orb--2{width:300px;height:300px;background:rgba(232,0,17,.12);bottom:-90px;left:12%;animation:orb-float 15s ease-in-out infinite reverse}
@keyframes orb-float{50%{transform:translate(22px,-34px) scale(1.06)}}
.hero__grid{animation:grid-pan 5s linear infinite}
@keyframes grid-pan{to{background-position:64px 64px}}
.accent{background:linear-gradient(95deg,#ff4750,#ffb3b7 30%,var(--red) 60%,#ff4750);background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shine 5.5s linear infinite}
@keyframes shine{to{background-position:-220% 0}}

/* ---- orbit visual (divisions around the {R} mark) ---- */
.orbit{position:relative;width:min(440px,86vw);aspect-ratio:1/1;margin-inline:auto}
.orbit__halo{position:absolute;inset:8%;border-radius:50%;background:radial-gradient(circle,rgba(232,0,17,.10),transparent 65%)}
.orbit__ring{position:absolute;border:1.5px dashed #e2e2e8;border-radius:50%}
.orbit__ring--1{inset:22%;animation:spin 26s linear infinite}
.orbit__ring--2{inset:5%;animation:spin 46s linear infinite reverse}
.orbit__dotpos{position:absolute;inset:0}
.orbit__dot{position:absolute;top:-6px;left:50%;width:12px;height:12px;margin-left:-6px;border-radius:50%;background:var(--red);box-shadow:0 0 0 5px rgba(232,0,17,.14)}
.orbit__dot--dark{background:var(--ink);box-shadow:0 0 0 5px rgba(17,17,20,.10)}
@keyframes spin{to{transform:rotate(360deg)}}
.orbit__core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:132px;height:132px;border-radius:50%;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-lg);display:grid;place-items:center;z-index:3}
.orbit__core img{width:62px;height:62px}
.orbit__chip{position:absolute;z-index:4;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 14px;
  font-family:var(--display);font-size:12.5px;font-weight:600;box-shadow:var(--shadow-sm);white-space:nowrap;animation:chip-float 6s ease-in-out infinite}
.orbit__chip i{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--red);margin-right:7px}
@keyframes chip-float{50%{transform:translateY(-9px)}}

/* ---- business model cards ---- */
.models-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.model{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:24px;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;will-change:transform}
.model:hover{box-shadow:var(--shadow);border-color:var(--red)}
.model__badge{flex-shrink:0;min-width:78px;text-align:center;background:var(--ink);color:#fff;font-family:var(--display);
  font-weight:700;font-size:13px;letter-spacing:.05em;border-radius:10px;padding:10px 12px}
.model--red .model__badge{background:var(--red)}
.model h3{font-size:1.08rem;margin-bottom:5px}
.model p{font-size:14.5px;color:var(--grey)}

/* badge chips (home teaser) */
.bm-badges{display:flex;flex-wrap:wrap;gap:8px}
.bm-badge{font-family:var(--display);font-size:12px;font-weight:700;letter-spacing:.05em;background:var(--ink);color:#fff;
  padding:8px 13px;border-radius:9px}
.bm-badge--red{background:var(--red)}
.bm-badge--ghost{background:var(--bg-soft);color:var(--ink);border:1px solid var(--line)}

/* ---- as-a-Service grid ---- */
.aas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.aas{background:var(--dark-2);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:22px;
  transition:transform .3s var(--ease),border-color .3s;will-change:transform}
.aas:hover{transform:translateY(-4px);border-color:rgba(232,0,17,.55)}
.aas b{font-family:var(--display);font-size:19px;color:#fff;display:block;margin-bottom:6px}
.aas b em{color:#ff5660;font-style:normal}
.aas span{font-size:13.5px;color:#a8a8b4}
.aas-note{margin-top:24px;color:#9b9ba6;font-size:14.5px;text-align:center}

/* ---- division chips (about brand card) ---- */
.divchips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.divchips span{font-family:var(--display);font-size:12px;font-weight:600;color:#d6d6de;border:1px solid rgba(255,255,255,.16);
  border-radius:999px;padding:6px 12px;background:rgba(255,255,255,.04)}

@media (max-width:900px){
  .models-grid{grid-template-columns:1fr}
  .aas-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .aas-grid{grid-template-columns:1fr}
  .lang button{padding:5px 8px;font-size:11px}
}
@media (prefers-reduced-motion:reduce){
  .marquee__track,.orbit__ring,.orbit__chip,.orb--1,.orb--2,.hero__grid,.accent{animation:none}
}

/* ---- language dropdown (9 languages) ---- */
.lang{gap:7px;padding:5px 8px 5px 12px}
.lang .lang__ic{width:15px;height:15px;color:var(--grey);flex-shrink:0}
.lang select{border:0;background:transparent;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink);cursor:pointer;max-width:108px}
.lang select:focus{outline:none}
@media (max-width:560px){
  .lang select{max-width:88px;font-size:12px}
}

/* ---- leadership contact links ---- */
.person__links{margin-top:12px;display:flex;flex-direction:column;gap:5px}
.person__links a{font-size:13.5px;color:var(--ink-2);display:inline-flex;gap:8px;align-items:center;transition:color .2s}
.person__links a:hover{color:var(--red)}
.person__links svg{width:14px;height:14px;color:var(--red);flex-shrink:0}

/* ---- venture motto ---- */
.motto{margin:48px auto 0;text-align:center;font-family:var(--display);font-weight:600;
  font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.55;max-width:780px;color:#fff}
.motto em{color:#ff5660;font-style:normal}
.section--soft .motto,.section:not(.section--dark) .motto{color:var(--ink)}
.section--soft .motto em,.section:not(.section--dark) .motto em{color:var(--red)}

/* ---- animation pack ---- */
.brand img{transition:transform .35s var(--ease);animation:logo-pop .7s var(--ease) both,brand-glow 6s ease-in-out 1.2s infinite}
.brand:hover img{transform:scale(1.06) rotate(-1.5deg)}
@keyframes logo-pop{from{opacity:0;transform:translateY(-8px)}}
@keyframes brand-glow{0%,100%{filter:drop-shadow(0 0 0 rgba(232,0,17,0))}50%{filter:drop-shadow(0 0 7px rgba(232,0,17,.45))}}
.btn{position:relative;overflow:hidden}
.btn::before{content:"";position:absolute;top:0;left:-80%;width:50%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg);transition:left .55s var(--ease);pointer-events:none}
.btn:hover::before{left:130%}
.card__icon,.val__ic,.contact-item__ic,.cert__seal{transition:transform .35s var(--ease)}
.card:hover .card__icon,.val:hover .val__ic,.contact-item:hover .contact-item__ic,.cert:hover .cert__seal{transform:translateY(-4px) scale(1.08)}
.reveal.in .eyebrow::before{animation:line-grow .7s var(--ease) both}
@keyframes line-grow{from{width:0}to{width:26px}}
.tl::before{animation:dot-pulse 3.2s ease-in-out infinite}
@keyframes dot-pulse{50%{box-shadow:0 0 0 7px rgba(232,0,17,.12)}}
.wa-float{animation:bob 3.4s ease-in-out infinite}
@keyframes bob{50%{translate:0 -6px}}

/* dark-section tick contrast */
.section--dark .ticks li{color:#cfcfd8}

@media (prefers-reduced-motion:reduce){
  .brand img,.btn::before,.tl::before,.wa-float,.reveal.in .eyebrow::before{animation:none}
}

/* ---- founder profiles ---- */
.profiles{display:grid;gap:24px;max-width:920px;margin-inline:auto}
.profile{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;
  transition:transform .3s var(--ease),box-shadow .3s}
.profile:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.profile__head{display:flex;gap:18px;align-items:center;margin-bottom:20px}
.profile__head h3{font-size:1.35rem}
.profile__tag{font-family:var(--display);font-size:13px;color:var(--muted);margin-top:4px;letter-spacing:.01em}
.profile__quote{margin:0 0 18px;padding:14px 18px;border-left:3px solid var(--red);background:var(--red-soft);
  border-radius:0 10px 10px 0;font-style:italic;color:var(--ink-2);font-size:15.5px;line-height:1.55}
.profile>p{color:var(--grey);font-size:15px}
.profile>p+p{margin-top:12px}
.profile .person__links{margin-top:18px;flex-direction:row;flex-wrap:wrap;gap:8px 20px}
@media (max-width:560px){.profile{padding:26px 22px}}

/* ============================================================
   GEO AUTO-LANGUAGE TOAST
   ============================================================ */
.geo-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,140%);z-index:400;
  display:flex;align-items:center;gap:12px;max-width:min(560px,calc(100vw - 32px));
  background:rgba(16,16,20,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  color:#fff;border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:13px 16px;
  box-shadow:0 24px 50px -18px rgba(0,0,0,.6);opacity:0;transition:transform .5s var(--ease),opacity .5s var(--ease)}
.geo-toast.show{transform:translate(-50%,0);opacity:1}
.geo-toast__ic{display:grid;place-items:center;width:32px;height:32px;border-radius:9px;background:rgba(232,0,17,.18);color:#ff5660;flex-shrink:0}
.geo-toast__ic svg{width:18px;height:18px}
.geo-toast__msg{font-size:14px;line-height:1.35;flex:1;min-width:0}
.geo-toast__en{flex-shrink:0;font-family:var(--display);font-weight:600;font-size:13px;color:#fff;
  background:var(--red);border:0;border-radius:999px;padding:7px 14px;cursor:pointer;transition:background .2s,transform .2s}
.geo-toast__en:hover{background:var(--red-dark);transform:translateY(-1px)}
.geo-toast__x{flex-shrink:0;background:none;border:0;color:#9a9aa6;font-size:22px;line-height:1;cursor:pointer;padding:0 2px;transition:color .2s}
.geo-toast__x:hover{color:#fff}
@media (max-width:480px){
  .geo-toast{flex-wrap:wrap;bottom:16px}
  .geo-toast__msg{flex-basis:100%;order:-1}
}

/* ============================================================
   3D / 4D EFFECTS & COOL MOTION
   ============================================================ */
/* depth context for tiltable surfaces */
.card,.val,.model,.profile,.cert,.aas,.tag,.lc{transform-style:preserve-3d;will-change:transform}

/* dynamic glare that tracks the cursor on tilt (vars set in main.js) */
.card,.val,.model{position:relative}
.card::after,.val::after,.model::after{content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at var(--gx,50%) var(--gy,50%),rgba(255,255,255,.28),transparent 42%);
  opacity:0;transition:opacity .35s var(--ease);pointer-events:none;z-index:1}
.card:hover::after,.val:hover::after,.model:hover::after{opacity:1}
.section--dark .card::after{background:radial-gradient(circle at var(--gx,50%) var(--gy,50%),rgba(255,255,255,.16),transparent 42%)}
.card>*,.val>*,.model>*{position:relative;z-index:2;transform:translateZ(.01px)}

/* hero cursor spotlight (element injected by main.js) */
.hero__spot{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0;transition:opacity .4s;
  background:radial-gradient(420px circle at var(--sx,50%) var(--sy,50%),rgba(232,0,17,.18),transparent 70%)}
.hero:hover .hero__spot,.page-hero:hover .hero__spot{opacity:1}

/* 3D coin-flip of the orbit {R} mark */
.orbit__core{perspective:700px}
.orbit__core img{animation:coin-spin 8s cubic-bezier(.45,0,.55,1) infinite;backface-visibility:visible}
@keyframes coin-spin{0%{transform:rotateY(0)}50%{transform:rotateY(180deg)}100%{transform:rotateY(360deg)}}

/* floating 3D bob on orbit chips already handled; add depth shadow pulse */
.orbit__chip{box-shadow:0 8px 18px -8px rgba(17,17,20,.25)}

/* subtle scale on stat numbers */
.stat__num{transition:transform .3s var(--ease)}
.stat:hover .stat__num{transform:scale(1.06)}

/* magnetic primary CTA glow */
.btn--primary.btn--lg{transition:transform .2s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease)}

/* animated gradient sheen on the CTA band */
.cta-band::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.10) 50%,transparent 70%);
  background-size:220% 100%;animation:band-sheen 7s linear infinite}
@keyframes band-sheen{to{background-position:-220% 0}}
.cta-band .container{position:relative;z-index:1}

@media (prefers-reduced-motion:reduce){
  .orbit__core img,.cta-band::after,.geo-toast{animation:none}
  .card::after,.val::after,.model::after,.hero__spot{display:none}
}
