/* ============================================================
   SyA Group Chile · main.css — Rev. 2026-G
   Cambios respecto a Rev. 2026-F:
   - Carrusel servicios: fix completo mobile/desktop
     · overflow:hidden en wrapper (corta slide siguiente)
     · aspect-ratio responsivo: 16/9 → 4/3 → 1/1
     · botones y dots más grandes (42px / 9px dot)
   - Título "Galería de proyectos": tamaño aumentado con clamp
   ============================================================ */

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

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }

/* ─── TOKENS ────────────────────────────────────────── */
:root {
  --off-white:    #F4F6FB;
  --parchment:    #EAF0F8;
  --bone:         #DDE5F2;
  --cloud:        #FAFBFD;
  --brand-blue:   #1249A0;
  --brand-blue2:  #0D3C84;
  --brand-blue3:  #082D66;
  --brand-blue-lt:#3B6EC4;
  --brand-sky:    #5B9BD5;
  --brand-accent: #0EA5E9;
  --brand-warm:   #E67E22;
  --brand-warm2:  #C9680F;
  --brand-warm-lt:#F5A04A;
  --brand-warm-bg:rgba(230,126,34,0.09);
  --ink:          #0D1B2E;
  --ink-mid:      #1E3352;
  --ink-muted:    #4E6278;
  --ink-faint:    #6B84A0;
  --ink-ghost:    #8BA4BC;
  --on-dark-primary:   #FFFFFF;
  --on-dark-secondary: rgba(255,255,255,0.80);
  --on-dark-muted:     rgba(255,255,255,0.60);
  --on-dark-faint:     rgba(255,255,255,0.45);
  --rule:         rgba(18,73,160,0.08);
  --rule-mid:     rgba(18,73,160,0.14);
  --rule-dark:    rgba(18,73,160,0.22);
  --dark-bg:      #05111F;
  --dark-surface: #0C1828;
  --dark-card:    #112037;
  --dark-card-hover: #162844;
  --font-display: 'Barlow Condensed','Arial Narrow',sans-serif;
  --font-sans:    'Barlow',system-ui,sans-serif;
  --font-serif:   'IBM Plex Serif',Georgia,serif;
  --shadow-xs:  0 1px 3px rgba(18,73,160,0.07);
  --shadow-sm:  0 2px 8px rgba(18,73,160,0.09),0 1px 2px rgba(18,73,160,0.05);
  --shadow-md:  0 8px 30px rgba(18,73,160,0.12),0 2px 8px rgba(18,73,160,0.07);
  --shadow-lg:  0 20px 60px rgba(18,73,160,0.14),0 4px 16px rgba(18,73,160,0.09);
  --shadow-xl:  0 40px 100px rgba(18,73,160,0.16);
  --r-sm: 6px;
  --r-md: 12px;
  --r-lg: 20px;
  --r-xl: 28px;
}

/* ─── BASE ──────────────────────────────────────────── */
body {
  font-family: var(--font-sans);
  background: var(--off-white);
  color: var(--ink);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}

/* ─── SCROLL PROGRESS ───────────────────────────────── */
#scroll-progress {
  position:fixed; top:0; left:0; height:3px; z-index:9000;
  background:linear-gradient(90deg,var(--brand-blue),var(--brand-warm),var(--brand-warm-lt));
  width:0%; transition:width .05s linear;
  box-shadow:0 0 12px rgba(230,126,34,.5);
}

/* ─── UTILITIES ─────────────────────────────────────── */
.section-inner { max-width:1280px; margin:0 auto; padding:0 48px; }
@media(max-width:768px){ .section-inner { padding:0 24px; } }

.section-label {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.67rem; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--brand-blue); margin-bottom:14px;
}
.section-label::before {
  content:''; display:block; width:18px; height:2px;
  background:var(--brand-blue); border-radius:2px;
}
.section-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-sans); font-size:.68rem; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:var(--brand-blue);
  margin-bottom:18px;
}
.section-eyebrow::before {
  content:''; display:block; width:20px; height:2px;
  background:var(--brand-blue); border-radius:2px;
}

h2,h3 {
  font-family:var(--font-display);
  font-weight:600; line-height:1.08; letter-spacing:-.01em; color:var(--ink);
}
h2 { font-size:clamp(2.4rem,5vw,4rem); }
h2 em { color:var(--brand-blue); font-weight:400; font-family:var(--font-serif); font-style:normal; }
h3 { font-size:clamp(1.1rem,2vw,1.5rem); }

/* ─── TOPOGRAPHIC ───────────────────────────────────── */
.relief-zone { position:relative; overflow:hidden; }
.relief-zone .section-inner { position:relative; z-index:1; }
.relief-placeholder { position:absolute; inset:0; z-index:0; opacity:.13; pointer-events:none; }
.cert-full-section .relief-placeholder,
.geo-section .relief-placeholder { opacity:.16; }
.topo-canvas,.topo-cta-bg { display:none !important; }

/* ─── NAVBAR ────────────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0;
  z-index:200; padding:0;
  transition:all .4s cubic-bezier(.4,0,.2,1);
}
nav.solid {
  background:rgba(240,245,253,0.94);
  backdrop-filter:blur(28px) saturate(200%);
  border-bottom:1px solid var(--rule);
  box-shadow:0 2px 24px rgba(18,73,160,0.1);
}
.nav-inner {
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  height:80px; padding:0 48px;
}
@media(max-width:768px){ .nav-inner { padding:0 24px; } }
.logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav-links { display:flex; align-items:center; gap:1.5rem; }
.nav-links a {
  font-family:var(--font-sans); font-size:.73rem; font-weight:600;
  letter-spacing:.06em; color:var(--brand-warm); text-decoration:none;
  text-transform:uppercase; transition:color .2s; position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-3px; left:0; right:0;
  height:2px; background:var(--brand-warm);
  transform:scaleX(0); transform-origin:center;
  transition:transform .3s cubic-bezier(.22,1,.36,1); border-radius:2px;
}
.nav-links a:hover { color:var(--brand-warm2); }
.nav-links a:hover::after { transform:scaleX(1); }

.nav-toggle {
  display:none; width:44px; height:44px;
  border:none; border-radius:10px; background:rgba(255,255,255,.1);
  color:var(--ink); align-items:center; justify-content:center;
  flex-direction:column; gap:6px; padding:8px 10px; cursor:pointer;
}
.nav-toggle span {
  display:block; width:20px; height:2px;
  background:currentColor; border-radius:999px;
  transition:transform .3s, opacity .3s;
}
.nav-toggle.is-open span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2){ opacity:0; transform:scaleX(0); }
.nav-toggle.is-open span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

.nav-mobile-panel {
  display:block; position:absolute; top:72px; left:0; right:0;
  background:rgba(240,245,253,0.98); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--rule); box-shadow:var(--shadow-sm);
  overflow:hidden; transition:max-height .32s ease, opacity .2s ease;
  max-height:0; opacity:0; z-index:180;
}
.nav-mobile-panel.open { max-height:480px; opacity:1; }
.nav-mobile-panel a {
  display:block; padding:14px 24px; color:var(--ink); text-decoration:none;
  font-family:var(--font-sans); font-size:.92rem; font-weight:600;
  text-transform:uppercase; border-top:1px solid rgba(0,0,0,.04);
  transition:background .15s, color .15s;
}
.nav-mobile-panel a:hover { background:rgba(18,73,160,.05); color:var(--brand-blue); }
.nav-mobile-panel a:first-child { border-top:none; }

@media(max-width:768px){
  .nav-links { display:none; }
  .nav-toggle { display:inline-flex; }
}

/* ─── HERO + CAROUSEL ───────────────────────────────── */
.hero {
  min-height:100vh; min-height:100svh;
  background:var(--dark-bg); position:relative; overflow:hidden;
  display:flex; flex-direction:column;
}
.hero-particles { position:absolute; inset:0; z-index:1; overflow:hidden; pointer-events:none; }
.hero-particle {
  position:absolute; border-radius:50%;
  animation:particleFloat linear infinite; opacity:0;
}
@keyframes particleFloat {
  0%   { transform:translateY(100vh) translateX(0) scale(0); opacity:0; }
  10%  { opacity:.6; }
  90%  { opacity:.3; }
  100% { transform:translateY(-20vh) translateX(var(--drift)) scale(1); opacity:0; }
}
.hero::before {
  content:''; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 60% 80% at 15% 50%, rgba(18,73,160,.28) 0%, transparent 60%),
    radial-gradient(ellipse 40% 50% at 85% 20%, rgba(230,126,34,.14) 0%, transparent 55%),
    radial-gradient(ellipse 30% 40% at 50% 80%, rgba(14,165,233,.08) 0%, transparent 50%);
  pointer-events:none;
  animation:ambientShift 12s ease-in-out infinite alternate;
}
@keyframes ambientShift {
  0%   { opacity:1; transform:scale(1); }
  100% { opacity:.85; transform:scale(1.05); }
}
.hero-grid {
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background-image:
    linear-gradient(rgba(18,73,160,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(18,73,160,.04) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.5) 30%, rgba(0,0,0,.5) 70%, transparent 100%);
}

