/* =========================================================
   EXTERMIMEX — styles.css (COMPLETO)
   ========================================================= */

/* ---------- Paleta corporativa ---------- */
:root{
  --color-primary:#0084DD;
  --color-primary-dark:#0487D9;
  --color-bg:#F2F2F2;
  --color-white:#FFFFFF;
  --color-text:#010440;
  --color-muted:#6b7280;
  --color-footer:#00004F;
  --color-footer-text:#e5e7eb;
}

/* ---------- Base ---------- */
*{ box-sizing:border-box }
html,body{ height:100% }
body{
  font-family:'Inter', Arial, sans-serif;
  background:var(--color-bg);
  color:var(--color-text);
  margin:0;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5,h6{ font-weight:700; margin-top:0 }
a{ color:inherit }

/* bloquear scroll al abrir menú/modal */
body.no-scroll{ overflow:hidden; }

/* =========================================================
   HEADER / NAV
   ========================================================= */
.header { position: sticky; top: 0; z-index: 50; }

.container{ max-width:1200px; margin:0 auto; padding:0 12px; }

/* distribuye: logo izq, menú centro, contacto/redes der */
.nav-flex{
  display:flex; align-items:center; min-height:70px;
  gap:24px; justify-content:space-between;
}

/* Logo (izquierda) */
.logo-block{ flex:0 0 auto; display:flex; align-items:center; gap:10px; }
.logo-img{ height:42px; width:auto; object-fit:contain; }
.logo-title{ font-weight:700; font-size:1.05rem; color:var(--color-text); }
.logo-years{ font-size:.8em; color:var(--color-muted); margin-left:4px; }

/* Menú (centro) */
.nav-menu{ flex:1 1 auto; display:flex; justify-content:center; }
.nav-menu ul{
  display:flex; align-items:center; justify-content:center;
  gap:18px; list-style:none; margin:0; padding:0;
}
.nav-menu a{
  color:var(--color-text); font-weight:500;
  padding:8px 12px; border-radius:8px;
  transition:background .2s, color .2s; text-decoration:none;
}
.nav-menu a:hover{ background:var(--color-bg); color:var(--color-primary); }

/* Dropdown (desktop) */
.dropdown{ position:relative; }
.nav-menu .dropdown-menu{
  display:none; position:absolute; top:100%; left:0;
  background:var(--color-white);
  box-shadow:0 8px 32px rgba(16,24,40,0.12);
  border-radius:12px; min-width:200px; padding:8px 0; z-index:10;
}
.nav-menu .dropdown-menu li a{
  display:block; padding:10px 20px; color:var(--color-text);
  font-weight:400; text-decoration:none;
}
.nav-menu .dropdown-menu li a:hover{ background:var(--color-bg); color:var(--color-primary); }
@media (min-width:901px){
  .nav-menu .dropdown:hover > .dropdown-menu{ display:block; }
}

/* Caret en items con submenu (desktop) */
.nav-menu > ul > li.dropdown > a{ position:relative; padding-right:18px; }
.nav-menu > ul > li.dropdown > a::after{
  content:"▾"; font-size:.8em; line-height:1;
  position:absolute; right:6px; top:50%; transform:translateY(-50%);
  color:var(--color-muted); transition:transform .2s ease;
}
@media (min-width:901px){
  .nav-menu > ul > li.dropdown:hover > a::after{ transform:translateY(-50%) rotate(180deg); }
}

/* Contacto + Redes (derecha) */
.nav-contact{ flex:0 0 auto; display:flex; align-items:center; gap:10px; }
.nav-phone{ color:var(--color-muted); font-size:.98rem; text-decoration:none; font-weight:500; }

/* =========================================================
   BOTONES SOCIALES EN NAV
   ========================================================= */
.nav-social-group{ display:inline-flex; gap:8px; margin-left:6px; }

/* --- Base común para WA/FB/IG + Tel --- */
.wa-nav-btn, .fb-nav-btn, .ig-nav-btn, .phone-icon-btn{
  width:45px; height:45px;
  display:flex; align-items:center; justify-content:center;
  position:relative; border:none; background:transparent;
  border-radius:9px; cursor:pointer; padding:0;
  transition:transform .25s ease; color:#fff; isolation:isolate;
}
.wa-svgContainer, .fb-svgBox, .ig-svgBox{
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  background:transparent; backdrop-filter:blur(4px);
  border:1px solid rgba(15,23,42,.15);
  border-radius:10px; z-index:1;
}
.wa-svgIcon, .fb-svg, .ig-svg{ width:1.4em; height:1.4em; fill:currentColor; }
.wa-BG, .fb-BG, .ig-BG, .phone-BG{
  position:absolute; inset:0; border-radius:9px; z-index:0;
  transition:transform .25s ease;
}

/* Colores de fondo */
.wa-BG{ background:#00d757; }
.fb-BG{ background:#1877F2; }
.ig-BG{
  background:radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%,
            #fd5949 45%, #d6249f 60%, #285AEB 90%);
}
.phone-BG{ background: var(--color-footer); }

/* Hover */
.wa-nav-btn:hover .wa-BG,
.fb-nav-btn:hover .fb-BG,
.ig-nav-btn:hover .ig-BG,
.phone-icon-btn:hover .phone-BG{
  transform:rotate(35deg) scale(1.03);
  transform-origin:bottom;
}
.wa-nav-btn:hover .wa-svgContainer,
.fb-nav-btn:hover .fb-svgBox,
.ig-nav-btn:hover .ig-svgBox,
.phone-icon-btn:hover .phone-svg{
  background:rgba(15,23,42,.08);
}

/* Teléfono con tooltip */
.phone-hover-container{ position:relative; display:inline-block; }
.phone-svg{ width:1.4em; height:1.4em; display:flex; align-items:center; justify-content:center; z-index:1; position:relative; }
.phone-tooltip{
  position:absolute; left:110%; top:50%; transform:translateY(-50%);
  background:#222; color:#fff; padding:6px 16px; border-radius:8px;
  white-space:nowrap; opacity:0; pointer-events:none;
  transition:opacity .3s, left .3s; font-size:1rem; z-index:10;
}
.phone-hover-container:hover .phone-tooltip,
.phone-hover-container:focus-within .phone-tooltip{ opacity:1; left:120%; pointer-events:auto; }

/* Seguridad extra para que siempre sean botones inline */
.logo-block{ display:flex !important; }
.nav-contact > a, .nav-social-group > a { display:inline-flex; }

/* =========================================================
   MENÚ HAMBURGUESA (drawer móvil — opcional)
   ========================================================= */
.nav-toggle{
  display:none; background:#fff; border:none; border-radius:8px;
  width:44px; height:44px; align-items:center; justify-content:center;
  cursor:pointer; position:relative; z-index:101;
}
.nav-toggle span{ display:block; width:28px; height:4px; background:#222; margin:4px 0; border-radius:2px; transition:all .3s; }

/* Panel móvil (drawer) */
.mobile-menu{
  position:fixed; top:0; right:0;
  width:100vw; max-width:340px; height:100vh;
  background:#fff; box-shadow:-2px 0 16px rgba(0,0,0,.12);
  z-index:1000; transform:translateX(100%);
  transition:transform .35s cubic-bezier(.77,.2,.05,1.0);
  overflow-y:auto; visibility:hidden;
}
.mobile-menu.open{ transform:translateX(0); visibility:visible; }
.mobile-menu-content{ padding:32px 18px 18px; display:flex; flex-direction:column; gap:24px; position:relative; z-index:1001; }
.mobile-menu-close{
  background:none; border:none; font-size:2.2rem; color:#222;
  position:absolute; top:18px; right:18px; cursor:pointer; z-index:1010;
}
.mobile-menu-list{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:12px;
}
.mobile-menu-list > li > a{
  font-size:1.1rem; color:#222; text-decoration:none; font-weight:600;
  padding:10px 0; border-bottom:1px solid #eee; display:block;
}
.mobile-menu-list .dropdown-menu{
  list-style:none; padding-left:18px; margin:0;
  display:flex; flex-direction:column; gap:8px;
}
.mobile-menu-list .dropdown > a{ font-weight:700; color:var(--color-primary-dark); }
.mobile-social-group{ display:flex; gap:10px; margin-top:18px; justify-content:flex-start; flex-wrap:wrap; }

/* Backdrop del drawer */
.mobile-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.45);
  opacity:0; pointer-events:none; transition:opacity .2s ease; z-index:990;
}
.mobile-backdrop.show{ opacity:1; pointer-events:auto; }

/* Mostrar/ocultar en breakpoints */
@media (max-width:900px){
  .nav-menu{ display:none !important; }
  .nav-contact{ gap:0; }
  .nav-toggle{ display:flex !important; }
}
@media (min-width:901px){
  .mobile-menu{ display:none !important; }
}

/* Ocultar redes en pantallas muy pequeñas (ahorra espacio) */
@media (max-width:500px){
  .nav-social-group{ display:none !important; }
}

/* =========================================================
   MODAL NAV — móvil full-screen / sheet en desktop
   ========================================================= */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Contenedor del modal */
.nav-modal{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}
.nav-modal.is-open{ display:block; }
 .nav-modal.is-open{ display:block !important; visibility:visible !important; opacity:1 !important; }

/* Fondo borroso */
.nav-modal__backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(3px) saturate(120%);
  -webkit-backdrop-filter: blur(3px) saturate(120%);
}

/* Panel */
.nav-modal__panel{
  position:absolute;
  right:0; top:0; bottom:0;

  /* MÓVIL: ocupa toda la pantalla */
  width:100vw; max-width:100%;
  background:#fff; color:#111;

  overflow-y:auto;
  transform:translateX(100%);
  transition:transform .28s ease;

  /* en móvil: sin sombra, sin bordes redondeados */
  box-shadow:none; border-radius:0;
  padding:16px;
}
.nav-modal.is-open .nav-modal__panel{ transform:translateX(0); }

/* Botón cerrar */
.nav-modal__close{
  position:sticky; top:0; margin-left:auto;
  width:44px; height:44px; border:0; background:transparent;
  font-size:24px; line-height:1; cursor:pointer; color:#111;
}

/* Lista principal */
.nav-modal__list{
  list-style:none; margin:8px 0 0; padding:0;
  display:grid; gap:10px;
  background: #fff !important;
  color: #111 !important;
}
.nav-modal__list > li > a,
.nav-acc > summary{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; padding:12px 14px; border-radius:10px;
  font-weight:700; color:#0f172a; text-decoration:none;
  background:#f3f4f6;
  color: #111 !important;
  background: #f3f4f6 !important;
  border: 1px solid #e5e7eb !important;
}
.nav-modal__list a:hover,
.nav-acc > summary:hover{ background:#e5e7eb; }

/* Submenús tipo acordeón (sin JS) */
.nav-acc{ border-radius:10px; overflow:hidden; background:#f3f4f6; }
.nav-acc > summary{ list-style:none; cursor:pointer; }
.nav-acc > summary::-webkit-details-marker{ display:none; }
.nav-acc > summary::after{ content:"▾"; font-size:14px; transition:transform .2s; }
.nav-acc[open] > summary::after{ transform:rotate(-180deg); }
.nav-acc > ul{
  list-style:none; margin:0; padding:6px 8px 10px;
  display:grid; gap:6px; background:#fff;
}
.nav-acc > ul a{
  display:block; padding:10px 12px; border-radius:8px;
  color:#334155; text-decoration:none; background:#f8fafc; border:1px solid #eef2f7;
}
.nav-acc > ul a:hover{ background:#eef2ff; border-color:#e2e8f0; }

/* bloque social/teléfono en modal */
.nav-modal__social{
  padding:8px 16px 20px; display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}
.nav-phone-chip{
  background:#00004F; color:#fff; padding:8px 12px; border-radius:10px; text-decoration:none; font-weight:700;
}

/* En pantallas ≥640px convertir a “sheet” lateral */
@media (min-width:640px){
  .nav-modal__panel{
    width:22rem;            /* ~352px */
    max-width:90vw;
    border-top-left-radius:16px;
    border-bottom-left-radius:16px;
    box-shadow:0 20px 60px rgba(0,0,0,.25);
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  }
}
@media (min-width:1024px){
  .nav-modal__panel{ width:26rem; }
}

/* (opcional) si usas solo el modal, oculta nav desktop en móvil */
@media (max-width:900px){
  .nav-menu{ display:none !important; }
  .nav-toggle{ display:flex !important; }
}

/* =========================================================
   BOTONES GENERALES
   ========================================================= */
.btn-primary{
  background:var(--color-primary); color:#fff; padding:8px 18px; border-radius:8px;
  font-weight:600; font-size:1rem; border:none; cursor:pointer;
  transition:background .2s; text-decoration:none; display:inline-block;
}
.btn-primary:hover{ background:var(--color-primary-dark); }
.btn-outline{
  background:#fff; color:var(--color-primary); padding:8px 18px; border-radius:8px;
  font-weight:700; border:2px solid var(--color-primary);
  text-decoration:none; display:inline-block; transition:background .2s, color .2s, border-color .2s;
}
.btn-outline:hover{ background:rgba(255,255,255,.9); }
.btn-ghost{
  background:rgba(255,255,255,.12); color:#fff; padding:8px 18px; border-radius:8px;
  font-weight:700; border:1px solid rgba(255,255,255,.22);
  text-decoration:none; display:inline-block; backdrop-filter:blur(4px);
}
.btn-ghost:hover{ background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.35); }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; min-height:100vh; height:100vh; width:100%; display:grid; place-items:center; background:#000; overflow:hidden; }
.hero-carousel{ position:absolute; inset:0; }
.hero-slide{ position:absolute; inset:0; opacity:0; visibility:hidden; transition:opacity .45s ease, visibility .45s ease; }
.hero-slide.is-active{ opacity:1; visibility:visible; }
.hero-slide img,.hero-slide video{ width:100%; height:100%; object-fit:cover; display:block; }
.hero-overlay{ position:absolute; inset:0; background:linear-gradient(to bottom,rgba(0,0,0,.25),rgba(0,0,0,.45)); pointer-events:none; }
.hero-content{ position:relative; z-index:2; text-align:center; color:#fff; padding-block:48px; }
.hero-title{ font-size:clamp(28px,3.2vw,44px); line-height:1.15; margin:0 0 14px 0; font-weight:800; text-shadow:0 2px 10px rgba(0,0,0,.35); }
.pill{ display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border-radius:999px; background:rgba(255,255,255,.9); color:var(--color-text); font-weight:600; box-shadow:0 8px 24px rgba(2,6,23,.12); }
.hero-pill{ margin:0 auto 16px; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:6px; }
.hero-dots{ display:flex; gap:8px; justify-content:center; margin-top:14px; }
.hero-dot{ width:8px; height:8px; border-radius:999px; background:rgba(255,255,255,.55); border:1px solid rgba(255,255,255,.75); cursor:pointer; }
.hero-dot.is-active{ background:var(--color-primary); border-color:#fff; }
.hero-nav{
  position:absolute; top:50%; transform:translateY(-50%); z-index:3;
  width:40px; height:40px; border-radius:999px; border:none;
  display:grid; place-items:center; background:rgba(255,255,255,.2);
  color:#fff; cursor:pointer; backdrop-filter:blur(4px); transition:background .2s;
}
.hero-nav:hover{ background:rgba(255,255,255,.32); }
.hero-nav.prev{ left:14px; } .hero-nav.next{ right:14px; }

/* =========================================================
   LIGHTBOX (equipo)
   ========================================================= */
.lb-overlay{
  position:fixed; inset:0; background:rgba(0,0,0,.75);
  display:none; align-items:center; justify-content:center; z-index:1000;
}
.lb-overlay.is-open{ display:flex; }
.lb-dialog{
  position:relative; max-width:min(92vw,1200px); max-height:90vh;
  display:grid; grid-template-rows:1fr auto; gap:10px; background:#000;
  border-radius:12px; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.35);
}
.lb-media{ display:grid; place-items:center; background:#000; }
.lb-media img{ max-width:100%; max-height:80vh; display:block; }
.lb-caption{
  padding:10px 14px; color:#fff; font:500 14px/1.4 'Inter',system-ui,sans-serif;
  background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.5));
}
.lb-close,.lb-prev,.lb-next{
  position:absolute; top:10px; width:40px; height:40px; display:grid; place-items:center;
  border:none; border-radius:999px; background:rgba(255,255,255,.18); color:#fff; cursor:pointer; backdrop-filter:blur(4px);
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{ background:rgba(255,255,255,.3); }
.lb-close{ right:10px; }
.lb-prev{ left:10px; top:50%; transform:translateY(-50%); }
.lb-next{ right:10px; top:50%; transform:translateY(-50%); }

/* =========================================================
   RESPONSIVE / TUNING
   ========================================================= */
@media (max-width:1148px){
  .container{ max-width:100vw; padding-left:8px; padding-right:8px; }
  .nav-flex{ gap:10px; min-height:62px; }
  .nav-menu ul{ gap:10px; }
  .nav-contact{ gap:6px; }
  .logo-img{ height:36px; }
}
@media (max-width:1024px){
  .nav-menu > ul{ gap:14px; }
  .logo-img{ height:38px; }
}
@media (max-width:960px){
  .nav-contact{ gap:8px; }
  .nav-phone{ display:none; }
}
@media (max-width:1024px){
  .container{ max-width:100vw; padding-left:4px; padding-right:4px; }
  .nav-flex{ gap:6px; min-height:56px; }
  .nav-menu ul{ gap:6px; }
  .nav-contact{ gap:4px; }
  .logo-img{ height:30px; }
  .wa-nav-btn, .fb-nav-btn, .ig-nav-btn, .phone-icon-btn{ width:38px; height:38px; }
}
@media (max-width:640px){
  .nav-phone{ display:none; }
}
@media (max-width:600px){
  body{ padding:0; }
  .container{ padding-left:12px !important; padding-right:12px !important; }
  section{ padding-left:0 !important; padding-right:0 !important; }

  h1,.hero-title{ font-size:1.7rem !important; line-height:1.2 !important; margin-bottom:10px !important; }
  h2{ font-size:1.2rem !important; margin-bottom:8px !important; }
  h3{ font-size:1rem !important; margin-bottom:6px !important; }

  .hero-content{ padding-block:10px !important; }
  .pill,.hero-pill{ font-size:.95rem !important; padding:8px 12px !important; margin-bottom:10px !important; }
  .hero-ctas{ gap:6px !important; margin-top:2px !important; }

  section,.py-16,.md\:py-20{ padding-top:18px !important; padding-bottom:18px !important; }
  .grid,.gap-8,.gap-6,.gap-4{ gap:12px !important; }
  .text-slate-600,.text-slate-700,.text-slate-500{ font-size:.98rem !important; line-height:1.5 !important; }

  #certificaciones .grid{ gap:14px !important; }
  #certificaciones article,#certificaciones .bg-white{ padding:12px !important; }
  #clientes .flex.flex-wrap{ gap:8px !important; margin-bottom:10px !important; }
  #clientes .grid{ gap:10px !important; }
  #clientes .text-center{ margin-bottom:8px !important; }
}

/* =========================================================
   SECCIONES CON FONDO GRADIENTE
   ========================================================= */
#sectores {
  background: #00004F;
  background: linear-gradient(204deg, rgba(0, 0, 79, 1) 9%, rgba(56, 116, 255, 1) 100%);
}

#clientes {
  background: #00004F;
  background: linear-gradient(31deg, rgba(0, 0, 79, 1) 9%, rgba(56, 116, 255, 1) 100%);
}

#cta-urgente {
  background:  #00004F;
background: linear-gradient(204deg, rgba(0, 0, 79, 1) 0%, rgba(56, 116, 255, 1) 100%);
}

#clientes, #sectores {
  color: #fff;
}
#clientes h2, #clientes h3, #clientes .section-title,
#sectores h2, #sectores h3, #sectores .section-title {
  color: #fff;
}
#clientes p, #sectores p {
  color: #f3f4f6;
}

