/* ---- self-hosted fonts ---- */
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('/assets/fonts/inter-300-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/inter-400-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/inter-500-normal.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/inter-600-normal.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/fraunces-400-normal.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/fraunces-400-italic.woff2') format('woff2');}

:root{
  --bg-top:#ffffff; --bg-bottom:#f5f0fe; --ink:#1a1726; --ink-soft:#4c4663;
  --ink-muted:#6c6680; /* AA-passing fine-print grey (≈4.6:1 on lavender) */
  --accent:#7c3aed; --accent-glow:#b366ff; --paper-warm:#faf8f3;
  --maxw:1080px; --pad:clamp(20px,5vw,64px);
  --font-body:'Inter',system-ui,sans-serif; --font-head:'Fraunces',Georgia,serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);color:var(--ink);
  background:linear-gradient(180deg,var(--bg-top),var(--bg-bottom));
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.5;
  overflow-x:hidden;}
::selection{background:rgba(124,58,237,.18);color:var(--ink);}
/* keyboard-only focus: clear violet ring with a soft halo, never on mouse click */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px;}
.btn:focus-visible,
a:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px;
  box-shadow:0 0 0 5px rgba(124,58,237,.18);
}
.btn:focus-visible{border-radius:11px;}
.btn-lg:focus-visible{border-radius:13px;}
img{display:block;max-width:100%;}

/* ============================================================
   HEADER  — sticky, translucent, editorial
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px var(--pad);
  background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(124,58,237,.10);
}
.brand{display:inline-flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink);}
.brand .sigil{width:23px;height:27px;flex:none;
  filter:drop-shadow(0 2px 8px rgba(124,58,237,.28));
  transition:transform .5s cubic-bezier(.34,1.56,.64,1);}
.brand:hover .sigil{transform:rotate(180deg) scale(1.06);}
.brand-name{font-family:var(--font-head);font-weight:400;font-size:18px;letter-spacing:.005em;}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  font:inherit;font-weight:500;cursor:pointer;
  display:inline-flex;align-items:center;gap:.5em;
  border:0;border-radius:11px;padding:10px 19px;
  line-height:1.1;letter-spacing:.005em;
  transition:transform .25s cubic-bezier(.34,1.4,.5,1),box-shadow .25s ease,background-color .2s ease;
}
.btn-primary{
  background:linear-gradient(160deg,#8b4ef2,var(--accent));
  color:#fff;
  box-shadow:0 1px 2px rgba(60,16,120,.25),0 12px 30px -12px rgba(124,58,237,.6);
}
.btn-primary:hover{transform:translateY(-2px);
  box-shadow:0 2px 4px rgba(60,16,120,.28),0 18px 40px -12px rgba(124,58,237,.72);}
.btn-primary:active{transform:translateY(0);}
.btn-lg{padding:16px 28px;font-size:15.5px;border-radius:13px;}
.btn .arrow{transition:transform .3s cubic-bezier(.34,1.4,.5,1);}
.btn:hover .arrow{transform:translateX(4px);}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(36px,5vw,64px);
  align-items:center;
  padding:clamp(52px,9vw,104px) var(--pad) clamp(64px,9vw,108px);
}
/* ambient violet glow washing the whole hero */
.hero::before{
  content:"";position:absolute;z-index:-1;pointer-events:none;
  top:-12%;right:-6%;width:min(620px,72vw);height:min(620px,72vw);
  background:radial-gradient(circle at 60% 40%,rgba(179,102,255,.20),rgba(179,102,255,0) 62%);
  filter:blur(8px);
}

.hero-copy{max-width:34rem;}
.eyebrow{
  font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:22px;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:linear-gradient(90deg,var(--accent),transparent);}

.display{
  font-family:var(--font-head);font-weight:400;
  font-size:clamp(36px,5.4vw,60px);line-height:1.02;letter-spacing:-.018em;
  text-wrap:balance;color:var(--ink);
}
.display em{
  font-style:italic;
  background:linear-gradient(110deg,var(--accent),var(--accent-glow));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  /* fallback if clip unsupported */
  -webkit-text-fill-color:transparent;
}

.lede{
  font-size:clamp(17px,1.5vw,19.5px);line-height:1.55;
  color:var(--ink-soft);max-width:34ch;margin-top:24px;
}
.proofline{margin-top:22px;font-size:14.5px;line-height:1.6;color:var(--ink-soft);}
.proofline strong{color:var(--ink);font-weight:600;}
.proofline .sep{color:var(--accent);margin:0 4px;opacity:.65;}

