/*
 * KY Soluciones Informáticas — Main Stylesheet
 * Diseño: Dark Tech / Digital Cosmos
 * Versión: 1.0.0
 */

/* Fonts loaded non-blocking via head.php — import kept as fallback for non-JS */

/* ============================================================
   1. VARIABLES
   ============================================================ */
:root {
  --bg:           #030712;
  --bg-2:         #0F172A;
  --bg-3:         #1E293B;
  --bg-card:      rgba(15,23,42,0.85);
  --primary:      #3B82F6;
  --primary-dk:   #1D4ED8;
  --accent:       #06B6D4;
  --green:        #10B981;
  --green-dk:     #059669;
  --white:        #FFFFFF;
  --text:         #F1F5F9;
  --muted:        #94A3B8;
  --subtle:       #475569;
  --border:       rgba(59,130,246,0.15);
  --border-h:     rgba(59,130,246,0.45);

  --grad-blue:    linear-gradient(135deg,#3B82F6,#06B6D4);
  --grad-green:   linear-gradient(135deg,#10B981,#06B6D4);
  --grad-hero:    radial-gradient(ellipse 80% 60% at 20% 40%,rgba(59,130,246,.18) 0%,transparent 70%),
                  radial-gradient(ellipse 60% 50% at 80% 15%,rgba(6,182,212,.12) 0%,transparent 60%),
                  #030712;

  --sh-sm:  0 1px 4px rgba(0,0,0,.35);
  --sh-md:  0 4px 24px rgba(0,0,0,.45);
  --sh-lg:  0 12px 48px rgba(0,0,0,.55);
  --sh-glow: 0 0 40px rgba(59,130,246,.22);
  --sh-glow-g: 0 0 40px rgba(16,185,129,.22);

  --font:    'Inter','Segoe UI',sans-serif;
  --font-d:  'Space Grotesk','Inter',sans-serif;

  --r-sm:  8px;
  --r-md:  16px;
  --r-lg:  24px;
  --r-xl:  40px;

  --ease: cubic-bezier(.4,0,.2,1);
  --tr: .3s var(--ease);
  --tr-s: .6s var(--ease);
}

/* ============================================================
   2. RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,textarea,select{font-family:inherit;}

/* ============================================================
   3. TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5{
  font-family:var(--font-d);
  line-height:1.2;
  font-weight:700;
}
h1{font-size:clamp(2.4rem,5vw,4rem);}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem);}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem);}
h4{font-size:1.15rem;}
p{color:var(--muted);line-height:1.75;}
.text-gradient{
  background:var(--grad-blue);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.text-gradient-green{
  background:var(--grad-green);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ============================================================
   4. LAYOUT
   ============================================================ */
.container{
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
}
.section{padding:100px 0;content-visibility:auto;contain-intrinsic-size:0 500px;}
.section-sm{padding:60px 0;content-visibility:auto;contain-intrinsic-size:0 300px;}
.section-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--primary);
  background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.2);
  padding:6px 16px;
  border-radius:100px;
  margin-bottom:20px;
}
.section-label.green{
  color:var(--green);
  background:rgba(16,185,129,.1);
  border-color:rgba(16,185,129,.2);
}
.section-title{
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-family:var(--font-d);
  color:var(--white);
  margin-bottom:16px;
}
.section-sub{
  font-size:1.05rem;
  color:var(--muted);
  max-width:600px;
  margin:0 auto;
}
.text-center{text-align:center;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.flex{display:flex;align-items:center;}
.flex-center{display:flex;align-items:center;justify-content:center;}
.gap-4{gap:16px;}
.gap-6{gap:24px;}
.mt-8{margin-top:32px;}
.mt-12{margin-top:48px;}
.mb-4{margin-bottom:16px;}
.mb-8{margin-bottom:32px;}

/* ============================================================
   5. BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 32px;
  border-radius:100px;
  font-size:.95rem;
  font-weight:600;
  transition:var(--tr);
  white-space:nowrap;
}
.btn-primary{
  background:var(--grad-blue);
  color:#fff;
  box-shadow:0 4px 20px rgba(59,130,246,.35);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(59,130,246,.5);
}
.btn-ghost{
  background:rgba(255,255,255,.05);
  color:var(--text);
  border:1px solid var(--border-h);
  backdrop-filter:blur(8px);
}
.btn-ghost:hover{
  background:rgba(59,130,246,.12);
  border-color:var(--primary);
  transform:translateY(-2px);
}
.btn-green{
  background:var(--grad-green);
  color:#fff;
  box-shadow:0 4px 20px rgba(16,185,129,.35);
}
.btn-green:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(16,185,129,.5);
}
.btn-outline-green{
  background:transparent;
  color:var(--green);
  border:1px solid rgba(16,185,129,.4);
}
.btn-outline-green:hover{
  background:rgba(16,185,129,.1);
  border-color:var(--green);
  transform:translateY(-2px);
}
.btn-sm{padding:10px 22px;font-size:.85rem;}
.btn-lg{padding:18px 40px;font-size:1.05rem;}

/* ============================================================
   6. NAVIGATION
   ============================================================ */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  padding:20px 0;
  transition:var(--tr);
}
.nav.scrolled{
  background:rgba(3,7,18,.88);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:14px 0;
  box-shadow:var(--sh-md);
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
}
.nav-logo{
  display:flex;
  align-items:center;
  gap:12px;
  flex-shrink:0;
}
.nav-logo img{height:40px;width:auto;}
.nav-logo-text{
  font-family:var(--font-d);
  font-size:.85rem;
  font-weight:600;
  line-height:1.2;
  color:var(--text);
}
.nav-logo-text span{
  display:block;
  font-size:.65rem;
  font-weight:400;
  color:var(--muted);
  letter-spacing:.05em;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:4px;
}
.nav-links a{
  padding:8px 16px;
  border-radius:100px;
  font-size:.9rem;
  font-weight:500;
  color:var(--muted);
  transition:var(--tr);
  position:relative;
}
.nav-links a:hover,
.nav-links a.active{
  color:var(--white);
  background:rgba(255,255,255,.07);
}
.nav-links a.active::after{
  content:'';
  position:absolute;
  bottom:-2px;left:50%;
  transform:translateX(-50%);
  width:20px;height:2px;
  background:var(--grad-blue);
  border-radius:2px;
}
.nav-cta{display:flex;align-items:center;gap:12px;}
.nav-phone{
  font-size:.85rem;
  color:var(--muted);
  display:flex;
  align-items:center;
  gap:6px;
  transition:var(--tr);
}
.nav-phone:hover{color:var(--accent);}
.nav-phone i{color:var(--accent);font-size:.8rem;}
.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  padding:8px;
  border-radius:var(--r-sm);
  transition:var(--tr);
}
.hamburger span{
  display:block;
  width:24px;height:2px;
  background:var(--text);
  border-radius:2px;
  transition:var(--tr);
}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* Mobile drawer */
.mobile-menu{
  display:none;
  position:fixed;
  top:0;right:-100%;
  width:min(320px,100vw);
  height:100vh;
  background:var(--bg-2);
  border-left:1px solid var(--border);
  z-index:999;
  flex-direction:column;
  padding:90px 32px 40px;
  gap:8px;
  transition:right .35s var(--ease);
  box-shadow:-20px 0 60px rgba(0,0,0,.5);
}
.mobile-menu.open{right:0;}
.mobile-menu a{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;
  border-radius:var(--r-sm);
  font-size:1rem;
  font-weight:500;
  color:var(--muted);
  transition:var(--tr);
  border:1px solid transparent;
}
.mobile-menu a:hover{color:var(--white);background:rgba(59,130,246,.1);border-color:var(--border);}
.mobile-menu a i{width:20px;color:var(--primary);}
.mobile-menu .btn{margin-top:16px;justify-content:center;}
.overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
  z-index:998;
}
.overlay.open{display:block;}