/* =========================================================
   CLASES ADICIONALES
   ========================================================= */
.text-justify {
  text-align: justify;
}

/* =========================================================
  TESTIMONIOS / OPINIONES
  ========================================================= */
.reviews-section{ padding:48px 0; }
.reviews-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:18px; max-width:1100px; margin:0 auto; padding:0 12px; }
.review-card{ background:var(--color-white); border-radius:12px; padding:16px; box-shadow:0 8px 24px rgba(2,6,23,.06); border:1px solid rgba(15,23,42,.04); display:flex; gap:12px; align-items:flex-start; }
.review-avatar{ width:56px; height:56px; border-radius:999px; display:grid; place-items:center; color:#fff; font-weight:700; font-size:20px; flex:0 0 56px; }
.review-content{ flex:1 1 auto; }
.review-author{ font-weight:700; color:var(--color-text); font-size:0.98rem; }
.review-meta{ font-size:0.85rem; color:var(--color-muted); margin-bottom:6px; }
.review-stars{ color:#FFD600; margin-bottom:8px; }
.review-text{ color:var(--color-text); line-height:1.4; }

/* colores de avatar por inicial (ejemplos) */
.avatar-bg-A{ background:#F97316; } /* naranja */
.avatar-bg-B{ background:#06B6D4; } /* cyan */
.avatar-bg-C{ background:#6366F1; } /* indigo */
.avatar-bg-D{ background:#10B981; } /* verde */
.avatar-bg-E{ background:#EF4444; } /* rojo */
.avatar-bg-default{ background:#374151; }


#clientes .bg-white,
#clientes .bg-white * {
  color: #010440 !important;
}

#clientes .bg-white .text-yellow-400 {
  color: #FFD600 !important;
}
#clientes .bg-white svg {
  color: #FFD600 !important;
  fill: #FFD600 !important;
}
#clientes .bg-white .text-brand-800,
#clientes .bg-white .text-slate-500,
#clientes .bg-white .text-slate-700,
#clientes .bg-white h3,
#clientes .bg-white p,
#clientes .bg-white span {
  color: #010440 !important;
}

/* =========================================================
   CARRUSEL DE TESTIMONIOS
   ========================================================= */
.testimonios-carousel {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 12px;
}

.testimonios-wrapper {
  overflow: hidden;
  border-radius: 16px;
}

.testimonios-track {
  display: flex;
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  gap: 20px;
}

.testimonio-slide {
  flex: 0 0 100%;
  min-width: 0;
  transition: opacity 0.3s ease;
}

/* Avatares por inicial */
.testimonio-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  flex-shrink: 0;
}

/* Colores de avatares por inicial */
.avatar-A { background: linear-gradient(135deg, #FF6B6B, #FF8E8E); }
.avatar-B { background: linear-gradient(135deg, #4ECDC4, #44A08D); }
.avatar-D { background: linear-gradient(135deg, #45B7D1, #96C6EA); }
.avatar-E { background: linear-gradient(135deg, #96CEB4, #FFEAA0); }
.avatar-J { background: linear-gradient(135deg, #FECA57, #48CAE4); }
.avatar-L { background: linear-gradient(135deg, #FF9FF3, #F368E0); }
.avatar-M { background: linear-gradient(135deg, #54A0FF, #5F27CD); }
.avatar-P { background: linear-gradient(135deg, #00D2D3, #54A0FF); }
.avatar-R { background: linear-gradient(135deg, #FF9F43, #EE5A24); }
.avatar-Z { background: linear-gradient(135deg, #A55EEA, #26DE81); }

/* Controles del carrusel */
.testimonios-controls {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  pointer-events: none;
  z-index: 10;
}

.testimonio-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.9);
  color: #333;
  font-size: 20px;
  font-weight: bold;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
  pointer-events: auto;
  backdrop-filter: blur(4px);
}

.testimonio-btn:hover {
  background: rgba(255, 255, 255, 1);
  transform: scale(1.05);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
}

.testimonio-btn.prev {
  margin-left: -22px;
}

.testimonio-btn.next {
  margin-right: -22px;
}

/* Indicadores */
.testimonios-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 24px;
}

.testimonio-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
  cursor: pointer;
  transition: all 0.3s ease;
  border: 2px solid transparent;
}

.testimonio-dot.active {
  background: #fff;
  border-color: var(--color-primary);
  transform: scale(1.2);
}

/* Responsive para carrusel */
@media (min-width: 768px) {
  .testimonio-slide {
    flex: 0 0 calc(50% - 10px);
  }
}

@media (min-width: 1024px) {
  .testimonio-slide {
    flex: 0 0 calc(33.333% - 14px);
  }
}

@media (max-width: 640px) {
  .testimonios-controls {
    display: none;
  }
  
  .testimonio-slide {
    padding: 0 8px;
  }
  
  .testimonios-carousel {
    padding: 0 8px;
  }
}