.cta-row{margin-top:34px;}
.reassure{margin-top:15px;font-size:13.5px;color:var(--ink-muted);}

/* photo: rounded frame, layered glow + violet rim */
.hero-photo{
  position:relative;margin:0;
  aspect-ratio:4/5;
  border-radius:20px;overflow:hidden;
  border:1px solid rgba(124,58,237,.16);
  box-shadow:
    0 1px 0 rgba(255,255,255,.7) inset,
    0 30px 70px -34px rgba(124,58,237,.5),
    0 8px 24px -16px rgba(26,23,38,.3);
}
.hero-photo::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  box-shadow:0 0 0 1px rgba(255,255,255,.35) inset;
  background:linear-gradient(155deg,rgba(255,255,255,.14),transparent 38%);
}
.hero-photo img{width:100%;height:100%;object-fit:cover;}

/* staggered entrance */
@media(prefers-reduced-motion:no-preference){
  .eyebrow,.display,.lede,.proofline,.cta-row,.reassure,.hero-photo{
    animation:hero-rise .8s cubic-bezier(.16,.84,.44,1) both;
  }
  .display{animation-delay:.06s;}
  .lede{animation-delay:.14s;}
  .proofline{animation-delay:.2s;}
  .cta-row{animation-delay:.26s;}
  .reassure{animation-delay:.32s;}
  .hero-photo{animation:hero-rise 1s cubic-bezier(.16,.84,.44,1) .12s both;}
}
@keyframes hero-rise{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}

/* ============================================================
   THE WORK  — credibility + proof vignettes
   ============================================================ */
.work{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(56px,8vw,92px) var(--pad);
}
/* honesty-flex kicker — small violet line with a glowing dot */
.flex-line{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--accent);font-weight:500;
  font-size:14px;letter-spacing:.01em;
  margin-bottom:18px;
}
.flex-dot{
  width:7px;height:7px;border-radius:50%;flex:none;
  background:var(--accent-glow);
  box-shadow:0 0 0 4px rgba(179,102,255,.16),0 0 12px rgba(179,102,255,.7);
}

.section-title{
  font-family:var(--font-head);font-weight:400;
  font-size:clamp(28px,4.2vw,42px);line-height:1.08;letter-spacing:-.015em;
  text-wrap:balance;color:var(--ink);max-width:18ch;
}
.section-title em{
  font-style:italic;
  background:linear-gradient(110deg,var(--accent),var(--accent-glow));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  -webkit-text-fill-color:transparent;
}

.bio{
  margin-top:22px;
  font-size:clamp(16.5px,1.5vw,18.5px);line-height:1.62;
  color:var(--ink-soft);max-width:64ch;
}
.bio strong{color:var(--ink);font-weight:600;}

.vignettes{
  list-style:none;margin-top:clamp(34px,4vw,46px);
  display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,1.6vw,20px);
}
.vignette{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(250,247,255,.78));
  border:1px solid rgba(124,58,237,.12);
  border-radius:18px;
  padding:clamp(22px,2.4vw,30px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.7) inset,
    0 18px 40px -28px rgba(124,58,237,.4);
  transition:transform .35s cubic-bezier(.16,.84,.44,1),box-shadow .35s ease,border-color .35s ease;
}
/* soft violet corner wash on each card */
.vignette::before{
  content:"";position:absolute;z-index:0;pointer-events:none;
  top:-40%;right:-20%;width:230px;height:230px;border-radius:50%;
  background:radial-gradient(circle,rgba(179,102,255,.14),rgba(179,102,255,0) 70%);
  opacity:0;transition:opacity .4s ease;
}
.vignette:hover{
  transform:translateY(-4px);
  border-color:rgba(124,58,237,.28);
  box-shadow:
    0 1px 0 rgba(255,255,255,.8) inset,
    0 28px 56px -28px rgba(124,58,237,.55);
}
.vignette:hover::before{opacity:1;}
.vignette h3,.vignette p{position:relative;z-index:1;}
.vignette h3{
  font-family:var(--font-head);font-weight:400;
  font-size:clamp(19px,1.8vw,22px);line-height:1.15;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:10px;
}
.vignette p{
  font-size:14.5px;line-height:1.62;color:var(--ink-soft);
}