/* ============================================================
   7. HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  background:var(--grad-hero);
  overflow:hidden;
  padding-top:80px;
}
.hero-canvas{
  position:absolute;
  inset:0;
  opacity:.7;
}
.hero-blobs{
  position:absolute;
  inset:0;
  pointer-events:none;
  overflow:hidden;
}
.hero-blob{
  position:absolute;
  border-radius:50%;
  filter:blur(80px);
  animation:blob-float 12s ease-in-out infinite;
}
.hero-blob-1{
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(59,130,246,.18),transparent 70%);
  top:-150px;right:-100px;
  animation-delay:0s;
}
.hero-blob-2{
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(6,182,212,.15),transparent 70%);
  bottom:-50px;left:5%;
  animation-delay:-4s;
}
.hero-blob-3{
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(16,185,129,.1),transparent 70%);
  top:40%;left:60%;
  animation-delay:-8s;
}
@keyframes blob-float{
  0%,100%{transform:translate(0,0) scale(1);}
  33%{transform:translate(-30px,40px) scale(1.08);}
  66%{transform:translate(25px,-20px) scale(.95);}
}
.hero-grid-overlay{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(59,130,246,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(59,130,246,.04) 1px,transparent 1px);
  background-size:60px 60px;
  pointer-events:none;
}
.hero-content{
  position:relative;
  z-index:2;
  max-width:760px;
}
.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 20px;
  background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.25);
  border-radius:100px;
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:28px;
}
.hero-badge::before{
  content:'';
  width:8px;height:8px;
  background:var(--accent);
  border-radius:50%;
  box-shadow:0 0 10px var(--accent);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:.5;transform:scale(.7);}
}
.hero-title{
  font-size:clamp(2.6rem,5.5vw,4.2rem);
  font-weight:800;
  line-height:1.1;
  color:var(--white);
  margin-bottom:12px;
  letter-spacing:-.02em;
}
.hero-typed-wrap{
  font-size:clamp(1.6rem,3.5vw,2.6rem);
  font-family:var(--font-d);
  font-weight:700;
  color:var(--muted);
  min-height:1.4em;
  margin-bottom:24px;
}
.typed-cursor{
  display:inline-block;
  width:3px;
  background:var(--accent);
  margin-left:2px;
  animation:blink .7s step-end infinite;
  vertical-align:middle;
  height:1em;
}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}
.hero-desc{
  font-size:1.1rem;
  color:var(--muted);
  max-width:600px;
  margin-bottom:36px;
  line-height:1.8;
}
.hero-btns{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.hero-trust{
  display:flex;
  align-items:center;
  gap:24px;
  margin-top:48px;
  flex-wrap:wrap;
}
.trust-item{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.85rem;
  color:var(--muted);
}
.trust-item i{color:var(--green);font-size:.8rem;}
.hero-scroll{
  position:absolute;
  bottom:40px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  color:var(--subtle);
  font-size:.75rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  animation:scroll-bounce 2s ease-in-out infinite;
}
.hero-scroll-bar{
  width:1px;
  height:50px;
  background:linear-gradient(var(--primary),transparent);
}
@keyframes scroll-bounce{
  0%,100%{transform:translateX(-50%) translateY(0);}
  50%{transform:translateX(-50%) translateY(8px);}
}

/* ============================================================
   8. STATS BAR
   ============================================================ */