.carousel { position:relative; width:100%; min-height:100vh; min-height:100svh; height:auto; overflow:hidden; }
.c-track {
  position:absolute; inset:0; display:flex;
  transition:transform 1.1s cubic-bezier(.77,0,.175,1);
  will-change:transform;
}
.c-slide { min-width:100%; height:100%; position:relative; overflow:hidden; flex-shrink:0; }
.c-img {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform:scale(1.08); transition:transform 8s cubic-bezier(.25,.46,.45,.94);
  will-change:transform;
}
.c-slide.active .c-img { transform:scale(1); }
.c-overlay {
  position:absolute; inset:0;
  background:
    linear-gradient(108deg, rgba(5,17,31,.98) 0%, rgba(5,17,31,.88) 28%, rgba(5,17,31,.45) 58%, rgba(5,17,31,.10) 80%, rgba(5,17,31,.02) 100%),
    linear-gradient(180deg, rgba(5,17,31,.7) 0%, transparent 18%, transparent 55%, rgba(5,17,31,.99) 100%);
}
.c-body {
  position:absolute; top:0; left:0; bottom:80px; width:58%;
  display:flex; flex-direction:column; justify-content:center;
  padding:120px 56px 40px; z-index:2;
}
@media(max-width:900px){ .c-body { width:100%; max-width:720px; padding:100px 28px 110px; bottom:100px; } }

.c-tag {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-sans); font-size:.65rem; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; color:var(--brand-warm-lt); margin-bottom:1rem;
  opacity:0; transform:translateY(20px) translateX(-10px);
  transition:opacity .6s ease, transform .6s cubic-bezier(.22,1,.36,1); transition-delay:.1s;
}
.c-tag::before { content:''; display:block; width:18px; height:2px; background:var(--brand-warm-lt); border-radius:2px; }
.c-slide.active .c-tag { opacity:1; transform:translateY(0) translateX(0); }

.c-title {
  font-family:var(--font-display); font-size:clamp(2.4rem,5vw,4.6rem);
  font-weight:800; line-height:1.02; color:#fff; letter-spacing:-.02em;
  margin-bottom:1.1rem; opacity:0; transform:translateY(24px);
  transition:opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); transition-delay:.2s;
  text-shadow:0 4px 60px rgba(0,0,0,.6);
}
.c-slide.active .c-title { opacity:1; transform:translateY(0); }

.c-desc {
  font-family:var(--font-sans); font-size:.92rem; line-height:1.88;
  color:rgba(255,255,255,.78); max-width:500px; margin-bottom:1.8rem;
  opacity:0; transform:translateY(18px);
  transition:opacity .6s ease, transform .6s ease; transition-delay:.32s;
}
.c-slide.active .c-desc { opacity:1; transform:translateY(0); }

.c-pills {
  display:flex; gap:8px; flex-wrap:wrap;
  opacity:0; transform:translateY(14px);
  transition:opacity .55s ease, transform .55s ease; transition-delay:.44s;
}
.c-slide.active .c-pills { opacity:1; transform:translateY(0); }

.c-pill {
  display:inline-flex; align-items:center; gap:5px;
  font-family:var(--font-sans); font-size:.62rem; font-weight:600; letter-spacing:.07em;
  text-transform:uppercase; padding:6px 14px; border-radius:99px;
  background:rgba(18,73,160,.28); border:1px solid rgba(91,155,213,.5);
  color:rgba(200,225,255,.92);
  transition:background .25s, border-color .25s;
}
.c-pill:hover {
  background:rgba(18,73,160,.5); border-color:rgba(91,155,213,.8); color:#fff;
}

/* Barra inferior del hero */
.c-bar {
  position:absolute; bottom:0; left:0; right:0; z-index:10;
  display:flex; background:rgba(5,17,31,.92);
  backdrop-filter:blur(28px) saturate(180%);
  border-top:1px solid rgba(255,255,255,.07); height:80px;
}
.c-bar-item {
  flex:1; display:flex; align-items:center; gap:12px;
  padding:0 22px; transition:background .3s;
  border-right:1px solid rgba(255,255,255,.05); position:relative; overflow:hidden;
  cursor:pointer;
}
.c-bar-item:last-child { border-right:none; }
.c-bar-item.active { background:rgba(18,73,160,.25); }
.c-bar-icon {
  width:34px; height:34px; border-radius:9px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.07); color:rgba(255,255,255,.55); font-size:.82rem;
  flex-shrink:0; transition:background .3s, color .3s;
}
.c-bar-item.active .c-bar-icon { background:rgba(230,126,34,.28); color:var(--brand-warm-lt); }
.c-bar-txt { display:flex; flex-direction:column; gap:2px; }
.c-bar-label {
  font-family:var(--font-sans); font-size:.62rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:rgba(255,255,255,.55); transition:color .3s;
}
.c-bar-item.active .c-bar-label { color:var(--brand-warm-lt); }
.c-bar-sub { font-size:.67rem; color:rgba(255,255,255,.40); }
.c-bar-prog {
  position:absolute; bottom:0; left:0; height:3px; width:0%;
  background:linear-gradient(90deg, var(--brand-warm), var(--brand-warm-lt));
  box-shadow:0 0 12px rgba(230,126,34,.8), 0 0 24px rgba(230,126,34,.4);
}
@media(max-width:640px){ .c-bar { display:none; } .c-body { padding:86px 16px 10px; } }

/* ─── SERVICIOS ─────────────────────────────────────── */
.services-section {
  padding:118px 0 110px;
  background:var(--off-white); position:relative; overflow:hidden;
}
.services-section::before {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 50% 60% at 92% 10%, rgba(18,73,160,.07) 0%, transparent 55%),
    radial-gradient(ellipse 40% 50% at 8% 90%, rgba(230,126,34,.05) 0%, transparent 50%);
}
.services-header {
  display:grid; grid-template-columns:1fr 1fr; gap:4rem;
  align-items:end; margin-bottom:56px; position:relative; z-index:1;
}
@media(max-width:900px){ .services-header { grid-template-columns:1fr; gap:1.5rem; margin-bottom:40px; } }
.services-lead {
  font-family:var(--font-sans); font-size:.9rem; line-height:1.88;
  color:var(--ink-muted); max-width:400px; align-self:end;
}
.services-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--rule);
  border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--rule-mid);
  box-shadow:0 8px 40px rgba(18,73,160,.08), 0 1px 4px rgba(18,73,160,.05);
  position:relative; z-index:1;
}
@media(max-width:900px){ .services-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .services-grid { grid-template-columns:1fr; } }

.svc-card {
  background:var(--cloud);
  display:flex; flex-direction:column; overflow:hidden;
  transition:transform .3s cubic-bezier(.22,1,.36,1), box-shadow .35s;
  position:relative;
  --spotlight-x:50%; --spotlight-y:50%;
}
.svc-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--brand-blue), var(--brand-accent));
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s cubic-bezier(.22,1,.36,1); z-index:1;
}
.svc-card:hover::before { transform:scaleX(1); }
.svc-card::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(circle 180px at var(--spotlight-x) var(--spotlight-y), rgba(18,73,160,.06), transparent 70%);
  opacity:0; transition:opacity .35s; z-index:2;
}
.svc-card:hover::after { opacity:1; }
.svc-card:hover { transform:translateY(-4px); box-shadow:0 20px 60px rgba(18,73,160,.16); z-index:2; }

.svc-card-image { width:100%; height:200px; overflow:hidden; flex-shrink:0; border-radius:var(--r-md) var(--r-md) 0 0; }
.svc-card-image img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s cubic-bezier(.22,1,.36,1); }
.svc-card:hover .svc-card-image img { transform:scale(1.08); }
.svc-card-content { padding:40px 36px; display:flex; flex-direction:column; gap:8px; flex-grow:1; }

.svc-tag {
  display:inline-block; font-family:var(--font-sans); font-size:.6rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  padding:3px 10px; border-radius:4px; margin-bottom:14px; align-self:flex-start;
}
.svc-title { font-family:var(--font-display); font-size:1.28rem; font-weight:600; color:var(--ink); line-height:1.22; margin-bottom:14px; }
.svc-desc { font-family:var(--font-sans); font-size:.82rem; line-height:1.82; color:var(--ink-muted); flex:1; }

/* ═══════════════════════════════════════════════════════════
   CARRUSEL DE GALERÍA DE SERVICIOS — Rev. 2026-G (fix total)
   ═══════════════════════════════════════════════════════════ */
.services-carousel { position:relative; z-index:1; }

/* Título de la galería — más grande y legible */
.services-carousel h3 {
  font-family:var(--font-display);
  font-size:clamp(1.7rem, 3.5vw, 2.4rem);
  font-weight:600;
  color:var(--ink);
  text-align:center;
  margin-bottom:48px;
  letter-spacing:-.01em;
  line-height:1.1;
}

.svc-carousel-wrapper {
  width:100%;
  overflow:hidden;              /* CRÍTICO: evita que el slide siguiente sea visible */
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  background:var(--dark-bg);
  position:relative;
  aspect-ratio:16/9;            /* desktop: proporción cinematográfica */
}

.svc-carousel-track {
  display:flex;
  width:100%;
  height:100%;
  transition:transform .7s cubic-bezier(.77,0,.175,1);
  will-change:transform;
}

.svc-carousel-slide {
  min-width:100%;               /* cada slide ocupa exactamente el wrapper */
  width:100%;
  flex-shrink:0;
  position:relative;
  overflow:hidden;
}

.svc-carousel-slide img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}

