/* ================================================
   TOKENS
================================================ */
:root{
  --purple:#8b5cf6;
  --purple-dark:#6366f1;
  --purple-light:#a78bfa;
  --black:#0a0a0a;
  --white:#fff;
  --gray-100:#f7f7f8;
  --gray-200:#ebebeb;
  --gray-400:#aaa;
  --gray-600:#666;
  --green:#22c55e;
}

/* ================================================
   RESET
================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--white);color:var(--black);overflow-x:hidden;-webkit-font-smoothing:antialiased;}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
p{line-height:1.7;color:var(--gray-600);}

/* ================================================
   LAYOUT
================================================ */
.wrap{max-width:1320px;margin:0 auto;padding:0 5%;}

/* ================================================
   LOGO IMAGE (navbar, loader, footer)
================================================ */
/* Logo original: 1624×1282px → wider than tall (ratio ~1.27:1)
   Use height-only sizing so width scales naturally */
.nav-logo{
  display:flex;align-items:center;gap:.55rem;
  text-decoration:none;flex-shrink:0;
}
.nav-logo span{
  font-size:1.55rem;font-weight:900;letter-spacing:-.04em;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.nav-logo-img{
  height:36px;width:auto;max-width:none;
  flex-shrink:0;display:block;
}

.loader-logo{
  display:flex;align-items:center;gap:.8rem;
}
.loader-logo span{
  font-size:2.4rem;font-weight:900;letter-spacing:-.04em;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.loader-logo-img{
  height:60px;width:auto;max-width:none;flex-shrink:0;display:block;
}

.fb-name{
  display:flex;align-items:center;gap:.55rem;
  margin-bottom:1rem;
}
.fb-name span{
  font-size:1.55rem;font-weight:900;letter-spacing:-.04em;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.footer-logo-img{
  height:30px;width:auto;max-width:none;flex-shrink:0;display:block;
}

/* ================================================
   NAV
================================================ */
.nav{
  position:absolute;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,.94);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--gray-200);
}
.nav-inner{
  display:flex;justify-content:space-between;align-items:center;
  max-width:1320px;margin:0 auto;padding:0 5%;height:70px;
}
.nav-links{display:flex;gap:2.4rem;}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--gray-600);transition:color .2s;}
.nav-links a:hover{color:var(--black);}
.nav-right{display:flex;align-items:center;gap:1rem;}
.btn-lang{font-size:.82rem;font-weight:600;color:var(--gray-400);transition:color .2s;}
.btn-lang:hover{color:var(--black);}
/* CTA button — Elara purple */
.btn-nav-cta{
  padding:.65rem 1.5rem;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  color:#fff;border-radius:50px;font-size:.88rem;font-weight:700;
  transition:all .25s;white-space:nowrap;
}
.btn-nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(139,92,246,.4);}

/* ================================================
   HERO — centered full-width 2026
================================================ */
.hero{
  padding:9rem 0 5rem;
  position:relative;overflow:hidden;
  background:#fff;
}

/* Subtle aurora gradient in background */
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(139,92,246,.1) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 80% 60%, rgba(99,102,241,.06) 0%, transparent 50%),
    radial-gradient(ellipse 40% 30% at 20% 70%, rgba(167,139,250,.05) 0%, transparent 50%);
  animation:auroraShift 14s ease-in-out infinite;
}
@keyframes auroraShift{
  0%,100%{opacity:1;}
  50%{opacity:.7;transform:scale(1.05);}
}

/* Dot grid overlay */
.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle, rgba(139,92,246,.12) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%, black 0%, transparent 100%);
}

.hero-center{
  max-width:1320px;margin:0 auto;padding:0 5%;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  position:relative;z-index:1;
}

/* Badge */
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.42rem 1.1rem;
  background:rgba(139,92,246,.07);
  border:1px solid rgba(139,92,246,.2);
  border-radius:50px;font-size:.74rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--purple);
  margin-bottom:2.4rem;position:relative;z-index:1;
}
.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--purple);animation:livePulse 2s ease infinite;}

/* Giant headline — word-by-word reveal, no clipping */
.hero-headline{
  font-size:clamp(2.8rem,7vw,7.5rem);
  font-weight:900;line-height:1.08;letter-spacing:-.055em;
  margin-bottom:2rem;position:relative;z-index:1;
  color:var(--black);
}
.hw{
  display:inline-block;
  margin-right:.18em;
  /* NO overflow:hidden — prevents letter clipping */
  opacity:0;
  transform:translateY(22px);
  transition:opacity .6s cubic-bezier(.22,.61,.36,1),
             transform .6s cubic-bezier(.22,.61,.36,1);
}
.hw:last-child{margin-right:0;}
.hw-inner{display:inline;}

.hero-headline.in .hw{opacity:1;transform:translateY(0);}
.hero-headline.in .hw:nth-child(1){transition-delay:.06s;}
.hero-headline.in .hw:nth-child(2){transition-delay:.14s;}
.hero-headline.in .hw:nth-child(3){transition-delay:.22s;}
.hero-headline.in .hw:nth-child(4){transition-delay:.30s;}
.hero-headline.in .hw:nth-child(5){transition-delay:.38s;}

/* "finanziario" — solid purple, no animation */
.hw-accent{color:var(--purple);}
.hw-accent .hw-inner{color:var(--purple);}

/* No floating chips */
.float-tag{display:none;}

.hero-sub{
  font-size:1.2rem;color:var(--gray-600);line-height:1.8;
  margin-bottom:3rem;max-width:52ch;position:relative;z-index:1;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-bottom:5rem;position:relative;z-index:1;}
.btn-primary{
  padding:1rem 2.4rem;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  color:#fff;border-radius:50px;font-size:1rem;font-weight:700;
  transition:all .28s;
  box-shadow:0 8px 28px rgba(139,92,246,.35);
}
/* ── MORPHING BUTTON (pill → circle + arrow) ── */
.btn-morph{
  position:relative;overflow:hidden;
  height:52px;
  min-width:52px;
  display:inline-flex;align-items:center;justify-content:center;
  white-space:nowrap;
}
.btn-morph .btn-label{
  transition:opacity .22s ease, transform .22s ease;
  display:block;
}
.btn-morph .btn-arrow{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;
  transform:scale(.5) rotate(-45deg);
  transition:opacity .3s ease .1s, transform .35s cubic-bezier(.34,1.56,.64,1) .1s;
}
.btn-morph .btn-arrow svg{
  width:22px;height:22px;stroke:currentColor;fill:none;
  stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;
}

/* ── btn-primary: slide-arrow hover (same as btn-secondary) ── */
.btn-primary.btn-morph{
  gap:0;
  transition:
    padding-right .42s cubic-bezier(.22,.61,.36,1),
    box-shadow .3s ease,
    transform .28s ease;
}
.btn-primary.btn-morph .btn-label{
  transition:transform .42s cubic-bezier(.22,.61,.36,1);
  display:inline-block;
}
.btn-primary.btn-morph .btn-arrow{
  /* Reset absolute positioning — inline slide instead */
  position:static;
  max-width:0;overflow:hidden;opacity:0;
  transform:translateX(-10px);
  transition:
    max-width .48s cubic-bezier(.34,1.15,.64,1),
    opacity .28s ease .08s,
    transform .48s cubic-bezier(.34,1.15,.64,1);
}
.btn-primary.btn-morph .btn-arrow svg{
  width:17px;height:17px;stroke:#fff;fill:none;
  stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;
}
.btn-primary.btn-morph:hover{
  padding-right:2rem;
  transform:translateY(-3px);
  box-shadow:0 18px 48px rgba(139,92,246,.5);
}
.btn-primary.btn-morph:hover .btn-label{transform:translateX(-3px);}
.btn-primary.btn-morph:hover .btn-arrow{
  max-width:28px;opacity:1;transform:translateX(4px);
}