.stats-bar{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:48px 0;
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  position:relative;
}
.stats-grid::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,transparent 24.5%,var(--border) 25%,var(--border) 25.5%,transparent 26%),
    linear-gradient(90deg,transparent 49.5%,var(--border) 50%,var(--border) 50.5%,transparent 51%),
    linear-gradient(90deg,transparent 74.5%,var(--border) 75%,var(--border) 75.5%,transparent 76%);
  pointer-events:none;
}
.stat-item{
  text-align:center;
  padding:16px 24px;
}
.stat-number{
  font-family:var(--font-d);
  font-size:clamp(2.2rem,4vw,3.2rem);
  font-weight:800;
  background:var(--grad-blue);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
  margin-bottom:8px;
}
.stat-label{
  font-size:.85rem;
  color:var(--muted);
  font-weight:500;
  letter-spacing:.03em;
}

/* ============================================================
   9. SERVICE CARDS
   ============================================================ */
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:60px;
}
.service-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:36px 28px;
  transition:var(--tr);
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.service-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:var(--grad-blue);
  transform:scaleX(0);
  transition:var(--tr);
  transform-origin:left;
}
.service-card:hover{
  border-color:var(--border-h);
  transform:translateY(-6px);
  box-shadow:var(--sh-lg),var(--sh-glow);
}
.service-card:hover::before{transform:scaleX(1);}
.service-icon{
  width:56px;height:56px;
  background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.2);
  border-radius:var(--r-sm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.5rem;
  margin-bottom:24px;
  color:var(--primary);
  transition:var(--tr);
}
.service-card:hover .service-icon{
  background:rgba(59,130,246,.18);
  border-color:rgba(59,130,246,.4);
  box-shadow:0 0 20px rgba(59,130,246,.2);
}
.service-card h3{
  font-size:1.15rem;
  font-weight:700;
  color:var(--white);
  margin-bottom:12px;
}
.service-card p{
  font-size:.9rem;
  color:var(--muted);
  line-height:1.7;
}
.service-card-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.85rem;
  font-weight:600;
  color:var(--primary);
  margin-top:20px;
  transition:var(--tr);
}
.service-card-link:hover{gap:12px;color:var(--accent);}

/* ============================================================
   10. FEATURED PRODUCT (SANAMENTE)
   ============================================================ */
.product-section{
  background:var(--bg-2);
  position:relative;
  overflow:hidden;
}
.product-section::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:radial-gradient(ellipse 60% 80% at 70% 50%,rgba(16,185,129,.08),transparent);
  pointer-events:none;
}
.product-features{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:28px;
}
.product-feature{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px;
  border-radius:var(--r-sm);
  background:rgba(16,185,129,.05);
  border:1px solid rgba(16,185,129,.12);
  transition:var(--tr);
}
.product-feature:hover{
  background:rgba(16,185,129,.1);
  border-color:rgba(16,185,129,.25);
}
.product-feature i{
  color:var(--green);
  font-size:1rem;
  flex-shrink:0;
  margin-top:2px;
}
.product-feature p{
  font-size:.85rem;
  color:var(--muted);
  line-height:1.5;
}
.product-feature h4{
  font-size:.9rem;
  color:var(--text);
  margin-bottom:4px;
}

/* ============================================================
   11. APP MOCKUP (Sanamente visual)
   ============================================================ */
