/* =========================================================
   acelera — hoja de estilos
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@600;700;800&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root{
  --navy:#1B1F3B;
  --navy-soft:#262B4D;
  --blue:#3D6BFF;
  --blue-light:#7FA6FF;
  --coral:#FF6B57;
  --coral-light:#FF9C8E;
  --violet:#8B5CF6;
  --violet-light:#A78BFA;
  --gray:#6B7280;
  --gray-light:#9CA3AF;
  --bg-light:#F4F5F7;
  --border:#E5E7EB;
  --white:#FFFFFF;

  --font-display:'Manrope', sans-serif;
  --font-body:'Poppins', sans-serif;

  --container: 1180px;
  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 28px;

  --shadow-sm: 0 2px 10px rgba(27,31,59,0.05);
  --shadow-md: 0 12px 40px rgba(27,31,59,0.10);
  --shadow-lg: 0 24px 70px rgba(27,31,59,0.18);

  --ease: cubic-bezier(.22,.85,.32,1);
}

*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--font-body);
  color:var(--navy);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }

a{ color:inherit; text-decoration:none; }

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}

/* color utility classes used for accents per pillar */
.c-blue   { --accent:var(--blue);   --accent-soft:var(--blue-light); }
.c-coral  { --accent:var(--coral);  --accent-soft:var(--coral-light); }
.c-violet { --accent:var(--violet); --accent-soft:var(--violet-light); }

/* =========================================================
   Reveal-on-scroll
   ========================================================= */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