/* Triggered state */
.btn-morph.morphing{
  width:52px!important;
  padding-left:0!important;padding-right:0!important;
  border-radius:50%!important;
  pointer-events:none;
}
.btn-morph.morphing .btn-label{opacity:0;transform:scale(.7);}
.btn-morph.morphing .btn-arrow{opacity:1;transform:scale(1) rotate(0deg);}

/* Success state */
.btn-morph.success{
  width:52px!important;
  padding-left:0!important;padding-right:0!important;
  border-radius:50%!important;
  pointer-events:none;
}
.btn-morph.success .btn-label{opacity:0;}
.btn-morph.success .btn-arrow{opacity:1;transform:scale(1) rotate(0deg);}

/* Transition for the container itself */
.btn-morph{
  transition:
    width .5s cubic-bezier(.4,0,.2,1),
    border-radius .5s cubic-bezier(.4,0,.2,1),
    padding .5s cubic-bezier(.4,0,.2,1),
    box-shadow .3s ease,
    transform .3s ease,
    background .3s ease;
}
.btn-secondary{
  padding:1rem 2.4rem;background:#fff;color:var(--black);
  border:1.5px solid var(--gray-200);border-radius:50px;
  font-size:1rem;font-weight:600;transition:all .28s;
}
.btn-secondary:hover{border-color:var(--black);transform:translateY(-3px);}

/* ── Hero card — wide floating dashboard ── */
.hero-visual{
  width:100%;max-width:900px;
  position:relative;z-index:1;
}
.hero-card{
  background:#fff;border-radius:28px;overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(139,92,246,.1),
    0 8px 24px rgba(0,0,0,.05),
    0 32px 80px rgba(139,92,246,.12),
    0 60px 120px rgba(0,0,0,.07);
  position:relative;
}
.hero-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:2;
  background:linear-gradient(90deg,var(--purple) 0%,var(--purple-dark) 50%,var(--purple-light) 100%);
}

/* Card header */
.hcard-header{
  padding:1.3rem 2rem;border-bottom:1px solid var(--gray-100);
  display:flex;justify-content:space-between;align-items:center;
}
.hcard-lbl{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-400);}
.hcard-live{
  display:flex;align-items:center;gap:.5rem;padding:.3rem .9rem;
  background:rgba(139,92,246,.07);border:1px solid rgba(139,92,246,.18);
  border-radius:50px;font-size:.7rem;font-weight:700;color:var(--purple);
}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--purple);
  animation:livePulse 2s ease infinite;}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(139,92,246,.5)}70%{box-shadow:0 0 0 6px rgba(139,92,246,0)}100%{box-shadow:0 0 0 0 rgba(139,92,246,0)}}

/* 4-col KPI row */
.hcard-kpis{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-bottom:1px solid var(--gray-100);
}
.hkpi{padding:1.6rem 2rem;border-right:1px solid var(--gray-100);}
.hkpi:last-child{border-right:none;}
.hkpi-lbl{font-size:.68rem;font-weight:600;color:var(--gray-400);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem;display:block;}
.hkpi-val{font-size:1.8rem;font-weight:900;letter-spacing:-.04em;color:var(--black);display:block;line-height:1;}
.hkpi-meta{font-size:.75rem;font-weight:700;color:var(--green);display:block;margin-top:.3rem;}
.hkpi-meta.neutral{color:var(--gray-400);}

/* Sparkline full-width */
.hcard-spark{
  height:110px;margin:0;
  background:linear-gradient(180deg,rgba(139,92,246,.03) 0%,rgba(139,92,246,.01) 100%);
  overflow:hidden;position:relative;border-bottom:1px solid var(--gray-100);
}
.hcard-spark svg{position:absolute;inset:0;width:100%;height:100%;}

/* AI insight bar */
.hcard-ai{
  padding:1rem 2rem;
  background:rgba(139,92,246,.04);
  display:flex;align-items:center;gap:.8rem;
}
.hcard-ai-dot{
  width:28px;height:28px;border-radius:8px;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;flex-shrink:0;
}
.hcard-ai p{font-size:.82rem;font-weight:500;color:var(--gray-600);line-height:1.45;margin:0;}
.hcard-ai strong{color:var(--purple);font-weight:700;}

/* Floating chips */
.float-tag{
  position:absolute;background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px);
  border:1px solid rgba(139,92,246,.14);
  border-radius:50px;padding:.55rem 1.1rem;
  font-size:.78rem;font-weight:700;color:var(--black);
  box-shadow:0 12px 32px rgba(139,92,246,.12),0 2px 8px rgba(0,0,0,.06);
  white-space:nowrap;display:flex;align-items:center;gap:.5rem;
}
.ft-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:livePulse 2s ease infinite;}
.ft-1{top:-18px;right:40px;animation:floatA 4.5s ease-in-out infinite;}
.ft-2{bottom:-18px;left:40px;animation:floatB 5.5s ease-in-out infinite 1.2s;}

@media(max-width:1100px){
  .hero-headline{font-size:clamp(3rem,10vw,6rem);}
}
@media(max-width:768px){
  .hcard-kpis{grid-template-columns:1fr 1fr;}
  .hkpi{border-bottom:1px solid var(--gray-100);}
  .hkpi:nth-child(2){border-right:none;}
  .hkpi:nth-child(3){border-bottom:none;}
  .hkpi:nth-child(4){border-right:none;border-bottom:none;}
  .hero-headline{font-size:clamp(2.8rem,12vw,5rem);}
}

/* ── PAGE LOADER ── */
.page-loader{
  position:fixed;inset:0;z-index:9999;background:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;
  transition:opacity .6s cubic-bezier(.4,0,.2,1),visibility .6s;
}
.page-loader.done{opacity:0;visibility:hidden;pointer-events:none;}
.loader-logo{
  font-size:2.4rem;font-weight:900;letter-spacing:-.04em;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.loader-bar{width:160px;height:2px;background:var(--gray-200);border-radius:2px;overflow:hidden;}
.loader-progress{height:100%;width:0%;background:linear-gradient(90deg,var(--purple),var(--purple-dark));border-radius:2px;transition:width .05s linear;}

/* ── ENTRANCE ANIMATIONS ── */
.a-up{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.22,.61,.36,1),transform .75s cubic-bezier(.22,.61,.36,1);}
.a-up.in{opacity:1;transform:none;}
.a-right{opacity:0;transform:translateX(52px) scale(.98);transition:opacity .85s cubic-bezier(.22,.61,.36,1),transform .85s cubic-bezier(.22,.61,.36,1);}
.a-right.in{opacity:1;transform:none;}
.a-fade{opacity:0;transition:opacity .6s ease;}
.a-fade.in{opacity:1;}

/* ── HERO CARD — modern 2026 ── */
.hero-visual{position:relative;perspective:1400px;}
.hero-card{
  background:#fff;
  border-radius:28px;
  overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(139,92,246,.1),
    0 4px 12px rgba(0,0,0,.04),
    0 24px 64px rgba(139,92,246,.1),
    0 48px 96px rgba(0,0,0,.06);
  position:relative;
}
.hero-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:2;
  background:linear-gradient(90deg,var(--purple) 0%,var(--purple-dark) 50%,var(--purple-light) 100%);
}
/* Card header */
.hcard-header{
  padding:1.3rem 1.8rem;border-bottom:1px solid var(--gray-100);
  display:flex;justify-content:space-between;align-items:center;
}
.hcard-lbl{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-400);}
.hcard-live{
  display:flex;align-items:center;gap:.5rem;padding:.3rem .9rem;
  background:rgba(139,92,246,.07);border:1px solid rgba(139,92,246,.18);
  border-radius:50px;font-size:.7rem;font-weight:700;color:var(--purple);
}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--purple);
  box-shadow:0 0 0 0 rgba(139,92,246,.5);
  animation:livePulse 2s ease infinite;}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(139,92,246,.5)}70%{box-shadow:0 0 0 6px rgba(139,92,246,0)}100%{box-shadow:0 0 0 0 rgba(139,92,246,0)}}

