/* =========================
   THEME TOKENS
========================= */
:root{
  --primary:#4108D5;
  --primary-2:#6A2FFF;
  --primary-3:#8E5BFF;
  --accent:#00E5C5;
  --accent-2:#FF4FB7;
  --ink:#0B0524;
  --ink-2:#1B0F46;
  --muted:#6B6385;
  --surface:#ffffff;
  --soft:#F5F1FF;
  --border:rgba(65,8,213,.12);
  --shadow-lg:0 30px 80px -20px rgba(65,8,213,.35);
  --shadow-md:0 18px 40px -16px rgba(65,8,213,.25);
  --radius-lg:24px;
  --radius-md:16px;
  --radius-sm:10px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{max-width:1240px;margin:0 auto;padding:0 24px}

/* Display font for headings */
h1,h2,h3,h4{font-family:'Space Grotesk','Plus Jakarta Sans',sans-serif;letter-spacing:-.02em;line-height:1.1}
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  padding:0;border:0;border-radius:0;background:none;
  color:var(--primary);
  font-weight:600;font-size:14px;
  text-transform:none;letter-spacing:0;
  margin-bottom:10px;
}
.eyebrow::before{content:"";width:34px;height:2px;border-radius:0;background:var(--primary)}

/* =========================
   NAV
========================= */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(180%) blur(18px);
  background:rgba(255,255,255,.78);
  border-bottom:1px solid var(--border);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;max-width:1240px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--ink)}
.brand-mark{
  width:34px;height:34px;border-radius:10px;
  background:conic-gradient(from 140deg,var(--primary),var(--accent-2),var(--primary));
  display:grid;place-items:center;color:#fff;font-weight:800;
  box-shadow:var(--shadow-md);
}
.nav-links{display:flex;gap:28px;font-weight:500;color:#3b3357}
.nav-links a{transition:color .2s}
.nav-links a:hover{color:var(--primary)}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 22px;border-radius:100px;
  font-weight:600;font-size:14.5px;cursor:pointer;border:0;
  transition:transform .2s ease, box-shadow .25s ease, background .2s;
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 10px 24px -8px rgba(65,8,213,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 36px -10px rgba(65,8,213,.6);background:var(--primary-2)}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}

/* =========================
   HERO IMAGE BANNER
========================= */
/* ============ HERO BANNER — split (content + laptop slider) ============ */
.hero-banner{
  width:100%;
  min-height:90vh;
  padding:60px 0;
  position:relative;
  overflow:hidden;
  background:#FAFAF7;
  display:flex;align-items:center;
}
.hero-banner > .container{position:relative;z-index:1;width:100%}

/* Subtle dotted background pattern */
.hero-banner::before{
  content:"";
  position:absolute;inset:0;z-index:0;
  background-image:radial-gradient(rgba(11,5,36,.06) 1.2px, transparent 1.2px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse at 50% 50%, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%, #000 30%, transparent 75%);
  pointer-events:none;
  opacity:.6;
}

.hb-grid{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  gap:60px;
  align-items:center;
}

/* LEFT: content */
.hb-content{text-align:left}
.hb-content .hb-trust{margin-bottom:28px}

/* ---------- LEFT: content ---------- */
.hb-pill{
  display:inline-block;
  padding:10px 18px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:100px;
  font-size:13px;font-weight:600;
  color:var(--ink);
  margin-bottom:28px;
  box-shadow:0 4px 12px -6px rgba(0,0,0,.08);
}

/* ---------- Trust row (avatars + Google icon + stars + rating + brands) ---------- */
.hb-trust{
  display:inline-flex;
  align-items:center;
  gap:16px;
  margin-bottom:30px;
}
.hb-avatars{display:inline-flex;flex:none}
.hb-avatar{
  width:46px;height:46px;border-radius:50%;
  border:3px solid #F5F4F1;          /* matches hero background */
  background:#D8C5B5;
  object-fit:cover;
  display:block;
}
.hb-avatar + .hb-avatar{margin-left:-14px}

/* Right side: Google icon (top-left), stars (top-right), brand text (bottom-right aligned with stars) */
.hb-trust-info{
  display:grid;
  grid-template-columns:auto 1fr;
  column-gap:12px;
  row-gap:6px;
  align-items:center;
}
.hb-google{
  grid-column:1;
  grid-row:1 / span 2;            /* spans both rows on the left */
  width:28px;height:28px;
  align-self:center;
  display:block;
}
.hb-stars-row{
  grid-column:2;grid-row:1;
  display:flex;align-items:center;gap:8px;
}
.hb-stars{display:inline-flex;align-items:center;gap:2px}
.hb-stars svg{width:18px;height:18px;display:block}
/* (old chip rule removed — replaced by inline .hb-rating layout below) */
.hb-trust-text{
  grid-column:2;grid-row:2;        /* aligned under the stars, not the Google icon */
  font-weight:600;
  font-size:14.5px;
  color:var(--ink);
  margin:0;
}
.hb-content h1{
  font-family:'Space Grotesk','Plus Jakarta Sans',sans-serif;
  font-size:clamp(34px,3.6vw,46px);              /* tighter — respark proportions */
  font-weight:700;
  line-height:1.18;
  letter-spacing:-.015em;
  color:var(--ink);
  margin-bottom:22px;
}
.hb-content h1 .grad-text{
  background:linear-gradient(90deg, var(--primary), var(--accent-2));
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
}
.hb-content > p{
  color:var(--muted);
  font-size:17px;
  line-height:1.65;
  max-width:520px;
  margin:0 0 36px;
}
.hb-content > p strong{color:var(--ink);font-weight:700}
.hero-cta-row{
  display:flex;align-items:center;
  gap:22px;flex-wrap:wrap;
  margin:0;
}
.hero-cta-row .btn-primary{
  background:#EF3550;                            /* respark red */
  color:#fff;
  padding:14px 28px;
  font-size:15px;
  font-weight:600;
  border:0;
  border-radius:8px;                              /* slightly rounded, not pill */
  cursor:pointer;
  text-decoration:none;
  display:inline-block;
  box-shadow:0 10px 22px -8px rgba(239,53,80,.45);
  transition:transform .2s ease, box-shadow .25s ease, background .2s;
}
.hero-cta-row .btn-primary:hover{
  background:#D62F49;
  transform:translateY(-2px);
  box-shadow:0 16px 28px -8px rgba(239,53,80,.55);
}

/* Inline Google Rating (respark-style) */
.hb-rating{
  display:inline-flex;align-items:center;gap:10px;
}
.hb-rating-icons{
  display:inline-flex;align-items:center;gap:4px;
}
.hb-g{width:24px;height:24px;display:block}
.hb-r-star{width:18px;height:18px;display:block}
.hb-r-info{
  display:flex;flex-direction:column;
  line-height:1.1;
}
.hb-r-info strong{
  font-family:'Space Grotesk',sans-serif;
  font-size:20px;font-weight:700;color:var(--ink);
}
.hb-r-info small{
  font-size:11px;color:var(--muted);
  margin-top:1px;
}
.hero-cta-row .btn-primary{
  background:var(--primary);
  color:#fff;
  padding:15px 26px;
  border-radius:12px;
  font-weight:600;font-size:15px;
  border:0;cursor:pointer;
  text-decoration:none;
  display:inline-block;
  box-shadow:0 14px 28px -10px rgba(65,8,213,.45);
  transition:transform .2s ease, box-shadow .25s ease;
}
.hero-cta-row .btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 20px 36px -10px rgba(65,8,213,.55);
}
.hb-link{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--ink);
  font-weight:600;font-size:15px;
  text-decoration:underline;
  text-underline-offset:5px;
  text-decoration-thickness:1.5px;
}
.hb-link span{transition:transform .2s ease;display:inline-block}
.hb-link:hover span{transform:translateX(4px)}