.reveal-stagger > *{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal-stagger.is-visible > *{
  opacity:1;
  transform:translateY(0);
}
.reveal-stagger.is-visible > *:nth-child(1){transition-delay:.02s}
.reveal-stagger.is-visible > *:nth-child(2){transition-delay:.09s}
.reveal-stagger.is-visible > *:nth-child(3){transition-delay:.16s}
.reveal-stagger.is-visible > *:nth-child(4){transition-delay:.23s}
.reveal-stagger.is-visible > *:nth-child(5){transition-delay:.30s}
.reveal-stagger.is-visible > *:nth-child(6){transition-delay:.37s}

/* =========================================================
   Top bar / nav
   ========================================================= */
.nav{
  position:fixed;
  top:0; left:0; right:0;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 28px;
  transition:background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease);
}
.nav.scrolled{
  background:rgba(27,31,59,0.72);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(255,255,255,0.06);
  padding:12px 28px;
}
.nav-inner{
  max-width:var(--container);
  margin:0 auto;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.nav-logo{ display:flex; align-items:center; gap:10px; }
.nav-logo svg{ height:30px; width:auto; transition:height .35s var(--ease); }
.nav.scrolled .nav-logo svg{ height:26px; }

.nav-links{
  display:flex;
  gap:36px;
  align-items:center;
}
.nav-links a{
  font-size:14.5px;
  font-weight:500;
  color:rgba(255,255,255,0.85);
  position:relative;
  padding:4px 0;
  transition:color .25s;
}
.nav-links a::after{
  content:'';
  position:absolute;
  left:0; bottom:-2px;
  width:0; height:2px;
  background:var(--blue-light);
  transition:width .3s var(--ease);
}
.nav-links a:hover::after{ width:100%; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-family:var(--font-body);
  font-weight:600;
  font-size:14.5px;
  letter-spacing:.2px;
  padding:13px 26px;
  border-radius:999px;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s, border-color .25s;
  white-space:nowrap;
}
.btn-primary{
  background:var(--navy);
  color:var(--white);
  box-shadow:0 8px 24px rgba(27,31,59,0.22);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(27,31,59,0.3);
}
.btn-light{
  background:var(--white);
  color:var(--navy);
}
.btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-outline{
  background:transparent;
  border-color:rgba(255,255,255,0.35);
  color:var(--white);
}
.btn-outline:hover{ background:rgba(255,255,255,0.12); transform:translateY(-2px); }
.btn-ghost{
  background:transparent;
  border-color:var(--border);
  color:var(--navy);
}
.btn-ghost:hover{ border-color:var(--navy); transform:translateY(-2px); }
.btn-sm{ padding:9px 18px; font-size:13px; }
.btn:disabled{ opacity:.35; cursor:not-allowed; transform:none !important; box-shadow:none !important; }

.btn-accent{
  background:var(--accent, var(--blue));
  color:var(--white);
  box-shadow:0 8px 24px color-mix(in srgb, var(--accent, #3D6BFF) 45%, transparent);
}
.btn-accent:hover{ transform:translateY(-2px); }

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  background:var(--navy);
  overflow:hidden;
  color:var(--white);
  padding-top:90px;
}
.hero-bg{
  position:absolute;
  inset:0;
  z-index:0;
  overflow:hidden;
}
.blob{
  position:absolute;
  border-radius:50%;
  filter:blur(70px);
  opacity:.55;
  will-change:transform;
}
.blob-1{
  width:560px; height:560px;
  background:radial-gradient(circle at 30% 30%, var(--blue), transparent 70%);
  top:-180px; left:-120px;
  animation:float1 22s ease-in-out infinite;
}
.blob-2{
  width:480px; height:480px;
  background:radial-gradient(circle at 70% 70%, var(--violet), transparent 70%);
  bottom:-160px; right:-100px;
  animation:float2 26s ease-in-out infinite;
}
.blob-3{
  width:380px; height:380px;
  background:radial-gradient(circle at 50% 50%, var(--coral), transparent 70%);
  top:30%; right:18%;
  opacity:.35;
  animation:float3 30s ease-in-out infinite;
}
@keyframes float1{
  0%,100%{ transform:translate(0,0) scale(1); }
  50%{ transform:translate(60px,80px) scale(1.15); }
}
@keyframes float2{
  0%,100%{ transform:translate(0,0) scale(1); }
  50%{ transform:translate(-70px,-50px) scale(1.1); }
}
@keyframes float3{
  0%,100%{ transform:translate(0,0) scale(1); }
  50%{ transform:translate(-40px,60px) scale(1.2); }
}

.hero-grid-overlay{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 50% 40%, rgba(0,0,0,0.6), transparent 75%);
}

.hero-inner{
  position:relative;
  z-index:2;
  width:100%;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:40px;
  align-items:center;
  padding:60px 0 80px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--blue-light);
  margin-bottom:22px;
}
.eyebrow .dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--coral);
  box-shadow:0 0 0 0 rgba(255,107,87,.6);
  animation:pulse 2.4s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(255,107,87,.55); }
  70%{ box-shadow:0 0 0 10px rgba(255,107,87,0); }
  100%{ box-shadow:0 0 0 0 rgba(255,107,87,0); }
}

