/* ╔══════════════════════════════════════════════════════════╗
   ║  ANIMATIONS                                              ║
   ╚══════════════════════════════════════════════════════════╝ */
@keyframes fadeUp  { from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);} }
@keyframes fadeIn  { from{opacity:0;}to{opacity:1;} }
@keyframes shimmer { from{background-position:-200% center;}to{background-position:200% center;} }
@keyframes blink   { 0%,100%{opacity:1}50%{opacity:.2} }
@keyframes glowPulse { 0%,100%{opacity:.5;transform:scale(1);}50%{opacity:1;transform:scale(1.15);} }
@keyframes spinCW  { to{transform:rotate(360deg);} }
@keyframes spinCCW { to{transform:rotate(-360deg);} }
@keyframes orbitA  { from{transform:rotate(0deg) translateX(160px) rotate(0deg);}to{transform:rotate(360deg) translateX(160px) rotate(-360deg);} }
@keyframes orbitB  { from{transform:rotate(180deg) translateX(120px) rotate(-180deg);}to{transform:rotate(540deg) translateX(120px) rotate(-540deg);} }
@keyframes orbitC  { from{transform:rotate(90deg) translateX(100px) rotate(-90deg);}to{transform:rotate(450deg) translateX(100px) rotate(-450deg);} }
@keyframes pingRing{
  0%   { transform:translate(-50%,-50%) scale(1);   opacity:.55; }
  100% { transform:translate(-50%,-50%) scale(2.4); opacity:0; }
}
@keyframes dashDraw{ from{stroke-dashoffset:300;}to{stroke-dashoffset:0;} }
@keyframes barGrow { from{width:0%;}to{width:var(--w);} }
@keyframes countUp { from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);} }

/* ╔══════════════════════════════════════════════════════════╗
   ║  REVEAL ON SCROLL                                        ║
   ╚══════════════════════════════════════════════════════════╝ */
.rv{opacity:0;transform:translateY(26px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1);}
.rv.on{opacity:1;transform:none;}
.d1{transition-delay:.08s;}.d2{transition-delay:.16s;}.d3{transition-delay:.24s;}
.d4{transition-delay:.32s;}.d5{transition-delay:.40s;}.d6{transition-delay:.48s;}

/* ╔══════════════════════════════════════════════════════════╗
   ║  NAVBAR                                                  ║
   ╚══════════════════════════════════════════════════════════╝ */
#navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:100;
  background:rgba(2,8,23,.88);backdrop-filter:blur(24px) saturate(160%);
  border-bottom:1px solid rgba(255,255,255,.07);}