/* Big net worth row */
.hcard-nw{padding:1.8rem 1.8rem 1.4rem;border-bottom:1px solid var(--gray-100);}
.hcard-nw-lbl{font-size:.68rem;font-weight:600;color:var(--gray-400);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem;}
.hcard-nw-row{display:flex;align-items:baseline;gap:.8rem;}
.hcard-nw-val{font-size:2.6rem;font-weight:900;letter-spacing:-.05em;color:var(--black);line-height:1;}
.hcard-nw-badge{
  font-size:.78rem;font-weight:700;color:var(--green);
  background:rgba(34,197,94,.09);border-radius:50px;
  padding:.22rem .75rem;
}

/* Sparkline */
.hcard-spark{
  height:52px;margin:.6rem 1.8rem 1.4rem;border-radius:12px;
  background:rgba(139,92,246,.03);overflow:hidden;position:relative;
}
.hcard-spark svg{position:absolute;inset:0;width:100%;height:100%;}

/* 3-col stats */
.hcard-stats3{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--gray-100);}
.hs3{padding:1rem 1.4rem;border-right:1px solid var(--gray-100);}
.hs3:last-child{border-right:none;}
.hs3-val{font-size:1.18rem;font-weight:900;letter-spacing:-.03em;color:var(--black);display:block;}
.hs3-lbl{font-size:.66rem;font-weight:500;color:var(--gray-400);display:block;margin-top:.18rem;}

/* AI insight bottom bar */
.hcard-ai{
  padding:.95rem 1.8rem;
  background:rgba(139,92,246,.04);border-top:1px solid rgba(139,92,246,.09);
  display:flex;align-items:center;gap:.8rem;
}
.hcard-ai-dot{
  width:28px;height:28px;border-radius:8px;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;flex-shrink:0;
}
.hcard-ai p{font-size:.8rem;font-weight:500;color:var(--gray-600);line-height:1.45;margin:0;}
.hcard-ai strong{color:var(--purple);font-weight:700;}

/* Floating chips */
.float-tag{
  position:absolute;background:rgba(255,255,255,.96);
  backdrop-filter:blur(20px);
  border:1px solid rgba(139,92,246,.14);
  border-radius:50px;padding:.55rem 1.1rem;
  font-size:.78rem;font-weight:700;color:var(--black);
  box-shadow:0 12px 32px rgba(139,92,246,.12),0 2px 8px rgba(0,0,0,.06);
  white-space:nowrap;display:flex;align-items:center;gap:.5rem;
}
.ft-dot{width:6px;height:6px;border-radius:50%;background:var(--green);
  animation:livePulse 2s ease infinite;}
.ft-1{top:-16px;right:16px;animation:floatA 4.5s ease-in-out infinite;}
.ft-2{bottom:12px;left:-18px;animation:floatB 5.5s ease-in-out infinite 1.2s;}

/* ================================================
   STATS BAR
================================================ */
.stats-bar{border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);}
.sbar-item{padding:3rem 0 3rem 4rem;border-right:1px solid var(--gray-200);position:relative;}
.sbar-item:last-child{border-right:none;}
.sbar-idx{position:absolute;top:3rem;right:3rem;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#ddd;}
/* Numbers use purple accent */
.sbar-num{
  font-size:clamp(2.6rem,5vw,4.8rem);font-weight:900;letter-spacing:-.05em;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;display:block;margin-bottom:.5rem;
}
.sbar-cat{font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#bbb;margin-bottom:.3rem;display:block;}
.sbar-desc{font-size:.97rem;color:var(--gray-600);font-weight:500;}

/* ================================================
   MARQUEE
================================================ */
.marquee-wrap{
  padding:1.7rem 0;overflow:hidden;
  border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);
  background:var(--gray-100);
}
.marquee-track{display:flex;gap:4.5rem;width:max-content;animation:marquee 30s linear infinite;}
.mitem{display:flex;align-items:center;gap:.6rem;font-size:.85rem;font-weight:700;color:#ccc;white-space:nowrap;flex-shrink:0;}
.mitem-dot{width:5px;height:5px;background:rgba(139,92,246,.4);border-radius:50%;}

/* ================================================
   SECTION HELPERS
================================================ */
.label{font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--purple);}
.section-title-lg{font-size:clamp(2rem,4.2vw,4rem);font-weight:900;line-height:1.05;letter-spacing:-.035em;}
.section-title-lg em{font-style:normal;color:var(--purple);}

/* ================================================
   VISION
================================================ */
.vision{padding:9rem 0;}
.vision-top{display:grid;grid-template-columns:1fr 2.2fr;gap:5rem;align-items:start;margin-bottom:5.5rem;}
.vision-copy h2{margin-bottom:1.4rem;}
.vision-copy p{font-size:1.1rem;color:var(--gray-600);line-height:1.8;max-width:55ch;}
.vcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.vcard{
  border:1.5px solid var(--gray-200);border-radius:20px;padding:2.2rem;
  transition:all .35s;position:relative;overflow:hidden;
}
.vcard::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--purple),var(--purple-dark));
  transform:scaleX(0);transform-origin:left;transition:transform .35s;
}
.vcard:hover{border-color:var(--purple);box-shadow:0 20px 50px rgba(139,92,246,.1);}
.vcard:hover::after{transform:scaleX(1);}
.vcard-n{font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#ccc;margin-bottom:1.6rem;}
.vcard h4{font-size:1.26rem;font-weight:800;margin-bottom:.75rem;}
.vcard p{font-size:.93rem;color:var(--gray-600);line-height:1.75;}

/* ================================================
   SERVICES
================================================ */
.services{padding:9rem 0;background:var(--gray-100);}
.services-hd{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:end;margin-bottom:4.5rem;}
.services-hd h2{margin-top:.8rem;}
.services-hd p{font-size:1.05rem;color:var(--gray-600);line-height:1.8;max-width:50ch;}
.scards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.scard{
  background:#fff;border:1.5px solid var(--gray-200);border-radius:22px;
  padding:2.6rem;transition:all .38s;
}
.scard:hover{transform:translateY(-8px);box-shadow:0 28px 64px rgba(139,92,246,.1);border-color:var(--purple);}
.scard-tag{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--purple-light);margin-bottom:1.8rem;display:block;}
.scard-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.8rem;transition:transform .35s;
}
.scard:hover .scard-icon{transform:rotate(-6deg) scale(1.08);}
.scard-icon svg{width:26px;height:26px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.scard h3{font-size:1.5rem;font-weight:800;margin-bottom:.9rem;letter-spacing:-.02em;}
.scard>p{font-size:.93rem;color:var(--gray-600);line-height:1.75;margin-bottom:1.6rem;}
.scard-list li{font-size:.88rem;color:var(--gray-600);font-weight:500;padding:.26rem 0 .26rem 1.1rem;position:relative;}
.scard-list li::before{content:'→';position:absolute;left:0;color:var(--purple);font-size:.8rem;}

/* ================================================
   AI DEMO CHAT
================================================ */
.ai-demo{padding:9rem 0;}
.ai-demo-hd{margin-bottom:4rem;}
.ai-demo-hd h2{margin-top:.8rem;}
.ai-demo-hd p{font-size:1.05rem;color:var(--gray-600);max-width:50ch;margin-top:.9rem;line-height:1.8;}
.chat-box{border:1.5px solid var(--gray-200);border-radius:22px;overflow:hidden;max-width:860px;}
.chat-hdr{padding:1.3rem 2rem;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:.9rem;}
.chat-avatar{
  width:36px;height:36px;border-radius:9px;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;
}
.chat-hdr-name{font-size:.92rem;font-weight:700;}
.chat-hdr-status{font-size:.74rem;color:var(--gray-400);display:flex;align-items:center;gap:.35rem;margin-top:.1rem;}
.online-dot{width:6px;height:6px;background:var(--green);border-radius:50%;display:inline-block;}
.chat-msgs{padding:1.8rem 2rem;min-height:260px;max-height:360px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--gray-200) transparent;}
.chat-msgs::-webkit-scrollbar{width:3px;}
.chat-msgs::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:2px;}
.ai-bubble-init{background:var(--gray-100);border-radius:4px 16px 16px 16px;padding:1rem 1.3rem;max-width:80%;}
.ai-bubble-init p{margin:0;font-size:.92rem;color:var(--black);line-height:1.7;}
.chat-pills{padding:.9rem 2rem;border-top:1px solid var(--gray-100);display:flex;flex-wrap:wrap;gap:.6rem;}
.qpill{
  padding:.5rem 1rem;border:1.5px solid var(--gray-200);border-radius:50px;
  font-size:.82rem;font-weight:600;color:var(--gray-600);background:#fff;
  cursor:pointer;transition:all .2s;
}
.qpill:hover{border-color:var(--purple);color:var(--purple);}
.chat-input-row{padding:.9rem 2rem 1.3rem;display:flex;gap:.7rem;}
.chat-text-input{
  flex:1;padding:.7rem 1.2rem;border:1.5px solid var(--gray-200);
  border-radius:50px;font-size:.9rem;font-family:inherit;outline:none;
  color:var(--black);transition:border-color .2s;
}
.chat-text-input:focus{border-color:var(--purple);}
.chat-send{
  width:48px;
  height:48px;
  padding:0;
  flex:0 0 48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  color:#fff;
  border-radius:50%;
  transition:all .22s ease;
}