.hero h1{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(40px, 6vw, 76px);
  line-height:1.05;
  letter-spacing:-1px;
  margin-bottom:24px;
}
.hero h1 .grad{
  background:linear-gradient(96deg, var(--blue-light), var(--violet-light) 55%, var(--coral-light));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero p.lead{
  font-size:clamp(16px, 2vw, 19px);
  color:rgba(255,255,255,0.72);
  max-width:520px;
  margin-bottom:36px;
}
.hero-cta{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:54px;
}
.hero-stats{
  display:flex;
  gap:36px;
  flex-wrap:wrap;
}
.hero-stats div{ min-width:120px; }
.hero-stats .num{
  font-family:var(--font-display);
  font-size:30px;
  font-weight:800;
  background:linear-gradient(96deg, var(--blue-light), var(--coral-light));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-stats .lbl{
  font-size:12.5px;
  color:rgba(255,255,255,0.55);
  letter-spacing:.5px;
  margin-top:4px;
}

/* Hero visual: animated icon */
.hero-visual{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  height:460px;
}
.hero-icon-card{
  position:relative;
  width:100%;
  max-width:380px;
  aspect-ratio:1/1;
  border-radius:32px;
  background:linear-gradient(155deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
  border:1px solid rgba(255,255,255,0.12);
  backdrop-filter:blur(6px);
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:46px;
  box-shadow:var(--shadow-lg);
}
.hero-bars{
  display:flex;
  align-items:flex-end;
  gap:22px;
  height:230px;
}
.hero-bars .bar{
  width:46px;
  border-radius:14px;
  transform:scaleY(0);
  transform-origin:bottom;
  animation:growBar 1.2s var(--ease) forwards;
}
.hero-bars .bar:nth-child(1){ height:35%; background:var(--white); animation-delay:.15s; }
.hero-bars .bar:nth-child(2){ height:60%; background:var(--blue-light); animation-delay:.32s; }
.hero-bars .bar:nth-child(3){ height:100%; background:var(--coral); animation-delay:.5s; position:relative; }
@keyframes growBar{ to{ transform:scaleY(1); } }
.hero-bars .spark{
  position:absolute;
  width:34px; height:34px;
  border-radius:50%;
  background:var(--violet-light);
  top:-17px; right:-17px;
  opacity:0;
  animation:popIn .6s var(--ease) forwards;
  animation-delay:.85s;
  box-shadow:0 0 0 0 rgba(167,139,250,.5);
}
@keyframes popIn{
  0%{ opacity:0; transform:scale(.2); }
  70%{ opacity:1; transform:scale(1.25); }
  100%{ opacity:1; transform:scale(1); box-shadow:0 0 0 14px rgba(167,139,250,0); }
}
.hero-tag{
  position:absolute;
  bottom:-22px;
  left:50%;
  transform:translateX(-50%);
  background:var(--white);
  color:var(--navy);
  font-weight:700;
  font-size:13px;
  letter-spacing:3px;
  padding:12px 28px;
  border-radius:999px;
  box-shadow:var(--shadow-md);
  white-space:nowrap;
}

.scroll-cue{
  position:absolute;
  bottom:28px; left:50%;
  transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color:rgba(255,255,255,0.5);
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  z-index:2;
}
.scroll-cue .line{
  width:1px; height:34px;
  background:rgba(255,255,255,0.35);
  overflow:hidden;
  position:relative;
}
.scroll-cue .line::after{
  content:'';
  position:absolute; left:0; top:-100%;
  width:100%; height:100%;
  background:var(--blue-light);
  animation:scrollLine 2.2s ease-in-out infinite;
}
@keyframes scrollLine{
  0%{ top:-100%; }
  60%{ top:100%; }
  100%{ top:100%; }
}

/* =========================================================
   Section basics
   ========================================================= */
section{ position:relative; }
.section{ padding:120px 0; }
.section-tight{ padding:80px 0; }
.label{
  display:inline-block;
  font-size:12.5px;
  font-weight:700;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--coral);
  margin-bottom:16px;
}
.section h2{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(30px, 4.2vw, 48px);
  line-height:1.15;
  letter-spacing:-.5px;
  color:var(--navy);
  margin-bottom:18px;
}
.section .sub{
  font-size:17px;
  color:var(--gray);
  max-width:620px;
}
.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:40px;
  flex-wrap:wrap;
  margin-bottom:56px;
}

/* =========================================================
   About / mission-vision
   ========================================================= */
.about-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:60px;
  align-items:start;
}
.about-text p{ color:#3f4358; font-size:17px; margin-bottom:18px; }
.mv-cards{ display:flex; flex-direction:column; gap:18px; }
.mv-card{
  background:var(--bg-light);
  border-radius:var(--radius-md);
  padding:28px 30px;
  border:1px solid var(--border);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.mv-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.mv-card .tag{
  display:inline-block;
  font-size:11.5px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--coral);
  margin-bottom:10px;
}
.mv-card p{ font-size:15px; color:#3f4358; margin:0; }

/* =========================================================
   Áreas / pillar cards
   ========================================================= */
.pillars-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.pillar-card{
  position:relative;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  gap:14px;
  cursor:pointer;
  overflow:hidden;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
}
.pillar-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(160deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 60%);
  opacity:0;
  transition:opacity .4s var(--ease);
}
.pillar-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:transparent;
}
.pillar-card:hover::before{ opacity:1; }
.pillar-card .pnum{
  font-family:var(--font-display);
  font-weight:800;
  font-size:14px;
  color:var(--accent);
  letter-spacing:2px;
}
.pillar-card .picon{
  width:46px; height:46px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background:color-mix(in srgb, var(--accent) 14%, white);
  color:var(--accent);
  margin-bottom:4px;
  position:relative;
  z-index:1;
}
.pillar-card .picon svg{ width:22px; height:22px; }
.pillar-card h3{
  font-family:var(--font-display);
  font-size:21px;
  font-weight:800;
  color:var(--navy);
  position:relative; z-index:1;
}
.pillar-card .ptag{
  font-size:13px;
  font-weight:600;
  color:var(--accent);
  position:relative; z-index:1;
}
.pillar-card .pdesc{
  font-size:14.5px;
  color:var(--gray);
  flex:1;
  position:relative; z-index:1;
}
.pillar-card .pcta{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  font-weight:700;
  color:var(--navy);
  margin-top:6px;
  position:relative; z-index:1;
}
.pillar-card .pcta svg{
  width:16px; height:16px;
  transition:transform .3s var(--ease);
}
.pillar-card:hover .pcta svg{ transform:translateX(6px); }