.app-mockup-wrap{
  position:relative;
}
.app-mockup-wrap::before{
  content:'';
  position:absolute;
  inset:-40px;
  background:radial-gradient(circle,rgba(16,185,129,.15),transparent 70%);
  border-radius:50%;
  z-index:0;
}
.app-mockup{
  position:relative;
  z-index:1;
  background:var(--bg-2);
  border-radius:var(--r-lg);
  border:1px solid rgba(16,185,129,.2);
  overflow:hidden;
  box-shadow:var(--sh-lg),var(--sh-glow-g);
}
.mockup-bar{
  background:var(--bg-3);
  padding:14px 20px;
  display:flex;
  align-items:center;
  gap:12px;
  border-bottom:1px solid rgba(16,185,129,.1);
}
.mockup-dots{display:flex;gap:7px;}
.mockup-dots span{width:12px;height:12px;border-radius:50%;}
.mockup-dots span:nth-child(1){background:#EF4444;}
.mockup-dots span:nth-child(2){background:#F59E0B;}
.mockup-dots span:nth-child(3){background:#10B981;}
.mockup-url{
  flex:1;
  background:var(--bg);
  border-radius:100px;
  padding:5px 16px;
  font-size:.75rem;
  color:var(--muted);
  border:1px solid var(--border);
  font-family:monospace;
}
.mockup-body{
  display:grid;
  grid-template-columns:180px 1fr;
  min-height:320px;
}
.mockup-sidebar{
  background:rgba(3,7,18,.7);
  border-right:1px solid rgba(16,185,129,.1);
  padding:16px 0;
}
.mockup-logo{
  padding:8px 16px 20px;
  font-family:var(--font-d);
  font-weight:700;
  font-size:.85rem;
  color:var(--green);
  border-bottom:1px solid rgba(16,185,129,.1);
  margin-bottom:8px;
  display:flex;align-items:center;gap:8px;
}
.mockup-nav-item{
  padding:10px 16px;
  display:flex;align-items:center;gap:10px;
  font-size:.78rem;
  color:var(--muted);
}
.mockup-nav-item.active{
  background:rgba(16,185,129,.1);
  color:var(--green);
  border-left:3px solid var(--green);
}
.mockup-nav-item i{font-size:.85rem;width:16px;}
.mockup-main{padding:20px;background:rgba(3,7,18,.5);}
.mockup-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.mockup-header h5{font-size:.85rem;color:var(--white);font-family:var(--font);}
.mockup-badge{
  background:rgba(16,185,129,.15);
  color:var(--green);
  border-radius:100px;
  padding:2px 10px;
  font-size:.7rem;
  font-weight:600;
}
.mockup-card{
  background:rgba(15,23,42,.8);
  border:1px solid rgba(16,185,129,.1);
  border-radius:var(--r-sm);
  padding:14px;
  margin-bottom:10px;
  display:flex;align-items:center;gap:12px;
}
.mockup-avatar{
  width:36px;height:36px;
  border-radius:50%;
  background:var(--grad-green);
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;
  font-weight:700;
  color:#fff;
  flex-shrink:0;
}
.mockup-info h6{font-size:.8rem;color:var(--text);margin-bottom:3px;}
.mockup-info small{font-size:.72rem;color:var(--muted);}
.mockup-progress-bar{
  width:100%;height:4px;
  background:rgba(255,255,255,.08);
  border-radius:2px;
  margin-top:6px;
  overflow:hidden;
}
.mockup-progress{height:100%;background:var(--grad-green);border-radius:2px;}
.mockup-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;
}
.mockup-stat{
  background:rgba(15,23,42,.8);
  border:1px solid rgba(16,185,129,.1);
  border-radius:var(--r-sm);
  padding:10px 12px;
  text-align:center;
}
.mockup-stat .num{
  font-family:var(--font-d);
  font-size:1.1rem;
  font-weight:700;
  color:var(--green);
}
.mockup-stat .lbl{font-size:.68rem;color:var(--muted);}

/* ============================================================
   12. WHY CHOOSE US
   ============================================================ */
.pillars-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:60px;
}
.pillar{
  text-align:center;
  padding:36px 24px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:var(--tr);
  backdrop-filter:blur(12px);
}
.pillar:hover{
  border-color:var(--border-h);
  transform:translateY(-4px);
  box-shadow:var(--sh-glow);
}
.pillar-icon{
  width:64px;height:64px;
  background:var(--grad-blue);
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;color:#fff;
  margin:0 auto 20px;
  box-shadow:0 8px 24px rgba(59,130,246,.3);
}
.pillar h3{
  font-size:1rem;
  font-weight:700;
  color:var(--white);
  margin-bottom:10px;
}
.pillar p{font-size:.85rem;color:var(--muted);}

/* ============================================================
   13. TECH STACK
   ============================================================ */
.tech-section{background:var(--bg-2);}
.tech-pills{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:center;
  margin-top:48px;
}
.tech-pill{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 20px;
  background:rgba(15,23,42,.9);
  border:1px solid var(--border);
  border-radius:100px;
  font-size:.85rem;
  color:var(--muted);
  font-weight:500;
  transition:var(--tr);
  backdrop-filter:blur(8px);
}
.tech-pill:hover{
  border-color:var(--border-h);
  color:var(--text);
  background:rgba(59,130,246,.08);
}
.tech-pill i{color:var(--primary);font-size:1rem;}

/* ============================================================
   14. CTA SECTION
   ============================================================ */
.cta-section{
  background:linear-gradient(135deg,#0F172A,#1E293B);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;
  overflow:hidden;
}
.cta-section::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 60% 100% at 50% 50%,rgba(59,130,246,.1),transparent);
}
.cta-inner{
  position:relative;
  text-align:center;
  max-width:700px;
  margin:0 auto;
}
.cta-inner h2{color:var(--white);margin-bottom:16px;}
.cta-inner p{color:var(--muted);margin-bottom:36px;font-size:1.05rem;}