/* entrance — same robust time-based rise as the hero, staggered.
   Time-based (not scroll-driven) so it always resolves to opacity:1
   with no JS and no scroll dependency — the proof content is never
   left invisible. */
@media(prefers-reduced-motion:no-preference){
  .work .flex-line,.work .section-title,.work .bio,.vignette{
    animation:hero-rise .8s cubic-bezier(.16,.84,.44,1) both;
  }
  .work .section-title{animation-delay:.08s;}
  .work .bio{animation-delay:.16s;}
  .vignette:nth-child(1){animation-delay:.24s;}
  .vignette:nth-child(2){animation-delay:.32s;}
  .vignette:nth-child(3){animation-delay:.40s;}
  .vignette:nth-child(4){animation-delay:.48s;}
}

/* ============================================================
   PAINS  — "Sound familiar?" problem framing
   ============================================================ */
.pains{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(48px,7vw,80px) var(--pad);
}
.pain-list{
  list-style:none;margin-top:clamp(26px,3vw,34px);
  display:grid;gap:clamp(14px,1.6vw,18px);max-width:62ch;
}
.pain-list li{
  position:relative;padding-left:30px;
  font-size:clamp(17px,1.5vw,19.5px);line-height:1.55;
  color:var(--ink-soft);
}
.pain-list li strong{color:var(--ink);}
/* glowing violet marker */
.pain-list li::before{
  content:"";position:absolute;left:0;top:.62em;
  width:9px;height:9px;border-radius:50%;
  background:var(--accent-glow);
  box-shadow:0 0 0 4px rgba(179,102,255,.14),0 0 11px rgba(179,102,255,.6);
}

/* ============================================================
   SERVICES  — Assess / Lead / Build buckets
   ============================================================ */
.services{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(48px,7vw,80px) var(--pad);
}
.buckets{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,1.6vw,20px);
  margin-top:clamp(30px,3.6vw,42px);
  align-items:stretch;
}
.bucket{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(250,247,255,.78));
  border:1px solid rgba(124,58,237,.12);
  border-radius:18px;
  padding:clamp(24px,2.5vw,30px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.7) inset,
    0 18px 40px -28px rgba(124,58,237,.4);
  transition:transform .35s cubic-bezier(.16,.84,.44,1),box-shadow .35s ease,border-color .35s ease;
}
/* soft violet corner wash, matching the work vignettes */
.bucket::before{
  content:"";position:absolute;z-index:0;pointer-events:none;
  top:-40%;right:-20%;width:230px;height:230px;border-radius:50%;
  background:radial-gradient(circle,rgba(179,102,255,.14),rgba(179,102,255,0) 70%);
  opacity:0;transition:opacity .4s ease;
}
.bucket:hover{
  transform:translateY(-4px);
  border-color:rgba(124,58,237,.28);
  box-shadow:
    0 1px 0 rgba(255,255,255,.8) inset,
    0 28px 56px -28px rgba(124,58,237,.55);
}
.bucket:hover::before{opacity:1;}
.bucket>*{position:relative;z-index:1;}
.bucket-num{
  font-family:var(--font-head);font-style:italic;font-size:14px;
  letter-spacing:.04em;color:var(--accent-glow);opacity:.85;
}
.bucket h3{
  font-family:var(--font-head);font-weight:400;
  font-size:clamp(22px,2.2vw,26px);line-height:1.1;letter-spacing:-.012em;
  margin-top:4px;
  background:linear-gradient(110deg,var(--accent),var(--accent-glow));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  -webkit-text-fill-color:transparent;
}
.bucket-line{
  margin:10px 0 18px;
  font-size:15px;line-height:1.5;font-weight:500;color:var(--ink);
}
.offerings{
  list-style:none;display:grid;gap:13px;
  font-size:14px;line-height:1.56;color:var(--ink-soft);
  margin-top:auto;
  padding-top:16px;border-top:1px solid rgba(124,58,237,.10);
}
.offerings strong{color:var(--ink);font-weight:600;}

.closer{
  margin-top:clamp(26px,3vw,34px);
  font-size:clamp(17px,1.5vw,19.5px);line-height:1.5;color:var(--ink);
}
.closer strong{
  color:var(--accent);font-weight:600;
}
.disqualify{
  margin-top:12px;
  font-size:14px;line-height:1.55;color:var(--ink-muted);max-width:60ch;
}

/* ============================================================
   PRINCIPLES  — large editorial Fraunces statements
   ============================================================ */