/* ── Controles: flechas ── */
.svc-carousel-nav {
  position:absolute;
  bottom:20px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  gap:18px;
  z-index:10;
}

.svc-carousel-btn {
  width:44px;
  height:44px;
  border-radius:50%;
  background:rgba(255,255,255,.22);
  border:1.5px solid rgba(255,255,255,.38);
  color:#fff;
  font-size:1rem;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:background .2s, transform .2s;
  backdrop-filter:blur(10px);
  flex-shrink:0;
}
.svc-carousel-btn:hover {
  background:rgba(255,255,255,.42);
  transform:scale(1.08);
}

/* ── Controles: dots ── */
.svc-carousel-dots { display:flex; gap:8px; align-items:center; }

.svc-carousel-dot {
  width:9px;
  height:9px;
  border-radius:50%;
  background:rgba(255,255,255,.38);
  border:none;
  cursor:pointer;
  transition:background .3s, width .3s;
  padding:0;
  flex-shrink:0;
}
.svc-carousel-dot.active {
  background:#fff;
  width:28px;
  border-radius:4.5px;
}
.svc-carousel-dot:hover:not(.active) {
  background:rgba(255,255,255,.62);
}

/* ── Tablet: 768px ── */
@media(max-width:768px) {
  .svc-carousel-wrapper {
    aspect-ratio:4/3;
    border-radius:var(--r-md);
  }

  .svc-carousel-btn {
    width:40px;
    height:40px;
    font-size:.9rem;
  }

  .svc-carousel-dot { width:8px; height:8px; }
  .svc-carousel-dot.active { width:22px; }

  .svc-carousel-nav {
    bottom:16px;
    gap:14px;
  }
}

/* ── Mobile pequeño: 480px ── */
@media(max-width:480px) {
  .svc-carousel-wrapper {
    aspect-ratio:1/1;           /* cuadrado: mejor para fotos verticales/mixtas */
    border-radius:10px;
  }

  .svc-carousel-btn {
    width:36px;
    height:36px;
    font-size:.82rem;
  }

  .svc-carousel-dot { width:7px; height:7px; }
  .svc-carousel-dot.active { width:20px; }

  .svc-carousel-nav {
    bottom:12px;
    gap:10px;
  }

  .services-carousel h3 {
    font-size:clamp(1.4rem, 6vw, 1.8rem);
    margin-bottom:32px;
  }
}

/* ─── CTA NARANJA ───────────────────────────────────── */
.topo-cta-strip {
  position:relative; overflow:hidden;
  background:linear-gradient(110deg, var(--brand-warm2) 0%, #D97113 45%, var(--brand-warm) 100%);
  padding:80px 0;
}
.topo-cta-strip::before {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 60% 80% at 100% 50%, rgba(255,255,255,.09) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 0% 50%, rgba(0,0,0,.1) 0%, transparent 50%);
}
.topo-cta-strip::after {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:repeating-linear-gradient(
    45deg, transparent, transparent 40px,
    rgba(255,255,255,.025) 40px, rgba(255,255,255,.025) 41px
  );
}
.topo-cta-inner {
  position:relative; z-index:1;
  max-width:1280px; margin:0 auto; padding:0 48px;
  display:flex; align-items:center; justify-content:space-between; gap:40px;
}
@media(max-width:900px){ .topo-cta-inner { flex-direction:column; text-align:center; padding:0 24px; gap:28px; } }
.topo-cta-left { max-width:560px; }
.topo-cta-overline {
  font-family:var(--font-sans); font-size:.64rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.85);
  display:flex; align-items:center; gap:10px; margin-bottom:14px;
}
.topo-cta-overline::before { content:''; display:block; width:20px; height:2px; background:rgba(255,255,255,.6); border-radius:2px; }
@media(max-width:900px){ .topo-cta-overline { justify-content:center; } }
.topo-cta-title {
  font-family:var(--font-display); font-size:clamp(2rem,4vw,3.6rem);
  font-weight:800; color:#fff; line-height:1.04; margin-bottom:14px;
  text-shadow:0 3px 24px rgba(0,0,0,.2);
}
.topo-cta-desc { font-family:var(--font-sans); font-size:.9rem; line-height:1.78; color:rgba(255,255,255,.90); max-width:440px; }
@media(max-width:900px){ .topo-cta-desc { margin:0 auto; } }
.topo-cta-right { flex-shrink:0; }

.btn-topo-cta {
  display:inline-flex; align-items:center; gap:18px;
  padding:22px 38px; background:#fff; color:var(--brand-warm2);
  border:none; border-radius:var(--r-lg);
  font-family:var(--font-sans); font-size:.88rem; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; text-decoration:none; cursor:pointer;
  transition:transform .28s cubic-bezier(.22,1,.36,1), box-shadow .28s;
  box-shadow:0 12px 48px rgba(0,0,0,.28);
  position:relative; overflow:hidden;
}
.btn-topo-cta:hover { transform:translateY(-4px); box-shadow:0 24px 64px rgba(0,0,0,.35); }
.btn-topo-cta-icon {
  width:38px; height:38px; border-radius:11px;
  background:rgba(230,126,34,.12);
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; color:var(--brand-warm2);
  animation:chatIconPulse 2.4s ease-in-out infinite; flex-shrink:0;
}
.btn-topo-cta-text { display:flex; flex-direction:column; gap:2px; text-align:left; }
.btn-topo-cta-label { font-size:.8rem; font-weight:700; line-height:1.2; }
.btn-topo-cta-sub   { font-size:.65rem; font-weight:400; opacity:.7; }
@keyframes chatIconPulse { 0%,100%{transform:scale(1);} 50%{transform:scale(1.22) rotate(-5deg);} }

/* ─── NOSOTROS ──────────────────────────────────────── */
.about-section {
  padding:118px 0;
  background:linear-gradient(160deg, #EAF0F8 0%, #EEF2FA 50%, #E6EEF8 100%);
  position:relative; overflow:hidden;
}
.about-section::before {
  content:''; position:absolute; top:0; left:10%; right:10%;
  height:1px; background:linear-gradient(90deg, transparent, rgba(18,73,160,.2), transparent);
}
.about-inner { display:grid; grid-template-columns:1fr 1fr; gap:7rem; align-items:start; position:relative; z-index:1; }
@media(max-width:960px){ .about-inner { grid-template-columns:1fr; gap:3.5rem; } }
.about-text { position:sticky; top:120px; }
@media(max-width:960px){ .about-text { position:static; } }
.about-p { font-family:var(--font-sans); font-size:.9rem; line-height:1.9; color:var(--ink-mid); margin-bottom:1rem; }
.pillars { margin-top:2.5rem; display:flex; flex-direction:column; gap:22px; }
.pillar {
  display:flex; align-items:flex-start; gap:18px;
  padding-bottom:22px; border-bottom:1px solid var(--rule);
  transition:transform .2s;
}
.pillar:last-child { border-bottom:none; padding-bottom:0; }
.pillar:hover { transform:translateX(4px); }
.pillar-icon {
  width:38px; height:38px; border-radius:var(--r-sm);
  background:rgba(18,73,160,.1);
  display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:2px;
  transition:transform .25s, background .25s;
}
.pillar:hover .pillar-icon { transform:scale(1.12) rotate(-5deg); background:rgba(18,73,160,.18); }
.pillar-title { font-family:var(--font-sans); font-size:.87rem; font-weight:600; color:var(--ink); margin-bottom:4px; }
.pillar-desc  { font-family:var(--font-sans); font-size:.78rem; line-height:1.75; color:var(--ink-muted); }

.about-cards { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.about-card {
  padding:28px 24px; background:#fff;
  border:1px solid var(--rule); border-radius:var(--r-lg);
  transition:box-shadow .3s, transform .3s cubic-bezier(.22,1,.36,1), border-color .3s;
  position:relative; overflow:hidden;
}
.about-card::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--brand-blue), var(--brand-accent));
  transform:scaleX(0); transform-origin:left; transition:transform .35s cubic-bezier(.22,1,.36,1);
}
.about-card:hover::before { transform:scaleX(1); }
.about-card:hover { box-shadow:0 16px 48px rgba(18,73,160,.16); transform:translateY(-4px); border-color:var(--rule-mid); }
.about-card-icon {
  display:flex; width:42px; height:42px; border-radius:var(--r-sm);
  background:rgba(18,73,160,.09); align-items:center; justify-content:center;
  color:var(--brand-blue); font-size:.86rem; margin-bottom:16px;
  transition:background .25s, transform .3s;
}
.about-card:hover .about-card-icon { background:rgba(18,73,160,.16); transform:rotate(-8deg) scale(1.1); }
.about-card-title { font-family:var(--font-sans); font-size:.85rem; font-weight:600; color:var(--ink); margin-bottom:7px; }
.about-card-body  { font-family:var(--font-sans); font-size:.75rem; line-height:1.75; color:var(--ink-muted); }

/* ─── EQUIPO ────────────────────────────────────────── */
.team-section {
  background:var(--off-white);
  padding:118px 0 110px; position:relative; overflow:hidden;
}
.team-section::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(135deg, rgba(18,73,160,.03) 0%, transparent 40%, rgba(230,126,34,.025) 100%);
}
.team-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-sans); font-size:.67rem; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--brand-blue); margin-bottom:14px; position:relative; z-index:1;
}
.team-eyebrow-rule { width:20px; height:2px; background:var(--brand-blue); border-radius:2px; display:inline-block; }
.team-head { display:flex; flex-direction:column; gap:14px; margin-bottom:52px; position:relative; z-index:1; }
.team-head-sub { max-width:460px; font-family:var(--font-sans); font-size:.88rem; line-height:1.82; color:var(--ink-muted); }