/* ---------- RIGHT: Respark-style showcase (image + center industry pills) ---------- */
.hb-visual{
  position:relative;
  width:100%;
  display:flex;align-items:center;justify-content:center;
}
.rs-showcase{
  position:relative;
  width:100%;
  max-width:700px;
  aspect-ratio:5/4;                            /* wider/landscape — matches respark proportions */
  border-radius:24px;
  overflow:hidden;
  background:#E8E5DE;
  box-shadow:0 30px 60px -20px rgba(65,8,213,.22);
}

/* Image slides — cross-fade */
.rs-slides{position:absolute;inset:0;z-index:0}
.rs-slide{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  opacity:0;
  transition:opacity .8s ease;
}
.rs-slide.active{opacity:1}

/* Subtle wash — lighter on left (where buttons live), darker on right corner (where label sits) */
.rs-wash{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,
    rgba(255,255,255,.4) 0%,
    rgba(255,255,255,.15) 30%,
    transparent 55%,
    rgba(0,0,0,.18) 100%);
  pointer-events:none;
}

/* Left-positioned vertical column of pills (respark-style) */
.rs-buttons{
  position:absolute;
  top:50%;left:8%;                              /* anchored to left side, vertically centered */
  transform:translateY(-50%);
  display:flex;flex-direction:column;
  gap:10px;
  z-index:2;
}
.rs-btn{
  background:#fff;
  border:0;
  padding:7px 7px 7px 22px;
  border-radius:100px;
  font-family:inherit;
  font-weight:600;font-size:13.5px;
  color:var(--ink);
  display:inline-flex;align-items:center;justify-content:space-between;gap:14px;
  cursor:pointer;
  min-width:210px;
  box-shadow:0 6px 18px -6px rgba(0,0,0,.18);
  transition:transform .35s cubic-bezier(.4,0,.2,1),
             box-shadow .35s ease;
}
.rs-btn:hover{transform:translateY(-1px)}
.rs-btn.active{
  transform:scale(1.04);
  box-shadow:0 14px 28px -8px rgba(0,0,0,.22);
}
.rs-icon{
  flex:none;
  width:30px;height:30px;border-radius:8px;
  display:grid;place-items:center;
  color:#fff;
  position:relative;
}
.rs-icon::before{
  content:"";
  position:absolute;
  top:-3px;left:50%;transform:translateX(-50%);
  width:0;height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-bottom:4px solid;
  border-bottom-color:inherit;
  display:none;                                  /* notch — enable if exact respark match needed */
}

/* Industry label tab at bottom-right (respark-style: pink-tinted bg, red text) */
.rs-label{
  position:absolute;
  bottom:0;
  right:0;
  background:rgba(255,228,225,.9);
  color:#E63946;
  font-weight:700;
  font-size:15px;
  letter-spacing:.005em;
  padding:10px 28px;
  border-radius:14px 0 0 0;
  backdrop-filter:blur(6px);
  z-index:3;
}

/* Responsive */
@media(max-width:1024px){
  .hb-grid{grid-template-columns:1fr;gap:50px}
  .hb-content{max-width:560px;margin:0 auto;text-align:center}
  .hb-content .hb-trust{margin-left:auto;margin-right:auto}
  .hb-content > p{margin-left:auto;margin-right:auto}
  .hero-cta-row{justify-content:center}
  .hero-banner{min-height:auto;padding:50px 0}
  .rs-showcase{max-width:520px;margin:0 auto}
}
@media(max-width:600px){
  .hero-banner{padding:36px 0 50px}
  .hb-content h1{font-size:38px}
  .hb-content > p{font-size:15.5px}
  .hero-cta-row .btn-primary{padding:14px 24px}
  .rs-btn{min-width:180px;font-size:13px;padding:8px 8px 8px 14px}
  .rs-icon{width:26px;height:26px}
  .rs-label{font-size:13.5px;padding:8px 22px}
}
/* =========================
   HERO / BANNER (legacy — unused)
========================= */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(900px 600px at 90% -10%, rgba(255,79,183,.25), transparent 60%),
    radial-gradient(900px 700px at -10% 110%, rgba(0,229,197,.18), transparent 60%),
    linear-gradient(135deg,#1A0568 0%,#4108D5 55%,#7331FF 100%);
  color:#fff;
  padding:90px 0 130px;
  isolation:isolate;
}
.hero::before{ /* grid lines */
  content:"";position:absolute;inset:0;z-index:-1;opacity:.18;
  background-image:
    linear-gradient(rgba(255,255,255,.18) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.18) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at 50% 30%, #000 30%, transparent 75%);
}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;z-index:-1;pointer-events:none}
.blob.b1{width:380px;height:380px;background:#ff4fb7;top:-100px;right:-80px;animation:float1 14s ease-in-out infinite}
.blob.b2{width:340px;height:340px;background:#00e5c5;bottom:-120px;left:-100px;animation:float2 18s ease-in-out infinite}
.blob.b3{width:260px;height:260px;background:#8E5BFF;top:40%;left:42%;animation:float1 22s ease-in-out infinite reverse}

@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-30px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-30px,30px)}}