.principles{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(48px,7vw,80px) var(--pad) clamp(56px,8vw,92px);
}
.principle-list{
  list-style:none;margin-top:clamp(30px,3.6vw,44px);
  display:grid;gap:clamp(24px,3vw,38px);
}
.principle-list li{
  position:relative;padding-left:clamp(28px,3vw,42px);
  font-family:var(--font-head);font-weight:400;
  font-size:clamp(19px,2.6vw,27px);line-height:1.32;letter-spacing:-.012em;
  text-wrap:balance;color:var(--ink);max-width:30ch;
}
/* slim violet rule down the left of each principle */
.principle-mark{
  position:absolute;left:0;top:.18em;bottom:.18em;
  width:3px;border-radius:3px;
  background:linear-gradient(180deg,var(--accent),var(--accent-glow));
  box-shadow:0 0 12px rgba(179,102,255,.45);
}

/* entrance — time-based rise, consistent with hero + work.
   Always resolves to opacity:1 (no scroll/JS dependency). */
@media(prefers-reduced-motion:no-preference){
  .pains .section-title,.pain-list li,
  .services .section-title,.bucket,.closer,.disqualify,
  .principles .section-title,.principle-list li{
    animation:hero-rise .8s cubic-bezier(.16,.84,.44,1) both;
  }
  .pain-list li:nth-child(1){animation-delay:.08s;}
  .pain-list li:nth-child(2){animation-delay:.16s;}
  .pain-list li:nth-child(3){animation-delay:.24s;}
  .bucket:nth-child(1){animation-delay:.08s;}
  .bucket:nth-child(2){animation-delay:.18s;}
  .bucket:nth-child(3){animation-delay:.28s;}
  .principle-list li:nth-child(1){animation-delay:.06s;}
  .principle-list li:nth-child(2){animation-delay:.16s;}
  .principle-list li:nth-child(3){animation-delay:.26s;}
}

/* ============================================================
   FAQ  — objection handling
   ============================================================ */
.faq{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(48px,7vw,80px) var(--pad);
}
.faq-list{
  margin-top:clamp(28px,3.4vw,40px);
  display:grid;gap:0;
  border-top:1px solid rgba(124,58,237,.12);
}
.faq-item{
  padding:clamp(18px,2.2vw,24px) 0;
  border-bottom:1px solid rgba(124,58,237,.12);
}
.faq-item dt{
  font-family:var(--font-head);font-weight:400;
  font-size:clamp(18px,1.9vw,22px);line-height:1.25;letter-spacing:-.01em;
  color:var(--ink);
}
.faq-item dd{
  margin-top:10px;max-width:64ch;
  font-size:clamp(15px,1.4vw,16.5px);line-height:1.62;
  color:var(--ink-soft);
}

@media(prefers-reduced-motion:no-preference){
  .faq .section-title,.faq-item{
    animation:hero-rise .8s cubic-bezier(.16,.84,.44,1) both;
  }
  .faq-item:nth-child(1){animation-delay:.06s;}
  .faq-item:nth-child(2){animation-delay:.12s;}
  .faq-item:nth-child(3){animation-delay:.18s;}
  .faq-item:nth-child(4){animation-delay:.24s;}
  .faq-item:nth-child(5){animation-delay:.30s;}
}

/* ============================================================
   FINAL CTA  — embedded Cal.com calendar
   ============================================================ */
.final-cta{
  position:relative;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(52px,8vw,96px) var(--pad) clamp(64px,9vw,104px);
  text-align:center;
}
/* ambient violet glow behind the booking block */
.final-cta::before{
  content:"";position:absolute;z-index:-1;pointer-events:none;
  top:8%;left:50%;transform:translateX(-50%);
  width:min(680px,80vw);height:min(520px,60vw);
  background:radial-gradient(ellipse at center,rgba(179,102,255,.16),rgba(179,102,255,0) 68%);
  filter:blur(10px);
}
.final-cta .section-title{
  max-width:20ch;margin:0 auto;
}
.final-reassure{
  max-width:54ch;margin:clamp(14px,1.8vw,20px) auto clamp(26px,3.2vw,36px);
  font-size:clamp(16px,1.5vw,18px);line-height:1.6;color:var(--ink-soft);
}
.final-reassure strong{color:var(--ink);font-weight:600;}