.chat-send svg{
  width:22px;
  height:22px;
  stroke:currentColor;
  fill:none;
  stroke-width:2.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.chat-send:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(139,92,246,.35);
}

/* ================================================
   ALGORITHMS SECTION — Elara algo on white bg
   (layout from inferentia step-list, visual from elarafin chart)
================================================ */
.algo-section{
  padding:9rem 0;
  background:var(--white);
  position:relative;overflow:hidden;
}
/* Subtle grid pattern (adapted from elarafin, lighter for white bg) */
.algo-section::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='g' width='60' height='60' patternUnits='userSpaceOnUse'%3E%3Cpath d='M 60 0 L 0 0 0 60' fill='none' stroke='rgba(139,92,246,0.06)' stroke-width='1'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='60' height='60' fill='url(%23g)'/%3E%3C/svg%3E");
  mask-image:radial-gradient(ellipse at center, black 20%, transparent 75%);
  pointer-events:none;
}
.algo-inner{
  max-width:1320px;margin:0 auto;padding:0 5%;
  display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:center;
  position:relative;z-index:1;
}
.algo-left h2{margin-bottom:1.5rem;}
.algo-left>p{font-size:1.08rem;color:var(--gray-600);line-height:1.8;margin-bottom:3.5rem;max-width:50ch;}