.lead-grid {
  display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:18px; margin-bottom:22px; position:relative; z-index:1;
}
@media(max-width:1024px){ .lead-grid { grid-template-columns:1fr 1fr; } .lead-card--prime { grid-column:1/-1; } }
@media(max-width:640px) { .lead-grid { grid-template-columns:1fr; } }

.lead-card {
  background:#fff; border:1px solid var(--rule);
  border-radius:var(--r-xl); padding:34px 30px;
  position:relative; overflow:hidden;
  transition:box-shadow .3s, transform .3s cubic-bezier(.22,1,.36,1), border-color .3s;
}
.lead-card:hover { box-shadow:0 20px 60px rgba(18,73,160,.15); transform:translateY(-5px); border-color:var(--rule-mid); }
.lead-card--prime {
  border-color:rgba(18,73,160,.22);
  background:linear-gradient(155deg, rgba(18,73,160,.05) 0%, #fff 55%);
}
.lead-card--prime::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--brand-blue3), var(--brand-blue-lt), var(--brand-accent));
  border-radius:var(--r-xl) var(--r-xl) 0 0;
}
.founder-pill {
  position:absolute; top:20px; right:20px;
  font-family:var(--font-sans); font-size:.58rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:4px 11px; border-radius:99px;
  background:rgba(18,73,160,.1); color:var(--brand-blue2); border:1px solid rgba(18,73,160,.22);
}
.role-tag {
  display:inline-flex; align-items:center; gap:5px;
  font-family:var(--font-sans); font-size:.63rem; font-weight:600; letter-spacing:.09em; text-transform:uppercase;
  padding:4px 10px; border-radius:var(--r-sm); margin-bottom:22px;
}
.role-tag--gm  { background:rgba(18,73,160,.09);  color:var(--brand-blue2); }
.role-tag--adm { background:rgba(14,165,233,.09); color:#0266A0; }
.role-tag--qly { background:rgba(180,83,9,.12);   color:#92400E; }
.lead-person-row { display:flex; align-items:center; gap:16px; margin-bottom:18px; }
.lead-av {
  width:54px; height:54px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-sans); font-size:.95rem; font-weight:700; flex-shrink:0;
  box-shadow:0 6px 18px rgba(0,0,0,.18); transition:transform .3s;
}
.lead-card:hover .lead-av { transform:scale(1.08) rotate(-3deg); }
.lead-av--teal  { background:linear-gradient(135deg, var(--brand-blue3), var(--brand-blue-lt)); color:#fff; }
.lead-av--blue  { background:linear-gradient(135deg, #0A2456, #2563EB); color:#fff; }
.lead-av--green { background:linear-gradient(135deg, #0D3C84, var(--brand-sky)); color:#fff; }
.lead-name  { font-family:var(--font-sans); font-size:1rem; font-weight:600; color:var(--ink); margin:0 0 3px; }
.lead-title { font-family:var(--font-sans); font-size:.73rem; color:var(--ink-faint); line-height:1.4; }
.lead-sep   { width:28px; height:2px; background:var(--brand-blue); opacity:.35; margin:0 0 14px; border-radius:2px; }
.lead-desc  { font-family:var(--font-sans); font-size:.78rem; color:var(--ink-mid); line-height:1.8; }
.chip-row   { display:flex; flex-wrap:wrap; gap:5px; margin-top:16px; }
.chip {
  font-family:var(--font-sans); font-size:.62rem; padding:4px 10px; border-radius:4px;
  background:var(--parchment); color:var(--ink-mid); border:1px solid var(--rule);
  transition:background .2s, color .2s;
}
.chip:hover { background:rgba(18,73,160,.1); color:var(--brand-blue2); }

.spec-hd { display:flex; align-items:center; gap:16px; margin:48px 0 22px; position:relative; z-index:1; }
.spec-hd-label { font-family:var(--font-sans); font-size:.63rem; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-ghost); white-space:nowrap; }
.spec-hd-rule { flex:1; height:1px; background:var(--rule); }

.spec-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; position:relative; z-index:1; }
@media(max-width:900px){ .spec-grid { grid-template-columns:repeat(2,1fr); } }

.spec-card {
  background:#fff; border:1px solid var(--rule);
  border-radius:var(--r-md); padding:26px 22px;
  transition:box-shadow .3s, border-color .3s, transform .3s;
}
.spec-card:hover { box-shadow:0 14px 40px rgba(18,73,160,.14); border-color:rgba(18,73,160,.22); transform:translateY(-4px); }
.spec-ico {
  width:42px; height:42px; border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center; margin-bottom:16px;
  transition:transform .35s;
}
@media(max-width:900px){ .spec-ico { display: none;} }
.spec-card:hover .spec-ico { transform:scale(1.15) rotate(-6deg); }
.spec-ico--teal   { background:rgba(18,73,160,.1);  color:var(--brand-blue); }
.spec-ico--green  { background:rgba(14,165,233,.1); color:#0266A0; }
.spec-ico--amber  { background:rgba(180,83,9,.1);   color:#92400E; }
.spec-ico--purple { background:rgba(99,102,241,.1); color:#3730A3; }
.spec-name { font-family:var(--font-sans); font-size:.82rem; font-weight:600; color:var(--ink); margin:0 0 6px; }
.spec-desc { font-family:var(--font-sans); font-size:.73rem; color:var(--ink-muted); line-height:1.7; }

.team-stats-row {
  margin-top:52px; padding-top:44px; border-top:1px solid var(--rule);
  display:grid; grid-template-columns:repeat(4,1fr); position:relative; z-index:1;
}
.team-stat { padding:0 32px 0 0; border-right:1px solid var(--rule); }
.team-stat+.team-stat { padding-left:32px; }
.team-stat--last { border-right:none; }
.team-stat-n {
  font-family:var(--font-display); font-size:3rem; font-weight:800;
  color:var(--brand-blue2); letter-spacing:-.04em; line-height:1; margin:0 0 6px;
}
.team-stat-n span { font-size:1.3rem; color:var(--brand-warm); }
.team-stat-lbl { font-family:var(--font-sans); font-size:.73rem; color:var(--ink-muted); line-height:1.48; }
@media(max-width:768px){
  .team-stats-row { grid-template-columns:1fr 1fr; gap:28px; }
  .team-stat,.team-stat--last { border-right:none; padding:0; }
}

/* ─── EXPERIENCIA ───────────────────────────────────── */
.exp-section {
  background:linear-gradient(165deg, #EAF0F8 0%, #DDE8F6 60%, #E6EDF8 100%);
  padding:118px 0 110px; position:relative; overflow:hidden;
}
.exp-section::before {
  content:''; position:absolute; top:0; left:10%; right:10%;
  height:1px; background:linear-gradient(90deg, transparent, rgba(18,73,160,.22), transparent);
}
.exp-section .section-inner { display:flex; flex-direction:column; align-items:center; position:relative; z-index:1; }
.exp-section h2 { text-align:center; margin-bottom:56px; }
.exp-grid { width:100%; display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-bottom:56px; }
@media(max-width:768px){ .exp-grid { grid-template-columns:1fr; } }

.exp-card {
  background:#fff; border:1px solid rgba(18,73,160,.1);
  border-radius:var(--r-xl); padding:36px 32px;
  display:flex; flex-direction:column;
  transition:box-shadow .3s, transform .3s, border-color .3s;
  position:relative; overflow:hidden;
}
.exp-card::before {
  content:''; position:absolute; left:0; top:20px; bottom:20px; width:3px;
  background:linear-gradient(180deg, var(--brand-blue), var(--brand-accent));
  border-radius:0 2px 2px 0; transform:scaleY(0); transform-origin:top;
  transition:transform .4s cubic-bezier(.22,1,.36,1);
}
.exp-card:hover::before { transform:scaleY(1); }
.exp-card:hover { box-shadow:0 20px 60px rgba(18,73,160,.17); transform:translateY(-5px); border-color:rgba(18,73,160,.22); }
.exp-card-tag { font-family:var(--font-sans); font-size:.63rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--brand-blue); display:block; margin-bottom:12px; }
.exp-card-title { font-family:var(--font-display); font-size:1.25rem; font-weight:600; color:var(--ink); line-height:1.32; margin-bottom:14px; flex:1; }
.exp-card-body { font-family:var(--font-sans); font-size:.82rem; line-height:1.82; color:var(--ink-muted); margin-bottom:24px; }
.exp-client {
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-sans); font-size:.72rem; color:var(--ink-faint); font-weight:500;
  border-top:1px solid var(--rule); padding-top:18px; letter-spacing:.04em;
}
.exp-client i { color:var(--brand-blue); font-size:.65rem; }

/* ─── SUBSECCIÓN MARINO ──────────────────────────────── */
.marino-subsection, .lab-subsection {
  width:100%; border-top:1px solid var(--rule); padding-top:56px;
}
.marino-subsection-header, .lab-subsection-header { margin-bottom:40px; }
.marino-subsection-header h3, .lab-subsection-header h3 {
  font-family:var(--font-display); font-size:clamp(1.8rem, 3vw, 2.4rem);
  font-weight:600; color:var(--ink); margin-bottom:12px;
}
.marino-subsection-lead, .lab-subsection-lead {
  font-family:var(--font-sans); font-size:.9rem; line-height:1.88;
  color:var(--ink-muted); max-width:600px;
}
.marino-subsection-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start;
}
@media(max-width:900px){ .marino-subsection-grid { grid-template-columns:1fr; gap:2rem; } }
.marino-subsection-image { border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md); }
.marino-subsection-image img { width:100%; height:auto; display:block; }
.marino-subsection-content h4 { font-family:var(--font-display); font-size:1.3rem; font-weight:600; color:var(--ink); margin-bottom:24px; }
.marino-subsection-items { display:grid; gap:16px; }
.marino-subsection-item {
  display:flex; align-items:flex-start; gap:16px; padding:18px;
  background:var(--parchment); border-radius:var(--r-md); transition:background .3s, transform .3s;
}
.marino-subsection-item:hover { background:rgba(18,73,160,.08); transform:translateX(4px); }
.marino-subsection-icon {
  width:40px; height:40px; border-radius:var(--r-sm); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(18,73,160,.1); color:var(--brand-blue); font-size:.95rem; margin-top:2px;
}
.marino-subsection-item-title { font-family:var(--font-sans); font-size:.87rem; font-weight:600; color:var(--ink); margin:0 0 4px; }
.marino-subsection-item-desc  { font-family:var(--font-sans); font-size:.78rem; line-height:1.75; color:var(--ink-muted); margin:0; }
@media(max-width:768px){
  .marino-subsection-icon { display: none; }
  .marino-subsection-items { grid-template-columns: 1fr 1fr; }
}

/* ─── LAB SLIDER ─────────────────────────────────────── */
.lab-subsection-slider-container { position:relative; width:100%; }
.lab-subsection-slider {
  position:relative; overflow:hidden;
  border-radius:var(--r-lg); box-shadow:var(--shadow-md);
  background:var(--dark-card); min-height:320px;
}
.lab-subsection-slide {
  position:absolute; inset:0; opacity:0;
  transition:opacity .55s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column;
}
.lab-subsection-slide:first-child { position:relative; }
.lab-subsection-slide.active { opacity:1; z-index:2; }
.lab-subsection-slide img {
  width:100%; max-height:400px; object-fit:cover; display:block; flex-shrink:0;
}
.lab-subsection-slide-caption {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.82) 60%, rgba(0,0,0,.97) 100%);
  padding:32px 28px; color:#fff;
}
.lab-subsection-slide-caption h4 {
  font-family:var(--font-display); font-size:1.15rem; font-weight:600; color:#fff; margin:0 0 8px;
}
.lab-subsection-slide-caption p {
  font-family:var(--font-sans); font-size:.82rem; line-height:1.62; color:rgba(255,255,255,.85); margin:0;
}
.lab-subsection-controls {
  display:flex; align-items:center; justify-content:center; gap:20px; margin-top:18px;
}
.lab-subsection-nav-btn {
  width:44px; height:44px; border-radius:50%;
  background:#fff; border:1px solid var(--rule);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink); cursor:pointer; font-size:.95rem;
  transition:background .25s, color .25s, box-shadow .25s;
}
.lab-subsection-nav-btn:hover { background:var(--brand-blue); color:#fff; box-shadow:0 8px 24px rgba(18,73,160,.25); }
.lab-subsection-dots { display:flex; gap:8px; align-items:center; }
.lab-subsection-dot {
  width:10px; height:10px; border-radius:50%;
  background:rgba(18,73,160,.2); border:none; cursor:pointer;
  transition:background .3s, width .3s; padding:0;
}
.lab-subsection-dot.active { background:var(--brand-blue); width:26px; border-radius:5px; }
.lab-subsection-dot:hover { background:rgba(18,73,160,.4); }

/* ─── CARRUSEL CLIENTES ─────────────────────────────── */
.clients-row { width:100%; margin-top:56px; }
.clients-label {
  font-family:var(--font-sans); font-size:1rem; font-weight:600; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink-faint); text-align:center; margin-bottom:20px;
}
.brands-carousel-wrapper {
  position:relative; width:100%; overflow:hidden; padding:1rem 0;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 80px, #000 calc(100% - 80px), transparent 100%);
  mask-image:linear-gradient(to right, transparent 0%, #000 80px, #000 calc(100% - 80px), transparent 100%);
}
.brands-carousel-track { display:flex; align-items:center; gap:16px; cursor:grab; will-change:transform; }
.brands-carousel-track:active { cursor:grabbing; }
.brand-carousel-item.cliente-item { flex:0 0 auto; min-width:180px; max-width:200px; }
.cliente-card {
  display:flex; align-items:center; justify-content:center;
  background:#fff; border:1px solid rgba(18,73,160,.1);
  border-radius:14px; padding:20px 28px; min-height:90px;
  box-shadow:0 2px 10px rgba(18,73,160,.06);
  transition:transform .3s, box-shadow .3s, border-color .3s;
  user-select:none;
}
.cliente-item:hover .cliente-card { transform:translateY(-5px) scale(1.04); box-shadow:0 14px 36px rgba(18,73,160,.17); border-color:rgba(18,73,160,.32); }
.cliente-logo-wrapper { display:flex; align-items:center; justify-content:center; width:120px; height:56px; overflow:hidden; }
.brand-logo {
  max-width:100%; max-height:100%; object-fit:contain; display:block;
  filter:saturate(.8) opacity(.82); transition:filter .3s;
}
.cliente-item:hover .brand-logo { filter:saturate(1) opacity(1); }

/* ─── CERTIFICACIONES ───────────────────────────────── */
.cert-full-section {
  background:linear-gradient(160deg, #050E1A 0%, #0A1628 50%, #060F1C 100%);
  padding:118px 0 110px; position:relative; overflow:hidden;
}
.cert-full-section::before {
  content:''; position:absolute; top:-15%; left:-8%; width:600px; height:600px;
  border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(18,73,160,.2) 0%, transparent 65%);
  filter:blur(70px); animation:blobDrift 15s ease-in-out infinite alternate;
}
.cert-full-section::after {
  content:''; position:absolute; bottom:-12%; right:3%; width:450px; height:450px;
  border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(230,126,34,.13) 0%, transparent 65%);
  filter:blur(60px); animation:blobDrift 18s ease-in-out infinite alternate-reverse;
}
@keyframes blobDrift { 0%{transform:translate(0,0) scale(1);} 100%{transform:translate(40px,-30px) scale(1.08);} }
.cert-full-inner { position:relative; z-index:1; }
.cert-full-header { max-width:680px; margin-bottom:64px; }
.cert-full-eyebrow {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-sans); font-size:.67rem; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.65); margin-bottom:20px;
}
.cert-eyebrow-dot {
  width:6px; height:6px; border-radius:50%; background:var(--brand-warm);
  box-shadow:0 0 12px rgba(230,126,34,.8); animation:dotPulseCert 2s ease-in-out infinite;
}
@keyframes dotPulseCert { 0%,100%{box-shadow:0 0 6px rgba(230,126,34,.6);} 50%{box-shadow:0 0 18px rgba(230,126,34,1);} }
.cert-full-header h2 { color:#fff; font-weight:800; margin-bottom:20px; }
.cert-full-lead { font-family:var(--font-sans); font-size:.89rem; line-height:1.85; color:rgba(255,255,255,.68); }
.cert-docs-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media(max-width:1100px){ .cert-docs-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px) { .cert-docs-grid { grid-template-columns:1fr; } }
.cert-doc-card {
  background:var(--dark-surface); border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r-xl); overflow:hidden; cursor:pointer;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.cert-doc-card:hover { transform:translateY(-6px); box-shadow:0 32px 72px rgba(0,0,0,.55),0 0 0 1px rgba(230,126,34,.22); border-color:rgba(230,126,34,.3); }
.cert-doc-preview { height:180px; position:relative; overflow:hidden; background:var(--dark-card); }
.cert-pdf-thumb {
  position:absolute; top:0; left:0; border:none; pointer-events:none; background:#fff;
  transform-origin:top left; transform:scale(.7);
  width:calc(100% / .7); height:calc(280px / .7);
}
.cert-doc-stamp {
  position:absolute; top:10px; right:10px; z-index:3;
  padding:4px 10px; border-radius:6px;
  backdrop-filter:blur(8px); background:rgba(0,0,0,.65); border:1px solid rgba(255,255,255,.14);
}
.cert-doc-stamp span { font-family:var(--font-sans); font-size:.6rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; }
.cert-doc-stamp--inn span { color:#A8D0EF; }
.cert-doc-stamp--sma span { color:var(--brand-warm-lt); }
.cert-doc-stamp--ias span { color:#F5A04A; }
.cert-doc-overlay {
  position:absolute; inset:0; z-index:2;
  background:rgba(6,16,30,.7); backdrop-filter:blur(6px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:7px; opacity:0; transition:opacity .28s; color:#fff;
}
.cert-doc-overlay i { font-size:1.5rem; }
.cert-doc-overlay span { font-family:var(--font-sans); font-size:.73rem; font-weight:500; }
.cert-doc-card:hover .cert-doc-overlay { opacity:1; }
.cert-doc-info { padding:20px 18px; }
.cert-doc-tag { display:inline-block; font-family:var(--font-sans); font-size:.58rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:3px 9px; border-radius:4px; margin-bottom:10px; }
.cert-doc-tag--blue   { background:rgba(18,73,160,.28);  color:#A8D0EF; }
.cert-doc-tag--green  { background:rgba(230,126,34,.22); color:var(--brand-warm-lt); }
.cert-doc-tag--orange { background:rgba(230,126,34,.22); color:#F5A04A; }
.cert-doc-title { font-family:var(--font-sans); font-size:.83rem; font-weight:600; color:rgba(255,255,255,.90); margin-bottom:5px; line-height:1.4; }
.cert-doc-body  { font-family:var(--font-sans); font-size:.72rem; color:rgba(255,255,255,.60); margin-bottom:16px; line-height:1.5; }
.cert-doc-btn {
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-sans); font-size:.7rem; font-weight:500; color:rgba(255,255,255,.65);
  text-decoration:none; padding:7px 14px; border-radius:var(--r-sm);
  border:1px solid rgba(255,255,255,.14); background:transparent; transition:all .25s;
}
.cert-doc-btn:hover { background:rgba(230,126,34,.2); color:var(--brand-warm-lt); border-color:rgba(230,126,34,.42); }

/* Modal certificados */
.cert-modal {
  display:none; position:fixed; inset:0; z-index:1000;
  background:rgba(5,14,26,.94); backdrop-filter:blur(12px);
  align-items:center; justify-content:center; padding:24px;
}
.cert-modal.active { display:flex; animation:modalIn .3s cubic-bezier(.22,1,.36,1); }
@keyframes modalIn { from{opacity:0;transform:scale(.96);} to{opacity:1;transform:scale(1);} }
.cert-modal-box {
  background:var(--dark-surface); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-xl); overflow:hidden;
  width:100%; max-width:860px; max-height:90vh;
  display:flex; flex-direction:column; box-shadow:0 56px 140px rgba(0,0,0,.8);
}
.cert-modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid rgba(255,255,255,.09); flex-shrink:0;
}
.cert-modal-title { font-family:var(--font-sans); font-size:.85rem; font-weight:600; color:rgba(255,255,255,.90); }
.cert-modal-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border-radius:var(--r-sm);
  border:1px solid rgba(255,255,255,.14); background:transparent; color:rgba(255,255,255,.72);
  font-family:var(--font-sans); font-size:.73rem;
  text-decoration:none; transition:all .2s; cursor:pointer;
}
.cert-modal-btn:hover { background:rgba(255,255,255,.12); color:#fff; }
.cert-modal-btn--close { padding:7px 12px; }
.cert-modal-box iframe { flex:1; border:none; min-height:500px; }

/* ─── SEDES ─────────────────────────────────────────── */
.geo-section {
  background:linear-gradient(160deg, #060F1C 0%, #0A1828 55%, #06101E 100%);
  padding:118px 0 110px; position:relative; overflow:hidden;
}
.geo-section::before {
  content:''; position:absolute; top:-10%; left:-5%; width:500px; height:500px;
  border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(230,126,34,.11) 0%, transparent 65%);
  filter:blur(60px); animation:blobDrift 20s ease-in-out infinite alternate;
}
.geo-inner { max-width:1280px; margin:0 auto; padding:0 48px; position:relative; z-index:1; }
@media(max-width:768px){ .geo-inner { padding:0 24px; } }
.geo-header { margin-bottom:56px; }
.geo-label {
  font-family:var(--font-sans); font-size:.67rem; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:rgba(255,255,255,.65);
  display:flex; align-items:center; gap:10px; margin-bottom:14px;
}
.geo-label::before { content:''; display:block; width:20px; height:2px; background:var(--brand-warm); }
.geo-header h2 { color:#fff; font-weight:800; }
.geo-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media(max-width:860px){ .geo-grid { grid-template-columns:1fr; } }
.geo-card {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r-xl); padding:36px 32px;
  transition:border-color .3s, transform .3s, box-shadow .3s, background .3s;
  position:relative; overflow:hidden; backdrop-filter:blur(8px);
}
.geo-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--brand-warm), transparent);
  opacity:0; transition:opacity .35s;
}
.geo-card:hover { border-color:rgba(230,126,34,.4); transform:translateY(-5px); box-shadow:0 24px 64px rgba(0,0,0,.45),0 0 0 1px rgba(230,126,34,.2); background:rgba(255,255,255,.06); }
.geo-card:hover::before { opacity:1; }
.geo-card:first-child { border-color:rgba(230,126,34,.22); }
.geo-card:first-child::before { opacity:.7; }
.geo-tag {
  font-family:var(--font-sans); font-size:.62rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--brand-warm-lt);
  display:inline-flex; align-items:center; gap:7px; margin-bottom:14px;
}
.geo-tag::before {
  content:''; width:6px; height:6px; border-radius:50%; background:var(--brand-warm);
  box-shadow:0 0 10px rgba(230,126,34,.9); flex-shrink:0; animation:dotPulse 2.5s ease-in-out infinite;
}
@keyframes dotPulse { 0%,100%{box-shadow:0 0 6px rgba(230,126,34,.6);} 50%{box-shadow:0 0 18px rgba(230,126,34,1);} }
.geo-title { font-family:var(--font-display); font-size:1.6rem; font-weight:700; color:#fff; margin-bottom:18px; }
.geo-addr { font-family:var(--font-sans); font-size:.82rem; line-height:1.92; color:rgba(255,255,255,.65); }

/* ─── CONTACTO ──────────────────────────────────────── */
.cta-block {
  background:linear-gradient(160deg, #F0F5FC 0%, #E8EFF9 50%, #F0F5FC 100%);
  padding:118px 0; position:relative; overflow:hidden;
}
.cta-block::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(18,73,160,.22), transparent);
}
.cta-inner { max-width:640px; margin:0 auto; text-align:center; padding:0 48px; position:relative; z-index:1; }
@media(max-width:768px){ .cta-inner { padding:0 24px; } }
.cta-inner h2 { margin-bottom:20px; }
.cta-inner p { font-family:var(--font-sans); font-size:.9rem; line-height:1.85; color:var(--ink-muted); max-width:480px; margin:0 auto 2.4rem; }
.cta-buttons { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
.btn-ocean {
  display:inline-flex; align-items:center; gap:8px; padding:15px 30px; border-radius:var(--r-md);
  background:var(--brand-blue); color:#fff;
  font-family:var(--font-sans); font-size:.8rem; font-weight:600; letter-spacing:.06em;
  text-decoration:none; text-transform:uppercase;
  transition:background .22s, transform .22s, box-shadow .25s;
  box-shadow:0 6px 22px rgba(18,73,160,.35);
}
.btn-ocean:hover { background:var(--brand-blue2); transform:translateY(-3px); box-shadow:0 12px 34px rgba(18,73,160,.5); }
.btn-outline-ocean {
  display:inline-flex; align-items:center; gap:8px; padding:14px 28px; border-radius:var(--r-md);
  background:transparent; border:1.5px solid var(--rule-dark); color:var(--ink);
  font-family:var(--font-sans); font-size:.8rem; font-weight:500; letter-spacing:.06em;
  text-decoration:none; text-transform:uppercase;
  transition:border-color .22s, color .22s, background .22s, transform .22s;
}
.btn-outline-ocean:hover { border-color:var(--brand-blue); color:var(--brand-blue); background:rgba(18,73,160,.06); transform:translateY(-2px); }

/* ─── FOOTER ─────────────────────────────────────────── */
footer {
  background:linear-gradient(160deg, #060F1C 0%, #0A1828 100%);
  border-top:1px solid rgba(255,255,255,.05);
}
.footer-inner { max-width:1280px; margin:0 auto; padding:72px 48px 48px; }
@media(max-width:768px){ .footer-inner { padding:52px 24px 36px; } }
.footer-top {
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:3rem;
  padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:32px;
}
@media(max-width:1024px){ .footer-top { grid-template-columns:1fr 1fr; gap:2rem; } }
@media(max-width:580px) { .footer-top { grid-template-columns:1fr; gap:2rem; } }
.footer-brand p { font-family:var(--font-sans); font-size:.79rem; line-height:1.8; color:rgba(255,255,255,.50); margin-top:.75rem; }
.footer-col-title { font-family:var(--font-sans); font-size:.65rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.45); margin-bottom:16px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:11px; }
.footer-links a { font-family:var(--font-sans); font-size:.79rem; color:rgba(255,255,255,.55); text-decoration:none; transition:color .2s, transform .2s; display:inline-block; }
.footer-links a:hover { color:rgba(255,255,255,.90); transform:translateX(4px); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.footer-bottom p { font-family:var(--font-sans); font-size:.73rem; color:rgba(255,255,255,.40); }
.footer-bottom a { color:rgba(255,255,255,.55); text-decoration:none; transition:color .22s; }
.footer-bottom a:hover { color:var(--brand-warm); }

/* ─── CHAT WIDGET ────────────────────────────────────── */
#chat-widget { position:fixed; bottom:28px; right:28px; z-index:500; display:flex; flex-direction:column; align-items:flex-end; gap:12px; }
#chat-cta {
  display:flex; align-items:center; gap:12px;
  background:rgba(255,255,255,.96); border:1px solid var(--rule);
  border-radius:var(--r-lg); padding:12px 14px;
  box-shadow:0 12px 48px rgba(18,73,160,.18);
  animation:floatIn .5s cubic-bezier(.22,1,.36,1);
  max-width:240px; backdrop-filter:blur(12px);
}
.hidden { display:none !important; }
@keyframes floatIn { from{opacity:0;transform:translateY(14px) scale(.96);} to{opacity:1;transform:translateY(0) scale(1);} }
#chat-window {
  width:380px; background:var(--cloud); border:1px solid var(--rule);
  border-radius:var(--r-xl); overflow:hidden;
  box-shadow:0 36px 90px rgba(18,73,160,.2),0 4px 16px rgba(18,73,160,.08);
  display:flex; flex-direction:column; max-height:580px;
  animation:chatWindowIn .35s cubic-bezier(.22,1,.36,1);
}
@keyframes chatWindowIn { from{opacity:0;transform:translateY(16px) scale(.97);} to{opacity:1;transform:translateY(0) scale(1);} }
#chat-window.fullscreen {
  position:fixed; inset:16px; width:auto; max-width:none;
  height:auto; max-height:none; border-radius:24px; z-index:1000;
}
@media(max-width:480px){ #chat-window { width:calc(100vw - 2.5rem); } }
.chat-header {
  display:flex; align-items:center; justify-content:space-between; padding:14px 16px;
  background:linear-gradient(110deg, var(--brand-blue3), var(--brand-blue2));
  flex-shrink:0; position:relative; overflow:hidden;
}
.chat-header::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 80% at 100% 50%, rgba(14,165,233,.15), transparent);
  pointer-events:none;
}
.chat-header-btn {
  width:30px; height:30px; border-radius:var(--r-sm);
  background:rgba(255,255,255,.12); border:none; color:rgba(255,255,255,.80); font-size:.8rem;
  display:flex; align-items:center; justify-content:center; transition:background .18s, color .18s;
  cursor:pointer;
}
.chat-header-btn:hover { background:rgba(255,255,255,.25); color:#fff; }
#chat-messages { flex:1; overflow-y:auto; padding:16px; }
#chat-messages::-webkit-scrollbar { width:3px; }
#chat-messages::-webkit-scrollbar-thumb { background:var(--rule-mid); border-radius:99px; }
#chat-history { display:flex; flex-direction:column; gap:14px; }
.msg-bot {
  background:#fff; border:1px solid var(--rule); border-radius:14px 14px 14px 4px;
  padding:10px 14px; font-family:var(--font-sans); font-size:.8rem; line-height:1.7;
  color:var(--ink-mid); box-shadow:var(--shadow-xs); max-width:260px;
  animation:msgIn .3s cubic-bezier(.22,1,.36,1);
}
.msg-user {
  background:linear-gradient(135deg, var(--brand-blue), var(--brand-blue2));
  color:#fff; border-radius:14px 14px 4px 14px;
  padding:10px 14px; font-family:var(--font-sans); font-size:.8rem; line-height:1.7; max-width:240px;
  animation:msgIn .3s cubic-bezier(.22,1,.36,1);
}
@keyframes msgIn { from{opacity:0;transform:translateY(8px) scale(.97);} to{opacity:1;transform:none;} }
.msg-time { font-family:var(--font-sans); font-size:.62rem; color:var(--ink-muted); display:block; margin-top:3px; }
@keyframes typingDot { 0%,60%,100%{transform:translateY(0);opacity:.35;} 30%{transform:translateY(-5px);opacity:1;} }
.typing-dot { width:6px; height:6px; border-radius:50%; background:var(--ink-ghost); display:inline-block; animation:typingDot 1.2s infinite; }
.typing-dot:nth-child(2){ animation-delay:.18s; }
.typing-dot:nth-child(3){ animation-delay:.36s; }
.qr-chip {
  display:inline-flex; align-items:center; gap:5px;
  font-family:var(--font-sans); font-size:.73rem; font-weight:500; padding:6px 13px; border-radius:99px;
  border:1px solid var(--rule-mid); background:#fff;
  color:var(--brand-blue2); transition:all .22s; cursor:pointer;
}
.qr-chip:hover { background:var(--brand-blue); border-color:var(--brand-blue); color:#fff; transform:translateY(-2px); box-shadow:0 6px 16px rgba(18,73,160,.3); }
.transfer-card {
  background:linear-gradient(135deg, rgba(230,126,34,.06), rgba(230,126,34,.02));
  border:1px solid rgba(230,126,34,.22); border-radius:var(--r-md); padding:16px 18px;
}
.transfer-card-title { font-family:var(--font-sans); font-size:.78rem; font-weight:700; color:var(--brand-warm2); margin-bottom:10px; display:flex; align-items:center; gap:6px; }
.transfer-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px; border-radius:var(--r-sm);
  font-family:var(--font-sans); font-size:.76rem; font-weight:600; border:none; transition:all .18s;
  cursor:pointer;
}
.transfer-btn-primary { background:var(--brand-warm); color:#fff; }
.transfer-btn-primary:hover { background:var(--brand-warm2); }
.transfer-btn-secondary { background:transparent; color:var(--ink-muted); border:1px solid var(--rule); }
.chat-input-area { padding:10px 12px 14px; background:var(--cloud); border-top:1px solid var(--rule); flex-shrink:0; }
.chat-input-row { display:flex; align-items:center; gap:8px; }
#chat-input {
  flex:1; padding:10px 14px; border:1.5px solid var(--rule-mid); border-radius:var(--r-md);
  font-family:var(--font-sans); font-size:.8rem; color:var(--ink);
  background:#fff; outline:none; transition:border-color .2s, box-shadow .2s;
}
#chat-input:focus { border-color:var(--brand-blue); box-shadow:0 0 0 3px rgba(18,73,160,.12); }
#chat-send {
  width:38px; height:38px; flex-shrink:0;
  background:var(--brand-warm); border:none; border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, box-shadow .2s;
  box-shadow:0 4px 12px rgba(230,126,34,.42); cursor:pointer;
}
#chat-send:hover { background:var(--brand-warm2); box-shadow:0 8px 22px rgba(230,126,34,.58); }
.chat-powered { font-family:var(--font-sans); font-size:.6rem; color:var(--ink-faint); text-align:center; margin-top:6px; }

