/* ============================================================
   ALTAF LATIF — Revenue Systems Engineer
   Design system: "Midnight Ledger"
   Display: Space Grotesk · Body: Inter · Proof voice: IBM Plex Mono
   ============================================================ */

:root{
  --ink:#F7F9FC;            /* page background (light) */
  --ink-2:#EEF2F9;          /* tinted band */
  --ink-3:#E5EBF5;          /* deeper tint */
  --navy:#0B101D;           /* contrast bands: footer, CTA, process */
  --glass:#FFFFFF;
  --glass-2:#FFFFFF;
  --line:rgba(11,21,38,.12);
  --line-soft:rgba(11,21,38,.07);
  --text:#0B1526;
  --mute:#5A6B85;
  --faint:#8C99B0;
  --teal-deep:#0E9F8C;      /* accessible teal for light surfaces */
  --violet:#7C6CFF;
  --blue:#4DA8FF;
  --teal:#2BE0C8;
  --gold:#F5B83D;
  --wa:#25D366;
  --grad:linear-gradient(120deg,#7C6CFF 0%,#4DA8FF 55%,#2BE0C8 100%);
  --grad-soft:linear-gradient(120deg,rgba(124,108,255,.16),rgba(77,168,255,.10),rgba(43,224,200,.14));
  --r-s:10px; --r-m:16px; --r-l:24px;
  --shadow:0 24px 50px -22px rgba(11,21,38,.22);
  --shadow-soft:0 12px 28px -16px rgba(11,21,38,.14);
  --font-d:"Space Grotesk",system-ui,sans-serif;
  --font-b:"Inter",system-ui,sans-serif;
  --font-m:"IBM Plex Mono",ui-monospace,monospace;
  --w:1140px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--font-b);
  font-size:16.5px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:rgba(124,108,255,.28)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--font-d);line-height:1.12;letter-spacing:-.015em;font-weight:600}
.h-display{font-size:clamp(2.4rem,5.2vw,4rem);font-weight:700}
.h-page{font-size:clamp(2.1rem,4.4vw,3.2rem);font-weight:700}
h2.h-sec{font-size:clamp(1.7rem,3.2vw,2.4rem);margin-bottom:.6rem}
h3{font-size:1.25rem}
.lead{color:var(--mute);font-size:1.1rem;max-width:46rem}
.eyebrow{
  font-family:var(--font-m);font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--teal-deep);display:inline-flex;
  align-items:center;gap:.55rem;margin-bottom:1rem;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--grad)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.mono{font-family:var(--font-m)}
.center{text-align:center}
.center .lead{margin:0 auto}
.center .eyebrow::after{content:"";width:22px;height:1px;background:var(--grad)}

/* ---------- layout ---------- */
.container{width:min(var(--w),92%);margin:0 auto}
.section{padding:clamp(4rem,8vw,6.5rem) 0;position:relative}
.section-tight{padding:clamp(2.5rem,5vw,3.5rem) 0}
.section-light{background:var(--navy);color:#F3F6FB;
  --text:#F3F6FB;--mute:#A9B6CE;--line:rgba(234,240,250,.18);--line-soft:rgba(234,240,250,.09);
  --glass:rgba(234,240,250,.05);--glass-2:rgba(234,240,250,.09);--faint:#7E8BA6;--teal-deep:#2BE0C8}
.section-light .lead,.section-light p{color:var(--mute)}
.section-light h2,.section-light h3{color:#F3F6FB}
.section-light .badge-chip,.cta-band .badge-chip{background:rgba(234,240,250,.07);box-shadow:none}
.sec-head{margin-bottom:clamp(2.2rem,4vw,3.2rem)}
.grid{display:grid;gap:1.4rem}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}

/* ---------- ambient background ---------- */
.orbs{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.orbs::before,.orbs::after{
  content:"";position:absolute;border-radius:50%;filter:blur(110px);opacity:.45;
}
.orbs::before{width:560px;height:560px;background:rgba(124,108,255,.20);top:-180px;right:-120px}
.orbs::after{width:480px;height:480px;background:rgba(43,224,200,.16);bottom:-200px;left:-140px}
.section>.container{position:relative;z-index:1}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-d);font-weight:600;font-size:.98rem;
  padding:.95rem 1.7rem;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border-color .2s;
  white-space:nowrap;
}
.btn-primary{background:var(--grad);color:#06121C;box-shadow:0 12px 32px -10px rgba(77,168,255,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(77,168,255,.7)}
.btn-ghost{border-color:var(--line);background:#fff;color:var(--text);box-shadow:var(--shadow-soft)}
.btn-ghost:hover{border-color:var(--blue);background:rgba(77,168,255,.08);transform:translateY(-2px)}
.cta-band .btn-ghost,.section-light .btn-ghost,.footer .btn-ghost{background:rgba(234,240,250,.07);color:var(--text);border-color:var(--line);box-shadow:none}
.cta-band .btn-ghost:hover,.section-light .btn-ghost:hover,.footer .btn-ghost:hover{background:rgba(234,240,250,.14);border-color:rgba(234,240,250,.4)}
.btn-sm{padding:.6rem 1.15rem;font-size:.86rem}
.btn-light{background:#0B101D;color:#fff}
.btn-light:hover{transform:translateY(-2px)}
.btn-row{display:flex;gap:.9rem;flex-wrap:wrap}
.arrow{transition:transform .2s}
.btn:hover .arrow,a:hover>.arrow{transform:translateX(3px)}

/* ---------- chips & badges ---------- */
.chip-row{display:flex;flex-wrap:wrap;gap:.6rem}
.chip{
  font-family:var(--font-m);font-size:.72rem;letter-spacing:.06em;
  padding:.42rem .85rem;border-radius:999px;border:1px solid var(--line);
  background:var(--glass);color:var(--mute);
}
.chip.on{background:var(--grad);color:#06121C;border-color:transparent;font-weight:600}
.badge-chip{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-m);font-size:.74rem;letter-spacing:.04em;
  padding:.5rem .95rem;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.85);backdrop-filter:blur(8px);box-shadow:var(--shadow-soft);
}
.badge-chip .star{color:var(--gold)}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(43,224,200,.6);animation:pulse 2.2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 9px rgba(43,224,200,0)}100%{box-shadow:0 0 0 0 rgba(43,224,200,0)}}

/* ---------- cards ---------- */
.card{
  background:var(--glass);border:1px solid var(--line-soft);border-radius:var(--r-m);
  padding:1.8rem;box-shadow:var(--shadow-soft);
  transition:transform .25s ease,border-color .25s,background .25s;
}
.card:hover{transform:translateY(-5px);border-color:rgba(124,108,255,.45);box-shadow:var(--shadow)}
.card h3{margin-bottom:.55rem}
.card p{color:var(--mute);font-size:.96rem}
.icon-tile{
  width:46px;height:46px;border-radius:12px;background:var(--grad-soft);
  border:1px solid var(--line);display:grid;place-items:center;margin-bottom:1.1rem;
  color:var(--teal);
}
.icon-tile svg{width:22px;height:22px}
.card .more{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-family:var(--font-d);font-weight:600;font-size:.9rem;color:var(--blue)}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:background .25s,border-color .25s,backdrop-filter .25s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(255,255,255,.85);backdrop-filter:blur(14px);border-color:var(--line-soft)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{display:flex;align-items:center;gap:.7rem;font-family:var(--font-d);font-weight:700;font-size:1.12rem}
.logo-mark{
  width:38px;height:38px;border-radius:11px;background:var(--grad);
  display:grid;place-items:center;color:#06121C;font-weight:700;font-size:1rem;letter-spacing:-.03em;
}
.logo small{display:block;font-family:var(--font-m);font-weight:400;font-size:.62rem;letter-spacing:.18em;color:var(--mute);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a{font-size:.93rem;color:var(--mute);transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--grad);border-radius:2px}
.nav-cta{display:flex;align-items:center;gap:.9rem}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:10px;color:var(--text);width:42px;height:42px;font-size:1.2rem;cursor:pointer}
.has-sub{position:relative}
.subnav{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(6px);
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:.6rem;min-width:240px;display:grid;gap:.15rem;opacity:0;pointer-events:none;
  transition:opacity .2s,transform .2s;backdrop-filter:blur(14px);box-shadow:var(--shadow);
}
.has-sub:hover .subnav,.has-sub:focus-within .subnav{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.subnav a{display:block;padding:.6rem .8rem;border-radius:9px;font-size:.9rem}
.subnav a:hover{background:var(--glass-2)}

/* ---------- hero ---------- */
.hero{padding:170px 0 90px;position:relative}
.hero .lead{margin:1.2rem 0 2rem}
.hero-visual{position:relative;justify-self:center}
.verify-frame{
  position:relative;width:min(360px,80vw);aspect-ratio:5/6;border-radius:26px;
  background:radial-gradient(120% 100% at 50% 0%,rgba(124,108,255,.18),rgba(255,255,255,.7) 62%),var(--ink-2);
  border:1px solid var(--line);overflow:visible;
}
.verify-frame::before{
  content:"";position:absolute;inset:-1px;border-radius:27px;padding:1px;
  background:var(--grad);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.7;
}
.verify-frame img{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:108%;max-width:none;filter:drop-shadow(0 26px 36px rgba(11,21,38,.28));
  border-radius:0 0 26px 26px;
}
.vf-tick{position:absolute;width:16px;height:16px;border-color:var(--teal);border-style:solid;opacity:.9}
.vf-tick.tl{top:-7px;left:-7px;border-width:2px 0 0 2px}
.vf-tick.tr{top:-7px;right:-7px;border-width:2px 2px 0 0}
.vf-tick.bl{bottom:-7px;left:-7px;border-width:0 0 2px 2px}
.vf-tick.br{bottom:-7px;right:-7px;border-width:0 2px 2px 0}
.vf-caption{
  position:absolute;left:50%;bottom:-22px;transform:translateX(-50%);
  background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:999px;
  font-family:var(--font-m);font-size:.66rem;letter-spacing:.14em;color:var(--mute);
  padding:.5rem 1rem;white-space:nowrap;display:flex;gap:.5rem;align-items:center;backdrop-filter:blur(8px);
}
.float-tag{
  position:absolute;background:rgba(255,255,255,.96);border:1px solid var(--line);
  border-radius:12px;padding:.6rem .9rem;font-family:var(--font-m);font-size:.7rem;
  color:var(--text);backdrop-filter:blur(8px);box-shadow:var(--shadow-soft);
  display:flex;align-items:center;gap:.5rem;animation:floaty 5.5s ease-in-out infinite;
}
.float-tag .star{color:var(--gold)}
.ft-1{top:9%;left:-16%}
.ft-2{top:42%;right:-19%;animation-delay:1.4s}
.ft-3{bottom:14%;left:-13%;animation-delay:2.6s}
@keyframes floaty{50%{transform:translateY(-9px)}}

.hero-copy{min-width:0}

/* ---------- stats strip ---------- */
.stats{
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  background:#fff;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:2.2rem 0}
.stat{text-align:center}
.stat-val{font-family:var(--font-d);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.6rem);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{font-family:var(--font-m);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin-top:.3rem}
.stats-note{font-family:var(--font-m);font-size:.68rem;color:var(--faint);text-align:center;padding-bottom:1.4rem;letter-spacing:.04em}
.stats-note a{color:var(--mute);text-decoration:underline}

/* ---------- proof / wall of trust ---------- */
.proof-card{padding:0;overflow:hidden;display:flex;flex-direction:column}
.proof-img{
  border-bottom:1px solid var(--line-soft);background:var(--ink-3);
  aspect-ratio:16/9.4;overflow:hidden;display:grid;place-items:center;
}
.proof-img img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .4s}
.proof-card:hover .proof-img img{transform:scale(1.04)}
.proof-body{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;gap:.8rem;flex:1}
.proof-top{display:flex;justify-content:space-between;align-items:center;gap:.6rem}
.platform{font-family:var(--font-d);font-weight:700;font-size:1.15rem}
.proof-meta{font-family:var(--font-m);font-size:.78rem;color:var(--mute);display:grid;gap:.45rem}
.proof-meta li{display:flex;justify-content:space-between;gap:1rem;border-bottom:1px dashed var(--line-soft);padding-bottom:.45rem}
.proof-meta b{color:var(--text);font-weight:600;text-align:right}
.stars{color:var(--gold);letter-spacing:.12em;font-size:.85rem}
.verify-link{
  margin-top:auto;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-m);font-size:.78rem;letter-spacing:.08em;
  border:1px solid var(--line);border-radius:10px;padding:.7rem 1rem;color:var(--teal-deep);
  transition:background .2s,border-color .2s;
}
.verify-link:hover{background:rgba(43,224,200,.08);border-color:var(--teal)}