/* =========================================================
   Process timeline
   ========================================================= */
.process{
  background:var(--navy);
  color:var(--white);
}
.process .label{ color:var(--blue-light); }
.process h2{ color:var(--white); }
.process .sub{ color:rgba(255,255,255,0.6); }

.process-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
  margin-top:60px;
  position:relative;
}
.process-line{
  position:absolute;
  top:24px; left:0; right:0;
  height:1px;
  background:rgba(255,255,255,0.12);
}
.process-step{ position:relative; }
.process-step .pnum{
  width:48px; height:48px;
  border-radius:50%;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.15);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display);
  font-weight:800;
  font-size:15px;
  margin-bottom:22px;
  position:relative;
  transition:background .4s, border-color .4s, transform .4s var(--ease);
}
.process-step.is-visible .pnum{
  background:linear-gradient(135deg, var(--blue), var(--violet));
  border-color:transparent;
  transform:scale(1.08);
}
.process-step h3{
  font-family:var(--font-display);
  font-weight:800;
  font-size:19px;
  margin-bottom:10px;
}
.process-step p{
  font-size:14.5px;
  color:rgba(255,255,255,0.6);
}

/* =========================================================
   Final CTA
   ========================================================= */
.cta-final{
  background:linear-gradient(135deg, var(--blue) 0%, var(--violet) 100%);
  color:var(--white);
  border-radius:var(--radius-lg);
  padding:70px 60px;
  text-align:center;
  position:relative;
  overflow:hidden;
  margin:0 28px;
}
.cta-final::before, .cta-final::after{
  content:'';
  position:absolute;
  border-radius:50%;
  background:rgba(255,255,255,0.08);
}
.cta-final::before{ width:280px; height:280px; top:-120px; left:-80px; }
.cta-final::after{ width:220px; height:220px; bottom:-100px; right:-40px; }
.cta-final h2{ color:var(--white); margin-bottom:14px; }
.cta-final p{
  color:rgba(255,255,255,0.85);
  max-width:560px;
  margin:0 auto 32px;
  font-size:17px;
}
.cta-final .hero-cta{ justify-content:center; margin-bottom:0; }

/* =========================================================
   Footer
   ========================================================= */