@keyframes pulseFab { 0%{box-shadow:0 0 0 0 rgba(230,126,34,.6);} 70%{box-shadow:0 0 0 16px rgba(230,126,34,0);} 100%{box-shadow:0 0 0 0 rgba(230,126,34,0);} }
#chat-button {
  width:58px; height:58px; border-radius:50%;
  background:linear-gradient(135deg, var(--brand-warm), var(--brand-warm2));
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 28px rgba(230,126,34,.52);
  animation:pulseFab 3s ease-out infinite;
  transition:transform .25s cubic-bezier(.22,1,.36,1); cursor:pointer;
}
#chat-button:hover { transform:scale(1.1); }

/* ─── SCROLL REVEAL ──────────────────────────────────── */
.reveal {
  opacity:0; transform:translateY(36px);
  transition:opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1);
}
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.22s; }
.reveal-delay-3 { transition-delay:.34s; }
.reveal-delay-4 { transition-delay:.46s; }
.reveal-left { opacity:0; transform:translateX(-28px); transition:opacity .7s, transform .7s; }
.reveal-left.visible { opacity:1; transform:translateX(0); }

/* ─── NAV RECLAMOS ───────────────────────────────────── */
.nav-link-reclamos {
  display:inline-flex; align-items:center; gap:7px; padding:9px 16px;
  background:linear-gradient(135deg, var(--brand-warm) 0%, var(--brand-warm2) 100%);
  color:#fff !important; border-radius:99px;
  font-family:var(--font-sans); font-weight:700; font-size:.7rem;
  letter-spacing:.07em; text-transform:uppercase; text-decoration:none;
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s;
  box-shadow:0 4px 14px rgba(230,126,34,.32);
}
.nav-link-reclamos::after { display:none !important; }
.nav-link-reclamos i { font-size:.82rem; }
.nav-link-reclamos:hover {
  color:#fff !important;
  box-shadow:0 8px 22px rgba(230,126,34,.5); transform:translateY(-2px);
}