/* Algo cards — adapted to white bg */
.algo-list{display:flex;flex-direction:column;gap:1rem;}
.algo-card{
  background:#fff;
  border:1.5px solid var(--gray-200);
  border-radius:16px;padding:1.6rem 1.8rem;
  display:flex;align-items:flex-start;gap:1.2rem;
  transition:all .4s;position:relative;overflow:hidden;cursor:default;
}
.algo-card::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(139,92,246,.06),transparent);
  transition:left .55s;
}
.algo-card:hover::before{left:100%;}
.algo-card:hover{
  border-color:var(--purple);
  transform:translateX(10px);
  box-shadow:0 12px 36px rgba(139,92,246,.1);
}
.algo-num-box{
  width:44px;height:44px;flex-shrink:0;
  background:rgba(139,92,246,.08);
  border:1.5px solid rgba(139,92,246,.2);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s;
}
.algo-card:hover .algo-num-box{background:rgba(139,92,246,.15);border-color:var(--purple);}
.algo-num-box svg{width:22px;height:22px;stroke:var(--purple);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.algo-body h4{font-size:1.1rem;font-weight:800;margin-bottom:.35rem;letter-spacing:-.02em;}
.algo-body p{font-size:.88rem;color:var(--gray-600);margin:0;line-height:1.65;}

/* Chart visual — white bg adaptation */
.chart-wrap{
  background:linear-gradient(135deg,rgba(139,92,246,.04) 0%,#fff 100%);
  border:1.5px solid rgba(139,92,246,.15);
  border-radius:28px;padding:3rem;
  position:relative;overflow:hidden;
  box-shadow:0 24px 64px rgba(139,92,246,.07);
}
.chart-wrap::before{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(circle,rgba(139,92,246,.07) 0%,transparent 60%);
  animation:spin 28s linear infinite;pointer-events:none;
}
.chart-visual{
  width:100%;height:380px;
  background:linear-gradient(180deg,rgba(139,92,246,.05) 0%,rgba(99,102,241,.02) 100%);
  border-radius:18px;position:relative;overflow:hidden;
}
.chart-grid-overlay{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(139,92,246,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(139,92,246,.08) 1px,transparent 1px);
  background-size:40px 40px;
}
.chart-svg-wrap{position:absolute;inset:0;padding:2rem;}
.chart-svg-wrap svg{width:100%;height:100%;}

/* SVG path animation */
.chart-path-line{
  fill:none;stroke:var(--purple);stroke-width:2.5;
  stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1200;stroke-dashoffset:1200;
}
.chart-area-fill{fill:url(#aG);opacity:0;}
.chart-wrap.animated .chart-path-line{animation:drawLine 2.2s cubic-bezier(.4,0,.2,1) forwards;}
.chart-wrap.animated .chart-area-fill{animation:fadeArea 1.6s ease forwards;animation-delay:1.2s;}

/* Chart axis labels */
.chart-labels{
  position:absolute;inset:0;padding:1.5rem 2rem;
  display:flex;justify-content:space-between;pointer-events:none;
}
.chart-y-labels{display:flex;flex-direction:column;justify-content:space-between;font-size:.75rem;font-weight:600;color:rgba(139,92,246,.5);}
.chart-x-label{align-self:flex-end;font-size:.75rem;font-weight:600;color:rgba(139,92,246,.5);}

/* Chart bottom metrics */
.chart-metrics{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;
}
.cmetric{text-align:center;}
.cmetric-val{font-size:1.5rem;font-weight:900;letter-spacing:-.03em;background:linear-gradient(135deg,var(--purple),var(--purple-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.cmetric-lbl{font-size:.72rem;font-weight:600;color:var(--gray-400);letter-spacing:.06em;text-transform:uppercase;margin-top:.2rem;}

/* ================================================
   CAPABILITY CARDS SECTION
   (6-up grid from elarafin, adapted to white bg)
================================================ */
.capabilities{padding:9rem 0;background:var(--gray-100);}
.capabilities-hd{margin-bottom:4.5rem;}
.capabilities-hd h2{margin-top:.8rem;}
.capabilities-hd p{font-size:1.05rem;color:var(--gray-600);max-width:50ch;margin-top:.9rem;line-height:1.8;}
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.cap-card{
  background:#fff;border:1.5px solid var(--gray-200);border-radius:20px;
  padding:2.4rem;transition:all .38s;position:relative;overflow:hidden;
}
.cap-card::before{
  content:'';position:absolute;inset:0;border-radius:20px;
  background:linear-gradient(135deg,rgba(139,92,246,.04),transparent);
  opacity:0;transition:opacity .38s;
}
.cap-card:hover{transform:translateY(-8px);border-color:var(--purple);box-shadow:0 24px 60px rgba(139,92,246,.1);}
.cap-card:hover::before{opacity:1;}
.cap-icon{
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(99,102,241,.06));
  border:1.5px solid rgba(139,92,246,.2);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.8rem;
}
.cap-icon svg{width:26px;height:26px;stroke:var(--purple);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.cap-card h3{font-size:1.2rem;font-weight:800;margin-bottom:.75rem;letter-spacing:-.02em;}
.cap-card p{font-size:.92rem;color:var(--gray-600);line-height:1.75;}

/* ================================================
   METHOD (Inferentia step list)
================================================ */
.method{padding:9rem 0;}
.method-hd{display:grid;grid-template-columns:1fr 2fr;gap:5rem;margin-bottom:5rem;align-items:end;}
.method-hd h2{margin-top:.8rem;}
.method-hd p{font-size:1.05rem;color:var(--gray-600);line-height:1.8;max-width:50ch;}
.steps{display:flex;flex-direction:column;}
.step{
  display:grid;grid-template-columns:70px 1fr 32px;gap:2rem;
  align-items:start;padding:2.6rem 1.6rem 2.6rem 0;
  border-bottom:1px solid var(--gray-200);
  position:relative;cursor:default;
  /* Smooth all transitions together */
  transition:
    padding-left .55s cubic-bezier(.22,.61,.36,1),
    background .45s ease;
  border-radius:0;
  overflow:hidden;
}
.step:first-child{border-top:1px solid var(--gray-200);}

/* Left accent bar — slides in from left */
.step::before{
  content:'';
  position:absolute;top:0;left:0;bottom:0;
  width:3px;
  background:linear-gradient(180deg,var(--purple),var(--purple-dark));
  transform:scaleY(0);
  transform-origin:bottom;
  transition:transform .5s cubic-bezier(.22,.61,.36,1);
  border-radius:0 2px 2px 0;
}

/* Subtle bg wash */
.step::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(139,92,246,.03) 0%,transparent 60%);
  opacity:0;
  transition:opacity .45s ease;
  pointer-events:none;
}

.step:hover{
  padding-left:1.4rem;
  background:rgba(139,92,246,.018);
}
.step:hover::before{transform:scaleY(1);}
.step:hover::after{opacity:1;}

/* Step number — fades to purple on hover */
.step-n{
  font-size:.67rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:#ccc;padding-top:.2rem;
  transition:color .4s ease;
}
.step:hover .step-n{color:var(--purple);}

.step-body h4{
  font-size:1.35rem;font-weight:800;margin-bottom:.55rem;letter-spacing:-.02em;
  transition:color .35s ease;
}
.step:hover .step-body h4{color:var(--purple);}
.step-body p{font-size:.95rem;color:var(--gray-600);line-height:1.75;}

/* Arrow — spring bounce to the right */
.step-arrow{
  font-size:1.2rem;color:#ddd;padding-top:.1rem;
  transition:
    color .35s ease,
    transform .55s cubic-bezier(.34,1.56,.64,1); /* spring overshoot */
}
.step:hover .step-arrow{
  color:var(--purple);
  transform:translateX(8px);
}

/* ================================================
   SECURITY (dark section)
================================================ */
.security{padding:9rem 0;background:var(--black);color:#fff;}
.security-hd{display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;margin-bottom:5rem;align-items:end;}
.security-hd h2{color:#fff;margin-top:.8rem;}
.security-hd p{font-size:1.05rem;color:#666;line-height:1.8;max-width:50ch;}
.security-hd .label{color:var(--purple-light);}
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.tcard{
  border:1px solid rgba(255,255,255,.1);border-radius:20px;
  padding:2.6rem;transition:all .38s;position:relative;overflow:hidden;
}
.tcard::before{
  content:'';position:absolute;inset:0;border-radius:20px;
  background:linear-gradient(135deg,rgba(139,92,246,.08),transparent);
  opacity:0;transition:opacity .38s;
}
.tcard:hover{border-color:rgba(139,92,246,.4);transform:translateY(-6px);}
.tcard:hover::before{opacity:1;}
.tcard-ico{
  width:50px;height:50px;border-radius:13px;
  border:1px solid rgba(139,92,246,.3);
  background:rgba(139,92,246,.1);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.8rem;
}
.tcard-ico svg{width:24px;height:24px;stroke:var(--purple-light);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.tcard h4{font-size:1.22rem;font-weight:800;margin-bottom:.75rem;color:#fff;}
.tcard p{font-size:.92rem;color:#777;line-height:1.8;}
.trust-row{
  display:flex;flex-wrap:wrap;gap:1.1rem;
  margin-top:4rem;padding-top:4rem;border-top:1px solid rgba(255,255,255,.07);
}
.tbadge{
  display:flex;align-items:center;gap:.55rem;
  padding:.45rem 1.1rem;border:1px solid rgba(139,92,246,.2);
  background:rgba(139,92,246,.06);
  border-radius:50px;font-size:.77rem;font-weight:700;color:var(--purple-light);
}
.tbadge-dot{width:5px;height:5px;background:var(--purple);border-radius:50%;}

/* ================================================
   TESTIMONIALS — CAROUSEL
================================================ */
.testimonials{padding:9rem 0;overflow:hidden;}
.testi-top{
  display:grid;grid-template-columns:1fr 1.6fr;
  gap:5rem;margin-bottom:4rem;align-items:end;
}
.testi-top h2{margin-top:.8rem;}
.testi-top p{font-size:1.05rem;color:var(--gray-600);line-height:1.8;max-width:50ch;}

/* Controls row */
.testi-controls{
  display:flex;align-items:center;gap:1.2rem;
  margin-bottom:3rem;
}
.testi-count{
  font-size:.82rem;font-weight:700;color:var(--gray-400);
  margin-right:auto;letter-spacing:.04em;
}
.testi-progress{
  flex:1;max-width:200px;height:2px;
  background:var(--gray-200);border-radius:2px;overflow:hidden;
}
.testi-progress-fill{
  height:100%;
  background:linear-gradient(90deg,var(--purple),var(--purple-dark));
  border-radius:2px;
  transition:width .45s cubic-bezier(.4,0,.2,1);
}
.carr-btn{
  width:44px;height:44px;border-radius:50%;
  border:1.5px solid var(--gray-200);
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-400);
  transition:all .25s;flex-shrink:0;cursor:pointer;
}
.carr-btn:hover{
  border-color:var(--purple);color:var(--purple);
  box-shadow:0 8px 20px rgba(139,92,246,.15);
  transform:scale(1.08);
}
.carr-btn:active{transform:scale(.96);}
.carr-btn.disabled{opacity:.3;pointer-events:none;}
.carr-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;}

/* Carousel viewport */
.testi-viewport{
  overflow:hidden;
  position:relative;
  cursor:grab;
  user-select:none;
}
.testi-viewport:active{cursor:grabbing;}
.testi-track{
  display:flex;
  gap:1.6rem;
  transition:transform .55s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}

/* Quote cards */
.tquote{
  flex:0 0 calc(50% - .8rem);
  background:#fff;
  border:1.5px solid var(--gray-200);
  border-radius:24px;
  padding:2.8rem;
  transition:border-color .3s,box-shadow .3s,transform .3s;
  position:relative;overflow:hidden;
}
.tquote::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--purple),var(--purple-dark));
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s;
}
.tquote:hover{border-color:rgba(139,92,246,.3);box-shadow:0 20px 50px rgba(139,92,246,.09);}
.tquote:hover::before{transform:scaleX(1);}

.tq-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.6rem;}
.tq-stars{font-size:.9rem;color:var(--purple);letter-spacing:.18rem;}
.tq-tag{
  font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--purple);background:rgba(139,92,246,.07);
  border:1px solid rgba(139,92,246,.15);border-radius:50px;
  padding:.28rem .8rem;
}
.tq-text{
  font-size:1.08rem;color:var(--black);line-height:1.8;
  font-weight:500;font-style:italic;margin-bottom:2rem;
}
.tq-author{display:flex;align-items:center;gap:.9rem;}
.tq-av{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(99,102,241,.1));
  border:1.5px solid rgba(139,92,246,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:.76rem;font-weight:800;color:var(--purple);flex-shrink:0;
}
.tq-name{font-size:.92rem;font-weight:700;}
.tq-role{font-size:.78rem;color:var(--gray-400);}

/* Dots */
.testi-dots{display:flex;gap:.5rem;justify-content:center;margin-top:2.4rem;}
.tdot{
  width:6px;height:6px;border-radius:50%;
  background:var(--gray-200);
  transition:all .3s;cursor:pointer;
}
.tdot.active{width:24px;border-radius:4px;background:var(--purple);}

@media(max-width:768px){
  .tquote{flex:0 0 calc(100% - 0px);}
  .testi-top{grid-template-columns:1fr;}
  .testi-progress{max-width:120px;}
}

/* ================================================
   PRICING
================================================ */
.pricing{padding:9rem 0;background:var(--gray-100);}
.pricing-hd{margin-bottom:4.5rem;}
.pricing-hd h2{margin-top:.8rem;}
.pricing-hd p{font-size:1.05rem;color:var(--gray-600);max-width:50ch;margin-top:.9rem;line-height:1.8;}
.pcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;align-items:start;}
.pcard{
  background:#fff;border:1.5px solid var(--gray-200);border-radius:22px;
  padding:2.8rem;transition:all .38s;position:relative;
}
.pcard:hover{border-color:var(--purple);box-shadow:0 24px 60px rgba(139,92,246,.1);}
.pcard.featured{
  background:linear-gradient(135deg,var(--purple) 0%,var(--purple-dark) 100%);
  border-color:var(--purple);
  box-shadow:0 24px 60px rgba(139,92,246,.35);
}
.pbadge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:#fff;color:var(--purple);
  font-size:.64rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  padding:.38rem 1.1rem;border-radius:50px;white-space:nowrap;
  box-shadow:0 4px 16px rgba(139,92,246,.2);
}
.pcard-nm{font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-400);margin-bottom:.9rem;}
.pcard.featured .pcard-nm{color:rgba(255,255,255,.55);}
.pcard-price{font-size:3.2rem;font-weight:900;letter-spacing:-.04em;color:var(--black);line-height:1;margin-bottom:.22rem;}
.pcard.featured .pcard-price{color:#fff;}
.pcard-per{font-size:.93rem;font-weight:500;color:var(--gray-400);margin-bottom:1.4rem;}
.pcard.featured .pcard-per{color:rgba(255,255,255,.45);}
.pcard-desc{font-size:.92rem;color:var(--gray-600);line-height:1.7;margin-bottom:1.8rem;padding-bottom:1.8rem;border-bottom:1px solid var(--gray-200);}
.pcard.featured .pcard-desc{color:rgba(255,255,255,.6);border-color:rgba(255,255,255,.15);}
.pcard-feats{display:flex;flex-direction:column;gap:.72rem;margin-bottom:2.2rem;}
.pcard-feats li{display:flex;align-items:flex-start;gap:.72rem;font-size:.9rem;color:var(--gray-600);line-height:1.55;}
.pcard.featured .pcard-feats li{color:rgba(255,255,255,.75);}
.pcard-feats li::before{content:'✓';font-weight:900;color:var(--purple);flex-shrink:0;}
.pcard.featured .pcard-feats li::before{color:#fff;}
.pcard-btn{
  width:100%;padding:.95rem;border-radius:50px;font-size:.92rem;font-weight:700;
  border:1.5px solid var(--purple);color:var(--purple);transition:all .25s;
}
.pcard-btn:hover{background:var(--purple);color:#fff;}
.pcard.featured .pcard-btn{background:#fff;color:var(--purple);border-color:#fff;}
.pcard.featured .pcard-btn:hover{background:rgba(255,255,255,.9);}

/* ================================================
   CTA FINAL — animated
================================================ */
.cta-final{
  padding:10rem 0;
  background:linear-gradient(140deg,#6d28d9 0%,#7c3aed 40%,#6366f1 100%);
  position:relative;overflow:hidden;
}
/* Typewriter cursor */
.tw-cursor{
  display:inline-block;
  width:3px;
  background:rgba(255,255,255,.7);
  margin-left:3px;
  border-radius:2px;
  vertical-align:baseline;
  animation:twBlink .75s step-end infinite;
  /* height matches the h2 cap height */
  font-size:inherit;
  line-height:inherit;
}
@keyframes twBlink{0%,100%{opacity:1}50%{opacity:0}}

/* Animated mesh blobs */
.cta-blob{
  position:absolute;border-radius:50%;filter:blur(80px);opacity:.35;
  animation:blobFloat 12s ease-in-out infinite;pointer-events:none;
}
.cta-blob-1{width:600px;height:600px;background:#a78bfa;top:-200px;left:-150px;animation-delay:0s;}
.cta-blob-2{width:500px;height:500px;background:#818cf8;bottom:-180px;right:-100px;animation-delay:-5s;}
.cta-blob-3{width:300px;height:300px;background:#c4b5fd;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-9s;}
@keyframes blobFloat{
  0%,100%{transform:scale(1) translate(0,0);}
  33%{transform:scale(1.15) translate(30px,-20px);}
  66%{transform:scale(.9) translate(-20px,30px);}
}

/* Noise texture overlay */
.cta-final::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  background-size:200px;opacity:.5;pointer-events:none;
}

.cta-inner{
  max-width:1060px;margin:0 auto;padding:0 5%;
  text-align:center;position:relative;z-index:1;
}
.cta-label{
  font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.45);margin-bottom:1.4rem;display:block;
}

/* Morphing headline */
.cta-headline{
  font-size:clamp(3rem,6vw,5.5rem);font-weight:900;line-height:1.0;
  letter-spacing:-.04em;color:#fff;margin-bottom:2rem;
}

/* CTA typewriter h2 — matches image 2 style */
.cta-inner h2{
  font-size:clamp(3.5rem,7vw,6.5rem);
  font-weight:900;
  line-height:1.0;
  letter-spacing:-.045em;
  color:#fff;
  margin-bottom:1.8rem;
  min-height:2.2em;
}
/* cursor height = cap-height of h2 */
.tw-cursor{
  display:inline-block;
  width:4px;height:.75em;
  background:#fff;
  margin-left:4px;
  border-radius:2px;
  vertical-align:middle;
  animation:twBlink .75s step-end infinite;
  position:relative;top:-.05em;
}
@keyframes twBlink{0%,100%{opacity:1}50%{opacity:0}}
.cta-static{display:block;}
.cta-word-wrap{
  display:inline-block;
  position:relative;overflow:hidden;
  /* matches tallest word height so layout doesn't jump */
  height:1.12em;vertical-align:bottom;
  min-width:4ch;
}
.cta-word{
  display:block;position:absolute;left:50%;transform:translateX(-50%);
  white-space:nowrap;
  background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,.7) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  opacity:0;
  transition:none;
}
.cta-word.active{
  animation:wordIn .55s cubic-bezier(.22,.61,.36,1) forwards;
}
.cta-word.leaving{
  animation:wordOut .4s cubic-bezier(.4,0,1,1) forwards;
}
@keyframes wordIn{
  from{opacity:0;transform:translateX(-50%) translateY(60%) rotateX(-30deg);}
  to  {opacity:1;transform:translateX(-50%) translateY(0)  rotateX(0);}
}
@keyframes wordOut{
  from{opacity:1;transform:translateX(-50%) translateY(0)   rotateX(0);}
  to  {opacity:0;transform:translateX(-50%) translateY(-60%) rotateX(30deg);}
}

/* Cursor blink on the animated word */
.cta-cursor{
  display:inline-block;width:3px;height:.85em;
  background:rgba(255,255,255,.6);border-radius:2px;
  margin-left:4px;vertical-align:middle;
  animation:cursorBlink 1.1s step-end infinite;
}
@keyframes cursorBlink{0%,100%{opacity:1}50%{opacity:0}}

.cta-inner>p{font-size:1.12rem;color:rgba(255,255,255,.75);line-height:1.85;margin-bottom:3.5rem;}
.cta-form{display:flex;gap:.9rem;max-width:520px;margin:0 auto 1.5rem;}
.cta-input{
  flex:1;padding:.92rem 1.6rem;
  background:rgba(255,255,255,.14);
  border:1.5px solid rgba(255,255,255,.28);border-radius:50px;
  color:#fff;font-size:.95rem;font-family:inherit;outline:none;transition:all .3s;
}
.cta-input::placeholder{color:rgba(255,255,255,.4);}
.cta-input:focus{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.6);box-shadow:0 0 0 4px rgba(255,255,255,.08);}
.cta-submit{
  padding:.92rem 2rem;background:#fff;color:var(--purple);
  border-radius:50px;font-size:.92rem;font-weight:800;white-space:nowrap;transition:all .28s;
}
.cta-submit:hover{background:rgba(255,255,255,.92);transform:translateY(-2px);box-shadow:0 14px 36px rgba(0,0,0,.22);}
.cta-note{font-size:.8rem;color:rgba(255,255,255,.38);letter-spacing:.02em;}

/* ================================================
   FOOTER
================================================ */
footer{background:var(--black);border-top:none;padding:5rem 0 2.8rem;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:4rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,.08);}
.fb-name{
  font-size:1.55rem;font-weight:900;letter-spacing:-.04em;margin-bottom:1rem;
  background:linear-gradient(135deg,var(--purple),var(--purple-dark));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.fb-desc{font-size:.88rem;color:#555;line-height:1.8;max-width:32ch;margin-bottom:1.8rem;}
.fb-socials{display:flex;gap:.7rem;}
.fsoc{
  width:34px;height:34px;border:1px solid rgba(255,255,255,.12);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:.76rem;font-weight:700;color:#555;transition:all .22s;
}
.fsoc:hover{border-color:var(--purple);color:var(--purple);}
.fcol h5{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.4rem;color:#fff;}
.fcol ul li{margin-bottom:.7rem;}
.fcol a{font-size:.86rem;color:#555;transition:color .2s;}
.fcol a:hover{color:var(--purple);}
.footer-bottom{
  padding-top:2rem;display:flex;justify-content:space-between;align-items:center;
  font-size:.8rem;color:#333;
}
.fbottom-right{display:flex;align-items:center;gap:2rem;}
.fbottom-right a{color:#333;transition:color .2s;}
.fbottom-right a:hover{color:var(--purple);}
.btn-footer-lang{font-size:.8rem;font-weight:600;color:#333;transition:color .2s;}
.btn-footer-lang:hover{color:var(--purple);}

/* ================================================
   REVEAL ANIMATIONS
================================================ */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity .65s cubic-bezier(.22,.61,.36,1),transform .65s cubic-bezier(.22,.61,.36,1);
}
.reveal.vis{opacity:1;transform:none;}
.d1{transition-delay:.1s;}.d2{transition-delay:.2s;}.d3{transition-delay:.3s;}.d4{transition-delay:.4s;}

/* ================================================
   KEYFRAMES
================================================ */
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes drawLine{to{stroke-dashoffset:0}}
@keyframes fadeArea{to{opacity:1}}
@keyframes dot{0%,80%,100%{opacity:.2;transform:scale(.85)}40%{opacity:1;transform:scale(1.15)}}




/* ================================================
   TEAM SECTION — Elara editorial style
================================================ */
.team-section{
  padding:9rem 0;
  background:var(--gray-100);
  position:relative;
  overflow:hidden;
}

.team-section::before{
  display:none;
}

.team-layout{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:.86fr 1.64fr;
  gap:5.8rem;
  align-items:start;
}
.team-head{position:sticky;top:110px;}
.team-head h2{margin-top:.8rem;}
.team-head p{
  font-size:1.06rem;
  color:var(--gray-600);
  max-width:38ch;
  margin-top:1.1rem;
  line-height:1.85;
}
.team-head-note{
  margin-top:2.2rem;
  display:flex;
  gap:.7rem;
  align-items:center;
  color:var(--purple);
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.team-head-note::before{
  content:'';
  width:34px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--purple),var(--purple-dark));
}
.team-list{border-top:1px solid var(--gray-200);min-width:0;}
.team-card{
  position:relative;
  display:grid;
  grid-template-columns:132px minmax(0,1fr);
  gap:2.35rem;
  align-items:center;
  padding:2.65rem 0;
  border-bottom:1px solid var(--gray-200);
  background:transparent;
  overflow:hidden;
  transition:background .55s ease;
}
.team-card::before{
  content:'';
  position:absolute;left:0;top:16%;bottom:16%;width:3px;
  background:linear-gradient(180deg,var(--purple),var(--purple-dark));
  transform:scaleY(0);
  transform-origin:center;
  transition:transform .58s cubic-bezier(.22,.61,.36,1);
}
.team-card::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(139,92,246,.03),transparent 68%);
  opacity:0;
  transition:opacity .55s ease;
  pointer-events:none;
}
.team-card:hover{background:rgba(139,92,246,.01);}
.team-card:hover::before{transform:scaleY(1);}
.team-card:hover::after{opacity:1;}
.team-avatar{
  width:118px;height:118px;
  border-radius:50%;
  overflow:hidden;
  background:#f5f3ff;
  border:4px solid #fff;
  outline:1.5px solid rgba(139,92,246,.35);
  box-shadow:0 22px 52px rgba(139,92,246,.14),0 5px 14px rgba(10,10,10,.06);
  position:relative;z-index:1;
  justify-self:center;
  flex-shrink:0;
}
.team-avatar img{
  width:100%;height:100%;display:block;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform .7s cubic-bezier(.22,.61,.36,1),filter .7s ease;
}
.team-card:hover .team-avatar img{transform:scale(1.065);filter:saturate(1.03) contrast(1.02);}
.team-avatar,
.team-content{transition:transform .62s cubic-bezier(.22,.61,.36,1);}
.team-card:hover .team-avatar,
.team-card:hover .team-content{transform:translateX(10px);}
.team-card:nth-child(1) .team-avatar img{object-position:50% 39%;}
.team-card:nth-child(2) .team-avatar img{object-position:50% 43%;}
.team-card:nth-child(3) .team-avatar img{object-position:50% 36%;}
.team-card:nth-child(4) .team-avatar img{object-position:50% 35%;}
.team-content{position:relative;z-index:1;min-width:0;}
.team-mainline{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  gap:1.2rem;
  margin-bottom:.75rem;
  min-width:0;
}
.team-name{
  font-size:clamp(1.55rem,2.2vw,2.25rem);
  font-weight:900;
  letter-spacing:-.055em;
  line-height:1.02;
  color:var(--black);
}
.team-role{
  margin-top:.55rem;
  font-size:.68rem;
  line-height:1.45;
  font-weight:850;
  color:var(--purple);
  letter-spacing:.13em;
  text-transform:uppercase;
}
.team-index{display:none;}
.team-degrees{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.52rem;
  margin:1.05rem 0 1.05rem;
  min-width:0;
}
.team-degree{
  display:flex;
  align-items:flex-start;
  gap:.7rem;
  font-size:.93rem;
  font-weight:800;
  color:#303442;
  line-height:1.42;
  letter-spacing:-.018em;
  max-width:100%;
}
.team-degree::before{
  content:'';
  width:2px;
  height:1.1em;
  border-radius:2px;
  margin-top:.18em;
  background:linear-gradient(180deg,var(--purple),var(--purple-dark));
  box-shadow:none;
  flex-shrink:0;
}
.team-degree em{font-style:normal;color:var(--purple);font-weight:850;}
.team-card p{
  margin:0;
  max-width:62ch;
  font-size:1rem;
  color:var(--gray-600);
  line-height:1.82;
}
@media(max-width:1100px){
  .team-layout{grid-template-columns:1fr;gap:3rem;}
  .team-head{position:relative;top:auto;max-width:760px;}
  .team-head p{max-width:62ch;}
}
@media(max-width:700px){
  .team-section{padding:7rem 0;}
  .team-card{grid-template-columns:86px minmax(0,1fr);gap:1.2rem;padding:2rem 0;}
  .team-avatar{width:78px;height:78px;border-width:3px;}
  .team-mainline{display:block;margin-bottom:.5rem;}
  .team-index{display:none;}
  .team-name{font-size:1.45rem;}
  .team-role{font-size:.6rem;}
  .team-degrees{display:block;margin:.85rem 0 .85rem;}
  .team-degree{display:flex;margin:.38rem 0;font-size:.82rem;}
  .team-card p{font-size:.92rem;}
  .team-card:hover .team-avatar,.team-card:hover .team-content{transform:translateX(5px);}
}




/* ================================================
   ALGORITHMS SECTION — dark institutional style
   aligned with Security section
================================================ */
.algo-section{
  background:var(--black);
  color:#fff;
}
.algo-section::before{
  background-image:
    linear-gradient(rgba(139,92,246,.055) 1px,transparent 1px),
    linear-gradient(90deg,rgba(139,92,246,.055) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse at center, black 10%, transparent 72%);
  opacity:.9;
}
.algo-section::after{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse 52% 38% at 78% 18%,rgba(139,92,246,.16),transparent 62%),
    radial-gradient(ellipse 45% 32% at 18% 82%,rgba(99,102,241,.10),transparent 60%);
}
.algo-inner{position:relative;z-index:1;}
.algo-left .label{color:var(--purple-light);}
.algo-left h2{color:#fff;}
.algo-left>p{color:#777;}
.algo-card{
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:none;
}
.algo-card::before{
  background:linear-gradient(90deg,transparent,rgba(139,92,246,.10),transparent);
}
.algo-card:hover{
  border-color:rgba(139,92,246,.45);
  box-shadow:0 18px 54px rgba(139,92,246,.12);
  background:rgba(139,92,246,.04);
}
.algo-num-box{
  background:rgba(139,92,246,.10);
  border:1px solid rgba(139,92,246,.32);
}
.algo-card:hover .algo-num-box{
  background:rgba(139,92,246,.16);
  border-color:rgba(167,139,250,.55);
}
.algo-num-box svg{stroke:var(--purple-light);}
.algo-body h4{color:#fff;}
.algo-body p{color:#777;}
.chart-wrap{
  background:linear-gradient(135deg,rgba(139,92,246,.10) 0%,rgba(255,255,255,.025) 55%,rgba(99,102,241,.05) 100%);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 28px 80px rgba(0,0,0,.38),0 0 80px rgba(139,92,246,.08);
}
.chart-wrap::before{
  background:radial-gradient(circle,rgba(139,92,246,.14) 0%,transparent 58%);
  opacity:.85;
}
.chart-visual{
  background:linear-gradient(180deg,rgba(139,92,246,.11) 0%,rgba(255,255,255,.025) 100%);
  border:1px solid rgba(255,255,255,.07);
}
.chart-grid-overlay{
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
}
.chart-path-line{stroke:var(--purple-light);}
.chart-y-labels,.chart-x-label{color:rgba(255,255,255,.38);}
.cmetric-val{
  background:linear-gradient(135deg,var(--purple-light),#fff);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.cmetric-lbl{color:#666;}



/* ================================================
   MOBILE SMOOTHNESS PATCH — Hero dashboard
   Lighter transforms, smaller shadows and no layout-heavy motion on mobile
================================================ */
@media (max-width:768px){
  .hero{
    padding:7.4rem 0 4rem;
  }
  .hero-visual{
    max-width:100%;
    perspective:none;
    transform:translateZ(0);
    -webkit-transform:translateZ(0);
  }
  .hero-visual.a-up{
    transform:translate3d(0,22px,0) scale(.985);
    transition:opacity .68s ease-out, transform .68s cubic-bezier(.22,.61,.36,1);
    will-change:opacity,transform;
  }
  .hero-visual.a-up.in{
    transform:translate3d(0,0,0) scale(1);
  }
  .hero-card{
    border-radius:22px;
    transform:translateZ(0);
    -webkit-transform:translateZ(0);
    will-change:transform,opacity;
    contain:layout paint;
    box-shadow:
      0 0 0 1px rgba(139,92,246,.10),
      0 14px 36px rgba(139,92,246,.10),
      0 18px 48px rgba(0,0,0,.045);
  }
  .hcard-header{
    padding:1.05rem 1.05rem;
  }
  .hcard-lbl{
    font-size:.58rem;
    letter-spacing:.13em;
  }
  .hcard-live{
    padding:.25rem .72rem;
    font-size:.66rem;
  }
  .hcard-kpis{
    grid-template-columns:1fr 1fr;
  }
  .hkpi{
    padding:1.18rem 1rem;
    border-right:1px solid var(--gray-100);
    border-bottom:1px solid var(--gray-100);
  }
  .hkpi:nth-child(2),
  .hkpi:nth-child(4){
    border-right:none;
  }
  .hkpi:nth-child(3),
  .hkpi:nth-child(4){
    border-bottom:none;
  }
  .hkpi-lbl{
    font-size:.58rem;
    letter-spacing:.08em;
  }
  .hkpi-val{
    font-size:1.65rem;
  }
  .hkpi-meta{
    font-size:.72rem;
  }
  .hcard-spark{
    height:78px;
    margin:0;
    border-radius:0;
    transform:translateZ(0);
  }
  .hcard-spark svg,
  .hcard-spark path{
    transform:translateZ(0);
    will-change:stroke-dashoffset;
  }
  .hcard-ai{
    padding:.9rem 1.05rem;
    gap:.65rem;
  }
  .hcard-ai-dot{
    width:26px;
    height:26px;
    border-radius:8px;
  }
  .hcard-ai p{
    font-size:.78rem;
    line-height:1.45;
  }
  .hw{
    transform:translate3d(0,18px,0);
    transition:opacity .56s ease-out, transform .56s cubic-bezier(.22,.61,.36,1);
    will-change:opacity,transform;
  }
  .hero-headline.in .hw{
    transform:translate3d(0,0,0);
  }
}

@media (max-width:480px){
  .hero-card{
    border-radius:20px;
  }
  .hcard-kpis{
    grid-template-columns:1fr;
  }
  .hkpi,
  .hkpi:nth-child(2),
  .hkpi:nth-child(3),
  .hkpi:nth-child(4){
    border-right:none;
    border-bottom:1px solid var(--gray-100);
  }
  .hkpi:last-child{
    border-bottom:none;
  }
}


/* ================================================
   RESPONSIVE
================================================ */
@media(max-width:1100px){
  .hero-headline{font-size:clamp(3rem,10vw,6rem);}
  .algo-inner{grid-template-columns:1fr;gap:4rem;}
  .services-hd,.method-hd,.security-hd,.testi-hd{grid-template-columns:1fr;}
  .vision-top{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr 1fr;}
}
@media(max-width:768px){
  .nav-links{display:none;}
  .stats-grid{grid-template-columns:1fr;}
  .sbar-item{border-right:none;border-bottom:1px solid var(--gray-200);padding:2rem 1.5rem;}
  .sbar-item:last-child{border-bottom:none;}
  .vcards,.scards,.cap-grid,.tcards,.tquotes,.pcards{grid-template-columns:1fr;}
  .pcard.featured{transform:none!important;}
  .cta-form{flex-direction:column;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:.9rem;text-align:center;}
  .method-hd{grid-template-columns:1fr;}
  .step{grid-template-columns:50px 1fr 24px;gap:1rem;}
}