/* ============================================================
   15. CONTACT PAGE
   ============================================================ */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:48px;
  align-items:start;
}
.contact-info-cards{display:flex;flex-direction:column;gap:16px;}
.contact-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:24px;
  display:flex;align-items:flex-start;gap:16px;
  transition:var(--tr);
  backdrop-filter:blur(12px);
}
.contact-card:hover{
  border-color:var(--border-h);
  box-shadow:var(--sh-glow);
}
.contact-icon{
  width:48px;height:48px;
  background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.2);
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--primary);
  font-size:1.1rem;
  flex-shrink:0;
}
.contact-card h4{
  font-size:.95rem;color:var(--white);margin-bottom:4px;
}
.contact-card p,.contact-card a{
  font-size:.9rem;color:var(--muted);
  transition:var(--tr);
}
.contact-card a:hover{color:var(--accent);}

/* FORM */
.contact-form-wrap{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:48px;
  backdrop-filter:blur(12px);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.form-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.form-group label{
  font-size:.85rem;font-weight:600;color:var(--text);
}
.form-group input,
.form-group textarea,
.form-group select{
  background:rgba(15,23,42,.8);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  padding:14px 16px;
  color:var(--text);
  font-size:.9rem;
  transition:var(--tr);
  outline:none;
  width:100%;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(59,130,246,.12);
  background:rgba(15,23,42,.95);
}
.form-group select option{background:var(--bg-2);color:var(--text);}
.form-group textarea{resize:vertical;min-height:140px;}
.form-check{display:flex;align-items:flex-start;gap:12px;margin-top:8px;}
.form-check input[type="checkbox"]{
  width:18px;height:18px;
  flex-shrink:0;
  accent-color:var(--primary);
  margin-top:2px;
  cursor:pointer;
}
.form-check label{font-size:.82rem;color:var(--muted);cursor:pointer;}
.form-check a{color:var(--primary);}
.form-msg{
  display:none;
  padding:16px 20px;
  border-radius:var(--r-sm);
  font-size:.9rem;
  margin-top:16px;
}
.form-msg.success{
  background:rgba(16,185,129,.1);
  border:1px solid rgba(16,185,129,.3);
  color:var(--green);
  display:flex;align-items:center;gap:10px;
}
.form-msg.error{
  background:rgba(239,68,68,.1);
  border:1px solid rgba(239,68,68,.3);
  color:#EF4444;
  display:flex;align-items:center;gap:10px;
}

/* ============================================================
   16. PAGE HERO (inner pages)
   ============================================================ */
.page-hero{
  padding:160px 0 80px;
  background:var(--grad-hero);
  position:relative;
  overflow:hidden;
  text-align:center;
  border-bottom:1px solid var(--border);
}
.page-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(59,130,246,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(59,130,246,.04) 1px,transparent 1px);
  background-size:60px 60px;
  pointer-events:none;
}
.page-hero.green-theme{
  background:
    radial-gradient(ellipse 80% 60% at 20% 40%,rgba(16,185,129,.12) 0%,transparent 70%),
    radial-gradient(ellipse 60% 50% at 80% 15%,rgba(6,182,212,.08) 0%,transparent 60%),
    #030712;
}
.page-hero h1{color:var(--white);margin-bottom:16px;}
.page-hero p{max-width:620px;margin:0 auto;font-size:1.1rem;}
.breadcrumb{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.8rem;color:var(--subtle);
  margin-bottom:20px;
}
.breadcrumb a{color:var(--muted);transition:var(--tr);}
.breadcrumb a:hover{color:var(--primary);}
.breadcrumb span{color:var(--subtle);}

/* ============================================================
   17. NOSOTROS PAGE
   ============================================================ */
.mission-vision{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
  margin-top:60px;
}
.mv-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:40px 36px;
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(12px);
}
.mv-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:4px;
  background:var(--grad-blue);
}
.mv-card h3{
  font-size:1.3rem;color:var(--white);margin-bottom:16px;
  display:flex;align-items:center;gap:12px;
}
.mv-card h3 i{color:var(--primary);}
.mv-card p{color:var(--muted);line-height:1.8;}

.values-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:60px;
}
.value-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:32px 24px;
  text-align:center;
  transition:var(--tr);
  backdrop-filter:blur(12px);
}
.value-card:hover{
  border-color:var(--border-h);
  transform:translateY(-4px);
}
.value-icon{
  font-size:2.5rem;margin-bottom:16px;
  display:block;
}
.value-card h3{font-size:1rem;color:var(--white);margin-bottom:8px;}
.value-card p{font-size:.85rem;color:var(--muted);}