/* ---------- testimonials ---------- */
.t-card{display:flex;flex-direction:column;gap:1.1rem}
.t-quote{font-size:1.02rem;color:var(--text);line-height:1.7}
.t-quote::before{content:"“";font-family:var(--font-d);font-size:2.6rem;line-height:0;display:block;margin:1rem 0 .4rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.t-who{display:flex;align-items:center;gap:.9rem;margin-top:auto}
.avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid rgba(124,108,255,.5)}
.t-who b{font-family:var(--font-d);display:block;font-size:.97rem}
.t-who span{font-family:var(--font-m);font-size:.72rem;color:var(--mute)}
.t-src{font-family:var(--font-m);font-size:.66rem;letter-spacing:.1em;color:var(--faint);text-transform:uppercase}

/* ---------- process ---------- */
.process{counter-reset:step;display:grid;grid-template-columns:repeat(5,1fr);gap:1.2rem}
.step{position:relative;padding:1.6rem 1.3rem;border-radius:var(--r-m);background:#fff;border:1px solid #E2E8F2;box-shadow:0 14px 30px -18px rgba(0,0,0,.5)}
.step::before{
  counter-increment:step;content:"0" counter(step);
  font-family:var(--font-m);font-size:.74rem;letter-spacing:.14em;color:#5A4DE0;
  display:block;margin-bottom:.7rem;
}
.step h3{font-size:1.02rem;color:#0B101D;margin-bottom:.4rem}
.step p{font-size:.87rem;color:#46556E}

/* ---------- portfolio ---------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:2.2rem}
.filter-bar .chip{cursor:pointer;transition:all .2s;background:#fff}
.filter-bar .chip:hover{border-color:var(--blue);color:var(--text)}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.pf-card{padding:0;overflow:hidden;display:flex;flex-direction:column}
.pf-card.hide{display:none}
.pf-cover{aspect-ratio:16/10;overflow:hidden;border-bottom:1px solid var(--line-soft);background:var(--ink-3);position:relative}
.pf-cover img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .45s}
.pf-card:hover .pf-cover img{transform:scale(1.05)}
.pf-cover .abstract{
  width:100%;height:100%;display:grid;place-items:center;
  font-family:var(--font-d);font-weight:700;font-size:2.2rem;color:rgba(234,240,250,.9);
}
.g-a{background:linear-gradient(135deg,#1b1f3f,#3c2f8f 55%,#1a5e63)}
.g-b{background:linear-gradient(135deg,#0d2b45,#1f5f8f 55%,#173a6b)}
.g-c{background:linear-gradient(135deg,#152c2a,#1f7a6c 60%,#0e3f54)}
.g-d{background:linear-gradient(135deg,#2c1f4f,#5a3fa0 55%,#23456e)}
.pf-tag{
  position:absolute;top:12px;left:12px;font-family:var(--font-m);font-size:.64rem;
  letter-spacing:.12em;text-transform:uppercase;background:rgba(255,255,255,.94);
  border:1px solid var(--line);border-radius:999px;padding:.35rem .7rem;color:#5A4DE0;
}
.pf-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.pf-body h3{font-size:1.12rem}
.pf-facts{font-size:.9rem;color:var(--mute);display:grid;gap:.35rem}
.pf-facts b{color:var(--text);font-weight:600}
.pf-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:.9rem;border-top:1px dashed var(--line-soft)}
.pf-platform{font-family:var(--font-m);font-size:.68rem;letter-spacing:.1em;color:var(--faint);text-transform:uppercase}

/* ---------- case studies ---------- */
.cs{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3.4rem);align-items:center;padding:clamp(2rem,4vw,3rem) 0;border-bottom:1px solid var(--line-soft)}
.cs:last-of-type{border-bottom:none}
.cs:nth-child(even) .cs-media{order:2}
.cs-media{border-radius:var(--r-l);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.cs-media img{width:100%;height:100%;object-fit:cover}
.cs-block{margin:1.1rem 0}
.cs-block h4{font-family:var(--font-m);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:.4rem;font-weight:500}
.cs-block p{color:var(--mute);font-size:.97rem}

/* ---------- lists ---------- */
.tick-list{display:grid;gap:.7rem}
.tick-list li{display:flex;gap:.7rem;align-items:flex-start;color:var(--mute);font-size:.97rem}
.tick-list li::before{
  content:"";flex:0 0 18px;height:18px;margin-top:.2rem;border-radius:6px;
  background:var(--grad-soft) ;border:1px solid rgba(43,224,200,.5);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232BE0C8' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:11px;background-position:center;background-repeat:no-repeat;
}
.section-light .tick-list li{color:var(--mute)}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem;max-width:760px}
.faq details{background:var(--glass);border:1px solid var(--line-soft);border-radius:var(--r-s);padding:1.1rem 1.3rem;transition:border-color .2s}
.faq details[open]{border-color:rgba(124,108,255,.45)}
.faq summary{cursor:pointer;font-family:var(--font-d);font-weight:600;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.3rem;color:var(--teal-deep);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin-top:.8rem;color:var(--mute);font-size:.95rem}

/* ---------- forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:grid;gap:.45rem}
.field.full{grid-column:1/-1}
.label{font-family:var(--font-m);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.input,select.input,textarea.input{
  width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r-s);
  color:var(--text);font-family:var(--font-b);font-size:.97rem;padding:.85rem 1rem;
  transition:border-color .2s,box-shadow .2s;appearance:none;
}
select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2393A1B8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;background-size:16px}
.input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(77,168,255,.18)}
textarea.input{min-height:140px;resize:vertical}
.form-note{font-family:var(--font-m);font-size:.7rem;color:var(--faint);margin-top:.9rem}
.form-ok{display:none;margin-top:1rem;border:1px solid rgba(14,159,140,.45);background:rgba(14,159,140,.07);color:var(--teal-deep);border-radius:var(--r-s);padding:.9rem 1.1rem;font-size:.92rem}

/* ---------- CTA band ---------- */
.cta-band{
  position:relative;border-radius:var(--r-l);overflow:hidden;
  border:1px solid rgba(234,240,250,.12);background:var(--navy);
  --text:#F3F6FB;--mute:#A9B6CE;--line:rgba(234,240,250,.18);--line-soft:rgba(234,240,250,.09);
  --glass:rgba(234,240,250,.05);--glass-2:rgba(234,240,250,.09);--faint:#7E8BA6;--teal-deep:#2BE0C8;
  color:var(--text);
  padding:clamp(2.6rem,5vw,4rem);text-align:center;
}
.cta-band::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:.12}
.cta-band::after{
  content:"";position:absolute;width:420px;height:420px;border-radius:50%;
  background:rgba(124,108,255,.3);filter:blur(110px);top:-200px;left:50%;transform:translateX(-50%);
}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{font-size:clamp(1.8rem,3.6vw,2.7rem);margin-bottom:.8rem;color:var(--text)}
.cta-band p{color:var(--mute);max-width:42rem;margin:0 auto 1.8rem}
.cta-band .btn-row{justify-content:center}
.cta-trust{margin-top:1.6rem;display:flex;justify-content:center;flex-wrap:wrap;gap:.6rem}

/* ---------- page hero / breadcrumbs ---------- */
.page-hero{padding:160px 0 70px;position:relative;border-bottom:1px solid var(--line-soft);background:radial-gradient(80% 110% at 50% -10%,rgba(124,108,255,.16),transparent 60%)}
.crumb{font-family:var(--font-m);font-size:.7rem;letter-spacing:.12em;color:var(--faint);margin-bottom:1.2rem;text-transform:uppercase}
.crumb a:hover{color:var(--mute)}

.contact-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}