.footer{
  background:var(--navy);
  color:rgba(255,255,255,0.65);
  padding:70px 0 30px;
  margin-top:120px;
}
.footer-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.footer-logo svg{ height:32px; width:auto; margin-bottom:14px; }
.footer-top p{ max-width:340px; font-size:14.5px; }
.footer-cols{ display:flex; gap:60px; flex-wrap:wrap; }
.footer-col h4{
  font-size:13px; letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,0.4); margin-bottom:16px; font-weight:600;
}
.footer-col a, .footer-col span{
  display:block;
  font-size:14.5px;
  margin-bottom:10px;
  color:rgba(255,255,255,0.75);
  transition:color .25s;
}
.footer-col a:hover{ color:var(--white); }
.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
  padding-top:24px;
  font-size:13px;
  color:rgba(255,255,255,0.4);
}

/* =========================================================
   MODAL — Diagnóstico interactivo
   ========================================================= */
.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(27,31,59,0.55);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1000;
  opacity:0;
  visibility:hidden;
  transition:opacity .35s var(--ease), visibility .35s;
  padding:24px;
}
.modal-overlay.open{
  opacity:1;
  visibility:visible;
}
.modal{
  background:var(--white);
  width:100%;
  max-width:680px;
  max-height:88vh;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transform:translateY(30px) scale(.98);
  transition:transform .4s var(--ease);
}
.modal-overlay.open .modal{ transform:translateY(0) scale(1); }

.modal-head{
  padding:26px 32px;
  background:var(--accent, var(--navy));
  color:var(--white);
  position:relative;
  overflow:hidden;
}
.modal-head::before{
  content:'';
  position:absolute;
  width:260px; height:260px;
  border-radius:50%;
  background:rgba(255,255,255,0.08);
  top:-140px; right:-80px;
}
.modal-head-top{
  display:flex; justify-content:space-between; align-items:flex-start;
  position:relative; z-index:1;
}
.modal-eyebrow{
  font-size:12px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,0.7); margin-bottom:6px;
}
.modal-head h3{
  font-family:var(--font-display);
  font-weight:800;
  font-size:24px;
}
.modal-close{
  width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,0.14);
  border:none;
  color:var(--white);
  font-size:18px;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .25s, transform .25s;
  flex-shrink:0;
}
.modal-close:hover{ background:rgba(255,255,255,0.26); transform:rotate(90deg); }

.modal-progress{
  display:flex; gap:6px; margin-top:20px; position:relative; z-index:1;
}
.modal-progress .seg{
  flex:1; height:4px; border-radius:4px;
  background:rgba(255,255,255,0.2);
  overflow:hidden;
}
.modal-progress .seg span{
  display:block; height:100%; width:0%;
  background:var(--white);
  transition:width .5s var(--ease);
}
.modal-progress .seg.done span{ width:100%; }
.modal-progress .seg.active span{ width:100%; }