/* Versión móvil del enlace de reclamos dentro del panel */
.nav-mobile-reclamos {
  display:flex !important; align-items:center; gap:10px;
  margin:10px 16px; padding:14px 18px !important;
  background:linear-gradient(135deg, var(--brand-warm) 0%, var(--brand-warm2) 100%);
  color:#fff !important; border-radius:var(--r-md);
  border-top:none !important; font-weight:700; letter-spacing:.04em;
  box-shadow:0 4px 14px rgba(230,126,34,.32);
}
.nav-mobile-reclamos:hover { background:linear-gradient(135deg, var(--brand-warm2), #b35a0c) !important; color:#fff !important; }

/* ─── SECCIÓN REPORTES Y RECLAMOS ────────────────────── */
.reclamos-section {
  position:relative; overflow:hidden;
  padding:104px 0;
  background:
    radial-gradient(ellipse 55% 70% at 90% 15%, rgba(14,165,233,.10) 0%, transparent 55%),
    radial-gradient(ellipse 50% 60% at 5% 95%, rgba(230,126,34,.10) 0%, transparent 55%),
    linear-gradient(155deg, var(--brand-blue3) 0%, var(--brand-blue2) 45%, var(--brand-blue) 100%);
}
.reclamos-section::before {
  content:''; position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size:54px 54px;
  mask-image:linear-gradient(180deg, transparent, rgba(0,0,0,.6) 35%, rgba(0,0,0,.6) 65%, transparent);
}
.reclamos-section::after {
  content:''; position:absolute; top:0; left:10%; right:10%; height:1px; z-index:1;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.25), transparent);
}
.reclamos-inner {
  position:relative; z-index:2;
  max-width:1280px; margin:0 auto; padding:0 48px;
  display:grid; grid-template-columns:1.15fr .85fr; gap:64px; align-items:center;
}
@media(max-width:900px){ .reclamos-inner { grid-template-columns:1fr; gap:40px; padding:0 24px; } }