/* Timeline */
.timeline{
  position:relative;
  margin-top:60px;
  padding-left:40px;
}
.timeline::before{
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;
  width:2px;
  background:linear-gradient(var(--primary),var(--accent),transparent);
}
.timeline-item{
  position:relative;
  padding:0 0 48px 32px;
}
.timeline-item::before{
  content:'';
  position:absolute;
  left:-5px;top:4px;
  width:12px;height:12px;
  background:var(--primary);
  border-radius:50%;
  box-shadow:0 0 12px rgba(59,130,246,.5);
}
.timeline-year{
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.1em;
  color:var(--primary);
  text-transform:uppercase;
  margin-bottom:8px;
}
.timeline-item h3{
  font-size:1.05rem;color:var(--white);margin-bottom:8px;
}
.timeline-item p{font-size:.9rem;color:var(--muted);}

/* ============================================================
   18. SERVICIOS PAGE
   ============================================================ */
.service-detail{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
  padding:80px 0;
  border-bottom:1px solid var(--border);
}
.service-detail:last-child{border-bottom:none;}
.service-detail.reverse .service-detail-visual{order:-1;}
.service-detail-list{
  display:flex;flex-direction:column;gap:12px;margin-top:24px;
}
.service-detail-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 16px;
  background:rgba(59,130,246,.05);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  transition:var(--tr);
}
.service-detail-item:hover{
  background:rgba(59,130,246,.1);
  border-color:var(--border-h);
}
.service-detail-item i{color:var(--primary);flex-shrink:0;margin-top:2px;}
.service-detail-item p{font-size:.88rem;color:var(--muted);line-height:1.5;}
.service-visual{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:48px;
  text-align:center;
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(12px);
  aspect-ratio:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
}
.service-visual::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 50%,rgba(59,130,246,.1),transparent 70%);
}
.service-visual-icon{
  font-size:5rem;
  position:relative;
  z-index:1;
  filter:drop-shadow(0 0 30px rgba(59,130,246,.4));
}
.service-visual p{
  font-size:.9rem;color:var(--muted);position:relative;z-index:1;
}

/* ============================================================
   19. SANAMENTE FEATURES
   ============================================================ */
.sana-features-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:60px;
}
.sana-feature{
  background:var(--bg-card);
  border:1px solid rgba(16,185,129,.15);
  border-radius:var(--r-md);
  padding:32px 24px;
  transition:var(--tr);
  backdrop-filter:blur(12px);
}
.sana-feature:hover{
  border-color:rgba(16,185,129,.35);
  transform:translateY(-4px);
  box-shadow:var(--sh-glow-g);
}
.sana-feature-icon{
  width:52px;height:52px;
  background:rgba(16,185,129,.1);
  border:1px solid rgba(16,185,129,.2);
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--green);
  font-size:1.3rem;
  margin-bottom:20px;
}
.sana-feature h3{font-size:1rem;color:var(--white);margin-bottom:8px;}
.sana-feature p{font-size:.85rem;color:var(--muted);line-height:1.65;}

/* Compliance badges */
.compliance-section{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.compliance-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:48px;
}
.compliance-badge{
  background:rgba(16,185,129,.05);
  border:1px solid rgba(16,185,129,.15);
  border-radius:var(--r-md);
  padding:28px 24px;
  text-align:center;
  transition:var(--tr);
}
.compliance-badge:hover{
  border-color:rgba(16,185,129,.3);
  background:rgba(16,185,129,.08);
}
.compliance-badge i{
  font-size:2rem;color:var(--green);
  margin-bottom:12px;display:block;
}
.compliance-badge h4{font-size:.95rem;color:var(--white);margin-bottom:6px;}
.compliance-badge p{font-size:.82rem;color:var(--muted);}

/* Pricing */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:60px;
}
.pricing-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:40px 32px;
  transition:var(--tr);
  backdrop-filter:blur(12px);
  position:relative;
}
.pricing-card.featured{
  border-color:rgba(16,185,129,.4);
  box-shadow:var(--sh-glow-g);
}
.pricing-card.featured::before{
  content:'Más popular';
  position:absolute;
  top:-14px;left:50%;transform:translateX(-50%);
  background:var(--grad-green);
  color:#fff;
  font-size:.75rem;
  font-weight:700;
  padding:5px 20px;
  border-radius:100px;
  white-space:nowrap;
}
.pricing-name{font-size:1rem;color:var(--muted);font-weight:600;margin-bottom:8px;}
.pricing-price{
  font-family:var(--font-d);
  font-size:2.8rem;
  font-weight:800;
  color:var(--white);
  line-height:1;
  margin-bottom:4px;
}
.pricing-price span{font-size:1rem;font-weight:400;color:var(--muted);}
.pricing-period{font-size:.82rem;color:var(--muted);margin-bottom:28px;}
.pricing-feats{
  display:flex;flex-direction:column;gap:12px;
  margin-bottom:32px;
}
.pricing-feat{
  display:flex;align-items:center;gap:10px;
  font-size:.88rem;color:var(--muted);
}
.pricing-feat i{color:var(--green);font-size:.85rem;flex-shrink:0;}