.modal-body{
  padding:32px;
  overflow-y:auto;
}
.modal-step{ display:none; animation:stepIn .45s var(--ease); }
.modal-step.active{ display:block; }
@keyframes stepIn{
  from{ opacity:0; transform:translateX(18px); }
  to{ opacity:1; transform:translateX(0); }
}
.modal-q{
  font-family:var(--font-display);
  font-weight:800;
  font-size:21px;
  color:var(--navy);
  margin-bottom:22px;
  line-height:1.3;
}
.options{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.option{
  display:flex;
  align-items:center;
  gap:14px;
  padding:16px 18px;
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-size:15px;
  font-weight:500;
  color:var(--navy);
  transition:border-color .25s, background .25s, transform .2s;
  text-align:left;
}
.option:hover{ border-color:var(--accent, var(--blue)); background:var(--bg-light); transform:translateX(3px); }
.option .radio{
  width:20px; height:20px; border-radius:50%;
  border:1.5px solid var(--border);
  flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  transition:border-color .25s, background .25s;
}
.option .radio::after{
  content:'';
  width:10px; height:10px; border-radius:50%;
  background:var(--accent, var(--blue));
  transform:scale(0);
  transition:transform .2s var(--ease);
}
.option.selected{
  border-color:var(--accent, var(--blue));
  background:color-mix(in srgb, var(--accent, #3D6BFF) 6%, white);
}
.option.selected .radio{ border-color:var(--accent, var(--blue)); }
.option.selected .radio::after{ transform:scale(1); }

.modal-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:22px 32px;
  border-top:1px solid var(--border);
  gap:12px;
}
.step-indicator{
  font-size:13px;
  color:var(--gray);
  font-weight:600;
  letter-spacing:1px;
}

/* loading state */
.modal-loading{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:50px 10px;
  text-align:center;
  gap:22px;
}
.loader-bars{
  display:flex; align-items:flex-end; gap:10px; height:60px;
}
.loader-bars .lb{
  width:14px; border-radius:6px;
  background:var(--accent, var(--blue));
  animation:loaderBounce 1s ease-in-out infinite;
}
.loader-bars .lb:nth-child(1){ height:30%; animation-delay:0s; }
.loader-bars .lb:nth-child(2){ height:60%; animation-delay:.15s; background:var(--violet); }
.loader-bars .lb:nth-child(3){ height:100%; animation-delay:.3s; background:var(--coral); }
@keyframes loaderBounce{
  0%,100%{ transform:scaleY(.5); opacity:.6; }
  50%{ transform:scaleY(1); opacity:1; }
}
.modal-loading p{ color:var(--gray); font-size:15px; font-weight:500; }

/* result */
.result-intro{
  font-size:16px;
  color:#3f4358;
  margin-bottom:26px;
  line-height:1.7;
}
.result-intro strong{ color:var(--navy); }
.result-label{
  font-size:12px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  color:var(--accent, var(--blue)); margin-bottom:14px;
}
.result-services{
  display:flex; flex-direction:column; gap:10px;
  margin-bottom:28px;
}
.result-service{
  display:flex; gap:14px; align-items:flex-start;
  padding:16px 18px;
  border-radius:var(--radius-sm);
  border:1.5px solid var(--border);
  font-size:14.5px;
  color:#3f4358;
  transition:transform .4s var(--ease), opacity .4s var(--ease);
}
.result-service.featured{
  border-color:var(--accent, var(--blue));
  background:color-mix(in srgb, var(--accent, #3D6BFF) 5%, white);
}
.result-service .ico{
  width:26px; height:26px; border-radius:50%;
  flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg-light);
  color:var(--gray);
  font-size:13px;
  font-weight:700;
}
.result-service.featured .ico{
  background:var(--accent, var(--blue));
  color:var(--white);
}
.result-service .badge{
  display:inline-block;
  font-size:10.5px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--accent, var(--blue));
  margin-bottom:4px;
}
.result-cta{
  background:var(--bg-light);
  border-radius:var(--radius-md);
  padding:24px 26px;
  text-align:center;
}
.result-cta p{ font-size:15px; color:#3f4358; margin-bottom:16px; }
.result-actions{
  display:flex; gap:12px; justify-content:center; flex-wrap:wrap;
  margin-top:18px;
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 980px){
  .hero-inner{ grid-template-columns:1fr; text-align:left; padding-top:30px; }
  .hero-visual{ height:340px; order:-1; }
  .about-grid{ grid-template-columns:1fr; gap:40px; }
  .pillars-grid{ grid-template-columns:repeat(2, 1fr); }
  .process-grid{ grid-template-columns:repeat(2, 1fr); gap:40px; }
  .process-line{ display:none; }
  .nav-links{ display:none; }
  .cta-final{ padding:50px 28px; }
}
@media (max-width: 640px){
  .pillars-grid{ grid-template-columns:1fr; }
  .process-grid{ grid-template-columns:1fr; }
  .hero-stats{ gap:24px; }
  .section{ padding:80px 0; }
  .footer-cols{ gap:36px; }
  .modal-body, .modal-head, .modal-footer{ padding-left:20px; padding-right:20px; }
}