.reclamos-overline {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-sans); font-size:.66rem; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase; color:var(--brand-warm-lt);
  margin-bottom:20px;
}
.reclamos-title {
  font-family:var(--font-display); font-size:clamp(2.1rem,4.4vw,3.6rem);
  font-weight:800; line-height:1.05; color:#fff; letter-spacing:-.01em;
  margin-bottom:20px; text-shadow:0 4px 40px rgba(0,0,0,.35);
}
.reclamos-title em {
  font-family:var(--font-serif); font-style:italic; font-weight:400;
  color:var(--brand-warm-lt);
}
.reclamos-desc {
  font-family:var(--font-sans); font-size:.94rem; line-height:1.85;
  color:rgba(255,255,255,.82); max-width:520px; margin-bottom:28px;
}
.reclamos-features { list-style:none; display:flex; flex-direction:column; gap:13px; }
.reclamos-features li {
  display:flex; align-items:center; gap:13px;
  font-family:var(--font-sans); font-size:.86rem; font-weight:500;
  color:rgba(255,255,255,.88);
}
.reclamos-features i {
  width:34px; height:34px; flex-shrink:0; border-radius:9px;
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; color:var(--brand-warm-lt);
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
}

/* Tarjeta de acción */
.reclamos-card {
  position:relative;
  background:linear-gradient(165deg, rgba(255,255,255,.97), rgba(244,246,251,.94));
  border:1px solid rgba(255,255,255,.6);
  border-radius:var(--r-xl);
  padding:40px 36px;
  box-shadow:0 30px 80px rgba(0,0,0,.32), 0 4px 14px rgba(0,0,0,.18);
  text-align:center;
}
.reclamos-card::before {
  content:''; position:absolute; top:0; left:24px; right:24px; height:3px;
  background:linear-gradient(90deg, var(--brand-warm), var(--brand-warm-lt));
  border-radius:0 0 3px 3px;
}
.reclamos-card-icon {
  width:64px; height:64px; margin:0 auto 20px; border-radius:18px;
  display:flex; align-items:center; justify-content:center; font-size:1.55rem;
  color:#fff; background:linear-gradient(135deg, var(--brand-warm), var(--brand-warm2));
  box-shadow:0 12px 30px rgba(230,126,34,.42);
}
.reclamos-card-title {
  font-family:var(--font-display); font-size:1.4rem; font-weight:600;
  color:var(--ink); line-height:1.2; margin-bottom:10px;
}
.reclamos-card-sub {
  font-family:var(--font-sans); font-size:.85rem; line-height:1.7;
  color:var(--ink-muted); margin-bottom:24px;
}
.reclamos-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  width:100%; padding:16px 28px; cursor:pointer; border:none;
  background:linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-blue2) 100%);
  color:#fff; border-radius:var(--r-md);
  font-family:var(--font-sans); font-size:.84rem; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase;
  box-shadow:0 10px 30px rgba(18,73,160,.38);
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s;
}
.reclamos-btn:hover { transform:translateY(-3px); box-shadow:0 18px 44px rgba(18,73,160,.5); }
.reclamos-card-note {
  display:flex; align-items:center; justify-content:center; gap:7px;
  margin-top:16px; font-family:var(--font-sans); font-size:.72rem;
  color:var(--ink-faint);
}
.reclamos-card-note i { color:var(--brand-blue); }