/* ============================================================
   20. FOOTER
   ============================================================ */
.footer{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  padding:80px 0 0;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.5fr;
  gap:48px;
  padding-bottom:60px;
}
.footer-brand img{height:44px;margin-bottom:20px;}
.footer-brand p{
  font-size:.88rem;color:var(--muted);line-height:1.75;
  max-width:280px;margin-bottom:24px;
}
.social-links{display:flex;gap:10px;}
.social-link{
  width:38px;height:38px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);
  font-size:.9rem;
  transition:var(--tr);
}
.social-link:hover{
  background:rgba(59,130,246,.15);
  border-color:var(--primary);
  color:var(--primary);
  transform:translateY(-2px);
}
.footer-col h4{
  font-size:.9rem;
  font-weight:700;
  color:var(--white);
  margin-bottom:20px;
  letter-spacing:.03em;
}
.footer-links{display:flex;flex-direction:column;gap:10px;}
.footer-links a{
  font-size:.88rem;color:var(--muted);
  transition:var(--tr);
  display:flex;align-items:center;gap:6px;
}
.footer-links a::before{
  content:'';
  width:4px;height:4px;
  background:var(--primary);
  border-radius:50%;
  flex-shrink:0;
  opacity:0;
  transition:var(--tr);
}
.footer-links a:hover{color:var(--text);padding-left:8px;}
.footer-links a:hover::before{opacity:1;}
.footer-contact-item{
  display:flex;align-items:flex-start;gap:12px;
  margin-bottom:16px;
}
.footer-contact-item i{
  color:var(--primary);
  font-size:.9rem;
  flex-shrink:0;
  margin-top:2px;
}
.footer-contact-item span{font-size:.88rem;color:var(--muted);line-height:1.6;}
.footer-contact-item a{font-size:.88rem;color:var(--muted);transition:var(--tr);}
.footer-contact-item a:hover{color:var(--accent);}

.footer-bottom{
  border-top:1px solid var(--border);
  padding:24px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.footer-bottom p{font-size:.82rem;color:var(--subtle);}
.footer-bottom a{color:var(--muted);transition:var(--tr);}
.footer-bottom a:hover{color:var(--primary);}
.footer-bottom-links{display:flex;gap:20px;}

/* ============================================================
   21. FLOATING ELEMENTS
   ============================================================ */
.whatsapp-fab{
  position:fixed;
  bottom:32px;right:32px;
  z-index:900;
  width:56px;height:56px;
  background:#25D366;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  font-size:1.6rem;
  box-shadow:0 4px 20px rgba(37,211,102,.45);
  transition:var(--tr);
  animation:fab-entrance .5s var(--ease) .8s both;
}
.whatsapp-fab:hover{
  transform:scale(1.1) translateY(-2px);
  box-shadow:0 8px 32px rgba(37,211,102,.6);
}
@keyframes fab-entrance{
  from{opacity:0;transform:scale(0);}
  to{opacity:1;transform:scale(1);}
}

.scroll-top{
  position:fixed;
  bottom:32px;right:100px;
  z-index:900;
  width:44px;height:44px;
  background:rgba(15,23,42,.9);
  border:1px solid var(--border-h);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);
  font-size:.9rem;
  backdrop-filter:blur(8px);
  transition:var(--tr);
  opacity:0;pointer-events:none;
}
.scroll-top.visible{opacity:1;pointer-events:auto;}
.scroll-top:hover{color:var(--primary);border-color:var(--primary);transform:translateY(-2px);}

/* ============================================================
   22. ANIMATIONS / SCROLL REVEAL
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(30px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-left{
  opacity:0;
  transform:translateX(-30px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.reveal-left.visible{opacity:1;transform:translateX(0);}
.reveal-right{
  opacity:0;
  transform:translateX(30px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.reveal-right.visible{opacity:1;transform:translateX(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}
.reveal-delay-4{transition-delay:.4s;}
.reveal-delay-5{transition-delay:.5s;}
.reveal-delay-6{transition-delay:.6s;}

@keyframes shimmer{
  0%{background-position:-200% 0;}
  100%{background-position:200% 0;}
}
.shimmer{
  background:linear-gradient(90deg,transparent 0%,rgba(59,130,246,.08) 50%,transparent 100%);
  background-size:200% 100%;
  animation:shimmer 3s ease-in-out infinite;
}

/* ============================================================
   23. RESPONSIVE — TABLET
   ============================================================ */