.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;border-radius:100px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  font-weight:600;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;
}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px rgba(0,229,197,.25)}
.hero h1{font-size:clamp(36px,5.2vw,68px);font-weight:700;margin:22px 0 18px}
.hero h1 .grad{
  background:linear-gradient(90deg,#00E5C5,#FFB6FF,#FFFFFF);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p.lead{font-size:18px;max-width:560px;color:rgba(255,255,255,.85)}
.hero-ctas{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.btn-light{background:#fff;color:var(--primary)}
.btn-light:hover{background:#f1eaff}
.btn-outline-light{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn-outline-light:hover{background:rgba(255,255,255,.1)}

.hero-stats{display:flex;gap:32px;margin-top:46px;flex-wrap:wrap}
.hero-stats .stat{display:flex;flex-direction:column}
.hero-stats .stat strong{font-family:'Space Grotesk';font-size:32px;color:#fff}
.hero-stats .stat span{font-size:13px;color:rgba(255,255,255,.7);letter-spacing:.04em}

/* Hero visual — creative browser + dashboard composition */
.hero-visual{position:relative;height:520px}
.window{
  position:absolute;background:#fff;color:var(--ink);
  border-radius:18px;box-shadow:0 40px 80px -20px rgba(0,0,0,.45);
  overflow:hidden;
}
.window .bar{display:flex;gap:6px;padding:12px 14px;background:#f6f3ff;border-bottom:1px solid #eee}
.window .bar i{width:11px;height:11px;border-radius:50%;background:#ddd;display:block}
.window .bar i:nth-child(1){background:#ff5f56}
.window .bar i:nth-child(2){background:#ffbd2e}
.window .bar i:nth-child(3){background:#27c93f}
.win-frontend{
  top:30px;left:0;width:78%;height:340px;transform:rotate(-3deg);
  animation:bobA 8s ease-in-out infinite;
}
.win-admin{
  bottom:0;right:0;width:62%;height:300px;transform:rotate(4deg);
  animation:bobB 9s ease-in-out infinite;
}
@keyframes bobA{0%,100%{transform:rotate(-3deg) translateY(0)}50%{transform:rotate(-3deg) translateY(-10px)}}
@keyframes bobB{0%,100%{transform:rotate(4deg) translateY(0)}50%{transform:rotate(4deg) translateY(12px)}}

.fe-body{padding:18px}
.fe-hero{background:linear-gradient(135deg,#4108D5,#8E5BFF);border-radius:10px;height:90px;display:flex;align-items:center;padding:0 16px;color:#fff;font-weight:700}
.fe-hero small{display:block;font-weight:500;opacity:.8;font-size:11px;margin-top:4px}
.fe-row{display:flex;gap:10px;margin-top:14px}
.fe-card{flex:1;background:#f5f1ff;border-radius:8px;height:54px;display:flex;align-items:center;padding:0 10px;gap:8px;font-size:12px;font-weight:600;color:#3b2a6e}
.fe-card .ic{width:22px;height:22px;border-radius:6px;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:11px}

.ad-body{display:grid;grid-template-columns:80px 1fr;height:100%}
.ad-side{background:#f5f1ff;padding:14px 10px;display:flex;flex-direction:column;gap:8px}
.ad-side .item{height:24px;border-radius:6px;background:#fff;display:flex;align-items:center;padding:0 8px;font-size:10.5px;color:#3b2a6e;font-weight:600}
.ad-side .item.active{background:var(--primary);color:#fff}
.ad-main{padding:14px}
.ad-title{font-size:12px;font-weight:700;color:var(--ink)}
.ad-bars{display:flex;gap:6px;align-items:flex-end;height:90px;margin-top:10px}
.ad-bars span{flex:1;background:linear-gradient(180deg,var(--primary),var(--primary-3));border-radius:6px 6px 0 0;animation:rise 2.6s ease-in-out infinite}
.ad-bars span:nth-child(1){height:35%}
.ad-bars span:nth-child(2){height:60%;animation-delay:.2s}
.ad-bars span:nth-child(3){height:45%;animation-delay:.4s}
.ad-bars span:nth-child(4){height:80%;animation-delay:.6s}
.ad-bars span:nth-child(5){height:55%;animation-delay:.8s}
.ad-bars span:nth-child(6){height:90%;animation-delay:1s}
.ad-bars span:nth-child(7){height:70%;animation-delay:1.2s}
@keyframes rise{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.85)}}
.ad-pills{display:flex;gap:8px;margin-top:10px}
.ad-pill{padding:6px 10px;background:#f5f1ff;border-radius:100px;font-size:10.5px;font-weight:600;color:#3b2a6e}
.ad-pill.green{background:#dcfff6;color:#0a8268}

.float-badge{
  position:absolute;background:#fff;color:var(--ink);
  border-radius:14px;padding:10px 14px;font-weight:600;font-size:13px;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 18px 40px -12px rgba(0,0,0,.35);
}
.float-badge .pulse{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px rgba(0,229,197,.25);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 6px rgba(0,229,197,.25)}50%{box-shadow:0 0 0 12px rgba(0,229,197,0)}}
.fb-1{top:-10px;right:30px;animation:bobA 6s ease-in-out infinite}
.fb-2{bottom:30px;left:-20px;animation:bobB 7s ease-in-out infinite}

/* Marquee strip */
.marquee{
  background:#0B0524;color:#fff;overflow:hidden;padding:18px 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.marquee-track{display:flex;gap:50px;animation:scroll 28s linear infinite;white-space:nowrap}
.marquee-track span{font-family:'Space Grotesk';font-size:22px;font-weight:600;color:rgba(255,255,255,.55)}
.marquee-track i{color:var(--accent);font-style:normal}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =========================
   SECTION DEFAULTS
========================= */
section{padding:70px 0;position:relative}
.section-head{text-align:center;max-width:760px;margin:0 auto 40px}
.section-head h2{font-size:clamp(30px,3.6vw,46px);margin:0 0 14px;font-weight:700}
.section-head p{color:var(--muted);font-size:17px}

.grad-text{
  background:linear-gradient(90deg,var(--primary),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* =========================
   FEATURES (Smart Website + CMS)
========================= */
.features{background:linear-gradient(180deg,#fff 0%,#FBF9FF 100%)}

/* =========================================================
   "HOW IT WORKS" — accordion (left) controls image (right)
========================================================= */
.hiw{
  display:grid;
  grid-template-columns:45% 55%;
  gap:clamp(28px,4vw,64px);
  align-items:start;
  margin-top:46px;
}

/* ---------- LEFT: accordion ---------- */
.hiw-steps{display:flex;flex-direction:column;gap:14px}
.hiw-item{
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  background:#fff;
  overflow:hidden;
  transition:border-color .35s ease, box-shadow .35s ease, background .35s ease;
}
.hiw-item.is-open{
  border-color:transparent;
  background:#fff;
  box-shadow:var(--shadow-md);
}
.hiw-h{margin:0}

/* Trigger button (accessible) */
.hiw-trigger{
  width:100%;
  display:flex;align-items:center;gap:18px;
  padding:22px 24px;
  background:none;border:0;cursor:pointer;
  text-align:left;
  font-family:'Space Grotesk','Plus Jakarta Sans',sans-serif;
  color:var(--ink);
  transition:color .25s ease;
}
.hiw-trigger:focus-visible{outline:2px solid var(--primary);outline-offset:-2px;border-radius:var(--radius-lg)}

.hiw-num{
  flex:none;
  font-size:14px;font-weight:700;
  color:var(--muted);
  font-variant-numeric:tabular-nums;
  transition:color .25s ease;
}
.hiw-title{
  flex:1;
  font-size:clamp(17px,1.7vw,20px);
  font-weight:600;letter-spacing:-.01em;
  line-height:1.25;
}
.hiw-chev{
  flex:none;width:20px;height:20px;color:var(--muted);
  transition:transform .4s cubic-bezier(.16,1,.3,1), color .25s ease;
}

/* Active styling */
.hiw-item.is-open .hiw-num{
  color:var(--primary);
}
.hiw-item.is-open .hiw-title{
  background:linear-gradient(90deg,var(--primary),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hiw-item.is-open .hiw-chev{transform:rotate(180deg);color:var(--primary)}

/* Accordion panel — smooth open via grid-rows (animates to auto height) */
.hiw-panel{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .45s cubic-bezier(.16,1,.3,1);
}
.hiw-item.is-open .hiw-panel{grid-template-rows:1fr}
.hiw-panel-in{
  overflow:hidden;
  padding:0 24px 0 60px;            /* aligns text under the title */
}
.hiw-item.is-open .hiw-panel-in{padding-bottom:24px}
.hiw-panel-in p{
  color:var(--muted);
  font-size:15.5px;line-height:1.65;
  margin:0;
}
/* image inside panel — only shown on mobile */
.hiw-panel-img{
  display:none;
  width:100%;border-radius:var(--radius-md);
  margin-top:18px;border:1px solid var(--border);
}

/* ---------- RIGHT: sticky swapping image ---------- */
.hiw-visual{
  position:sticky;
  top:96px;
}
.hiw-frame{
  position:relative;
  width:100%;
  aspect-ratio:3/ 2.1;
 

}
.hiw-shot{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:contain;                 /* show full image, no crop */
      /* breathing room around image */
  opacity:0;
  transform:scale(1.06) translateY(14px);
  transition:opacity .6s ease, transform .7s cubic-bezier(.16,1,.3,1);
  pointer-events:none;
}
.hiw-shot.is-active{
  opacity:1;
  transform:none;
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hiw{grid-template-columns:1fr;gap:0}
  .hiw-visual{display:none}            /* hide right column; image moves inside panel */
  .hiw-panel-img{display:block}        /* show image inside the active step */
  .hiw-panel-in{padding-left:24px}
}
@media (max-width:600px){
  .hiw-trigger{padding:18px 18px;gap:14px}
  .hiw-panel-in{padding:0 18px}
  .hiw-item.is-open .hiw-panel-in{padding-bottom:20px}
}

/* =========================
   BENEFITS (Why Every Business)
========================= */
.benefits-wrap{display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:center}
.benefits-media{
  
}
.benefits-media img{
  width:100%;height:100%;
  object-fit:contain;
  display:block;
}

.media-placeholder{
  position:relative;z-index:1;text-align:center;padding:24px;
  border:1px dashed rgba(255,255,255,.4);border-radius:18px;
  width:80%;height:80%;display:grid;place-items:center;
}
.media-placeholder svg{width:64px;height:64px;opacity:.85;margin-bottom:14px}
.media-placeholder p{opacity:.75;font-size:13px;max-width:240px;margin:0 auto}
.media-placeholder strong{display:block;font-size:18px;margin-bottom:8px}

.benefit-list{display:grid;grid-template-columns:1fr;gap:14px;margin-top:30px}
.benefit-item{
  display:flex;gap:16px;align-items:flex-start;
  padding:6px 0;
  background:transparent;border:0;
  transition:transform .25s;
}
.benefit-item:hover{transform:translateX(6px)}
.benefit-item .num{
  flex:none;width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff;display:grid;place-items:center;font-weight:700;font-family:'Space Grotesk'
}
.benefit-item h5{font-size:15.5px;margin-bottom:2px}
.benefit-item p{color:var(--muted);font-size:14px}

/* =========================
   CERTIFICATES (under banner)
========================= */
/* =========================================================
   AWARDS & RECOGNITION — left heading + bordered award cards
========================================================= */
.awards{background:#fff;padding:64px 0}
.aw-grid{
  display:grid;
  grid-template-columns:340px 1fr;
  gap:48px;
  align-items:stretch;
}

/* Left heading block */
.aw-head{align-self:center}
.aw-head h2{
  font-size:clamp(34px,4vw,52px);
  font-weight:700;letter-spacing:-.03em;line-height:1.05;
  margin:20px 0 18px;
  color:var(--ink);
}
.aw-head p{
  color:var(--muted);
  font-size:16px;line-height:1.6;
  max-width:300px;
}

/* Cards row — separated by thin borders */
.aw-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border:1px solid #ECEAF0;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.aw-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;
  padding:44px 24px;
  text-align:center;
  border-left:1px solid #ECEAF0;
  transition:background .3s ease;
}
.aw-card:first-child{border-left:0}
.aw-card:hover{background:#FAFAFB}

.aw-stat{
  font-family:'Space Grotesk','Plus Jakarta Sans',sans-serif;
  font-size:clamp(40px,4.6vw,58px);
  font-weight:700;letter-spacing:-.03em;line-height:1;
  color:var(--ink);
}
.aw-stat small{font-size:.55em;font-weight:700;color:var(--primary);margin-left:2px}

.aw-badge{width:104px;max-width:60%}
.aw-badge svg{width:100%;height:auto;display:block}

.aw-cap{
  font-size:14px;line-height:1.5;
  color:var(--muted);font-weight:500;
  margin:0;
}

/* =========================
   STATS / REVIEW BAR
========================= */
.stats-bar{
  background:#fff;
  padding:50px 0;
  border-top:1px solid #F1ECFB;
  border-bottom:1px solid #F1ECFB;
}
.stats-bar-inner{
  display:grid;
  grid-template-columns:1.1fr auto 1fr 1fr 1fr;
  align-items:center;
  column-gap:36px;
  row-gap:24px;
}
/* Review badge */
.stats-review{display:flex;flex-direction:column;gap:8px}
.stats-review-head{display:flex;align-items:center;gap:10px}
.stats-review-label{
  font-size:10.5px;letter-spacing:.18em;font-weight:700;
  color:var(--muted);
}
.g-logo{display:flex;align-items:center;gap:6px}
.g-logo svg{width:18px;height:18px}
.g-logo strong{font-family:'Plus Jakarta Sans',sans-serif;font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.stats-stars{display:flex;align-items:center;gap:3px}
.stats-stars svg{width:14px;height:14px}
.stats-stars span{
  margin-left:8px;color:var(--muted);font-size:13px;
}
.stat-divider{width:1px;height:54px;background:#E5E0F0}
/* Stat cells */
.stats-cell{display:flex;align-items:center;gap:14px}
.stats-icon{
  flex:none;
  width:50px;height:50px;border-radius:14px;
  display:grid;place-items:center;
}
.stats-icon svg{width:24px;height:24px}
.stats-ic-1{background:rgba(255,180,0,.12);color:#E89B0E}
.stats-ic-2{background:rgba(0,229,197,.14);color:#06B6A8}
.stats-ic-3{background:rgba(65,8,213,.10);color:var(--primary)}
.stats-info{display:flex;flex-direction:column;min-width:0}
.stats-info strong{
  font-family:'Space Grotesk',sans-serif;
  font-size:30px;font-weight:700;color:var(--ink);
  line-height:1;
  letter-spacing:-.01em;
}
.stats-info strong small{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:16px;font-weight:500;color:var(--ink);
  margin-left:4px;
  letter-spacing:0;
}
.stats-info > span{
  font-size:13px;color:var(--muted);
  margin-top:6px;
}
.stats-underline{
  display:block;width:80px;height:2px;border-radius:2px;
  margin-top:10px;
}
.stats-underline.u1{background:linear-gradient(90deg,#FFB400,#FFE0A0)}
.stats-underline.u2{background:linear-gradient(90deg,#06B6A8,#A8F0E9)}
.stats-underline.u3{background:linear-gradient(90deg,var(--primary),var(--accent-2))}

@media(max-width:1024px){
  .stats-bar-inner{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto auto;
    column-gap:24px;row-gap:32px;
  }
  .stats-review{grid-column:1 / -1}
  .stat-divider{display:none}
}
@media(max-width:600px){
  .stats-bar-inner{grid-template-columns:1fr;row-gap:24px}
  .stats-bar{padding:36px 0}
}

/* =========================
   CLIENT LOGO AUTO-SCROLL
========================= */
.clients{
  padding:60px 0 40px;
  background:#fff;
  border-top:1px solid #F1ECFB;
  border-bottom:1px solid #F1ECFB;
}
.clients-label{
  text-align:center;
  color:var(--muted);
  font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;font-weight:600;
  margin-bottom:30px;
}
.logo-track-wrap{
  position:relative;overflow:hidden;
  mask-image:linear-gradient(90deg,transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.logo-track{
  display:flex;align-items:center;gap:60px;
  width:max-content;
  animation:logoScroll 35s linear infinite;
}
.logo-item{
  flex:none;
  height:90px;
  display:grid;place-items:center;
}
.logo-item img{
  max-height:72px;
  max-width:170px;
  width:auto;height:auto;
  object-fit:contain;
  filter:grayscale(100%);
  opacity:.55;
  transition:.3s;
}
.logo-item:hover img{filter:grayscale(0);opacity:1;transform:scale(1.08)}
@keyframes logoScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =========================
   SERVICES — Stack Scroll
========================= */
.services-stack{
  background:linear-gradient(180deg,#fff 0%,#FBFAFF 100%);
  padding:70px 0 90px;
  position:relative;
}
.stack-list{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:30px;
}
.stack-card{
  position:sticky;
  top:calc(80px + var(--i) * 14px);
  background:#fff;
  border:1px solid #ECE7F7;
  border-radius:28px;
  padding:24px;
  transition:transform .4s ease;
  overflow:hidden;
}

/* simple 2-column service row: image left, content right */
.svc-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}
.svc-media{
  border-radius:18px;
  overflow:hidden;
  aspect-ratio:4 / 3;
}
.svc-media img{
  width:100%;height:100%;
  object-fit:contain;
  display:block;
}

/* right side — all content in one column */
.svc-content{display:flex;flex-direction:column}
.svc-content .sc-num{
  font-family:'Space Grotesk',sans-serif;
  font-size:11px;font-weight:700;letter-spacing:.18em;
  color:var(--primary);opacity:.6;
  margin-bottom:16px;
}
.svc-head{display:flex;align-items:center;gap:16px;margin-bottom:14px}
.svc-head .sc-ic{
  flex:none;
  width:50px;height:50px;border-radius:14px;
  background:linear-gradient(135deg,#F4ECFF,#FAF5FF);
  border:1px solid #ECE7F7;
  color:var(--primary);
  display:grid;place-items:center;
  box-shadow:0 6px 14px -6px rgba(65,8,213,.2);
}
.svc-head .sc-ic svg{width:24px;height:24px}
.svc-head h3{
  font-size:23px;font-weight:700;letter-spacing:-.01em;
  color:var(--ink);line-height:1.2;margin:0;
}
.svc-content > p{
  color:var(--muted);font-size:14.5px;line-height:1.6;
  margin:0 0 24px;
}
.svc-list{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:1fr 1fr;gap:13px 24px;
}
.svc-list li{
  position:relative;
  padding-left:28px;
  font-size:14.5px;font-weight:500;color:#3b3357;
  line-height:1.4;
}
.svc-list li::before{
  content:"✓";
  position:absolute;left:0;top:1px;
  width:20px;height:20px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff;font-size:11px;font-weight:700;
  display:grid;place-items:center;
  box-shadow:0 4px 10px -3px rgba(65,8,213,.4);
}

/* =========================
   PHP vs WORDPRESS COMPARISON
========================= */
/* =========================================================
   WHY BUSINESSES CHOOSE CUSTOM PHP — premium value props
========================================================= */
.cphp{
  background:#fff;
  padding:72px 0;
  position:relative;overflow:hidden;
}
.cphp::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(620px 420px at 88% 6%, rgba(65,8,213,.05), transparent 60%),
    radial-gradient(620px 420px at 8% 94%, rgba(255,79,183,.04), transparent 60%);
}
.cphp .container{position:relative;z-index:1}

/* Two side-by-side foundation cards (PHP highlighted vs WordPress) */
.found-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:26px;
  align-items:center;            /* lets the feature card sit slightly taller */
  margin-top:54px;
}

.found-card{
  position:relative;
  display:flex;flex-direction:column;
  padding:38px 34px;
  border-radius:var(--radius-lg);
  background:#fff;
  border:1px solid var(--border);
  box-shadow:0 14px 34px -26px rgba(11,5,36,.25);
  transition:transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s ease, border-color .4s ease;
}
.found-card:hover{
  transform:translateY(-8px);
  box-shadow:0 30px 60px -30px rgba(11,5,36,.3);
}

/* Badge */
.found-badge{
  align-self:flex-start;
  font-size:11.5px;font-weight:700;letter-spacing:.06em;
  padding:7px 14px;border-radius:100px;
  margin-bottom:22px;
  background:var(--soft);
  color:var(--primary);
  border:1px solid var(--border);
}

/* Title row */
.found-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.found-ic{
  flex:none;
  width:52px;height:52px;border-radius:14px;
  display:grid;place-items:center;
  color:var(--primary);
  background:linear-gradient(135deg,rgba(65,8,213,.12),rgba(255,79,183,.12));
  transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.found-card:hover .found-ic{transform:scale(1.08) rotate(-3deg)}
.found-ic svg{width:26px;height:26px}
.found-head h3{font-size:23px;font-weight:700;letter-spacing:-.015em;color:var(--ink)}

.found-desc{
  font-size:15.5px;line-height:1.6;
  color:var(--muted);
  margin:0 0 26px;
}

/* Feature points — soft dot markers, no checkmarks */
.found-list{
  list-style:none;margin:0 0 26px;padding:0;
  display:grid;grid-template-columns:1fr 1fr;gap:12px 20px;
}
.found-list li{
  position:relative;
  padding-left:20px;
  font-size:14.5px;line-height:1.45;
  color:#3b3357;
}
.found-list li::before{
  content:"";position:absolute;left:0;top:.5em;
  width:7px;height:7px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--accent-2));
}

/* Bottom note */
.found-note{
  margin:auto 0 0;                /* pin to bottom for equal alignment */
  padding-top:22px;
  border-top:1px solid var(--border);
  font-size:13.5px;line-height:1.6;
  color:var(--muted);
}

/* ---- Highlighted Custom PHP card ---- */
.found-card--feature{
  background:linear-gradient(160deg,#140A3D 0%, var(--primary) 60%, var(--primary-2) 100%);
  border-color:transparent;
  box-shadow:0 36px 80px -30px rgba(65,8,213,.6);
  transform:scale(1.025);          /* slightly larger */
}
.found-card--feature:hover{transform:scale(1.025) translateY(-8px)}
/* soft glow */
.found-card--feature::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;z-index:-1;
  background:linear-gradient(135deg,var(--primary),var(--accent-2));
  filter:blur(26px);opacity:.35;
}
.found-card--feature .found-badge{
  background:rgba(255,255,255,.16);
  color:#fff;border-color:rgba(255,255,255,.28);
}
.found-card--feature .found-ic{background:rgba(255,255,255,.16);color:#fff}
.found-card--feature .found-head h3{color:#fff}
.found-card--feature .found-desc{color:rgba(255,255,255,.82)}
.found-card--feature .found-list li{color:#fff}
.found-card--feature .found-list li::before{background:#fff}
.found-card--feature .found-note{
  color:rgba(255,255,255,.78);
  border-top-color:rgba(255,255,255,.18);
}

/* =========================
   ADMIN PANEL BENEFITS
========================= */
.admin{background:#FBF9FF}
.admin-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:end}
.do-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:30px}
.do-item{
  display:flex;align-items:center;gap:12px;
  padding:8px 0;
  background:none;border:0;
  font-size:14.5px;font-weight:500;
}
.do-item .tick{
  flex:none;width:24px;height:24px;border-radius:8px;
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff;display:grid;place-items:center;font-size:12px;
}
.adv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px}
.adv{
  padding:18px;border-radius:14px;
  background:linear-gradient(135deg,rgba(65,8,213,.06),rgba(255,79,183,.05));
  border:1px solid var(--border);
}
.adv strong{display:block;font-size:15px;margin-bottom:4px}
.adv span{font-size:13px;color:var(--muted)}

.admin-visual{
  position:relative;
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.admin-visual img{
  display:block;
  width:100%;
  height:auto;                /* natural height; box sits at bottom, aligned with do-list */
  object-fit:contain;
}
.dash-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.dash-head h6{font-size:14px;color:var(--ink)}
.dash-head .live{font-size:11px;color:#0a8268;background:#dcfff6;padding:4px 10px;border-radius:100px;font-weight:600}
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.kpi{background:#fff;border:1px solid var(--border);padding:14px;border-radius:12px}
.kpi span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.kpi strong{display:block;font-family:'Space Grotesk';font-size:22px;color:var(--primary);margin-top:4px}
.dash-chart{
  background:linear-gradient(135deg,var(--primary),var(--primary-3));
  border-radius:14px;padding:18px;color:#fff;
}
.dash-chart h6{font-size:13px;opacity:.9;margin-bottom:10px}
.dash-chart svg{width:100%;height:100px}
.dash-list{margin-top:14px;background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.dash-row{display:flex;justify-content:space-between;padding:12px 14px;font-size:13px;border-bottom:1px solid var(--border)}
.dash-row:last-child{border-bottom:0}
.dash-row .tag{font-size:11px;background:#f5f1ff;color:var(--primary);padding:3px 10px;border-radius:100px;font-weight:600}
.dash-row .tag.green{background:#dcfff6;color:#0a8268}

/* =========================
   WHY CHOOSE US
========================= */
/* ---- minimal "spec-sheet" grid — thin dividers, no boxes ---- */
.why-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;                              /* the gap shows as hairline dividers */
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  counter-reset:why;
  margin-top:46px;
}
.why-card{
  counter-increment:why;
  position:relative;
  background:#fff;
  padding:34px 28px 30px;
  transition:background .4s ease;
}
/* faint index number, top-right */
.why-card::before{
  content:"0" counter(why);
  position:absolute;top:22px;right:24px;
  font-family:'Space Grotesk','Plus Jakarta Sans',sans-serif;
  font-size:13px;font-weight:700;letter-spacing:.04em;
  color:var(--muted);opacity:.45;
  transition:color .35s, opacity .35s;
}
/* accent line that draws across the top on hover */
.why-card::after{
  content:"";position:absolute;left:0;top:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--primary),var(--accent-2));
  transition:width .45s cubic-bezier(.16,1,.3,1);
}
.why-card:hover{background:#FBFAFF}
.why-card:hover::after{width:100%}
.why-card:hover::before{color:var(--primary);opacity:1}

.why-ic{
  width:46px;height:46px;
  display:grid;place-items:center;
  color:var(--primary);
  border:1.5px solid var(--border);
  border-radius:14px;
  background:#fff;
  transition:transform .4s cubic-bezier(.16,1,.3,1), border-color .35s, color .35s;
}
.why-card:hover .why-ic{
  transform:translateY(-3px);
  border-color:var(--primary);
}
.why-ic svg{width:22px;height:22px}
.why-card h4{font-size:17.5px;font-weight:700;letter-spacing:-.01em;margin:18px 0 8px}
.why-card p{color:var(--muted);font-size:14px;line-height:1.55;margin:0}

/* =========================
   PROCESS
========================= */
.process{background:linear-gradient(180deg,#FBF9FF 0%,#fff 100%)}

/* ---- flexfollio-style horizontal flow (dashed circles + wavy line) ---- */
.proc-flow{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  gap:6px;
  margin-top:54px;
}

/* each step column */
.proc-node{
  position:relative;z-index:1;          /* circles paint above the line */
  flex:0 0 auto;
  width:clamp(150px,15vw,200px);
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
}
.proc-circle{
  width:88px;height:88px;border-radius:50%;
  display:grid;place-items:center;
  background:#fff;
  border:1.6px dashed rgba(65,8,213,.35);
  color:var(--primary);
  box-shadow:0 14px 34px -18px rgba(65,8,213,.4);
  margin-bottom:26px;
  transition:transform .35s cubic-bezier(.16,1,.3,1), border-color .35s, box-shadow .35s;
}
.proc-circle svg{width:32px;height:32px}
.proc-node:hover .proc-circle{
  transform:translateY(-4px) scale(1.04);
  border-color:var(--primary);
  box-shadow:0 22px 44px -18px rgba(65,8,213,.5);
}
.proc-node h5{
  font-family:'Space Grotesk','Plus Jakarta Sans',sans-serif;
  font-size:18px;font-weight:700;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:8px;
}
.proc-node p{font-size:14px;line-height:1.55;color:var(--muted);margin:0;max-width:220px}

/* wavy dashed connector — endpoints sit at the circle centre and tuck behind
   the circles, so the line visually connects edge-to-edge */
.proc-conn{
  position:relative;z-index:0;
  flex:1 1 auto;
  min-width:30px;
  height:88px;                    /* same as circle → endpoints land on its centre */
  margin:0 -44px;                 /* reach into both circles (radius = 44px) */
  display:flex;align-items:center;
}
.proc-conn svg{
  width:100%;height:100%;display:block;
  overflow:visible;
}
.proc-conn path{
  fill:none;
  stroke:rgba(65,8,213,.4);
  stroke-width:2;
  stroke-linecap:round;
  stroke-dasharray:1.5 7;
  vector-effect:non-scaling-stroke;
}


/* =========================
   INDUSTRIES
========================= */
.industries{background:#0B0524;color:#fff;position:relative;overflow:hidden}
.industries::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(800px 400px at 50% 0%, rgba(65,8,213,.55), transparent 60%);
}
.industries .section-head h2{color:#fff}
.industries .section-head p{color:rgba(255,255,255,.7)}
.industries .eyebrow{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.18)}
.industries .eyebrow::before{background:var(--accent)}
/* ---- Vertical editorial slider (light, magazine style) ---- */
.vs-source{display:none !important}
.vslider{
  background:#ECE8E1;
  padding:64px 24px;
  display:flex;flex-direction:column;align-items:center;
  overflow:hidden;
}
.vs-card{
  position:relative;
  width:min(1120px,100%);min-height:460px;
  background:#fff;border-radius:22px;
  box-shadow:0 40px 80px -36px rgba(60,48,36,.32), 0 12px 30px -16px rgba(60,48,36,.12);
  display:flex;align-items:center;
  padding:60px 110px 60px 420px;
  outline:none;
  touch-action:none;            /* capture vertical swipe gestures */
}
.vs-card:focus-visible{box-shadow:0 0 0 2px rgba(232,116,59,.5), 0 34px 70px -34px rgba(60,48,36,.30)}

/* Left overlapping image */
.vs-figure{
  position:absolute;left:-44px;top:50%;transform:translateY(-50%);
  width:340px;height:404px;margin:0;border-radius:16px;overflow:hidden;
  background:#e7e2da;
  box-shadow:0 30px 60px -22px rgba(50,40,30,.45);
}
.vs-figure img{
  width:100%;height:100%;object-fit:cover;display:block;
  will-change:opacity,transform;
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.vs-figure.is-out img{opacity:0;transform:translateY(18px) scale(1.02)}

/* Right content */
.vs-body{
  flex:1;max-width:540px;
  will-change:opacity,transform;
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.vs-body.is-out{opacity:0;transform:translateY(20px)}
.vs-pill{
  display:inline-flex;align-items:center;gap:9px;
  padding:7px 15px;border-radius:100px;background:#F4EFE8;
  font-size:12px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#9a8d7d;
  margin-bottom:22px;
}
.vs-pill i{width:7px;height:7px;border-radius:50%;background:#E8743B;flex:none}
.vs-body h3{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;
  font-size:31px;line-height:1.18;letter-spacing:-.01em;color:#3f3f3f;margin:0 0 18px;
}
.vs-body p{font-size:16px;line-height:1.75;color:#6f6f6f;margin:0;max-width:460px}

/* Bullet points — two columns side by side */
.vs-lists{display:flex;gap:26px;margin-top:22px;flex-wrap:wrap}
.vs-list{list-style:none;margin:0;padding:0;display:grid;gap:13px;flex:1;min-width:190px;align-content:start}
.vs-list li{
  display:flex;align-items:flex-start;gap:11px;
  font-size:15px;line-height:1.5;font-weight:600;color:#46433f;
}
.vs-list li svg{
  flex:none;width:20px;height:20px;margin-top:1px;
  color:#E8743B;
}
/* CTA button */
.vs-cta{
  display:inline-flex;align-items:center;gap:9px;margin-top:28px;
  padding:13px 26px;border-radius:100px;
  background:#E8743B;color:#fff;font-size:15px;font-weight:700;
  box-shadow:0 16px 30px -12px rgba(232,116,59,.55);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, gap .25s ease;
}
.vs-cta svg{width:16px;height:16px}
.vs-cta:hover{background:#d8632b;transform:translateY(-2px);gap:13px;box-shadow:0 22px 40px -14px rgba(232,116,59,.6)}

/* Vertical indicator dots */
.vs-dots{
  position:absolute;right:44px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:11px;align-items:center;
}
.vs-dot{
  width:7px;height:7px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:#D8D2C8;
  transition:background .35s ease, height .45s cubic-bezier(.22,1,.36,1);
}
.vs-dot.is-active{height:30px;border-radius:6px;background:#E8743B}

@media (prefers-reduced-motion: reduce){
  .vs-body,.vs-figure img{transition:opacity .25s linear}
  .vs-body.is-out{transform:none}
  .vs-figure.is-out img{transform:none}
}

/* =========================
   MARKETING QUOTES
========================= */
/* =========================================================
   TESTIMONIALS — heading + intro, peeking scroll carousel
========================================================= */
.tst{background:#F7F6F9;padding:64px 0 70px;overflow:hidden}

/* Header row */
.tst-head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:end;
  margin-bottom:50px;
}
.tst-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:14px;font-weight:600;color:var(--primary);
  margin-bottom:18px;
}
.tst-eyebrow::before{content:"";width:34px;height:2px;background:var(--primary)}
.tst-head h2{
  font-size:clamp(34px,5vw,58px);
  font-weight:700;letter-spacing:-.03em;line-height:1.02;
  color:var(--ink);
}
.tst-intro{
  color:var(--muted);font-size:16.5px;line-height:1.7;
  max-width:440px;justify-self:end;
}

/* Seamless marquee — viewport clips, inner row auto-scrolls infinitely */
.tst-track{
  overflow:hidden;
  padding:8px 0 22px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
}
.tst-marquee{
  display:flex;
  gap:24px;
  width:max-content;
  padding-left:24px;
  animation:tstScroll 60s linear infinite;
}
.tst-marquee:hover{animation-play-state:paused}   /* pause on hover */
@media (prefers-reduced-motion:reduce){.tst-marquee{animation:none}}
@keyframes tstScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}      /* one full set (padding-left = gap → seamless) */
}

.tst-card{
  flex:0 0 clamp(300px,30vw,360px);
  background:#fff;
  border-radius:18px;
  padding:32px 30px;
  box-shadow:0 24px 50px -34px rgba(11,5,36,.35);
  display:flex;flex-direction:column;
  transition:transform .35s ease, box-shadow .35s ease;
}
.tst-card:hover{transform:translateY(-6px);box-shadow:0 34px 60px -30px rgba(11,5,36,.4)}

.tst-stars{
  color:#FFB400;font-size:18px;letter-spacing:3px;
  margin-bottom:20px;
}
.tst-stars i{color:#E2DEEC;font-style:normal}   /* empty star */

.tst-quote{
  color:#42405A;font-size:15.5px;line-height:1.7;
  margin:0 0 28px;
}

.tst-author{display:flex;align-items:center;gap:14px;margin-top:auto}
.tst-avatar{
  flex:none;
  width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;
  font-size:14px;font-weight:700;color:#fff;
  font-family:'Space Grotesk',sans-serif;letter-spacing:.02em;
  background:linear-gradient(135deg,var(--c1),var(--c2));
  box-shadow:0 8px 18px -8px rgba(11,5,36,.4);
}
.tst-author strong{display:block;font-size:15px;color:var(--ink)}
.tst-author span{font-size:13px;color:var(--muted)}

/* =========================
   CTA
========================= */
.cta{
  background:linear-gradient(135deg,#4108D5,#7331FF);
  color:#fff;border-radius:32px;padding:70px 60px;
  margin:80px auto;max-width:1180px;position:relative;overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(500px 300px at 100% 0%, rgba(255,79,183,.45), transparent 60%),
    radial-gradient(500px 300px at 0% 100%, rgba(0,229,197,.35), transparent 60%);
}
.cta-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center}
.cta h2{font-size:clamp(28px,3.4vw,42px);margin-bottom:14px}
.cta p{color:rgba(255,255,255,.85);margin-bottom:24px;max-width:520px}
.cta .ticks{display:flex;flex-wrap:wrap;gap:8px}
.cta .ticks span{
  font-size:13px;padding:6px 12px;border-radius:100px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
}
.cta-card{
  background:rgba(255,255,255,.08);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:28px;
}
.cta-card h5{font-size:14px;color:rgba(255,255,255,.7);font-weight:500;margin-bottom:6px;letter-spacing:.05em;text-transform:uppercase}
.cta-card a.big{font-size:22px;font-weight:700;color:#fff;display:block;margin-bottom:18px}
.cta-card .row{display:flex;align-items:center;gap:14px;font-size:14.5px;color:rgba(255,255,255,.92);margin-bottom:10px}
.cta-card .row .icb{width:32px;height:32px;border-radius:10px;background:rgba(255,255,255,.12);display:grid;place-items:center}

/* =========================
   FOOTER
========================= */
footer{background:#0B0524;color:rgba(255,255,255,.7);padding:50px 0 30px}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.foot p{font-size:14px}
.foot a{color:#fff}

/* =========================
   ANIMATIONS
========================= */
.reveal{opacity:0;transform:translateY(30px);transition:all .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* =========================
   RESPONSIVE
========================= */
@media(max-width:1024px){
  .hero-grid,.benefits-wrap,.admin-grid,.cta-inner{grid-template-columns:1fr;gap:48px}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .vs-card{padding:48px 70px 48px 320px}
  .vs-figure{width:264px;height:320px;left:-32px}
  .vs-body h3{font-size:27px}
  .proc-flow{flex-direction:column;align-items:center;gap:30px}
  .proc-conn{display:none}
  .proc-node{width:100%;max-width:340px}
  .proc-circle{margin-bottom:16px}
  .tst-head{grid-template-columns:1fr;gap:18px;align-items:start}
  .tst-intro{justify-self:start;max-width:none}
  .service-row,.service-row.reverse{grid-template-columns:1fr;direction:ltr}
  .aw-grid{grid-template-columns:1fr;gap:32px}
  .aw-head{align-self:start;text-align:center}
  .aw-head p{max-width:none;margin:0 auto}
  .aw-head .eyebrow{margin:0 auto}
  .svc-row{grid-template-columns:1fr;gap:28px}
  .stack-card{padding:18px}
  .hero-visual{height:440px}
  .cta{padding:50px 30px;margin:60px 20px}
  .nav-links{display:none}
}
@media(max-width:600px){
  section{padding:48px 0}
  .feature-grid,.why-grid,.do-list,.adv-grid,.kpi-row,.benefit-list,.found-grid{grid-template-columns:1fr}
  /* Vertical slider stacks: image above content, dots horizontal at bottom */
  .vslider{padding:60px 18px}
  .vs-card{flex-direction:column;align-items:center;text-align:center;padding:0 26px 56px;overflow:visible}
  .vs-figure{position:relative;left:auto;top:auto;transform:none;width:230px;height:248px;margin:-42px auto 26px}
  .vs-body{max-width:none}
  .vs-body p{margin:0 auto}
  .vs-dots{position:static;transform:none;flex-direction:row;justify-content:center;margin-top:28px}
  .vs-dot.is-active{height:7px;width:30px}
  /* stack the process flow vertically; hide wavy connectors */
  .proc-flow{flex-direction:column;align-items:center;gap:30px;margin-top:40px}
  .proc-conn{display:none}
  .proc-node{width:100%;max-width:340px}
  .proc-circle{margin-bottom:16px}
  .aw-cards{grid-template-columns:1fr}
  .aw-card{border-left:0;border-top:1px solid #ECEAF0}
  .aw-card:first-child{border-top:0}
  .found-card--feature{order:-1;transform:none}
  .found-card--feature:hover{transform:translateY(-8px)}
  .found-list{grid-template-columns:1fr}
  .svc-list{grid-template-columns:1fr}
  .stack-card{padding:14px;top:80px}
  .hero{padding:60px 0 100px}
  .hero h1{font-size:38px}
  .hero-visual{height:380px}
  .win-frontend{width:90%}
  .win-admin{width:75%}
  .cta{padding:40px 22px}
}

/* =========================================================
   NUMA-STYLE HERO — full-screen centered + scroll zoom
   DOM: .numa-hero(200vh) > .nh-pin(sticky 100vh)
        .nh-pin > .nh-bg(img.nh-img) + .nh-overlay + .nh-content + .nh-hint
        .nh-content > .nh-badge + h1.nh-title + p.nh-sub + a.nh-cta
========================================================= */
.numa-hero{
  position:relative;
  height:200vh;                 /* scroll distance that drives the zoom */
  background:#06040F;
}

/* Sticky full-screen stage */
.nh-pin{
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* Full-bleed background image (zooms via GSAP) */
.nh-bg{position:absolute;inset:0;overflow:hidden}
.nh-img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1);           /* GSAP scrubs 1 → 1.35 */
  transform-origin:center center;
  will-change:transform;
}

/* Dark overlay for readability */
.nh-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 120% at 50% 40%, rgba(6,4,15,.25), rgba(6,4,15,.62) 70%, rgba(6,4,15,.8) 100%),
    linear-gradient(180deg, rgba(6,4,15,.45) 0%, rgba(6,4,15,.15) 45%, rgba(6,4,15,.6) 100%);
  pointer-events:none;
}

/* Bottom-left aligned content (Numa text hierarchy) */
.nh-content{
  position:absolute;
  z-index:2;
  left:0;right:0;bottom:0;
  width:100%;
  padding:clamp(36px,6vw,80px) clamp(28px,5vw,80px);
  text-align:left;
  color:#fff;
  display:flex;
  flex-direction:row;
  align-items:center;            /* button vertically centered with text block */
  justify-content:space-between;
  gap:40px;
  will-change:transform,opacity;
}
/* text column on the left */
.nh-text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}
.nh-content .nh-title,
.nh-content .nh-sub{max-width:760px}

/* Badge pill — "New · ..." */
.nh-badge{
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:7px 7px 7px 14px;
  border-radius:100px;
  font-size:13px;font-weight:600;
  letter-spacing:.01em;
  color:rgba(255,255,255,.9);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(10px);
  margin-bottom:30px;
}
.nh-badge i{
  font-style:normal;
  padding:3px 10px;border-radius:100px;
  background:#fff;color:#06040F;
  font-size:11.5px;font-weight:700;
  letter-spacing:.02em;
}

/* Large premium centered headline */
.nh-title{
  font-family:'Space Grotesk','Plus Jakarta Sans',sans-serif;
  font-weight:600;
  font-size:clamp(44px,7.6vw,70px);
  line-height:1.0;
  letter-spacing:-.035em;
  margin:0;
  color:#fff;
  text-shadow:0 4px 50px rgba(0,0,0,.35);
}

/* Subheading */
.nh-sub{
  margin:24px 0 0;
  max-width:600px;
  font-size:clamp(15px,1.5vw,11.5px);
  line-height:1.6;
  color:rgba(255,255,255,.8);
}

/* CTA — vertically centered with text, on the right */
.nh-cta{
  flex:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:16px 34px;
  border-radius:100px;
  background:#fff;
  color:#06040F;
  font-weight:700;
  font-size:15.5px;
  box-shadow:0 16px 44px -14px rgba(0,0,0,.55);
  transition:transform .25s ease, box-shadow .25s ease;
}
.nh-cta:hover{transform:translateY(-3px);box-shadow:0 24px 56px -16px rgba(0,0,0,.65)}

/* Scroll hint */
.nh-hint{
  position:absolute;
  left:50%;bottom:30px;
  transform:translateX(-50%);
  z-index:2;
  width:26px;height:42px;
  border:2px solid rgba(255,255,255,.4);
  border-radius:100px;
}
.nh-hint i{
  position:absolute;
  left:50%;top:9px;
  transform:translateX(-50%);
  width:4px;height:8px;border-radius:4px;
  background:#fff;
  animation:nhScroll 1.7s ease-in-out infinite;
}
@keyframes nhScroll{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,14px)}100%{opacity:0}}

/* ---------- Responsive breakpoints ---------- */

/* Tablet */
@media (max-width:900px){
  .nh-title{font-size:clamp(40px,9vw,72px)}
  .nh-sub{max-width:90%}
}

/* Mobile — no pin/zoom, simple full-screen banner for performance */
@media (max-width:600px){
  .numa-hero{height:auto}
  .nh-pin{position:static;height:auto;min-height:92vh;padding:0 0 70px}
  .nh-img{transform:none !important}
  .nh-content{transform:none !important;opacity:1 !important;flex-direction:column;align-items:flex-start;gap:24px}
  .nh-title{font-size:clamp(34px,11vw,52px)}
  .nh-cta{width:100%;max-width:320px}
  .nh-hint{display:none}
}

/* =========================
   TECHNOLOGIES & SOFTWARE
   (Framer "Integrations"-style layout)
========================= */
.techstack{padding:64px 0;overflow:hidden}
.techstack .ts-grid{
  display:grid;
  grid-template-columns:1fr 1.12fr;
  gap:64px;
  align-items:center;
}

/* LEFT: copy block */
.ts-copy{max-width:500px}
.ts-copy h2{
  font-size:clamp(32px,4.4vw,52px);
  font-weight:700;
  line-height:1.04;
  margin:6px 0 18px;
  color:var(--ink);
}
.ts-copy p{
  color:var(--muted);
  font-size:17px;
  line-height:1.65;
  margin-bottom:30px;
}
.ts-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 26px;border-radius:100px;
  background:var(--ink);color:#fff;
  font-weight:600;font-size:15px;
  border:1px solid var(--ink);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.ts-btn svg{width:16px;height:16px}
.ts-btn:hover{transform:translateY(-2px);background:var(--primary);border-color:var(--primary);box-shadow:0 16px 34px -14px rgba(65,8,213,.5)}

/* RIGHT: floating app-icon cloud with soft edge fade */
.ts-cloud{
  display:flex;
  gap:18px;
  justify-content:center;
  -webkit-mask-image:linear-gradient(180deg,transparent 0,#000 16%,#000 84%,transparent 100%);
          mask-image:linear-gradient(180deg,transparent 0,#000 16%,#000 84%,transparent 100%);
}
.ts-col{
  display:flex;flex-direction:column;gap:18px;
  flex:1;min-width:0;
  animation:tsFloat 4s ease-in-out infinite;
}
.ts-col:nth-child(1){margin-top:18px}
.ts-col:nth-child(2){margin-top:-22px;animation-delay:-2s}
.ts-col:nth-child(3){margin-top:30px;animation-delay:-4s}
.ts-col:nth-child(4){margin-top:-8px;animation-delay:-1s}
.ts-col:nth-child(5){margin-top:36px;animation-delay:-3s}
@keyframes tsFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.tech-logo{
  width:100%;aspect-ratio:1;
  background:#fff;
  border:1px solid rgba(11,5,36,.07);
  border-radius:20px;
  box-shadow:0 14px 30px -20px rgba(11,5,36,.35);
  display:grid;place-items:center;
  transition:transform .3s ease, box-shadow .3s ease;
}
.tech-logo:hover{
  transform:translateY(-5px) scale(1.04);
  box-shadow:0 24px 46px -22px rgba(11,5,36,.42);
}
.tech-logo .tl-ic{
  width:56%;aspect-ratio:1;border-radius:26%;
  display:grid;place-items:center;
  font-family:'Space Grotesk','Plus Jakarta Sans',sans-serif;
  font-weight:700;letter-spacing:-.02em;
  font-size:clamp(11px,1.35vw,16px);
  color:var(--t,#fff);
  background:var(--c,#4108D5);
}
.tech-logo .tl-ic svg{width:64%;height:64%}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .ts-col{animation:none}
}

/* Tablet / mobile */
@media (max-width:900px){
  .techstack{padding:72px 0}
  .techstack .ts-grid{grid-template-columns:1fr;gap:40px}
  .ts-copy{max-width:620px;margin:0 auto;text-align:center}
  .ts-copy .eyebrow{justify-content:center}
}
@media (max-width:560px){
  .ts-cloud{gap:12px}
  .tech-logo{border-radius:16px}
  .ts-col:nth-child(5){display:none}
}
@media (max-width:400px){
  .ts-col:nth-child(4){display:none}
}