/* ---------- footer ---------- */
.footer{border-top:1px solid rgba(234,240,250,.1);background:var(--navy);padding:4rem 0 0;color:#F3F6FB;
  --text:#F3F6FB;--mute:#A9B6CE;--line:rgba(234,240,250,.18);--line-soft:rgba(234,240,250,.09);
  --glass:rgba(234,240,250,.05);--glass-2:rgba(234,240,250,.09);--faint:#7E8BA6;--teal-deep:#2BE0C8}
.footer .chip{background:rgba(234,240,250,.06)}
.footer .badge-chip{background:rgba(234,240,250,.07);box-shadow:none}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.4rem;padding-bottom:3rem}
.f-grid h4{font-family:var(--font-m);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:1.1rem;font-weight:500}
.f-grid a{display:block;color:var(--mute);font-size:.93rem;padding:.28rem 0;transition:color .2s}
.f-grid a:hover{color:var(--text)}
.f-about p{color:var(--mute);font-size:.93rem;margin:1rem 0 1.3rem;max-width:30ch}
.f-bottom{border-top:1px solid var(--line-soft);padding:1.4rem 0;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-family:var(--font-m);font-size:.7rem;color:var(--faint)}

/* ---------- floating actions ---------- */
.wa-float{
  position:fixed;right:22px;bottom:92px;z-index:70;width:56px;height:56px;border-radius:50%;
  background:var(--wa);display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(37,211,102,.55);
  transition:transform .2s;
}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:28px;height:28px;fill:#fff}
.m-ctabar{display:none}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ---------- misc ---------- */
.note{
  border:1px solid var(--line);border-left:3px solid var(--teal-deep);
  background:rgba(43,224,200,.05);border-radius:var(--r-s);
  padding:1rem 1.2rem;font-size:.9rem;color:var(--mute);
}
.kbd-divider{height:1px;background:var(--line-soft);margin:2.4rem 0}
.section-light .card{background:#fff;border-color:#E2E8F2;box-shadow:0 14px 30px -18px rgba(0,0,0,.5)}
.section-light .card h3{color:#0B101D}
.section-light .card p{color:#46556E}
.section-light .chip{background:rgba(234,240,250,.06);color:var(--mute)}

/* ---------- responsive ---------- */
@media (max-width:1020px){
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .cols-3,.pf-grid{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:3.2rem}
  .hero{padding:140px 0 70px}
  .hero-visual{margin-top:1rem}
  .f-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .cs,.cs:nth-child(even){grid-template-columns:1fr}
  .cs:nth-child(even) .cs-media{order:0}
}
@media (max-width:740px){
  body{font-size:15.5px}
  .cols-2,.cols-3,.pf-grid,.form-grid{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}
  .nav-links{
    position:fixed;inset:74px 0 auto 0;background:rgba(255,255,255,.98);backdrop-filter:blur(16px);
    flex-direction:column;align-items:flex-start;padding:1.4rem 6%;gap:1.1rem;
    border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .3s;
  }
  .nav-links.open{transform:none}
  .nav-toggle{display:grid;place-items:center}
  .nav .btn{display:none}
  .subnav{position:static;transform:none;opacity:1;pointer-events:auto;box-shadow:none;border:none;background:none;padding:.2rem 0 0 1rem;min-width:0}
  .ft-1{left:-4%}.ft-2{right:-4%}.ft-3{left:-2%}
  .m-ctabar{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:65;
    background:rgba(255,255,255,.95);backdrop-filter:blur(14px);border-top:1px solid var(--line);
    padding:.7rem 5%;gap:.7rem;
  }
  .m-ctabar .btn{flex:1;padding:.8rem 1rem}
  .wa-float{bottom:158px}
  body{padding-bottom:70px}
  .f-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   V2 COMPONENT LAYER — light theme signature pieces
   ============================================================ */

/* anchor offset under fixed nav */
[id]{scroll-margin-top:96px}

/* ---------- scroll progress ---------- */
.nav-progress{position:absolute;left:0;bottom:-1px;height:2.5px;width:0;background:var(--grad);transition:width .12s linear}

/* ---------- aurora hero ambience ---------- */
.aurora{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.aurora::before,.aurora::after,.aurora .blob{content:"";position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;mix-blend-mode:multiply}
.aurora::before{width:620px;height:620px;background:#DCD7FF;top:-220px;left:-140px;animation:drift1 16s ease-in-out infinite}
.aurora::after{width:560px;height:560px;background:#CDEAFB;top:-120px;right:-160px;animation:drift2 19s ease-in-out infinite}
.aurora .blob{width:480px;height:480px;background:#CFF6EE;bottom:-240px;left:32%;animation:drift3 22s ease-in-out infinite}
@keyframes drift1{50%{transform:translate(70px,50px) scale(1.08)}}
@keyframes drift2{50%{transform:translate(-60px,70px) scale(1.12)}}
@keyframes drift3{50%{transform:translate(50px,-60px) scale(1.06)}}
.aurora .gridlines{position:absolute;inset:0;border-radius:0;filter:none;opacity:.5;mix-blend-mode:normal;
  background-image:linear-gradient(rgba(11,21,38,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(11,21,38,.05) 1px,transparent 1px);
  background-size:44px 44px;
  -webkit-mask-image:radial-gradient(70% 60% at 50% 20%,#000 30%,transparent 75%);
          mask-image:radial-gradient(70% 60% at 50% 20%,#000 30%,transparent 75%);}

/* ---------- rotating headline word ---------- */
.rotor{display:inline-grid;vertical-align:bottom;text-align:left}
.rotor>span{grid-area:1/1;opacity:0;transform:translateY(.55em);transition:opacity .45s ease,transform .45s ease;white-space:nowrap}
.rotor>span.on{opacity:1;transform:none}

/* ---------- marketplace badge showcase ---------- */
.mp-badges{display:flex;flex-wrap:wrap;gap:1rem}
.mp-badge{
  --mp:#14A800;position:relative;display:flex;align-items:center;gap:.9rem;
  background:#fff;border:1px solid var(--line-soft);border-radius:16px;
  padding:.9rem 1.25rem .9rem 1.1rem;box-shadow:var(--shadow-soft);
  transition:transform .22s ease,box-shadow .22s ease;overflow:hidden;
}
.mp-badge::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--mp)}
.mp-badge:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.mp-glyph{
  width:44px;height:44px;border-radius:12px;flex:0 0 44px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--mp) 12%,#fff);color:var(--mp);
  font-family:var(--font-d);font-weight:700;font-size:1rem;border:1px solid color-mix(in srgb,var(--mp) 30%,#fff);
}
.mp-badge b{font-family:var(--font-d);font-weight:700;font-size:.98rem;display:block;line-height:1.2;color:var(--text)}
.mp-badge small{font-family:var(--font-m);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:block;margin-top:.18rem}
.mp-badge .stars{font-size:.78rem;display:block;margin-top:.18rem}
.mp-upwork{--mp:#14A800}.mp-fiverr{--mp:#1DBF73}.mp-freelancer{--mp:#0E7BD1}.mp-linkedin{--mp:#0A66C2}
.section-light .mp-badge,.cta-band .mp-badge{border-color:transparent}

/* ---------- floating marketplace rail ---------- */
.rail{position:fixed;left:18px;top:50%;transform:translateY(-50%);z-index:62;display:grid;gap:.7rem}
.rail a{
  --mp:#14A800;display:flex;align-items:center;height:48px;width:48px;border-radius:999px;
  background:#fff;border:1px solid var(--line-soft);box-shadow:var(--shadow-soft);
  overflow:hidden;transition:width .28s ease,box-shadow .2s ease,border-color .2s;
  white-space:nowrap;
}
.rail a:hover{width:max-content;padding-right:1.1rem;border-color:color-mix(in srgb,var(--mp) 45%,#fff);box-shadow:var(--shadow)}
.rail .mp-glyph{width:46px;height:46px;flex:0 0 46px;border-radius:999px;border:none;background:transparent;font-size:.92rem}
.rail a span:not(.mp-glyph){font-family:var(--font-m);font-size:.72rem;letter-spacing:.04em;color:var(--text);opacity:0;transform:translateX(-6px);transition:opacity .22s .06s,transform .22s .06s}
.rail a:hover span:not(.mp-glyph){opacity:1;transform:none}
.rail .mp-glyph{opacity:1}
.rail a span b{color:var(--mp)}
@media (max-width:1100px){.rail{display:none}}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:#fff;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.marquee-track{display:flex;gap:3.2rem;width:max-content;padding:1.05rem 0;animation:marquee 30s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--font-m);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);display:flex;align-items:center;gap:.7rem}
.marquee-track span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--grad)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- free audit panel ---------- */
.audit-panel{
  position:relative;border-radius:var(--r-l);background:#fff;border:1px solid var(--line-soft);
  box-shadow:var(--shadow);overflow:hidden;
  display:grid;grid-template-columns:1.1fr .9fr;
}
.audit-panel::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--grad)}
.audit-copy{padding:clamp(1.8rem,4vw,3rem)}
.audit-form-wrap{background:var(--ink-2);border-left:1px solid var(--line-soft);padding:clamp(1.8rem,4vw,3rem);display:flex;flex-direction:column;justify-content:center}
.audit-list{display:grid;grid-template-columns:1fr 1fr;gap:.55rem .9rem;margin:1.4rem 0 1.6rem}
.audit-list li{display:flex;gap:.55rem;align-items:flex-start;font-size:.9rem;color:var(--mute)}
.audit-list li::before{content:"✓";flex:0 0 auto;font-family:var(--font-m);font-weight:700;color:var(--teal-deep)}
.audit-meta{display:flex;flex-wrap:wrap;gap:.6rem}
@media (max-width:900px){.audit-panel{grid-template-columns:1fr}.audit-form-wrap{border-left:none;border-top:1px solid var(--line-soft)}.audit-list{grid-template-columns:1fr}}

/* ---------- review wall ---------- */
.rv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;align-items:start}
.rv-card{display:flex;flex-direction:column;gap:.85rem;padding:1.5rem 1.5rem 1.4rem}
.rv-card[hidden]{display:none}
.rv-head{display:flex;align-items:center;gap:.8rem}
.rv-ava{width:44px;height:44px;border-radius:50%;flex:0 0 44px;object-fit:cover;border:2px solid #fff;box-shadow:0 0 0 2px var(--line-soft)}
.rv-ava-fallback{width:44px;height:44px;border-radius:50%;flex:0 0 44px;display:grid;place-items:center;background:var(--grad-soft);font-family:var(--font-d);font-weight:700;color:#3F37A8}
.rv-head b{font-family:var(--font-d);font-size:.95rem;display:block;line-height:1.25}
.rv-head small{font-family:var(--font-m);font-size:.66rem;color:var(--faint);letter-spacing:.06em}
.rv-pill{--mp:#1DBF73;margin-left:auto;font-family:var(--font-m);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mp);background:color-mix(in srgb,var(--mp) 10%,#fff);border:1px solid color-mix(in srgb,var(--mp) 28%,#fff);border-radius:999px;padding:.32rem .65rem;white-space:nowrap}
.rv-text{font-size:.94rem;color:var(--text);line-height:1.65}
.rv-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:.8rem;border-top:1px dashed var(--line-soft);font-family:var(--font-m);font-size:.64rem;letter-spacing:.08em;color:var(--faint);text-transform:uppercase}
.rv-shot{padding:0;overflow:hidden}
.rv-shot img{width:100%;display:block;border-bottom:1px solid var(--line-soft)}
.rv-shot .rv-cap{padding:.9rem 1.2rem;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-m);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.rv-shot .rv-cap a{color:var(--teal-deep)}
.load-more-wrap{text-align:center;margin-top:2.2rem}
@media (max-width:1020px){.rv-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:860px){.rv-grid{grid-template-columns:1fr}}
@media (max-width:740px){.rv-grid{grid-template-columns:1fr}}

/* ---------- AI chat demo ---------- */
.chat-demo{
  background:#fff;border:1px solid var(--line-soft);border-radius:22px;box-shadow:var(--shadow);
  max-width:430px;margin:0 auto;overflow:hidden;
}
.chat-top{display:flex;align-items:center;gap:.8rem;padding:1rem 1.2rem;border-bottom:1px solid var(--line-soft);background:var(--ink-2)}
.chat-top .mp-glyph{width:38px;height:38px;flex:0 0 38px;border-radius:11px;background:var(--grad);color:#06121C;border:none;font-size:.85rem}
.chat-top b{font-family:var(--font-d);font-size:.92rem;display:block;line-height:1.2}
.chat-top small{font-family:var(--font-m);font-size:.64rem;color:var(--teal-deep);display:flex;align-items:center;gap:.4rem}
.chat-body{padding:1.2rem;display:grid;gap:.7rem;min-height:330px;align-content:start}
.msg{max-width:82%;padding:.7rem .95rem;border-radius:14px;font-size:.88rem;line-height:1.5;opacity:0;transform:translateY(8px);animation:msgin .5s ease forwards}
.msg.bot{background:var(--ink-2);border:1px solid var(--line-soft);border-bottom-left-radius:4px}
.msg.user{background:var(--grad);color:#06121C;margin-left:auto;border-bottom-right-radius:4px;font-weight:500}
.msg .mono{font-size:.72rem;color:var(--teal-deep);display:block;margin-top:.35rem}
.msg.m1{animation-delay:.6s}.msg.m2{animation-delay:1.7s}.msg.m3{animation-delay:3.1s}
.msg.m4{animation-delay:4.6s}.msg.m5{animation-delay:6.2s}
@keyframes msgin{to{opacity:1;transform:none}}
.typing{display:inline-flex;gap:4px;padding:.7rem .9rem;background:var(--ink-2);border:1px solid var(--line-soft);border-radius:14px;border-bottom-left-radius:4px;width:max-content;opacity:0;animation:typeblink 1.1s ease .1s forwards, typeout .3s ease 5.9s forwards}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--faint);animation:bounce 1s infinite}
.typing i:nth-child(2){animation-delay:.15s}.typing i:nth-child(3){animation-delay:.3s}
@keyframes bounce{30%{transform:translateY(-4px)}}
@keyframes typeblink{to{opacity:1}}
@keyframes typeout{to{opacity:0;height:0;padding:0;margin:0;border:0}}
.chat-foot{display:flex;gap:.6rem;padding: .9rem 1.2rem;border-top:1px solid var(--line-soft)}
.chat-foot .fake-input{flex:1;border:1px solid var(--line);border-radius:999px;padding:.6rem 1rem;font-size:.84rem;color:var(--faint);background:#fff}
.chat-foot .send{width:38px;height:38px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#06121C;font-weight:700}

/* ---------- voice agent demo ---------- */
.voice-demo{background:#fff;border:1px solid var(--line-soft);border-radius:22px;box-shadow:var(--shadow);padding:1.6rem;max-width:430px;margin:0 auto}
.voice-head{display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}
.voice-head .mp-glyph{border-radius:50%;background:var(--grad);color:#06121C;border:none}
.eq{display:flex;align-items:center;gap:5px;height:64px;justify-content:center;margin:0 0 1.1rem}
.eq i{width:5px;border-radius:3px;background:var(--grad);height:14px;animation:eq 1.15s ease-in-out infinite}
.eq i:nth-child(2){animation-delay:.1s}.eq i:nth-child(3){animation-delay:.2s}.eq i:nth-child(4){animation-delay:.3s}
.eq i:nth-child(5){animation-delay:.4s}.eq i:nth-child(6){animation-delay:.5s}.eq i:nth-child(7){animation-delay:.6s}
.eq i:nth-child(8){animation-delay:.45s}.eq i:nth-child(9){animation-delay:.3s}.eq i:nth-child(10){animation-delay:.15s}
.eq i:nth-child(11){animation-delay:.25s}.eq i:nth-child(12){animation-delay:.05s}.eq i:nth-child(13){animation-delay:.35s}
@keyframes eq{50%{height:46px}}
.voice-line{font-family:var(--font-m);font-size:.76rem;color:var(--mute);border:1px dashed var(--line);border-radius:10px;padding:.8rem .9rem;min-height:58px}
.voice-line b{color:var(--teal-deep)}
.voice-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}

/* dark-band variants for demos */
.section-light .chat-demo,.section-light .voice-demo{border-color:transparent}

/* ============================================================
   V3 — official-style badges · neural bg · live icons · chatbot
   ============================================================ */

/* ---------- logo with real photo ---------- */
.logo-img{width:40px;height:40px;border-radius:50%;object-fit:cover;object-position:top;background:#E9EDF6;border:2px solid #fff;box-shadow:0 0 0 2px rgba(124,108,255,.45)}
.footer .logo-img{border-color:#1A2236;box-shadow:0 0 0 2px rgba(124,108,255,.55)}

/* ---------- avatar fallback (broken-image proof) ---------- */
.avatar-fb{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;flex:0 0 46px;
  background:linear-gradient(135deg,rgba(124,108,255,.18),rgba(43,224,200,.18)),#fff;
  font-family:var(--font-d);font-weight:700;color:#4338CA;border:2px solid rgba(124,108,255,.5)}

/* ---------- official-style marketplace badges ---------- */
.ob-row{display:flex;flex-wrap:wrap;gap:1rem}
.ob{position:relative;display:flex;align-items:center;gap:.95rem;background:#fff;border:1px solid var(--line-soft);
  border-radius:16px;padding:.85rem 1.3rem .85rem .95rem;box-shadow:var(--shadow-soft);
  transition:transform .22s,box-shadow .22s}
.ob:hover{transform:translateY(-4px) scale(1.015);box-shadow:var(--shadow)}
.ob-art{flex:0 0 auto;display:grid;place-items:center}
.ob b{font-family:var(--font-d);font-weight:700;font-size:1rem;display:block;line-height:1.2;color:var(--text)}
.ob small{font-family:var(--font-m);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:block;margin-top:.22rem}
.ob .stars{font-size:.78rem;display:block;margin-top:.2rem}
.ob-verify{position:absolute;top:.55rem;right:.7rem;font-family:var(--font-m);font-size:.56rem;letter-spacing:.12em;color:var(--faint)}
.ob:hover .ob-verify{color:var(--teal-deep)}
/* Upwork Top Rated Plus — pink shield */
.ob-up .ob-art{width:46px;height:46px;border-radius:12px;background:linear-gradient(150deg,#FF5CA8,#E91E73);box-shadow:0 6px 14px -6px rgba(233,30,115,.55)}
.ob-up .ob-art svg{width:24px;height:24px;fill:#fff}
/* Fiverr Level 2 — green diamonds */
.ob-fi .ob-art{width:46px;height:46px;border-radius:12px;background:linear-gradient(150deg,#27D886,#13A463);box-shadow:0 6px 14px -6px rgba(29,191,115,.55);flex-direction:column;display:flex;align-items:center;justify-content:center;gap:3px}
.ob-fi .ob-art .fi-word{color:#fff;font-family:var(--font-d);font-weight:700;font-size:.78rem;line-height:1}
.ob-fi .ob-art .fi-diamonds{display:flex;gap:3px}
.ob-fi .ob-art .fi-diamonds i{width:7px;height:7px;background:#fff;transform:rotate(45deg);border-radius:1.5px}
.ob-fi .ob-art .fi-diamonds i.off{background:rgba(255,255,255,.35)}
/* Freelancer — blue bird */
.ob-fl .ob-art{width:46px;height:46px;border-radius:12px;background:linear-gradient(150deg,#3FA9F5,#0E6FC0);box-shadow:0 6px 14px -6px rgba(14,123,209,.5)}
.ob-fl .ob-art svg{width:24px;height:24px;fill:#fff}
.ob-laurel{color:var(--gold);font-size:.95rem}

/* ---------- neural network canvas ---------- */
.neural{position:absolute;inset:0;width:100%;height:100%;opacity:.55;pointer-events:none}

/* ---------- animated service icons ---------- */
.icon-tile.live{background:linear-gradient(135deg,rgba(124,108,255,.10),rgba(43,224,200,.10)),#fff}
.icon-tile.live svg{width:28px;height:28px;overflow:visible}
.icon-tile.live svg *{transform-box:fill-box;transform-origin:center}
.tdot{animation:tdot 1.2s ease-in-out infinite}
.tdot:nth-of-type(2){animation-delay:.18s}.tdot:nth-of-type(3){animation-delay:.36s}
@keyframes tdot{0%,60%,100%{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-2.2px)}}
.spark{animation:spark 2.4s ease-in-out infinite}
.spark.s2{animation-delay:1.2s}
@keyframes spark{0%,100%{opacity:0;transform:scale(.4)}50%{opacity:1;transform:scale(1)}}
.vbar{animation:vbar 1.1s ease-in-out infinite}
.vbar:nth-of-type(2){animation-delay:.12s}.vbar:nth-of-type(3){animation-delay:.24s}
.vbar:nth-of-type(4){animation-delay:.36s}.vbar:nth-of-type(5){animation-delay:.48s}
@keyframes vbar{50%{transform:scaleY(2.1)}}
.boltp{animation:boltp 1.8s ease-in-out infinite}
@keyframes boltp{0%,100%{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.14);filter:drop-shadow(0 0 5px rgba(124,108,255,.8))}}
.ringp{animation:ringp 1.8s ease-out infinite}
@keyframes ringp{0%{opacity:.7;transform:scale(.6)}100%{opacity:0;transform:scale(1.5)}}
.crmdot{animation:crmdot 2.6s ease-in-out infinite}
@keyframes crmdot{0%,12%{transform:translate(0,-3px)}38%,50%{transform:translate(6.7px,-5px)}76%,88%{transform:translate(13.4px,-7px)}100%{transform:translate(0,-3px);opacity:.3}}
.fdrop{animation:fdrop 1.9s ease-in infinite}
.fdrop.f2{animation-delay:.6s}.fdrop.f3{animation-delay:1.2s}
@keyframes fdrop{0%{opacity:0;transform:translateY(-7px)}25%{opacity:1}80%{opacity:1;transform:translateY(7px)}100%{opacity:0;transform:translateY(9px)}}
.gear1{animation:gspin 5s linear infinite}
.gear2{animation:gspin 5s linear infinite reverse}
@keyframes gspin{to{transform:rotate(360deg)}}
.orbit{animation:gspin 4s linear infinite}
.typeln{stroke-dasharray:14;stroke-dashoffset:14;animation:typeln 2.2s ease infinite}
.typeln.t2{animation-delay:.5s}
@keyframes typeln{40%,80%{stroke-dashoffset:0;opacity:1}100%{stroke-dashoffset:0;opacity:0}}
.cartitem{animation:cartitem 2.1s ease-in-out infinite}
@keyframes cartitem{0%{opacity:0;transform:translateY(-8px)}35%{opacity:1;transform:translateY(0)}55%{transform:translateY(-1.6px)}70%,100%{opacity:1;transform:translateY(0)}}
.cartbody{animation:cartn 2.1s ease-in-out infinite}
@keyframes cartn{55%{transform:translateX(0)}62%{transform:translateX(1.6px)}70%{transform:translateX(0)}}

/* ---------- AI chat widget ---------- */
.cw-launch{
  position:fixed;right:22px;bottom:22px;z-index:71;width:56px;height:56px;border-radius:50%;
  background:var(--grad);border:none;cursor:pointer;display:grid;place-items:center;
  box-shadow:0 14px 32px -8px rgba(77,168,255,.6);transition:transform .2s;
}
.cw-launch:hover{transform:scale(1.08)}
.cw-launch svg{width:28px;height:28px;fill:#06121C}
.cw-launch::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(124,108,255,.5);animation:ringp 2.2s ease-out infinite}
.cw-badge{position:absolute;top:-2px;right:-2px;width:14px;height:14px;border-radius:50%;background:var(--teal);border:2.5px solid #fff}
.cw{
  position:fixed;right:22px;bottom:92px;z-index:72;width:min(380px,calc(100vw - 32px));
  background:#fff;border:1px solid var(--line-soft);border-radius:20px;box-shadow:0 30px 70px -20px rgba(11,21,38,.4);
  display:flex;flex-direction:column;overflow:hidden;max-height:min(620px,calc(100vh - 130px));
  opacity:0;transform:translateY(14px) scale(.98);pointer-events:none;transition:opacity .25s,transform .25s;
}
.cw.open{opacity:1;transform:none;pointer-events:auto}
.cw-head{display:flex;align-items:center;gap:.8rem;padding:1rem 1.1rem;background:var(--navy);color:#F3F6FB}
.cw-head img{width:40px;height:40px;border-radius:50%;object-fit:cover;object-position:top;border:2px solid rgba(124,108,255,.7);background:#1A2236}
.cw-head b{font-family:var(--font-d);font-size:.95rem;display:block;line-height:1.2}
.cw-head small{font-family:var(--font-m);font-size:.64rem;color:#2BE0C8;display:flex;align-items:center;gap:.4rem;margin-top:.15rem}
.cw-close{margin-left:auto;background:rgba(234,240,250,.1);border:none;color:#F3F6FB;width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:1rem}
.cw-body{padding:1rem;display:grid;gap:.6rem;overflow-y:auto;flex:1;background:linear-gradient(180deg,#F7F9FC,#FFFFFF)}
.cw-msg{max-width:85%;padding:.65rem .9rem;border-radius:13px;font-size:.88rem;line-height:1.55;animation:msgin .35s ease}
.cw-msg.bot{background:#fff;border:1px solid var(--line-soft);border-bottom-left-radius:4px;box-shadow:var(--shadow-soft)}
.cw-msg.user{background:var(--grad);color:#06121C;margin-left:auto;border-bottom-right-radius:4px;font-weight:500}
.cw-msg a{color:#4F46E5;font-weight:600;text-decoration:underline}
.cw-msg.bot ul{margin:.4rem 0 0 .9rem;list-style:disc}
.cw-typing{display:inline-flex;gap:4px;padding:.65rem .85rem;background:#fff;border:1px solid var(--line-soft);border-radius:13px;border-bottom-left-radius:4px;width:max-content}
.cw-typing i{width:6px;height:6px;border-radius:50%;background:var(--faint);animation:bounce 1s infinite}
.cw-typing i:nth-child(2){animation-delay:.15s}.cw-typing i:nth-child(3){animation-delay:.3s}
.cw-chips{display:flex;gap:.45rem;flex-wrap:wrap;padding:.5rem 1rem .7rem;border-top:1px dashed var(--line-soft);background:#fff}
.cw-chips button{font-family:var(--font-m);font-size:.68rem;border:1px solid var(--line);background:#fff;color:var(--mute);border-radius:999px;padding:.42rem .8rem;cursor:pointer;transition:all .18s}
.cw-chips button:hover{border-color:var(--violet);color:var(--text);background:rgba(124,108,255,.06)}
.cw-input{display:flex;gap:.55rem;padding: .8rem 1rem;border-top:1px solid var(--line-soft);background:#fff}
.cw-input input{flex:1;border:1px solid var(--line);border-radius:999px;padding:.65rem 1rem;font-size:.9rem;font-family:var(--font-b);color:var(--text)}
.cw-input input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(77,168,255,.16)}
.cw-input button{width:42px;height:42px;border-radius:50%;border:none;background:var(--grad);color:#06121C;font-weight:700;cursor:pointer;display:grid;place-items:center}
.cw-note{font-family:var(--font-m);font-size:.58rem;letter-spacing:.06em;color:var(--faint);text-align:center;padding:0 1rem .7rem;background:#fff}
@media (max-width:740px){
  .cw-launch{bottom:90px}
  .cw{bottom:158px;right:16px}
}

/* ============================================================
   V4 — refined hero trust strip · video proof · large live visuals
   ============================================================ */

/* ---------- compact hero trust strip ---------- */
.trust-strip{
  display:inline-flex;align-items:center;flex-wrap:wrap;gap:.4rem 1.15rem;
  background:rgba(255,255,255,.85);backdrop-filter:blur(8px);
  border:1px solid var(--line-soft);border-radius:18px;
  padding:.8rem 1.25rem;box-shadow:var(--shadow-soft);margin-top:1.9rem;
}
.trust-strip a{display:flex;align-items:center;gap:.65rem;transition:transform .18s}
.trust-strip a:hover{transform:translateY(-2px)}
.ts-ic{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:0 0 32px;color:#fff;font-family:var(--font-d);font-weight:700;font-size:.8rem}
.ts-ic svg{width:17px;height:17px;fill:#fff}
.ts-up{background:linear-gradient(150deg,#FF5CA8,#E91E73)}
.ts-fi{background:linear-gradient(150deg,#27D886,#13A463)}
.ts-fl{background:linear-gradient(150deg,#3FA9F5,#0E6FC0)}
.trust-strip b{font-family:var(--font-d);font-weight:700;font-size:.86rem;display:block;line-height:1.15;color:var(--text)}
.trust-strip small{font-family:var(--font-m);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:block;margin-top:.12rem}
.trust-strip .gold{color:var(--gold)}
.ts-div{width:1px;height:30px;background:var(--line-soft)}
@media (max-width:680px){.ts-div{display:none}.trust-strip{gap:.7rem 1.2rem}}

/* ---------- YouTube video testimonials (lite embed) ---------- */
.yt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.yt-card{position:relative;border-radius:var(--r-m);overflow:hidden;border:1px solid var(--line-soft);
  background:#0B101D;box-shadow:var(--shadow-soft);aspect-ratio:16/9;cursor:pointer;
  transition:transform .22s,box-shadow .22s}
.yt-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.yt-card img{width:100%;height:100%;object-fit:cover;opacity:.92;transition:opacity .2s,transform .35s}
.yt-card:hover img{opacity:1;transform:scale(1.04)}
.yt-card iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.yt-play{position:absolute;inset:0;margin:auto;width:62px;height:62px;border-radius:50%;
  background:var(--grad);display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(77,168,255,.7);
  transition:transform .2s;pointer-events:none}
.yt-card:hover .yt-play{transform:scale(1.1)}
.yt-play svg{width:24px;height:24px;fill:#06121C;margin-left:3px}
.yt-tag{position:absolute;left:12px;bottom:12px;font-family:var(--font-m);font-size:.62rem;letter-spacing:.12em;
  text-transform:uppercase;background:rgba(6,8,15,.78);color:#EAF0FA;border:1px solid rgba(234,240,250,.2);
  border-radius:999px;padding:.35rem .75rem;pointer-events:none}
@media (max-width:1020px){.yt-grid{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.yt-grid{grid-template-columns:1fr}}

/* ---------- LARGE animated service visuals ---------- */
.svc-visual{
  margin:-1.8rem -1.8rem 1.3rem;border-radius:var(--r-m) var(--r-m) 0 0;
  background:
    radial-gradient(90% 120% at 20% 0%,rgba(124,108,255,.14),transparent 60%),
    radial-gradient(90% 120% at 85% 100%,rgba(43,224,200,.14),transparent 60%),
    linear-gradient(180deg,#F2F5FC,#FFFFFF);
  border-bottom:1px solid var(--line-soft);
  padding:1.1rem 1rem .9rem;display:grid;place-items:center;
}
.svc-visual svg{width:100%;max-width:230px;height:auto;overflow:visible}
.svc-visual svg *{transform-box:fill-box;transform-origin:center}
.card:hover .svc-visual{background:
    radial-gradient(90% 120% at 20% 0%,rgba(124,108,255,.2),transparent 60%),
    radial-gradient(90% 120% at 85% 100%,rgba(43,224,200,.2),transparent 60%),
    linear-gradient(180deg,#EEF2FB,#FFFFFF)}
.flowdot{animation:flow 2.8s linear infinite}
.flowdot.f2{animation-delay:.9s}.flowdot.f3{animation-delay:1.8s}
@keyframes flow{0%{transform:translateX(0);opacity:0}12%{opacity:1}85%{opacity:1}100%{transform:translateX(118px);opacity:0}}
.kbcard{animation:kbcard 3.6s ease-in-out infinite}
@keyframes kbcard{0%,14%{transform:translate(0,0)}36%,50%{transform:translate(64px,6px)}72%,86%{transform:translate(128px,-4px)}100%{transform:translate(0,0);opacity:.4}}
.cursorb{animation:cursorb 1s steps(1) infinite}
@keyframes cursorb{50%{opacity:0}}
.wavearc{animation:wavearc 1.6s ease-out infinite;transform-origin:left center}
.wavearc.w2{animation-delay:.4s}
@keyframes wavearc{0%{opacity:0;transform:scale(.7)}40%{opacity:.9}100%{opacity:0;transform:scale(1.25)}}
.pricepop{animation:pricepop 2.1s ease-in-out infinite}
@keyframes pricepop{0%,30%{opacity:0;transform:translateY(4px) scale(.8)}45%,80%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:0}}


/* ============================================================
   V5 — full-width hero trust bar · readable screenshot proof
   ============================================================ */
.hero-trustbar{
  margin-top:2.8rem;background:rgba(255,255,255,.82);backdrop-filter:blur(10px);
  border:1px solid var(--line-soft);border-radius:20px;box-shadow:var(--shadow-soft);
  display:grid;grid-template-columns:repeat(3,1fr);overflow:hidden;
}
.hero-trustbar a{display:flex;align-items:center;gap:1rem;padding:1.15rem 1.5rem;transition:background .2s}
.hero-trustbar a + a{border-left:1px solid var(--line-soft)}
.hero-trustbar a:hover{background:rgba(124,108,255,.05)}
.hero-trustbar .ts-ic{width:40px;height:40px;border-radius:11px;flex:0 0 40px;font-size:.95rem}
.hero-trustbar .ts-ic svg{width:21px;height:21px}
.hero-trustbar b{font-family:var(--font-d);font-weight:700;font-size:1rem;display:block;line-height:1.18;color:var(--text)}
.hero-trustbar small{font-family:var(--font-m);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);display:block;margin-top:.18rem}
.hero-trustbar .gold{color:var(--gold)}
.hero-trustbar .tb-go{margin-left:auto;font-family:var(--font-m);font-size:.62rem;letter-spacing:.1em;color:var(--faint);transition:color .2s}
.hero-trustbar a:hover .tb-go{color:var(--teal-deep)}
@media (max-width:880px){
  .hero-trustbar{grid-template-columns:1fr}
  .hero-trustbar a + a{border-left:none;border-top:1px solid var(--line-soft)}
  .hero-trustbar .tb-go{display:none}
}

/* readable, clickable review screenshots */
.rv-shot a.shot-link{display:block;overflow:hidden;cursor:zoom-in}
.rv-shot img{transition:transform .35s}
.rv-shot:hover img{transform:scale(1.015)}
.proof-strip{display:grid;gap:1.3rem;max-width:920px;margin:0 auto}
.proof-strip .rv-shot{box-shadow:var(--shadow-soft)}

/* ============================================================
   V6 — video popup player (lightbox)
   ============================================================ */
.vmodal{position:fixed;inset:0;z-index:90;display:grid;place-items:center;padding:4vh 4vw;
  background:rgba(6,8,15,.78);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .25s}
.vmodal.open{opacity:1;pointer-events:auto}
.vmodal-box{position:relative;width:min(940px,100%);aspect-ratio:16/9;background:#000;
  border-radius:18px;overflow:hidden;box-shadow:0 40px 90px -20px rgba(0,0,0,.7);
  transform:translateY(16px) scale(.98);transition:transform .25s}
.vmodal.open .vmodal-box{transform:none}
.vmodal-box iframe{width:100%;height:100%;border:0;display:block}
.vmodal-close{position:absolute;top:-46px;right:0;width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(234,240,250,.35);background:rgba(234,240,250,.1);color:#fff;
  font-size:1.05rem;cursor:pointer;display:grid;place-items:center;transition:background .2s}
.vmodal-close:hover{background:rgba(234,240,250,.22)}
.vmodal-fallback{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:2rem;color:#EAF0FA}
.vmodal-fallback p{font-family:var(--font-m);font-size:.78rem;color:#A9B6CE;max-width:46ch;margin-bottom:1.2rem}
body.modal-open{overflow:hidden}
@media (max-width:740px){.vmodal-close{top:auto;bottom:-50px;right:calc(50% - 19px)}}

/* ============================================================
   V7 — premium hero portrait · animated light process flow
   ============================================================ */
ol{list-style:none}

/* ---------- hero portrait ---------- */
.hero-portrait{position:relative;width:min(430px,86vw);aspect-ratio:4.2/5;justify-self:center}
.hp-plate{
  position:absolute;left:4%;right:4%;bottom:0;height:72%;border-radius:36px;
  background:linear-gradient(135deg,#7C6CFF,#4DA8FF 52%,#2BE0C8);
  background-size:190% 190%;animation:hpgrad 9s ease-in-out infinite;
  box-shadow:0 40px 80px -28px rgba(77,108,255,.55),inset 0 1px 0 rgba(255,255,255,.4);
}
.hp-plate::after{
  content:"";position:absolute;inset:0;border-radius:inherit;opacity:.35;
  background-image:radial-gradient(rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:18px 18px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 70%);
          mask-image:linear-gradient(180deg,#000,transparent 70%);
}
@keyframes hpgrad{50%{background-position:100% 100%}}
.hp-ring{
  position:absolute;top:1.5%;left:50%;transform:translateX(-50%);
  width:64%;aspect-ratio:1;border-radius:50%;opacity:.9;
  background:conic-gradient(from 0deg,#7C6CFF,#2BE0C8,#4DA8FF,#7C6CFF);
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 3.5px),#000 calc(100% - 3.5px));
          mask:radial-gradient(farthest-side,transparent calc(100% - 3.5px),#000 calc(100% - 3.5px));
  animation:gspin 16s linear infinite;
}
.hp-img{
  position:absolute;bottom:3.5%;left:50%;transform:translateX(-50%);
  width:97%;max-width:none;z-index:2;
  filter:drop-shadow(0 26px 30px rgba(11,21,38,.38));
}
.hp-bar{
  position:absolute;left:50%;bottom:-21px;transform:translateX(-50%);z-index:3;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border:1px solid var(--line-soft);box-shadow:var(--shadow-soft);border-radius:999px;
  font-family:var(--font-m);font-size:.64rem;letter-spacing:.14em;color:var(--mute);
  padding:.62rem 1.15rem;display:flex;align-items:center;gap:.55rem;white-space:nowrap;
}
.hero-portrait .float-tag{z-index:3}
.hero-portrait .ft-1{top:7%;left:-8%}
.hero-portrait .ft-2{top:40%;right:-10%}
.hero-portrait .ft-3{bottom:22%;left:-7%}
@media (max-width:740px){
  .hero-portrait .ft-1{left:-2%}.hero-portrait .ft-2{right:-2%}.hero-portrait .ft-3{left:-1%}
}

/* ---------- animated process flow (light) ---------- */
.flowproc{position:relative;padding-top:22px;margin-top:.6rem}
.fp-track{position:absolute;top:19px;left:10%;right:10%;height:3px;border-radius:3px;
  background:linear-gradient(90deg,rgba(124,108,255,.22),rgba(77,168,255,.22),rgba(43,224,200,.22))}
.fp-pulse{position:absolute;top:50%;left:0;width:15px;height:15px;border-radius:50%;
  background:var(--grad);transform:translate(-50%,-50%);
  box-shadow:0 0 0 6px rgba(124,108,255,.16),0 0 20px rgba(77,168,255,.85);
  animation:fppulse 12.5s linear infinite}
@keyframes fppulse{
  0%{left:0;opacity:1}18%{left:25%}22%{left:25%}38%{left:50%}42%{left:50%}
  58%{left:75%}62%{left:75%}78%{left:100%}94%{left:100%;opacity:1}97%{opacity:0}
  98%{left:0;opacity:0}100%{left:0;opacity:1}}
.fp-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:1.2rem}
.fp-step{position:relative;background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-m);
  padding:2.5rem 1.25rem 1.5rem;box-shadow:var(--shadow-soft);
  animation:stepglow 12.5s ease-in-out infinite;animation-delay:calc(var(--i)*2.5s)}
@keyframes stepglow{
  0%,16%,100%{transform:translateY(0);box-shadow:var(--shadow-soft);border-color:var(--line-soft)}
  4%,12%{transform:translateY(-8px);box-shadow:0 26px 50px -18px rgba(124,108,255,.45);border-color:rgba(124,108,255,.55)}}
.fp-num{position:absolute;top:-19px;left:1.25rem;width:38px;height:38px;border-radius:50%;
  background:var(--grad);color:#06121C;font-family:var(--font-d);font-weight:700;font-size:.85rem;
  display:grid;place-items:center;box-shadow:0 10px 24px -8px rgba(77,168,255,.65);
  animation:numglow 12.5s ease-in-out infinite;animation-delay:calc(var(--i)*2.5s)}
@keyframes numglow{4%,12%{transform:scale(1.2)}}
.fp-scene{height:78px;border-radius:12px;margin-bottom:1rem;display:grid;place-items:center;
  background:radial-gradient(80% 120% at 30% 0%,rgba(124,108,255,.12),transparent 60%),
             radial-gradient(80% 120% at 80% 100%,rgba(43,224,200,.12),transparent 60%),#F4F7FD;
  border:1px solid var(--line-soft)}
.fp-scene svg{width:108px;height:62px;overflow:visible}
.fp-scene svg *{transform-box:fill-box;transform-origin:center}
.fp-step h3{font-size:1.05rem;margin-bottom:.45rem}
.fp-step p{font-size:.88rem;color:var(--mute)}
.scan{animation:scan 3.2s ease-in-out infinite}
@keyframes scan{0%,100%{transform:translate(0,0)}50%{transform:translate(26px,9px)}}
.drawln{stroke-dasharray:100;stroke-dashoffset:100;animation:drawln 3.4s ease-in-out infinite}
@keyframes drawln{45%,75%{stroke-dashoffset:0;opacity:1}95%{stroke-dashoffset:0;opacity:0}100%{opacity:0}}
.rise{animation:rise 3s ease-out infinite}
.rise.r2{animation-delay:.45s}.rise.r3{animation-delay:.9s}
@keyframes rise{0%{opacity:0;transform:translateY(14px)}25%,85%{opacity:1;transform:translateY(0)}100%{opacity:0}}
.lift{animation:lift 2.6s ease-in-out infinite}
@keyframes lift{50%{transform:translateY(-7px)}}
.flame{animation:flame .45s ease-in-out infinite alternate}
@keyframes flame{to{transform:scaleY(1.5);opacity:.7}}
@media (max-width:1020px){
  .fp-steps{grid-template-columns:1fr;gap:1.6rem}
  .fp-track{left:19px;right:auto;top:24px;bottom:24px;width:3px;height:auto;
    background:linear-gradient(180deg,rgba(124,108,255,.22),rgba(43,224,200,.22))}
  .fp-pulse{animation-name:fppulsev;left:50%!important;top:0}
  @keyframes fppulsev{
    0%{top:0;opacity:1}18%{top:25%}22%{top:25%}38%{top:50%}42%{top:50%}
    58%{top:75%}62%{top:75%}78%{top:100%}94%{top:100%;opacity:1}97%{opacity:0}
    98%{top:0;opacity:0}100%{top:0;opacity:1}}
  .fp-step{margin-left:44px}
  .fp-num{left:-44px;top:18px}
}

/* muted looping video previews inside the cards */




/* ============================================================
   V8 — clean premium hero · blinking NEW nav · no whatsapp
   ============================================================ */

/* studio-style portrait: soft stage, gradient halo, crisp cutout */
.hero-stage{position:relative;width:min(460px,88vw);aspect-ratio:1/1.04;justify-self:center;display:grid;place-items:center}
.hs-halo{position:absolute;inset:6%;border-radius:50%;
  background:conic-gradient(from 210deg,#7C6CFF,#4DA8FF,#2BE0C8,#7C6CFF);
  filter:blur(46px);opacity:.42;animation:gspin 22s linear infinite}
.hs-disc{position:absolute;inset:9%;border-radius:50%;
  background:radial-gradient(120% 120% at 50% 20%,#FFFFFF,#EEF2FB 55%,#E3EAF6);
  box-shadow:inset 0 1px 0 #fff, 0 30px 70px -30px rgba(11,21,38,.45)}
.hs-disc::before{content:"";position:absolute;inset:0;border-radius:50%;padding:1.5px;
  background:linear-gradient(160deg,rgba(124,108,255,.6),rgba(43,224,200,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude}
.hs-grid{position:absolute;inset:9%;border-radius:50%;overflow:hidden;opacity:.5}
.hs-grid::after{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(124,108,255,.18) 1px,transparent 1px),linear-gradient(90deg,rgba(124,108,255,.18) 1px,transparent 1px);
  background-size:30px 30px;
  -webkit-mask-image:radial-gradient(60% 60% at 50% 45%,#000,transparent 72%);mask-image:radial-gradient(60% 60% at 50% 45%,#000,transparent 72%)}
.hs-img{position:relative;z-index:2;width:90%;max-width:none;align-self:end;
  filter:drop-shadow(0 22px 26px rgba(11,21,38,.32))}
.hs-ribbon{position:absolute;z-index:3;top:9%;left:50%;transform:translateX(-50%);
  font-family:var(--font-m);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);
  background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border:1px solid var(--line-soft);
  border-radius:999px;padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem;box-shadow:var(--shadow-soft);white-space:nowrap}
/* floating glass stat pills */
.hs-pill{position:absolute;z-index:3;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);
  border:1px solid var(--line-soft);border-radius:14px;box-shadow:0 14px 30px -14px rgba(11,21,38,.3);
  padding:.62rem .85rem;display:flex;align-items:center;gap:.6rem;animation:floaty 6s ease-in-out infinite}
.hs-pill .pic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:#fff;flex:0 0 30px}
.hs-pill b{font-family:var(--font-d);font-weight:700;font-size:.82rem;display:block;line-height:1.1;color:var(--text)}
.hs-pill small{font-family:var(--font-m);font-size:.58rem;letter-spacing:.08em;color:var(--faint);text-transform:uppercase}
.hs-p1{top:14%;left:-6%;animation-delay:.2s}
.hs-p2{top:46%;right:-9%;animation-delay:1.3s}
.hs-p3{bottom:9%;left:-4%;animation-delay:2.4s}
.hs-star{color:var(--gold)}
@media (max-width:740px){.hs-p1{left:-2%}.hs-p2{right:-2%}.hs-p3{left:-1%}.hs-img{width:88%}}

/* blinking NEW nav item */
.nav-new{position:relative;display:inline-flex;align-items:center;gap:.4rem}
.nav-new .grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:600}
.nav-new .tagnew{font-family:var(--font-m);font-size:.54rem;font-weight:600;letter-spacing:.12em;
  color:#fff;background:var(--grad);border-radius:5px;padding:.12rem .32rem;line-height:1;
  animation:blink 1.25s steps(1) infinite;box-shadow:0 0 0 0 rgba(124,108,255,.5)}
@keyframes blink{50%{opacity:.25}}
.nav-new::after{display:none!important}
.subnav a.sub-new{display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.subnav a.sub-new .tagnew{font-family:var(--font-m);font-size:.5rem;color:#fff;background:var(--grad);border-radius:4px;padding:.1rem .3rem;letter-spacing:.1em;animation:blink 1.25s steps(1) infinite}


/* ============================================================
   V9 — hero stage polish (clip photo to disc, depth, glow)
   ============================================================ */
.hero-stage{isolation:isolate}
/* clip the portrait neatly inside the disc with a soft fade at the base */
.hs-img{
  width:78%;bottom:0;
  -webkit-mask-image:linear-gradient(180deg,#000 86%,transparent 99%);
          mask-image:linear-gradient(180deg,#000 86%,transparent 99%);
}
/* the white disc becomes a true circular frame the photo sits inside */
.hs-disc{inset:8%;overflow:visible}
.hs-frame{
  position:absolute;inset:8%;border-radius:50%;overflow:hidden;z-index:1;
  background:radial-gradient(120% 120% at 50% 18%,#FFFFFF,#EEF2FB 58%,#E1E8F5);
  box-shadow:inset 0 2px 6px rgba(255,255,255,.9), inset 0 -22px 50px -20px rgba(124,108,255,.28);
}
.hs-frame::after{content:"";position:absolute;inset:0;border-radius:50%;
  background-image:linear-gradient(rgba(124,108,255,.16) 1px,transparent 1px),linear-gradient(90deg,rgba(124,108,255,.16) 1px,transparent 1px);
  background-size:28px 28px;-webkit-mask-image:radial-gradient(58% 58% at 50% 42%,#000,transparent 74%);mask-image:radial-gradient(58% 58% at 50% 42%,#000,transparent 74%)}
.hs-img{z-index:2}
.hs-halo{inset:3%;filter:blur(54px);opacity:.5}
/* richer floating pills */
.hs-pill{border-radius:16px;padding:.7rem .95rem;box-shadow:0 18px 36px -16px rgba(11,21,38,.35),0 2px 8px rgba(11,21,38,.06)}
.hs-pill .pic{box-shadow:0 6px 14px -4px rgba(11,21,38,.3)}
.hs-ribbon{top:5%;background:rgba(11,16,29,.9);color:#EAF0FA;border-color:rgba(234,240,250,.18);box-shadow:0 12px 26px -12px rgba(11,21,38,.5)}
.hs-ribbon .live-dot{box-shadow:0 0 0 0 rgba(43,224,200,.7)}


/* ============================================================
   V10 — cinematic hero: one cohesive credential card (premium)
   ============================================================ */
.hero-cred{position:relative;width:min(440px,90vw);justify-self:center}
/* layered glow behind the whole card */
.hc-aura{position:absolute;inset:-14% -10% -8% -10%;z-index:0;border-radius:40px;
  background:
    radial-gradient(60% 50% at 30% 20%,rgba(124,108,255,.5),transparent 60%),
    radial-gradient(55% 50% at 80% 35%,rgba(77,168,255,.42),transparent 60%),
    radial-gradient(60% 55% at 55% 95%,rgba(43,224,200,.42),transparent 62%);
  filter:blur(36px);opacity:.7;animation:hcaura 11s ease-in-out infinite}
@keyframes hcaura{50%{transform:scale(1.05) translateY(-6px);opacity:.85}}
.hc-card{position:relative;z-index:1;border-radius:28px;overflow:hidden;
  background:linear-gradient(180deg,#EAF0FB,#DCE6F6);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:0 50px 90px -34px rgba(40,54,98,.6), inset 0 1px 0 rgba(255,255,255,.9)}
/* soft tech grid inside the photo zone */
.hc-photo{position:relative;aspect-ratio:1/1.02;overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% 0%,#F4F8FF, #DCE6F6 70%),
    linear-gradient(180deg,#E7EEFA,#D3DEF2)}
.hc-photo::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(124,108,255,.13) 1px,transparent 1px),linear-gradient(90deg,rgba(124,108,255,.13) 1px,transparent 1px);
  background-size:30px 30px;-webkit-mask-image:radial-gradient(75% 75% at 50% 30%,#000,transparent 78%);mask-image:radial-gradient(75% 75% at 50% 30%,#000,transparent 78%)}
.hc-ring{position:absolute;top:-12%;left:50%;transform:translateX(-50%);width:84%;aspect-ratio:1;border-radius:50%;
  background:conic-gradient(from 200deg,#7C6CFF,#4DA8FF,#2BE0C8,#7C6CFF);opacity:.85;
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 2.5px),#000 0);mask:radial-gradient(farthest-side,transparent calc(100% - 2.5px),#000 0);
  animation:gspin 20s linear infinite}
.hc-img{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:96%;max-width:none;z-index:2;
  filter:drop-shadow(0 18px 22px rgba(40,54,98,.34))}
.hc-status{position:absolute;top:16px;left:16px;z-index:3;display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-m);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:#0B1526;
  background:rgba(255,255,255,.82);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.7);
  border-radius:999px;padding:.42rem .8rem;box-shadow:0 8px 20px -10px rgba(40,54,98,.4)}
.hc-badge{position:absolute;top:16px;right:16px;z-index:3;width:46px;height:46px;border-radius:13px;
  background:linear-gradient(150deg,#FF5CA8,#E91E73);display:grid;place-items:center;
  box-shadow:0 12px 26px -8px rgba(233,30,115,.6)}
.hc-badge svg{width:24px;height:24px;fill:#fff}
.hc-badge small{position:absolute;-9999px}
/* glass info bar fused to the bottom of the card */
.hc-bar{position:relative;z-index:3;display:grid;grid-template-columns:1fr 1fr 1fr;
  background:rgba(255,255,255,.55);backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.7)}
.hc-bar .cell{padding:1rem .6rem;text-align:center;position:relative}
.hc-bar .cell + .cell::before{content:"";position:absolute;left:0;top:22%;bottom:22%;width:1px;background:rgba(40,54,98,.14)}
.hc-bar .v{font-family:var(--font-d);font-weight:700;font-size:1.15rem;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hc-bar .v .hs-star{-webkit-text-fill-color:#F5B83D;color:#F5B83D}
.hc-bar .l{font-family:var(--font-m);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-top:.4rem;display:block}
/* identity strip */
.hc-id{position:relative;z-index:3;background:#0B101D;color:#F3F6FB;padding:.9rem 1.2rem;display:flex;align-items:center;gap:.7rem}
.hc-id .dot{width:8px;height:8px;border-radius:50%;background:#2BE0C8;box-shadow:0 0 0 0 rgba(43,224,200,.6);animation:pulse 2.2s infinite;flex:0 0 8px}
.hc-id b{font-family:var(--font-d);font-weight:700;font-size:.95rem;line-height:1.1}
.hc-id span{font-family:var(--font-m);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:#A9B6CE;display:block;margin-top:.2rem}
@media (max-width:740px){.hero-cred{width:min(360px,92vw)}}


/* ============================================================
   V11 — portrait-aware popup player
   ============================================================ */
.vmodal-box:not(.portrait){width:min(960px,94vw);aspect-ratio:16/9}
.vmodal-box.portrait{width:auto;height:min(86vh,720px);aspect-ratio:9/16;max-width:96vw}
.vmodal-box.portrait iframe{width:100%;height:100%}


/* ============================================================
   V12 — stable poster video cards (no YouTube chrome anywhere)
   ============================================================ */
.yt-card.poster-mode{background:#0B101D}
.yt-card.poster-mode img{display:block;position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
/* subtle gradient so the label + play button always read well */
.yt-card.poster-mode::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(6,8,15,.05),rgba(6,8,15,.0) 30%,rgba(6,8,15,.55));}
.yt-card.poster-mode .yt-play,.yt-card.poster-mode .yt-tag{z-index:2}
.yt-card.poster-mode .yt-play{
  width:66px;height:66px;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);
  border:2px solid rgba(255,255,255,.85);box-shadow:0 12px 30px -8px rgba(0,0,0,.55);
  transition:transform .2s,background .2s}
.yt-card.poster-mode .yt-play svg{fill:#fff;width:26px;height:26px;margin-left:3px}
.yt-card.poster-mode:hover .yt-play{transform:scale(1.12);background:var(--grad)}
.yt-card.poster-mode:hover .yt-play svg{fill:#06121C}