@media(max-width:1024px){
  .grid-2,.service-detail{grid-template-columns:1fr;}
  .service-detail.reverse .service-detail-visual{order:0;}
  .grid-4,.pillars-grid{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .contact-grid{grid-template-columns:1fr;}
}

@media(max-width:900px){
  .services-grid,.sana-features-grid,.compliance-grid,.pricing-grid,
  .values-grid{grid-template-columns:1fr 1fr;}
  .mockup-body{grid-template-columns:1fr;}
  .mockup-sidebar{display:none;}
  .mission-vision{grid-template-columns:1fr;}
}

/* ============================================================
   24. RESPONSIVE — MOBILE
   ============================================================ */
@media(max-width:640px){
  .section{padding:70px 0;}
  .hero-title{font-size:2.2rem;}
  .hero-btns{flex-direction:column;align-items:flex-start;}
  .btn{width:100%;justify-content:center;}
  .hero-trust{gap:16px;}
  .services-grid,.sana-features-grid,.compliance-grid,.pricing-grid,
  .values-grid,.grid-3,.pillars-grid,.mission-vision{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .stats-grid::before{display:none;}
  .nav-links,.nav-phone,.nav-cta .btn{display:none;}
  .hamburger{display:flex;}
  .mobile-menu{display:flex;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .grid-4{grid-template-columns:1fr 1fr;}
  .form-row{grid-template-columns:1fr;}
  .contact-form-wrap{padding:28px 20px;}
  .hero-scroll{display:none;}
  .product-features{grid-template-columns:1fr;}
  .scroll-top{right:80px;}
}

/* ============================================================
   25. PROCESS STEPS
   ============================================================ */
.process-steps{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  gap:0;
  align-items:start;
  margin-top:60px;
}
.process-step{
  text-align:center;
  padding:0 16px;
  position:relative;
}
.process-num{
  font-family:var(--font-d);
  font-size:3.5rem;
  font-weight:900;
  background:var(--grad-blue);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
  margin-bottom:16px;
  opacity:.35;
}
.process-icon{
  width:72px;height:72px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;color:var(--primary);
  margin:0 auto 20px;
  backdrop-filter:blur(12px);
  transition:var(--tr);
}
.process-step:hover .process-icon{
  border-color:var(--border-h);
  box-shadow:var(--sh-glow);
  transform:translateY(-4px);
}
.process-step h3{
  font-size:1rem;font-weight:700;
  color:var(--white);margin-bottom:10px;
}
.process-step p{font-size:.85rem;color:var(--muted);line-height:1.6;}
.process-connector{
  display:flex;align-items:center;justify-content:center;
  padding-top:100px;
  color:var(--primary);
  opacity:.4;
  font-size:1.5rem;
}
.process-connector::after{
  content:'›';
  display:block;
}

/* ============================================================
   26. TESTIMONIALS
   ============================================================ */
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.testimonial-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:36px;
  backdrop-filter:blur(12px);
  display:flex;
  flex-direction:column;
  gap:20px;
  transition:var(--tr);
  position:relative;
  overflow:hidden;
}
.testimonial-card::before{
  content:'\201C';
  position:absolute;
  top:12px;right:24px;
  font-size:6rem;
  color:var(--primary);
  opacity:.08;
  font-family:Georgia,serif;
  line-height:1;
}
.testimonial-card:hover{
  border-color:var(--border-h);
  transform:translateY(-4px);
  box-shadow:var(--sh-glow);
}
.test-stars{
  display:flex;gap:4px;
  color:#F59E0B;
  font-size:.9rem;
}
.testimonial-card blockquote{
  font-size:.95rem;
  color:var(--text);
  line-height:1.75;
  font-style:italic;
  flex:1;
  position:relative;
}
.test-author{
  display:flex;align-items:center;gap:14px;
  padding-top:20px;
  border-top:1px solid var(--border);
}
.test-avatar{
  width:44px;height:44px;
  background:var(--grad-blue);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;font-weight:700;
  color:#fff;flex-shrink:0;
}
.test-author strong{
  display:block;font-size:.9rem;
  color:var(--white);margin-bottom:2px;
}
.test-author span{font-size:.78rem;color:var(--muted);}

/* ============================================================
   27. FAQ
   ============================================================ */
.faq-list{
  max-width:820px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.faq-item{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  backdrop-filter:blur(12px);
  overflow:hidden;
  transition:border-color var(--tr);
}
.faq-item[open]{border-color:var(--border-h);}
.faq-item summary{
  padding:24px 28px;
  font-size:1rem;
  font-weight:600;
  color:var(--white);
  cursor:pointer;
  list-style:none;
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;
  user-select:none;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:'+';
  font-size:1.4rem;
  color:var(--primary);
  font-weight:300;
  flex-shrink:0;
  transition:transform var(--tr);
}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-item summary:hover{color:var(--primary);}
.faq-answer{
  padding:0 28px 24px;
  border-top:1px solid var(--border);
}
.faq-answer p{font-size:.95rem;color:var(--muted);line-height:1.75;margin:0;padding-top:20px;}

/* Responsive additions */
@media(max-width:900px){
  .process-steps{
    grid-template-columns:1fr 1fr;
    gap:24px;
  }
  .process-connector{display:none;}
  .testimonials-grid{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .process-steps{grid-template-columns:1fr;}
  .testimonials-grid{grid-template-columns:1fr;}
}