/* the inline calendar: framed paper card */
#cal-inline{
  position:relative;
  min-height:560px;
  max-width:920px;margin:0 auto;
  border-radius:22px;overflow:hidden;
  border:1px solid rgba(124,58,237,.16);
  background:#fff;
  box-shadow:
    0 1px 0 rgba(255,255,255,.7) inset,
    0 30px 70px -34px rgba(124,58,237,.45),
    0 8px 24px -16px rgba(26,23,38,.28);
}
#cal-inline iframe{width:100%;border:0;display:block;}

.cal-fallback{
  margin-top:clamp(16px,2vw,22px);
  font-size:14.5px;
}
.cal-fallback a{
  color:var(--accent);text-decoration:none;font-weight:500;
  display:inline-flex;align-items:center;gap:.4em;
}
.cal-fallback a:hover{text-decoration:underline;}
.cal-fallback .arrow{transition:transform .3s cubic-bezier(.34,1.4,.5,1);}
.cal-fallback a:hover .arrow{transform:translateX(4px);}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(34px,4vw,48px) var(--pad) clamp(40px,5vw,56px);
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  border-top:1px solid rgba(124,58,237,.12);
}
.footer-brand{
  display:inline-flex;align-items:center;gap:11px;
  text-decoration:none;color:var(--ink);
}
.footer-brand .sigil{
  width:20px;height:24px;flex:none;
  filter:drop-shadow(0 2px 8px rgba(124,58,237,.25));opacity:.92;
}
.copyright{font-family:var(--font-head);font-size:15px;letter-spacing:.005em;color:var(--ink-soft);}
.contacts{display:flex;gap:clamp(16px,2vw,26px);}
.contacts a{
  color:var(--ink-soft);text-decoration:none;font-size:14px;font-weight:500;
  letter-spacing:.01em;transition:color .2s ease;
}
.contacts a:hover{color:var(--accent);}

/* ============================================================
   MOBILE STICKY CTA  — carries the reassurance, not a naked button
   ============================================================ */
.sticky-cta{display:none;}
@media(max-width:780px){
  .sticky-cta{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    position:fixed;left:0;right:0;bottom:0;z-index:60;
    padding:11px 16px calc(11px + env(safe-area-inset-bottom,0px));
    background:rgba(255,255,255,.92);
    -webkit-backdrop-filter:saturate(180%) blur(14px);
    backdrop-filter:saturate(180%) blur(14px);
    border-top:1px solid rgba(124,58,237,.16);
    box-shadow:0 -8px 24px -16px rgba(26,23,38,.3);
  }
  .sticky-cta .btn-primary{flex:none;padding:11px 18px;font-size:14.5px;}
  .sticky-reassure{
    font-size:12px;line-height:1.3;color:var(--ink-soft);
    text-align:right;flex:1;min-width:0;
  }
  /* keep the inline calendar + footer clear of the fixed bar */
  .final-cta{padding-bottom:clamp(40px,12vw,72px);}
  .site-footer{margin-bottom:64px;}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:820px){
  .hero{grid-template-columns:1fr;gap:36px;text-align:left;}
  .hero-copy{max-width:none;order:2;}
  .hero-photo{order:1;max-width:300px;width:100%;}
}
@media(max-width:600px){
  .site-footer{flex-direction:column;align-items:flex-start;gap:18px;}
}
@media(max-width:820px){
  .buckets{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .vignettes{grid-template-columns:1fr;}
}
@media(max-width:540px){
  .brand-name{font-size:16px;}
  .site-header .btn-primary{padding:9px 15px;font-size:14px;}
  .btn-lg{width:100%;justify-content:center;}
}

/* ---- scale stat band ---- */
.stats{
  max-width:var(--maxw);margin:8px auto 0;padding:28px var(--pad);
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.stat{
  position:relative;padding:22px 22px 22px 26px;border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(245,240,254,.5));
  border:1px solid #ece5fb;
}
.stat::before{
  content:"";position:absolute;left:0;top:18px;bottom:18px;width:3px;border-radius:3px;
  background:linear-gradient(180deg,var(--accent),var(--accent-glow));
}
.stat-num{
  display:block;font-family:var(--font-head);font-weight:400;
  font-size:clamp(24px,3vw,32px);line-height:1.05;color:var(--accent);letter-spacing:-.01em;
}
.stat-label{display:block;margin-top:8px;font-size:13.5px;line-height:1.45;color:var(--ink-soft);}
@media(max-width:780px){
  .stats{grid-template-columns:1fr;gap:14px;padding:18px var(--pad);}
}