#navbar .container{height:100%;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%;}
.nav-logo{display:flex;align-items:center;gap:.75rem;}
.nav-logo-mark{width:36px;height:36px;border-radius:9px;display:block;flex-shrink:0;object-fit:contain;}
.nav-logo-text{font-size:1.2rem;font-weight:800;color:#fff;letter-spacing:-.03em;}
.nav-links{display:flex;align-items:center;gap:2rem;}
.nav-links a{font-size:.9rem;font-weight:500;color:rgba(255,255,255,.55);transition:color .2s;}
.nav-links a:hover,.nav-links a.cur{color:#fff;}
@media(max-width:768px){.nav-links{display:none;}}

/* ╔══════════════════════════════════════════════════════════╗
   ║  HERO  – 2-column split                                  ║
   ╚══════════════════════════════════════════════════════════╝ */
.hero{
  min-height:100vh;
  padding:var(--nav-h) max(2rem,calc((100vw - 1140px)/2)) 0;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:3rem;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(ellipse 70% 55% at 30% 50%, rgba(14,165,233,.14) 0%, transparent 60%),
    radial-gradient(ellipse 55% 45% at 80% 30%, rgba(99,102,241,.12) 0%, transparent 60%),
    #020817;
}
/* dot grid */
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:30px 30px;
}
/* left column */
.hero-left{
  padding:5rem 0;
  position:relative;z-index:1;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.28);
  color:#38bdf8;padding:.38rem 1rem;border-radius:999px;
  font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:1.75rem;animation:fadeIn .7s ease both;
}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;animation:blink 1.8s ease-in-out infinite;}
.hero-title{
  font-size:clamp(2rem,4vw,3.6rem);font-weight:800;line-height:1.07;
  letter-spacing:-.04em;color:#fff;margin-bottom:1.25rem;
  animation:fadeUp .8s .1s cubic-bezier(.16,1,.3,1) both;
}
.hero-title em{
  font-style:normal;
  background:linear-gradient(130deg,#38bdf8 0%,#818cf8 50%,#c084fc 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  background-size:200%;animation:shimmer 6s linear infinite;
}
.hero-sub{
  font-size:1.05rem;color:rgba(255,255,255,.58);line-height:1.78;
  max-width:470px;margin-bottom:2.25rem;
  animation:fadeUp .8s .2s cubic-bezier(.16,1,.3,1) both;
}
.hero-cta{
  display:flex;gap:.875rem;flex-wrap:wrap;
  animation:fadeUp .8s .3s cubic-bezier(.16,1,.3,1) both;
}
.btn-p{
  padding:.875rem 2rem;background:linear-gradient(135deg,#0ea5e9,#3b82f6);
  color:#fff;border-radius:999px;font-weight:700;font-size:.95rem;
  box-shadow:0 4px 24px rgba(14,165,233,.38);
  transition:transform .2s,box-shadow .2s;
  display:inline-flex;align-items:center;gap:.5rem;
}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(14,165,233,.55);}
.btn-g{
  padding:.875rem 2rem;border:1.5px solid rgba(255,255,255,.16);
  color:rgba(255,255,255,.7);border-radius:999px;font-weight:600;font-size:.95rem;
  transition:border-color .2s,color .2s;
}
.btn-g:hover{border-color:rgba(255,255,255,.45);color:#fff;}
.hero-chips{
  display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:2rem;
  animation:fadeUp .8s .4s cubic-bezier(.16,1,.3,1) both;
}
.chip{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:rgba(255,255,255,.37);}
.chip-dot{width:5px;height:5px;border-radius:50%;background:#22c55e;}

/* right column – network visual */
.hero-right{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:center;
  padding:3rem 0;
}

/* ─── NETWORK VISUAL ─────────────────────────────────────── */
/*
  Container is 480×480px.
  Center = (240, 240).
  Everything is positioned relative to this center.
*/
.nv{
  position:relative;
  width:480px;
  height:480px;
  flex-shrink:0;
}
@media(max-width:1100px){.nv{width:380px;height:380px;}}
@media(max-width:900px){.hero{grid-template-columns:1fr;padding-left:1.5rem;padding-right:1.5rem;} .hero-right{display:none;}}

/* glow behind center – absolutely centered via margin:auto */
.nv-glow{
  position:absolute;top:0;left:0;right:0;bottom:0;margin:auto;
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(14,165,233,.25) 0%,rgba(99,102,241,.1) 40%,transparent 70%);
  animation:glowPulse 4s ease-in-out infinite;
}
@media(max-width:1100px){.nv-glow{width:230px;height:230px;}}

/* rings – centered via margin:auto + absolute inset:0 */
.nv-ring{
  position:absolute;top:0;left:0;right:0;bottom:0;
  margin:auto;
  border-radius:50%;
}
.ring-1{width:200px;height:200px;border:1px dashed rgba(14,165,233,.3);animation:spinCW 20s linear infinite;}
.ring-2{width:320px;height:320px;border:1px solid rgba(99,102,241,.18);animation:spinCCW 32s linear infinite;}
.ring-3{width:440px;height:440px;border:1px solid rgba(139,92,246,.1);animation:spinCW 55s linear infinite;}
@media(max-width:1100px){
  .ring-1{width:160px;height:160px;}
  .ring-2{width:255px;height:255px;}
  .ring-3{width:350px;height:350px;}
}

/* SVG connection lines – fills full container */
.nv-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;}
.nv-line{stroke:rgba(14,165,233,.3);stroke-width:1.5;stroke-dasharray:5 4;}
.nv-line:nth-child(1){animation:dashDraw 1s .2s ease-out both;}
.nv-line:nth-child(2){animation:dashDraw 1s .4s ease-out both;}
.nv-line:nth-child(3){animation:dashDraw 1s .6s ease-out both;}
.nv-line:nth-child(4){animation:dashDraw 1s .8s ease-out both;}
.nv-line:nth-child(5){animation:dashDraw 1s 1.0s ease-out both;}
.nv-line:nth-child(6){animation:dashDraw 1s 1.2s ease-out both;}

/* CENTER NODE – absolutely centered via margin:auto */
.nv-center{
  position:absolute;top:0;left:0;right:0;bottom:0;
  margin:auto;
  width:72px;height:72px;
  border-radius:50%;
  background:linear-gradient(135deg,#0ea5e9,#3b82f6,#6366f1);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;font-weight:900;color:#fff;
  box-shadow:0 0 50px rgba(14,165,233,.55),0 0 100px rgba(14,165,233,.2);
  z-index:2;
  animation:glowPulse 3s ease-in-out infinite;
}
@media(max-width:1100px){.nv-center{width:56px;height:56px;font-size:1.2rem;}}

/* ping ring around center */
.nv-ping{
  position:absolute;top:50%;left:50%;
  width:72px;height:72px;border-radius:50%;
  border:2px solid rgba(14,165,233,.5);
  transform:translate(-50%,-50%);
  transform-origin:center center;
  animation:pingRing 2.5s ease-out infinite;
  pointer-events:none;
}
@media(max-width:1100px){.nv-ping{width:56px;height:56px;}}

/*
  SATELLITE NODES – 6 nodes in hexagonal pattern.
  Container: 480×480, center at (240,240).
  Radius from center: 180px. Node size: 54px.
  top = center_y - radius*sin(angle) - node_half = 240 - radius*sin(a) - 27
  left = center_x + radius*cos(a) - 27

  Using angle measured from top, clockwise (0°=top):
  n1: top=0° → x=0,    y=-180 → top=33px,  left=213px
  n2: top=60° → x=+156,y=-90  → top=123px, left=369px  [actually 240+156-27=369, 240-90-27=123]
  n3: top=120°→ x=+156,y=+90  → top=303px, left=369px
  n4: top=180°→ x=0,   y=+180 → top=393px, left=213px
  n5: top=240°→ x=-156,y=+90  → top=303px, left=57px
  n6: top=300°→ x=-156,y=-90  → top=123px, left=57px

  For 1100px breakpoint (380px container, center=190, radius=140, node=42px→half=21):
  n1: top=190-140-21=29px, left=190-21=169px
  n2: top=190-70-21=99px,  left=190+121-21=290px  [140*sin60=121, 140*cos60=70]
  ...
*/
.nv-node{
  position:absolute;
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#0d1f3c,#162a42);
  border:1.5px solid rgba(14,165,233,.38);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 20px rgba(14,165,233,.18);
  transition:box-shadow .3s,border-color .3s;
  z-index:2;
}
.nv-node:hover{border-color:rgba(14,165,233,.7);box-shadow:0 0 36px rgba(14,165,233,.4);}
.nv-node svg{width:22px;height:22px;stroke:rgba(255,255,255,.82);}
@media(max-width:1100px){.nv-node{width:42px;height:42px;}.nv-node svg{width:17px;height:17px;}}

/* 480px container, radius=180 */
.n1{top:33px; left:213px;}
.n2{top:123px;left:369px;}
.n3{top:303px;left:369px;}
.n4{top:393px;left:213px;}
.n5{top:303px;left:57px;}
.n6{top:123px;left:57px;}

/* 380px container (≤1100px), radius=140 */
@media(max-width:1100px){
  .n1{top:29px; left:169px;}
  .n2{top:99px; left:290px;}
  .n3{top:239px;left:290px;}
  .n4{top:309px;left:169px;}
  .n5{top:239px;left:49px;}
  .n6{top:99px; left:49px;}
}

/* orbit dots */
.orb{position:absolute;top:50%;left:50%;border-radius:50%;}
.orb-a{width:10px;height:10px;background:#38bdf8;box-shadow:0 0 10px #38bdf8;animation:orbitA 8s linear infinite;margin-top:-5px;margin-left:-5px;}
.orb-b{width:8px;height:8px;background:#818cf8;box-shadow:0 0 10px #818cf8;animation:orbitB 12s linear infinite;margin-top:-4px;margin-left:-4px;}
.orb-c{width:7px;height:7px;background:#c084fc;box-shadow:0 0 10px #c084fc;animation:orbitC 10s linear infinite;margin-top:-3.5px;margin-left:-3.5px;}

/* node labels */
.nv-label{
  position:absolute;
  font-size:.6rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.45);white-space:nowrap;
  background:rgba(14,165,233,.08);border:1px solid rgba(14,165,233,.16);
  padding:.2rem .55rem;border-radius:4px;z-index:3;
}
/* labels positioned slightly outside each node */
.lbl-1{top:0px;  left:240px;transform:translateX(-50%);}
.lbl-2{top:115px;left:432px;}
.lbl-3{top:305px;left:432px;}
.lbl-4{top:452px;left:240px;transform:translateX(-50%);}
.lbl-5{top:305px;right:432px;transform:translateX(100%);}
.lbl-6{top:115px;right:432px;transform:translateX(100%);}
@media(max-width:1100px){.nv-label{display:none;}}

/* ╔══════════════════════════════════════════════════════════╗
   ║  TRUST BAR                                               ║
   ╚══════════════════════════════════════════════════════════╝ */
.trust-bar{
  background:#040e1d;
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
  padding:1.5rem 0;
}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap;}
.ti{display:flex;align-items:center;gap:.6rem;}
.ti-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;}
.ti-icon svg{width:15px;height:15px;}
.ti-text{font-size:.8rem;font-weight:600;color:rgba(255,255,255,.4);}
.ti-sep{width:1px;height:24px;background:rgba(255,255,255,.07);}
@media(max-width:640px){.ti-sep{display:none;}}

/* ╔══════════════════════════════════════════════════════════╗
   ║  STATS                                                   ║
   ╚══════════════════════════════════════════════════════════╝ */
.stats-section{padding:5rem 0;background:#020817;}
.stats-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid rgba(255,255,255,.07);border-radius:20px;overflow:hidden;
}
@media(max-width:768px){.stats-row{grid-template-columns:repeat(2,1fr);}}
.stat-cell{
  padding:2.5rem 1.75rem;text-align:center;background:#020817;
  border-right:1px solid rgba(255,255,255,.07);
  transition:background .3s;
}
.stat-cell:last-child{border-right:none;}
@media(max-width:768px){.stat-cell:nth-child(2){border-right:none;}.stat-cell:nth-child(3){border-right:1px solid rgba(255,255,255,.07);}}
.stat-cell:hover{background:#08111f;}
.stat-icon2{width:44px;height:44px;border-radius:12px;margin:0 auto .875rem;display:flex;align-items:center;justify-content:center;}
.stat-icon2 svg{width:21px;height:21px;}
.stat-val{font-size:2.5rem;font-weight:800;letter-spacing:-.05em;line-height:1;
  background:linear-gradient(135deg,#38bdf8,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.4rem;}
.stat-lbl{font-size:.82rem;color:rgba(255,255,255,.38);line-height:1.45;}

/* ╔══════════════════════════════════════════════════════════╗
   ║  SECTION HEADER                                          ║
   ╚══════════════════════════════════════════════════════════╝ */
.s-pill{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.35rem 1rem;border-radius:999px;
  font-size:.73rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:1rem;
}
.s-pill svg{width:12px;height:12px;}
.pill-sky{background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.22);color:#0ea5e9;}
.pill-indigo{background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.22);color:#6366f1;}
.pill-green{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.22);color:#22c55e;}
.pill-violet{background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.22);color:#8b5cf6;}
.pill-amber{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.22);color:#f59e0b;}
.s-title{font-size:clamp(1.75rem,3.2vw,2.5rem);font-weight:800;letter-spacing:-.03em;color:var(--text);line-height:1.15;}
.s-title-w{color:#fff;}
.s-sub{font-size:.975rem;color:var(--text-muted);line-height:1.78;max-width:560px;margin-top:.875rem;}
.s-sub-w{color:rgba(255,255,255,.5);}
.tc{text-align:center;}.mx{margin-left:auto;margin-right:auto;}

/* ╔══════════════════════════════════════════════════════════╗
   ║  HOW IT WORKS                                            ║
   ╚══════════════════════════════════════════════════════════╝ */
.how-sec{padding:7rem 0;background:#fff;}
.steps{display:flex;flex-direction:column;gap:5.5rem;margin-top:4rem;}
.step-row{
  display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:center;
}
@media(max-width:900px){.step-row{grid-template-columns:1fr;gap:2.5rem;}}
.step-row.flip .step-txt{order:2;}.step-row.flip .step-card{order:1;}
@media(max-width:900px){.step-row.flip .step-txt,.step-row.flip .step-card{order:unset;}}

.step-num{display:inline-flex;align-items:center;gap:.65rem;margin-bottom:1.25rem;}
.sn-circle{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,#0ea5e9,#6366f1);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;font-weight:900;color:#fff;
}
.sn-label{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);}
.step-title{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;color:var(--text);margin-bottom:.85rem;line-height:1.2;}
.step-desc{font-size:.95rem;color:var(--text-muted);line-height:1.78;margin-bottom:1.5rem;}
.step-checks{display:flex;flex-direction:column;gap:.625rem;}
.step-check{display:flex;align-items:center;gap:.625rem;font-size:.9rem;color:var(--text);}
.sc-icon{width:20px;height:20px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.sc-icon svg{width:11px;height:11px;}

/* step website mockups – full app shell (light) */
.step-card{
  border-radius:18px;overflow:hidden;
  border:1px solid var(--border);
  box-shadow:0 16px 48px rgba(15,23,42,.08),0 4px 16px rgba(15,23,42,.04);
  background:#fff;
  transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s;
}
.step-card:hover{
  transform:translateY(-6px) scale(1.01);
  box-shadow:0 24px 56px rgba(15,23,42,.12),0 8px 24px rgba(15,23,42,.06);
}

.sm-bar{
  background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 55%,#e0e7ff 100%);
  padding:.7rem 1rem;
  display:flex;align-items:center;gap:.75rem;
  border-bottom:1px solid rgba(59,130,246,.12);
}
.sm-dots{display:flex;gap:5px;flex-shrink:0;}
.sm-dot{width:10px;height:10px;border-radius:50%;}
.sm-dot.r{background:#ff5f57;}.sm-dot.y{background:#febc2e;}.sm-dot.g{background:#28c840;}
.sm-title{
  flex:1;text-align:center;font-size:.72rem;font-weight:600;
  color:#475569;letter-spacing:.01em;
}
.sm-live{
  display:flex;align-items:center;gap:.35rem;font-size:.62rem;font-weight:700;color:#16a34a;
  padding:.18rem .5rem;border-radius:999px;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.18);
}
.sm-live-dot{width:5px;height:5px;border-radius:50%;background:#22c55e;animation:blink 1.5s ease-in-out infinite;}

.sm-shell{display:flex;min-height:300px;background:#fff;}
.sm-side{
  width:31%;flex-shrink:0;
  background:#f8fafc;border-right:1px solid var(--border);
  padding:.85rem .65rem;display:flex;flex-direction:column;gap:.35rem;
}
.sm-logo{
  display:flex;align-items:center;gap:.45rem;
  padding:.35rem .5rem .65rem;margin-bottom:.25rem;
  border-bottom:1px solid var(--border);
}
.sm-logo-ic{
  width:24px;height:24px;border-radius:6px;
  background:linear-gradient(135deg,#0ea5e9,#3b82f6);
  display:flex;align-items:center;justify-content:center;
  font-size:.55rem;font-weight:900;color:#fff;
}
.sm-logo-txt{font-size:.62rem;font-weight:800;color:var(--text);letter-spacing:-.01em;}
.sm-nav{display:flex;flex-direction:column;gap:.2rem;}
.sm-nav-i{
  display:flex;align-items:center;gap:.45rem;
  padding:.42rem .55rem;border-radius:8px;
  font-size:.58rem;font-weight:600;color:var(--text-muted);
  transition:background .2s,color .2s;
}
.sm-nav-i svg{width:11px;height:11px;flex-shrink:0;opacity:.7;}
.sm-nav-i.on{
  background:rgba(59,130,246,.1);color:#2563eb;
  box-shadow:inset 3px 0 0 #3b82f6;
}
.sm-nav-i.on svg{opacity:1;}

.sm-main{flex:1;padding:.85rem .9rem 1rem;min-width:0;background:#fff;}
.sm-page-hd{margin-bottom:.75rem;}
.sm-page-title{font-size:.78rem;font-weight:800;color:var(--text);letter-spacing:-.01em;}
.sm-page-sub{font-size:.55rem;color:var(--text-muted);margin-top:.15rem;}

.sm-card{
  background:#f8fafc;border:1px solid var(--border);
  border-radius:10px;padding:.7rem .75rem;margin-bottom:.5rem;
}
.sm-card:last-child{margin-bottom:0;}

.sm-profile{display:flex;align-items:center;gap:.65rem;}
.sm-av{
  width:36px;height:36px;border-radius:9px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.68rem;font-weight:800;color:#fff;
}
.sm-info{flex:1;min-width:0;}
.sm-name{font-size:.72rem;font-weight:700;color:var(--text);}
.sm-meta{font-size:.52rem;color:var(--text-muted);margin-top:.05rem;}
.sm-pill{
  font-size:.52rem;font-weight:700;padding:.2rem .45rem;border-radius:999px;flex-shrink:0;
}
.sm-pill.ok{background:rgba(34,197,94,.12);color:#16a34a;border:1px solid rgba(34,197,94,.22);}
.sm-pill.new{background:rgba(59,130,246,.1);color:#2563eb;border:1px solid rgba(59,130,246,.2);}
.sm-pill.wait{background:rgba(245,158,11,.12);color:#d97706;border:1px solid rgba(245,158,11,.22);}

.sm-prog{margin-top:.65rem;}
.sm-prog-top{display:flex;justify-content:space-between;font-size:.52rem;color:var(--text-muted);margin-bottom:.25rem;}
.sm-prog-top span:last-child{color:#16a34a;font-weight:700;}
.sm-prog-bg{height:4px;background:#e2e8f0;border-radius:999px;overflow:hidden;}
.sm-prog-fill{height:4px;border-radius:999px;background:linear-gradient(90deg,#22c55e,#4ade80);animation:barGrow 1.2s 1s ease-out both;}

.sm-docs{display:grid;grid-template-columns:1fr 1fr;gap:.35rem;margin-top:.5rem;}
.sm-doc{
  display:flex;align-items:center;gap:.35rem;
  padding:.4rem .45rem;border-radius:7px;
  background:#fff;border:1px solid var(--border);
}
.sm-doc-ic{width:18px;height:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sm-doc-ic svg{width:9px;height:9px;}
.sm-doc-ic.ok{background:rgba(34,197,94,.12);color:#16a34a;}
.sm-doc-ic.wait{background:rgba(245,158,11,.12);color:#d97706;}
.sm-doc-l{font-size:.52rem;font-weight:700;color:var(--text);}
.sm-doc-s{font-size:.46rem;color:var(--text-muted);}

.sm-req{display:flex;align-items:center;gap:.5rem;padding:.55rem .6rem;}
.sm-req.featured{
  background:rgba(99,102,241,.08);border-color:rgba(99,102,241,.22);
  box-shadow:0 0 0 1px rgba(99,102,241,.08);
}
.sm-req.dim{opacity:.55;}
.sm-req-info{flex:1;min-width:0;}
.sm-score{
  text-align:center;padding:.25rem .4rem;border-radius:7px;min-width:38px;
  background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.18);
}
.sm-req.featured .sm-score{background:rgba(99,102,241,.12);border-color:rgba(99,102,241,.25);}
.sm-score-v{font-size:.72rem;font-weight:800;color:#2563eb;line-height:1;}
.sm-req.featured .sm-score-v{color:#6366f1;}
.sm-score-l{font-size:.42rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);}

.sm-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem;margin-bottom:.5rem;}
.sm-kpi{
  text-align:center;padding:.45rem .3rem;border-radius:7px;
  background:#f8fafc;border:1px solid var(--border);
}
.sm-kpi-v{font-size:.78rem;font-weight:800;color:#2563eb;line-height:1;}
.sm-kpi-l{font-size:.42rem;color:var(--text-muted);margin-top:.1rem;}

.sm-inv-hd{
  display:grid;grid-template-columns:1fr auto auto;gap:.35rem;
  padding:0 .2rem .35rem;font-size:.46rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);
  border-bottom:1px solid var(--border);margin-bottom:.35rem;
}
.sm-inv{
  display:grid;grid-template-columns:1fr auto auto;gap:.35rem;align-items:center;
  padding:.45rem .55rem;border-radius:7px;
  background:#f8fafc;border:1px solid var(--border);
  margin-bottom:.3rem;font-size:.58rem;
}
.sm-inv.paid{background:rgba(34,197,94,.06);border-color:rgba(34,197,94,.18);}
.sm-inv-no{font-weight:700;color:var(--text);}
.sm-inv-sub{font-size:.48rem;color:var(--text-muted);margin-top:.05rem;}
.sm-inv-amt{font-weight:800;color:#16a34a;text-align:right;}
.sm-inv-amt.wait{color:#d97706;}
.sm-inv-st{
  font-size:.46rem;font-weight:700;text-align:right;
  padding:.12rem .35rem;border-radius:999px;
}
.sm-inv-st.ok{background:rgba(34,197,94,.12);color:#16a34a;}
.sm-inv-st.wait{background:rgba(245,158,11,.12);color:#d97706;}

.sm-footer{
  margin-top:.55rem;padding:.55rem .65rem;border-radius:8px;
  background:linear-gradient(135deg,#eff6ff,#eef2ff);
  border:1px solid rgba(59,130,246,.15);
  display:flex;align-items:center;justify-content:space-between;
}
.sm-footer-l{font-size:.58rem;color:var(--text-muted);font-weight:600;}
.sm-footer-v{
  font-size:.85rem;font-weight:800;
  background:linear-gradient(135deg,#2563eb,#6366f1);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.sm-btn{
  display:inline-block;margin-top:.45rem;font-size:.52rem;font-weight:700;
  padding:.28rem .55rem;border-radius:999px;
  background:linear-gradient(135deg,#0ea5e9,#6366f1);color:#fff;
}

@media(max-width:900px){
  .sm-side{width:28%;}
  .sm-shell{min-height:260px;}
}
@media(max-width:520px){
  .sm-side{display:none;}
  .sm-shell{min-height:240px;}
}

/* ╔══════════════════════════════════════════════════════════╗
   ║  BENTO FEATURES                                          ║
   ╚══════════════════════════════════════════════════════════╝ */
.feat-sec{padding:7rem 0;background:#f8fafc;}
.bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:auto;
  gap:1.25rem;
  margin-top:3.5rem;
}
@media(max-width:1024px){.bento{grid-template-columns:repeat(6,1fr);}}
@media(max-width:640px){.bento{grid-template-columns:1fr 1fr;}}
@media(max-width:420px){.bento{grid-template-columns:1fr;}}

.bc{
  grid-column:span 4;
  background:#fff;border:1px solid var(--border);border-radius:18px;
  padding:1.875rem;position:relative;overflow:hidden;
  transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s,border-color .3s;
}
.bc:hover{transform:translateY(-5px);box-shadow:0 18px 45px rgba(0,0,0,.08);border-color:rgba(14,165,233,.22);}
.bc::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--ac,linear-gradient(90deg,#0ea5e9,#3b82f6));
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s cubic-bezier(.16,1,.3,1);
}
.bc:hover::before{transform:scaleX(1);}
.bc-wide{grid-column:span 6;}
.bc-full{grid-column:span 12;}
@media(max-width:1024px){.bc,.bc-wide,.bc-full{grid-column:span 6;}}
@media(max-width:640px){.bc,.bc-wide,.bc-full{grid-column:span 2;}}
@media(max-width:420px){.bc,.bc-wide,.bc-full{grid-column:span 1;}}

.bc-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;transition:transform .3s;}
.bc:hover .bc-icon{transform:scale(1.1) rotate(-5deg);}
.bc-icon svg{width:24px;height:24px;}
.bc-h{font-size:1rem;font-weight:800;color:var(--text);margin-bottom:.5rem;}
.bc-p{font-size:.875rem;color:var(--text-muted);line-height:1.65;}
.bc-tag{
  display:inline-flex;align-items:center;gap:.35rem;
  margin-top:.875rem;font-size:.7rem;font-weight:700;letter-spacing:.04em;
  padding:.22rem .65rem;border-radius:999px;
}
.bc-tag svg{width:10px;height:10px;}

/* wide card horizontal layout */
.bc-row{display:flex;gap:1.5rem;align-items:flex-start;}

/* ╔══════════════════════════════════════════════════════════╗
   ║  SHOWCASE MOCKUP                                         ║
   ╚══════════════════════════════════════════════════════════╝ */
.showcase-sec{padding:7rem 0;background:#020817;}
.showcase-ui{
  margin-top:3.5rem;border-radius:20px;overflow:hidden;
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 50px 120px rgba(0,0,0,.6);
  background:linear-gradient(150deg,#08111f,#0c1a2e);
}
.sui-bar{
  background:linear-gradient(135deg,#1e3a8a,#2563eb);
  padding:.875rem 1.5rem;
  display:flex;align-items:center;gap:1rem;
}
.sui-dots{display:flex;gap:.375rem;}
.sui-dot{width:11px;height:11px;border-radius:50%;}
.d-r{background:#ff5f57;}.d-y{background:#ffbd2e;}.d-g{background:#28ca41;}
.sui-title{flex:1;text-align:center;font-size:.8rem;font-weight:600;color:rgba(255,255,255,.75);}
.sui-live{display:flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:700;color:#4ade80;}
.sui-live-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:blink 1.5s ease-in-out infinite;}
.sui-body{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.25rem;padding:1.75rem;
}
@media(max-width:900px){.sui-body{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.sui-body{grid-template-columns:1fr;}}
.sui-panel{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:1.25rem;}
.sui-panel-title{font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1rem;}
.sp-item{
  display:flex;align-items:center;gap:.7rem;
  padding:.6rem .75rem;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);
  margin-bottom:.5rem;transition:background .2s;
}
.sp-item:hover{background:rgba(255,255,255,.07);}
.sp-av{width:34px;height:34px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:#fff;}
.sp-name{font-size:.8rem;font-weight:700;color:rgba(255,255,255,.8);}
.sp-loc{font-size:.65rem;color:rgba(255,255,255,.3);}
.sp-score{margin-left:auto;font-size:.75rem;font-weight:800;color:#4ade80;}
.sp-req{
  display:flex;align-items:center;justify-content:space-between;
  padding:.625rem .75rem;border-radius:10px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);
  margin-bottom:.5rem;
}
.sp-req-info{font-size:.78rem;color:rgba(255,255,255,.7);}
.sp-req-time{font-size:.65rem;color:rgba(255,255,255,.28);}
.sp-req-badge{font-size:.65rem;font-weight:700;padding:.2rem .5rem;border-radius:999px;}
.sg{display:grid;grid-template-columns:1fr 1fr;gap:.625rem;}
.ss{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:.875rem;text-align:center;}
.ss-v{font-size:1.3rem;font-weight:800;letter-spacing:-.03em;color:#fff;}
.ss-l{font-size:.62rem;color:rgba(255,255,255,.28);margin-top:.2rem;}

/* ╔══════════════════════════════════════════════════════════╗
   ║  PERSONAS                                                ║
   ╚══════════════════════════════════════════════════════════╝ */
.personas-sec{padding:7rem 0;background:#fff;}
.pers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem;}
@media(max-width:900px){.pers-grid{grid-template-columns:1fr;}}
.pers-card{
  border-radius:20px;padding:2.5rem 2rem;
  position:relative;overflow:hidden;
  transition:transform .3s,box-shadow .3s;
}
.pers-card:hover{transform:translateY(-5px);box-shadow:0 22px 55px rgba(0,0,0,.1);}
.pc-blue{background:linear-gradient(155deg,#eff6ff,#dbeafe);border:1px solid rgba(59,130,246,.2);}
.pc-ind {background:linear-gradient(155deg,#eef2ff,#e0e7ff);border:1px solid rgba(99,102,241,.2);}
.pc-grn {background:linear-gradient(155deg,#f0fdf4,#dcfce7);border:1px solid rgba(34,197,94,.2);}
.pers-icon{width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;}
.pers-icon svg{width:26px;height:26px;}
.pers-role{font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem;}
.pers-title{font-size:1.2rem;font-weight:800;color:var(--text);margin-bottom:.75rem;line-height:1.25;}
.pers-desc{font-size:.875rem;color:var(--text-muted);line-height:1.72;margin-bottom:1.5rem;}
.pers-perks{display:flex;flex-direction:column;gap:.5rem;}
.pers-perk{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text);}
.pp-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}

/* ╔══════════════════════════════════════════════════════════╗
   ║  TESTIMONIALS                                            ║
   ╚══════════════════════════════════════════════════════════╝ */
.testi-sec{padding:7rem 0;background:#f8fafc;}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem;}
@media(max-width:1024px){.testi-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.testi-grid{grid-template-columns:1fr;}}
.testi-card{
  background:#fff;border:1px solid var(--border);border-radius:18px;
  padding:2rem;display:flex;flex-direction:column;gap:1.25rem;
  transition:transform .3s,box-shadow .3s;
}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.07);}
.t-stars{color:#f59e0b;font-size:.9rem;letter-spacing:.05em;}
.t-quote{font-size:.9rem;color:var(--text);line-height:1.78;flex:1;font-style:italic;}
.t-author{display:flex;align-items:center;gap:.875rem;padding-top:1rem;border-top:1px solid var(--border);}
.t-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;color:#fff;flex-shrink:0;}
.t-name{font-size:.875rem;font-weight:700;color:var(--text);}
.t-role{font-size:.75rem;color:var(--text-muted);}

/* ╔══════════════════════════════════════════════════════════╗
   ║  FAQ                                                     ║
   ╚══════════════════════════════════════════════════════════╝ */
.faq-sec{padding:7rem 0;background:#fff;}
.faq-list{max-width:800px;margin:3rem auto 0;display:flex;flex-direction:column;gap:.875rem;}
.faq-item{border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .25s,box-shadow .25s;}
.faq-item[open]{border-color:rgba(14,165,233,.32);box-shadow:0 4px 20px rgba(14,165,233,.09);}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.25rem 1.5rem;cursor:pointer;list-style:none;
  font-size:.95rem;font-weight:700;color:var(--text);
}
.faq-q::-webkit-details-marker{display:none;}
.faq-chev{flex-shrink:0;color:var(--text-muted);transition:transform .3s;}
.faq-item[open] .faq-chev{transform:rotate(180deg);}
.faq-item[open] .faq-q{color:#0ea5e9;}
.faq-a{padding:.25rem 1.5rem 1.25rem;font-size:.875rem;color:var(--text-muted);line-height:1.78;border-top:1px solid var(--border);}
.faq-a a{color:var(--c-500);text-decoration:underline;}

/* ╔══════════════════════════════════════════════════════════╗
   ║  DARK CTA                                                ║
   ╚══════════════════════════════════════════════════════════╝ */
.cta-sec{
  padding:7rem 0;text-align:center;position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 65% 55% at 50% 0%,rgba(14,165,233,.22) 0%,transparent 60%),
    radial-gradient(ellipse 45% 40% at 80% 100%,rgba(99,102,241,.16) 0%,transparent 60%),
    #020817;
}
.cta-sec::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:28px 28px;
}
.cta-sec .container{position:relative;z-index:1;}
.cta-title{font-size:clamp(2rem,4.5vw,3.25rem);font-weight:800;letter-spacing:-.04em;color:#fff;margin-bottom:1rem;line-height:1.1;}
.cta-title em{font-style:normal;background:linear-gradient(130deg,#38bdf8,#818cf8,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.cta-sub{font-size:1.05rem;color:rgba(255,255,255,.52);max-width:500px;margin:0 auto 2.75rem;line-height:1.75;}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}

/* ╔══════════════════════════════════════════════════════════╗
   ║  FOOTER                                                  ║
   ╚══════════════════════════════════════════════════════════╝ */
footer{background:#020817;border-top:1px solid rgba(255,255,255,.06);padding:3.5rem 0 2rem;}
.foot-inner{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:2.5rem;}
.foot-logo{display:flex;align-items:center;gap:.65rem;margin-bottom:.6rem;}
.foot-logo-mark{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,#0ea5e9,#1d4ed8);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;color:#fff;}
.foot-logo-text{font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:-.03em;}
.foot-tag{font-size:.78rem;color:rgba(255,255,255,.27);max-width:220px;line-height:1.65;}
.foot-cols{display:flex;gap:3rem;flex-wrap:wrap;}
.foot-col-h{font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:.875rem;}
.foot-links{display:flex;flex-direction:column;gap:.5rem;}
.foot-links a{font-size:.83rem;color:rgba(255,255,255,.42);transition:color .2s;}
.foot-links a:hover,.foot-links a.cur{color:#fff;}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.05);}
.foot-copy{font-size:.75rem;color:rgba(255,255,255,.22);}
.foot-legal{display:flex;gap:1.5rem;}
.foot-legal a{font-size:.75rem;color:rgba(255,255,255,.22);transition:color .2s;}
.foot-legal a:hover{color:rgba(255,255,255,.6);}
.foot-flag{font-size:.75rem;color:rgba(255,255,255,.22);}