/* ─── MODAL DE RECLAMOS ──────────────────────────────── */
.reclamo-modal {
  position:fixed; inset:0; z-index:9999;
  display:flex; align-items:center; justify-content:center; padding:20px;
  background:rgba(5,17,31,.62); backdrop-filter:blur(6px);
  animation:modalIn .3s cubic-bezier(.22,1,.36,1);
}
.reclamo-modal-box {
  width:100%; max-width:460px; max-height:92vh; overflow-y:auto;
  background:var(--cloud); border:1px solid var(--rule-mid);
  border-radius:var(--r-xl);
  box-shadow:0 40px 100px rgba(5,17,31,.5);
  animation:chatWindowIn .35s cubic-bezier(.22,1,.36,1);
}
.reclamo-modal-header {
  display:flex; align-items:flex-start; justify-content:space-between; gap:16px;
  padding:24px 26px;
  background:linear-gradient(120deg, var(--brand-blue3), var(--brand-blue2));
  position:relative; overflow:hidden;
}
.reclamo-modal-header::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 60% 90% at 100% 0%, rgba(14,165,233,.22), transparent 60%);
}
.reclamo-modal-eyebrow {
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-sans); font-size:.62rem; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase; color:var(--brand-warm-lt);
  margin-bottom:7px;
}
.reclamo-modal-title {
  font-family:var(--font-display); font-size:1.45rem; font-weight:600;
  color:#fff; line-height:1.15;
}
.reclamo-modal-close {
  flex-shrink:0; width:36px; height:36px; border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  background:rgba(255,255,255,.12); border:none; color:rgba(255,255,255,.8);
  font-size:.95rem; transition:background .18s, color .18s; position:relative; z-index:1;
}
.reclamo-modal-close:hover { background:rgba(255,255,255,.26); color:#fff; }

.reclamo-form { display:flex; flex-direction:column; gap:18px; padding:26px; }
.reclamo-field { display:flex; flex-direction:column; gap:7px; }
.reclamo-field label {
  font-family:var(--font-sans); font-size:.78rem; font-weight:600; color:var(--ink-mid);
}
.reclamo-field label span { font-weight:400; color:var(--ink-faint); }
.reclamo-field input[type="text"],
.reclamo-field input[type="tel"],
.reclamo-field textarea {
  width:100%; padding:12px 14px;
  font-family:var(--font-sans); font-size:.86rem; color:var(--ink);
  background:#fff; border:1.5px solid var(--rule-mid); border-radius:var(--r-md);
  outline:none; transition:border-color .2s, box-shadow .2s; resize:vertical;
}
.reclamo-field input::placeholder,
.reclamo-field textarea::placeholder { color:var(--ink-ghost); }
.reclamo-field input:focus,
.reclamo-field textarea:focus {
  border-color:var(--brand-blue); box-shadow:0 0 0 3px rgba(18,73,160,.12);
}
.reclamo-file {
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:16px; cursor:pointer; text-align:center;
  font-family:var(--font-sans); font-size:.82rem; color:var(--ink-muted);
  background:rgba(18,73,160,.03); border:1.5px dashed var(--rule-dark);
  border-radius:var(--r-md); transition:border-color .2s, background .2s, color .2s;
}
.reclamo-file:hover { border-color:var(--brand-blue); background:rgba(18,73,160,.06); color:var(--brand-blue2); }
.reclamo-file i { font-size:1.05rem; color:var(--brand-blue); }
.reclamo-submit {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  margin-top:4px; padding:15px 24px; cursor:pointer; border:none;
  background:linear-gradient(135deg, var(--brand-warm), var(--brand-warm2));
  color:#fff; border-radius:var(--r-md);
  font-family:var(--font-sans); font-size:.84rem; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase;
  box-shadow:0 10px 28px rgba(230,126,34,.38);
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s;
}
.reclamo-submit:hover { transform:translateY(-2px); box-shadow:0 16px 38px rgba(230,126,34,.5); }
.reclamo-msg {
  font-family:var(--font-sans); font-size:.82rem; text-align:center;
  color:var(--ink-muted); min-height:1.2em;
}
@media(max-width:480px){
  .reclamos-card { padding:32px 24px; }
  .reclamo-form, .reclamo-modal-header { padding:22px; }
}

/* ─── RESPONSIVE GLOBAL ──────────────────────────────── */
@media(max-width:600px){
  .svc-card-content { padding:26px 20px; }
  .svc-title { font-size:1.05rem; }
  .svc-desc  { font-size:.75rem; }
  .about-cards { grid-template-columns:1fr; }
}
@media(max-width:540px){
  .services-section,.about-section,.team-section,.exp-section,
  .cert-full-section,.geo-section { padding:72px 0 68px; }
  h2 { font-size:clamp(2rem,7vw,3rem); }
  .lead-grid { grid-template-columns:1fr !important; }
  .lead-card--prime { grid-column:auto !important; }
  .cert-docs-grid { grid-template-columns:1fr !important; }
  .geo-grid { grid-template-columns:1fr !important; }
  .c-title { font-size:clamp(1.9rem,8vw,2.6rem); }
}
