


:root {
  --azul-marino:   #1b2d5e;  
  --azul-medio:    #2f5aad;   
  --azul-claro:    #4878d0;   
  --rojo:          #c0272d;   
  --rojo-osc:      #96191f;   
  --blanco:        #ffffff;
  --blanco1:       #1b2d5e;
  --gris-claro:    #f0f3f9;
  --gris-claro1:   #ffffff;
  --gris-borde:    #d0d8e8;
  --gris-texto:    #4a5568;
  --negro:         #111520;

  
  --font-titulo:  'Barlow Condensed', sans-serif;
  --font-cuerpo:  'Barlow', sans-serif;

  
  --max-w: 1200px;
  --radio:  10px;
  --header-h: 152px;
}


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

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-cuerpo);
  background: var(--blanco);
  color: var(--negro);
  overflow-x: hidden;
  line-height: 1.6;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
ul { list-style: none; }


.topbar {
  background: var(--azul-marino);
  color: #8aaad8;
  font-size: 0.78rem;
  letter-spacing: 0.03em;
  padding: 6px 0;
  border-bottom: 2px solid var(--rojo);
}
.topbar-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.topbar-left  { display: flex; gap: 22px; flex-wrap: wrap; }
.topbar-item  { display: flex; align-items: center; gap: 6px; }
.topbar-item svg { flex-shrink: 0; opacity: .8; }
.topbar a     { color: #8aaad8; transition: color .15s; }
.topbar a:hover { color: var(--blanco); }


header {
  background: var(--azul-marino);
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 2px 20px rgba(0,0,0,.35);
  overflow: visible;
}
.header-inner {
  width: 100%;
  margin: 0 auto;
  padding: 0 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 152px;
  gap: 24px;
  overflow: visible;
  position: relative;
}


.logo {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-shrink: 0;
}
.logo-icono {
  position: relative;
  width: 52px;
  height: 52px;
  background: var(--azul-medio);
  border-radius: var(--radio);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.logo-icono::after {
  content: '';
  position: absolute;
  bottom: 6px; left: 6px;
  width: 18px; height: 18px;
  background: var(--rojo);
  border-radius: 3px;
}
.logo-icono-onda {
  position: absolute;
  top: 6px; left: 6px;
  width: 40px; height: 24px;
}
.logo-icono-onda path { fill: none; stroke: var(--blanco); stroke-width: 2.5; }

.logo-texto { line-height: 1.50; }
.logo-nombre {
  font-family: 'Times New Roman', Times, serif;
  font-weight: 600;
  font-size: 2.75rem;
  color: var(--blanco);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.logo-sub {
  font-size: 1.05rem;
  color: var(--blanco);
  text-transform: uppercase;
  letter-spacing: 0.09em;
  font-weight: 500;
}


/* Ondas decorativas del header */
.header-ondas-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}
.header-inner > *:not(.header-ondas-bg) {
  position: relative;
  z-index: 1;
}

nav { display: flex; align-items: center; gap: 8px; position: relative; overflow: visible; }
nav a {
  color: #b0c8e8;
  font-size: 1.22rem;
  font-weight: 600;
  padding: 14px 20px;
  border-radius: 6px;
  transition: background .18s, color .18s;
  white-space: nowrap;
}
nav a:hover,
nav a.activo { background: rgba(255,255,255,.1); color: var(--blanco); }

.nav-cta {
  background: var(--rojo) !important;
  color: var(--blanco) !important;
  font-weight: 700;
  margin-left: 10px;
  letter-spacing: .03em;
}
.nav-cta:hover { background: var(--rojo-osc) !important; }


.hero {
  background: linear-gradient(140deg, var(--azul-marino) 0%, #1e3a78 55%, #2a508c 100%);
  padding: 88px 24px 76px;
  position: relative;
  overflow: hidden;
}

.hero-onda {
  position: absolute;
  bottom: -20px; left: -40px;
  opacity: .12;
  pointer-events: none;
}
.hero-onda2 {
  position: absolute;
  top: -60px; right: -80px;
  opacity: .08;
  pointer-events: none;
}
.hero-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 60px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(192,39,45,.2);
  border: 1px solid rgba(192,39,45,.5);
  color: #f09098;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 999px;
  margin-bottom: 22px;
}
.hero-badge-punto {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--rojo);
}
.hero h1 {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  color: var(--blanco);
  line-height: 1.05;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 20px;
}
.hero h1 em {
  font-style: normal;
  color: #6a9de0;
}
.hero-desc {
  color: #8aaad8;
  font-size: 1.05rem;
  line-height: 1.68;
  max-width: 520px;
  margin-bottom: 10px;
}
.hero-desc strong { color: var(--blanco); }

.hero-sin-cita {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--blanco);
  font-family: var(--font-titulo);
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 12px 28px;
  border-radius: 8px;
  margin-bottom: 10px;

  animation: sincita-color 3s infinite;
}
@keyframes sincita-color {
  0%   { color: #ff0000; }
  25%  { color: #ffffff; }
  50%  { color: #4466f6; }
  75%  { color: #ffffff; }
  100% { color: #ff0000; }
}
.hero-sin-cita-icono {
  font-style: normal;
  font-size: 1.1rem;
}


.hero-btns { display: flex; gap: 14px; flex-wrap: wrap; }

.btn-rojo {
  background: var(--rojo);
  color: var(--blanco);
  font-weight: 700;
  font-size: 0.95rem;
  padding: 13px 28px;
  border-radius: 8px;
  transition: background .18s, transform .15s;
  display: inline-block;
}
.btn-rojo:hover { background: var(--rojo-osc); transform: translateY(-2px); }

.btn-borde {
  border: 2px solid rgba(255,255,255,.3);
  color: var(--blanco);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 11px 26px;
  border-radius: 8px;
  transition: border-color .18s, background .18s;
  display: inline-block;
}
.btn-borde:hover { border-color: var(--blanco); background: rgba(255,255,255,.08); }


.hero-tarjeta {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 16px;
  backdrop-filter: blur(8px);
  padding: 28px 24px;
}
.hero-tarjeta h3 {
  font-family: var(--font-titulo);
  font-weight: 700;
  font-size: 1rem;
  color: var(--blanco);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.tarjeta-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 8px;
  border-radius: 8px;
  transition: background .15s;
  color: inherit;
}
.tarjeta-item:hover { background: rgba(255,255,255,.08); }
.tarjeta-icono {
  width: 36px; height: 36px;
  background: rgba(192,39,45,.2);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.tarjeta-icono svg { color: #f09098; }
.tarjeta-texto strong {
  display: block;
  color: #ddeaff;
  font-size: 0.86rem;
  font-weight: 600;
  margin-bottom: 1px;
}
.tarjeta-texto span { color: #6a8ab8; font-size: 0.76rem; }


.stats-bar {
  background: var(--azul-marino);
  border-top: 3px solid var(--rojo);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.stats-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 28px 24px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.stat {
  text-align: center;
  padding: 8px 12px;
  border-right: 1px solid rgba(255,255,255,.1);
}
.stat:last-child { border-right: none; }
.stat-num {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: 2.3rem;
  color: var(--blanco);
  line-height: 1;
}
.stat-num span { color: var(--rojo); }
.stat-label {
  font-size: 0.76rem;
  color: #6a8ab8;
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-top: 5px;
  font-weight: 500;
}


.seccion { padding: 80px 24px; }
.seccion-inner { max-width: var(--max-w); margin: 0px auto; }

.seccion-etiqueta {
  display: inline-block;
  background: rgba(192,39,45,.1);
  color: var(--rojo-osc);
  font-size: 0.73rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 4px 13px;
  border-radius: 999px;
  margin-bottom: 14px;
}
.seccion-titulo {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: clamp(1.8rem, 3.5vw, 2.7rem);
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1.1;
  margin-bottom: 12px;
}
.seccion-titulo1 {
  font-family: var(--font-titulo);
  font-weight: 800;
  margin-left: 12px;
  font-size: clamp(1.8rem, 3.5vw, 2.7rem);
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1.1;
  margin-bottom: 12px;
}
.seccion-sub {
  color: var(--gris-texto);
  font-size: 1rem;
  line-height: 1.65;
  max-width: 580px;
  margin-bottom: 50px;
}
.seccion-sub1 {
  color: var(--gris-texto);
  font-size: 1rem;
  line-height: 1.65;
  max-width: 580px;
  margin-bottom: 50px;
  margin-left: 12px;
}


.servicios-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.servicio-card {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: 14px;
  padding: 28px 24px;
  transition: box-shadow .2s, transform .2s, border-color .2s;
  position: relative;
  overflow: hidden;
}
.servicio-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--rojo), var(--azul-medio));
  opacity: 0;
  transition: opacity .2s;
}
.servicio-card:hover {
  box-shadow: 0 8px 32px rgba(27,45,94,.12);
  transform: translateY(-3px);
  border-color: transparent;
}
.servicio-card:hover::before { opacity: 1; }

.servicio-icono {
  width: 52px; height: 52px;
  background: linear-gradient(135deg, var(--azul-marino), var(--azul-medio));
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.servicio-icono svg { color: var(--blanco); }

.servicio-card h3 {
  font-family: var(--font-titulo);
  font-weight: 700;
  font-size: 1.12rem;
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 10px;
}
.servicio-card p {
  color: var(--gris-texto);
  font-size: 0.87rem;
  line-height: 1.62;
  margin-bottom: 16px;
}
.servicio-icono--rojo {
  background: linear-gradient(135deg, var(--rojo-osc), var(--rojo));
}
.servicio-etiqueta--rojo {
  background: rgba(192,39,45,.1);
  color: var(--rojo-osc);
}

.servicio-etiqueta {
  display: inline-block;
  background: var(--gris-claro);
  color: var(--azul-marino);
  font-size: 0.71rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  letter-spacing: .05em;
}


.sedes-seccion {
  background: linear-gradient(180deg, var(--azul-marino) 0%, #111d40 100%);
  padding: 80px 24px;
}
.sedes-seccion .seccion-etiqueta {
  background: rgba(255,255,255,.1);
  color: #8aaad8;
}
.sedes-seccion .seccion-titulo { color: var(--blanco1); }
.sedes-seccion .seccion-sub    { color: #6a8ab8; }

.sedes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
  gap: 12px;
}
.sede-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 10px;
  padding: 15px 18px;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: background .18s, border-color .18s;
}
.sede-card:hover {
  background: rgba(192,39,45,.15);
  border-color: rgba(192,39,45,.4);
}
.sede-punto {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--rojo);
  flex-shrink: 0;
}
.sede-nombre {
  color: #c8ddf5;
  font-size: 0.88rem;
  font-weight: 500;
}


.dgt-seccion { background: var(--gris-claro1); padding: 80px 24px; }

.dgt-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
}
.dgt-link {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: 12px;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  transition: box-shadow .18s, border-color .18s, transform .15s;
}
.dgt-link:hover {
  box-shadow: 0 4px 20px rgba(27,45,94,.1);
  border-color: var(--azul-medio);
  transform: translateY(-2px);
}
.dgt-link-icono {
  width: 42px; height: 42px;
  background: linear-gradient(135deg, var(--azul-marino), var(--azul-medio));
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.dgt-link-icono svg { color: var(--blanco); }
.dgt-link-icono.rojo { background: linear-gradient(135deg, var(--rojo-osc), var(--rojo)); }

.dgt-link-texto strong {
  display: block;
  color: var(--azul-marino);
  font-size: 0.87rem;
  font-weight: 600;
  margin-bottom: 2px;
}
.dgt-link-texto span {
  color: var(--gris-texto);
  font-size: 0.75rem;
}


.cta-strip {
  background: linear-gradient(90deg, var(--rojo-osc) 0%, var(--rojo) 100%);
  padding: 56px 24px;
  text-align: center;
}
.cta-strip h2 {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  color: var(--blanco);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 10px;
}
.cta-strip p {
  color: rgba(255,255,255,.85);
  font-size: 1rem;
  margin-bottom: 28px;
}
.btn-blanco {
  background: var(--blanco);
  color: var(--rojo-osc);
  font-weight: 700;
  font-size: 0.95rem;
  padding: 13px 32px;
  border-radius: 8px;
  display: inline-block;
  transition: transform .15s, box-shadow .15s;
}
.btn-blanco:hover { transform: translateY(-2px); box-shadow: 0 4px 20px rgba(0,0,0,.2); }


footer {
  background: var(--negro);
  color: #5a7a9a;
  padding: 56px 24px 28px;
  border-top: 3px solid var(--rojo);
}
.footer-inner { max-width: var(--max-w); margin: 0 auto; }
.footer-top {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  margin-bottom: 28px;
}
.footer-logo-nombre {
  font-family: 'Times New Roman', Times, serif;
  font-weight: 800;
  font-size: 2.2rem;
  color: var(--blanco);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.footer-logo-sub {
  font-size: 0.68rem;
  color: #4a6a8a;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 16px;
}
.footer-desc {
  font-size: 0.83rem;
  line-height: 1.68;
  color: #4a6a8a;
}
.footer-col h4 {
  color: #a0c0e0;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: 16px;
}
.footer-col ul li { margin-bottom: 9px; }
.footer-col ul li a {
  color: #4a6a8a;
  font-size: 0.84rem;
  transition: color .15s;
}
.footer-col ul li a:hover { color: var(--blanco); }

.footer-bottom {
  text-align: center;
  justify-content: space-between;
  align-items: center;
  font-size: 0.77rem;
  flex-wrap: wrap;
  gap: 10px;
}
.footer-bottom p { 
  text-align: center;
}

.footer-bottom a { color: #4a6a8a; }
.footer-bottom a:hover { color: var(--blanco); }


@media (max-width: 1024px) {
  .servicios-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-tarjeta { display: none; }
  .stats-inner { grid-template-columns: repeat(2, 1fr); }
  .stat:nth-child(2) { border-right: none; }
  .footer-top { grid-template-columns: 1fr 1fr; }
}







.hero-interior {
  background: linear-gradient(140deg, var(--azul-marino) 0%, #1e3a78 60%, #2a508c 100%);
  padding: 56px 24px 52px;
  position: relative;
  overflow: hidden;
}
.hero-interior::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='600' height='200' viewBox='0 0 600 200' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 140 Q150 60 300 110 Q450 160 600 80' stroke='white' stroke-width='2' fill='none' opacity='0.07'/%3E%3Cpath d='M0 170 Q150 90 300 140 Q450 190 600 110' stroke='white' stroke-width='1.5' fill='none' opacity='0.05'/%3E%3C/svg%3E") no-repeat center bottom;
  pointer-events: none;
}
.hero-interior-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 18px;
  font-size: 0.8rem;
  color: #6a8ab8;
}
.breadcrumb a { color: #6a8ab8; transition: color .15s; }
.breadcrumb a:hover { color: var(--blanco); }
.breadcrumb-sep { opacity: .4; }
.hero-interior h1 {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--blanco);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1.05;
  margin-bottom: 12px;
}
.hero-interior h1 em {
  font-style: normal;
  color: #6a9de0;
}
.hero-interior p {
  color: #8aaad8;
  font-size: 1rem;
  max-width: 540px;
}


.centros-seccion {
  background: var(--gris-claro);
  padding: 70px 24px 80px;
}
.centros-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 56px;
}


.centro-card {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(27,45,94,.06);
  transition: box-shadow .2s, transform .2s;
}
.centro-card:hover {
  box-shadow: 0 8px 32px rgba(27,45,94,.13);
  transform: translateY(-2px);
}
.centro-header {
  background: linear-gradient(135deg, var(--azul-marino) 0%, var(--azul-medio) 100%);
  padding: 20px 24px 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.centro-nombre {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--blanco);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 5px;
}
.centro-direccion {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #9abde0;
  font-size: 0.84rem;
}
.centro-direccion svg { flex-shrink: 0; }
.centro-badge {
  background: var(--rojo);
  color: var(--blanco);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  white-space: nowrap;
  flex-shrink: 0;
}
.centro-body { padding: 22px 24px; }


.horario-bloque { margin-bottom: 14px; }
.horario-bloque:last-of-type { margin-bottom: 0; }
.horario-dia {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--azul-marino);
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.horario-dia::before {
  content: '';
  width: 3px;
  height: 12px;
  background: var(--rojo);
  border-radius: 2px;
  display: inline-block;
}
.horario-franjas {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-left: 9px;
}
.horario-franja {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.86rem;
  color: var(--gris-texto);
}
.franja-tipo {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #8aaad8;
  min-width: 52px;
}
.franja-hora {
  font-weight: 600;
  color: var(--azul-marino);
}
.horario-separador {
  border: none;
  border-top: 1px solid var(--gris-borde);
  margin: 16px 0;
}


.centro-mapa {
  margin: 0 24px 24px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--gris-borde);
  height: 200px;
  display: flex;
}
.centro-mapa iframe {
  width: 50%;
  height: 100%;
  border: none;
  display: block;
  flex-shrink: 0;
}
.centro-foto {
  width: 50%;
  flex-shrink: 0;
  overflow: hidden;
  border-left: 1px solid var(--gris-borde);
}
.centro-foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}


.centro-footer {
  padding: 0 24px 20px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.btn-maps {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--azul-marino);
  color: var(--blanco);
  font-size: 0.8rem;
  font-weight: 600;
  padding: 8px 16px;
  border-radius: 7px;
  transition: background .18s;
}
.btn-maps:hover { background: var(--azul-medio); }
.btn-llamar {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--rojo);
  color: var(--blanco);
  font-size: 0.8rem;
  font-weight: 600;
  padding: 8px 16px;
  border-radius: 7px;
  transition: background .18s;
}
.btn-llamar:hover { background: var(--rojo-osc); }


@media (max-width: 860px) {
  .centros-grid { grid-template-columns: 1fr; }
}





.srv-nav {
  background: var(--blanco);
  border-bottom: 2px solid var(--gris-borde);
  position: sticky;
  top: 152px;
  z-index: 90;
  box-shadow: 0 2px 8px rgba(27,45,94,.06);
}
@media (max-width: 860px) {
  .srv-nav { top: 110px; }
}
@media (max-width: 600px) {
  .srv-nav { top: 72px; }
}
.srv-nav-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  gap: 4px;
  overflow-x: auto;
  scrollbar-width: none;
}
.srv-nav-inner::-webkit-scrollbar { display: none; }
.srv-nav-item {
  display: flex;
  align-items: center;
  gap: 7px;
  color: var(--gris-texto);
  font-size: 0.85rem;
  font-weight: 600;
  padding: 14px 16px;
  white-space: nowrap;
  border-bottom: 3px solid transparent;
  transition: color .18s, border-color .18s;
  text-decoration: none;
}
.srv-nav-item:hover {
  color: var(--azul-marino);
  border-bottom-color: var(--rojo);
}
.srv-nav-item svg { flex-shrink: 0; }

.srv-nav-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 36px;
  height: 100%;
  background: var(--blanco);
  border: none;
  cursor: pointer;
  color: var(--azul-marino);
  z-index: 2;
  transition: background .15s, color .15s;
}
.srv-nav-arrow--left {
  border-right: 1px solid var(--gris-borde);
  box-shadow: 4px 0 8px rgba(255,255,255,0.9);
}
.srv-nav-arrow--right {
  border-left: 1px solid var(--gris-borde);
  box-shadow: -4px 0 8px rgba(255,255,255,0.9);
}
.srv-nav-arrow:hover {
  background: var(--gris-claro);
  color: var(--rojo);
}


.srv-main { background: var(--blanco); }

.srv-seccion {
  padding: 72px 24px;
  border-bottom: 1px solid var(--gris-borde);
  scroll-margin-top: 210px;
}
@media (max-width: 860px) {
  .srv-seccion { scroll-margin-top: 170px; }
}
@media (max-width: 600px) {
  .srv-seccion { scroll-margin-top: 150px; }
}
.srv-seccion--alt { background: var(--gris-claro); }
.srv-seccion-inner { max-width: var(--max-w); margin: 0 auto; }


.srv-header {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  margin-bottom: 40px;
}
.srv-header-icono {
  width: 60px; height: 60px;
  background: linear-gradient(135deg, var(--azul-marino), var(--azul-medio));
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--blanco);
}
.srv-etiqueta {
  display: inline-block;
  background: rgba(192,39,45,.1);
  color: var(--rojo-osc);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 3px 12px;
  border-radius: 999px;
  margin-bottom: 8px;
}
.srv-titulo {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1.05;
  margin-bottom: 8px;
}
.srv-subtitulo {
  color: var(--gris-texto);
  font-size: 0.97rem;
  line-height: 1.6;
  max-width: 640px;
}


.srv-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-bottom: 48px;
}
.srv-bloque {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: 12px;
  padding: 24px;
}
.srv-seccion--alt .srv-bloque { background: var(--blanco); }

.srv-bloque-titulo {
  font-family: var(--font-titulo);
  font-weight: 700;
  font-size: 1rem;
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--rojo);
  display: inline-block;
}
.srv-lista {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.srv-lista li {
  color: var(--gris-texto);
  font-size: 0.88rem;
  padding-left: 18px;
  position: relative;
  line-height: 1.5;
}
.srv-lista li::before {
  content: '';
  position: absolute;
  left: 0; top: 8px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--rojo);
}
.srv-nota {
  margin-top: 16px;
  background: rgba(27,45,94,.05);
  border-left: 3px solid var(--azul-medio);
  border-radius: 0 8px 8px 0;
  padding: 10px 14px;
  font-size: 0.82rem;
  color: var(--gris-texto);
  line-height: 1.55;
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
.srv-nota svg { flex-shrink: 0; margin-top: 1px; color: var(--azul-medio); }


.srv-tabla { width: 100%; border-collapse: collapse; font-size: 0.84rem; }
.srv-tabla-fila {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  padding: 9px 12px;
  border-radius: 6px;
  gap: 8px;
}
.srv-tabla-fila.cabecera {
  background: var(--azul-marino);
  color: var(--blanco);
  font-weight: 700;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  border-radius: 8px 8px 0 0;
  margin-bottom: 2px;
}
.srv-tabla-fila:not(.cabecera) {
  border-bottom: 1px solid var(--gris-borde);
  color: var(--gris-texto);
}
.srv-tabla-fila:not(.cabecera):last-child { border-bottom: none; }
.srv-tabla-fila span:not(:first-child) { text-align: center; font-weight: 600; color: var(--azul-mari); }
.srv-tabla-fila.cabecera span { text-align: center; }
.srv-tabla-fila.cabecera span:first-child { text-align: left; }


.srv-subtitulo-seccion {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--gris-borde);
}


.permisos-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.permiso-card {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: 10px;
  padding: 18px 16px;
  transition: border-color .18s, box-shadow .18s;
}
.srv-seccion--alt .permiso-card { background: var(--blanco); }
.permiso-card:hover {
  border-color: var(--azul-medio);
  box-shadow: 0 4px 16px rgba(27,45,94,.08);
}
.permiso-badge {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--blanco);
  background: linear-gradient(135deg, var(--azul-marino), var(--azul-medio));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 12px;
  border-radius: 6px;
  margin-bottom: 10px;
  letter-spacing: 1px;
}
.permiso-card p {
  font-size: 0.81rem;
  color: var(--gris-texto);
  line-height: 1.55;
}
.permiso-card p strong { color: var(--azul-marino); }


.licencias-lista {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.licencia-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: 10px;
  padding: 16px 20px;
  transition: border-color .18s, box-shadow .18s;
}
.srv-seccion--alt .licencia-item { background: var(--blanco); }
.licencia-item:hover {
  border-color: var(--azul-claro);
  box-shadow: 0 3px 12px rgba(27,45,94,.07);
}
.licencia-badge {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: 1rem;
  color: var(--blanco);
  background: var(--rojo);
  padding: 5px 12px;
  border-radius: 6px;
  white-space: nowrap;
  flex-shrink: 0;
  letter-spacing: 1px;
  min-width: 52px;
  text-align: center;
}
.licencia-info {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.licencia-info strong {
  font-size: 0.9rem;
  color: var(--azul-marino);
  font-weight: 600;
}
.licencia-info span {
  font-size: 0.82rem;
  color: var(--gris-texto);
  line-height: 1.5;
}


.razas-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.raza-tag {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  color: var(--azul-marino);
  font-size: 0.83rem;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 999px;
  transition: background .15s, border-color .15s;
}
.raza-tag:hover {
  background: var(--azul-marino);
  color: var(--blanco);
  border-color: var(--azul-marino);
}


@media (max-width: 960px) {
  .permisos-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .srv-grid { grid-template-columns: 1fr; }
  .permisos-grid { grid-template-columns: repeat(2, 1fr); }
  .srv-header { flex-direction: column; gap: 14px; }
}
@media (max-width: 480px) {
  .permisos-grid { grid-template-columns: 1fr 1fr; }
}





.contacto-seccion {
  background: var(--gris-claro);
  padding: 72px 24px;
}
.contacto-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 40px;
  align-items: start;
}


.contacto-datos {
  background: var(--azul-marino);
  border-radius: 16px;
  padding: 36px 28px;
  position: sticky;
  top: 96px;
}
.datos-bloque {
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.datos-titulo {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: 1.5rem;
  color: var(--blanco);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 4px;
}
.datos-sub {
  color: #6a8ab8;
  font-size: 0.82rem;
  line-height: 1.5;
}

.datos-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 20px;
}
.datos-icono {
  width: 38px; height: 38px;
  background: rgba(192,39,45,.2);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: #f09098;
}
.datos-texto {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.datos-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #6a8ab8;
}
.datos-valor {
  font-size: 0.88rem;
  color: #c8ddf5;
  font-weight: 500;
  line-height: 1.45;
  text-decoration: none;
  transition: color .15s;
}
a.datos-valor:hover { color: var(--blanco); }

.datos-centros-link {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.datos-centros-link a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #9abde0;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  transition: color .15s;
}
.datos-centros-link a:hover { color: var(--blanco); }

.datos-autorizado {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.autorizado-logos {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 10px;
}
.autorizado-tag {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  color: #8aaad8;
  font-size: 0.71rem;
  font-weight: 600;
  letter-spacing: .06em;
  padding: 4px 10px;
  border-radius: 999px;
}


.contacto-formulario {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: 16px;
  padding: 40px 36px;
}
.form-cabecera { margin-bottom: 30px; }
.form-titulo {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: 1.7rem;
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 6px;
}
.form-sub {
  color: var(--gris-texto);
  font-size: 0.9rem;
}


.form-aviso {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  border-radius: 10px;
  margin-bottom: 28px;
  font-size: 0.88rem;
  line-height: 1.55;
}
.form-aviso--ok {
  background: rgba(44,160,90,.08);
  border: 1px solid rgba(44,160,90,.35);
  color: #1d6e3a;
}
.form-aviso--ok svg { color: #2ca05a; flex-shrink: 0; margin-top: 2px; }
.form-aviso--error {
  background: rgba(192,39,45,.07);
  border: 1px solid rgba(192,39,45,.3);
  color: var(--rojo-osc);
}
.form-aviso--error svg { color: var(--rojo); flex-shrink: 0; margin-top: 2px; }
.form-aviso strong { display: block; margin-bottom: 4px; font-weight: 700; }
.form-aviso ul { padding-left: 16px; margin-top: 4px; }
.form-aviso ul li { margin-bottom: 2px; }
.form-aviso a { color: inherit; font-weight: 600; }


.form-fila {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}
.form-grupo { display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px; }
.form-fila .form-grupo { margin-bottom: 0; }

.form-label {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.form-req { color: var(--rojo); }

.form-input {
  width: 100%;
  background: var(--gris-claro);
  border: 1.5px solid var(--gris-borde);
  border-radius: 8px;
  padding: 11px 14px;
  font-family: var(--font-cuerpo);
  font-size: 0.92rem;
  color: var(--negro);
  transition: border-color .18s, box-shadow .18s, background .18s;
  outline: none;
  appearance: none;
}
.form-input:focus {
  border-color: var(--azul-medio);
  background: var(--blanco);
  box-shadow: 0 0 0 3px rgba(47,90,173,.1);
}
.form-input--error {
  border-color: var(--rojo);
  background: rgba(192,39,45,.04);
}
.form-input--error:focus { box-shadow: 0 0 0 3px rgba(192,39,45,.1); }
.form-input::placeholder { color: var(--gris-med); }

.form-select { cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a5568' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }

.form-textarea { resize: vertical; min-height: 130px; line-height: 1.6; }


.form-privacidad {
  margin-bottom: 24px;
}
.form-check-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: 0.84rem;
  color: var(--gris-texto);
  line-height: 1.5;
}
.form-check {
  width: 18px; height: 18px;
  accent-color: var(--azul-marino);
  flex-shrink: 0;
  margin-top: 2px;
  cursor: pointer;
}
.form-check-label a {
  color: var(--azul-medio);
  font-weight: 600;
  text-decoration: none;
}
.form-check-label a:hover { text-decoration: underline; }


.form-submit {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: var(--rojo);
  color: var(--blanco);
  font-family: var(--font-titulo);
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 13px 32px;
  border: none;
  border-radius: 9px;
  cursor: pointer;
  transition: background .18s, transform .15s, box-shadow .18s;
  width: 100%;
  justify-content: center;
}
.form-submit:hover {
  background: var(--rojo-osc);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(192,39,45,.3);
}
.form-submit:active { transform: translateY(0); }


@media (max-width: 900px) {
  .contacto-inner {
    grid-template-columns: 1fr;
  }
  .contacto-datos { position: static; }
}
@media (max-width: 600px) {
  .form-fila { grid-template-columns: 1fr; }
  .contacto-formulario { padding: 28px 20px; }
}





.dgt-buscador-wrap {
  background: var(--azul-marino);
  padding: 22px 24px;
  border-bottom: 2px solid rgba(255,255,255,.06);
}
.dgt-buscador-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.dgt-buscador {
  flex: 1;
  min-width: 260px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,.08);
  border: 1.5px solid rgba(255,255,255,.15);
  border-radius: 10px;
  padding: 10px 16px;
  transition: border-color .18s, background .18s;
}
.dgt-buscador:focus-within {
  border-color: rgba(255,255,255,.4);
  background: rgba(255,255,255,.12);
}
.dgt-buscador svg { color: #6a8ab8; flex-shrink: 0; }
.dgt-buscador input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--blanco);
  font-family: var(--font-cuerpo);
  font-size: 0.95rem;
}
.dgt-buscador input::placeholder { color: #5a7a9a; }
.dgt-search-clear {
  background: none;
  border: none;
  cursor: pointer;
  color: #6a8ab8;
  padding: 2px;
  display: flex;
  transition: color .15s;
}
.dgt-search-clear:hover { color: var(--blanco); }
.dgt-buscador-hint {
  color: #6a8ab8;
  font-size: 0.82rem;
  white-space: nowrap;
}


.dgt-main { background: var(--blanco); }


.dgt-categoria {
  padding: 64px 24px;
  border-bottom: 1px solid var(--gris-borde);
}
.dgt-categoria--alt { background: var(--gris-claro); }
.dgt-categoria-inner { max-width: var(--max-w); margin: 0 auto; }

.dgt-cat-header {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 32px;
}
.dgt-cat-icono {
  width: 54px; height: 54px;
  background: linear-gradient(135deg, var(--azul-marino), var(--azul-medio));
  border-radius: 13px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--blanco);
}
.dgt-cat-icono--rojo {
  background: linear-gradient(135deg, var(--rojo-osc), var(--rojo));
}
.dgt-cat-titulo {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1.05;
  margin-bottom: 6px;
}
.dgt-cat-sub {
  color: var(--gris-texto);
  font-size: 0.92rem;
}


.dgt-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.dgt-card {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: 12px;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  transition: box-shadow .18s, border-color .18s, transform .15s;
  position: relative;
}
.dgt-categoria--alt .dgt-card { background: var(--blanco); }
.dgt-card:hover {
  box-shadow: 0 4px 20px rgba(27,45,94,.1);
  border-color: var(--azul-medio);
  transform: translateY(-2px);
}
.dgt-card[hidden] { display: none; }

.dgt-card-icono {
  width: 40px; height: 40px;
  background: linear-gradient(135deg, var(--azul-marino), var(--azul-medio));
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--blanco);
}
.dgt-card-texto {
  flex: 1;
  min-width: 0;
}
.dgt-card-texto strong {
  display: block;
  font-size: 0.88rem;
  color: var(--azul-marino);
  font-weight: 600;
  margin-bottom: 2px;
  line-height: 1.3;
}
.dgt-card-texto span {
  font-size: 0.76rem;
  color: var(--gris-texto);
  line-height: 1.4;
}
.dgt-card-ext {
  color: var(--gris-med);
  font-size: 0.9rem;
  flex-shrink: 0;
  transition: color .15s, transform .15s;
}
.dgt-card:hover .dgt-card-ext {
  color: var(--azul-medio);
  transform: translate(2px, -2px);
}


.dgt-sin-resultados {
  padding: 80px 24px;
  text-align: center;
  color: var(--gris-texto);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.dgt-sin-resultados[hidden] { display: none; }
.dgt-sin-resultados svg { opacity: .3; }
.dgt-sin-resultados p { font-size: 1rem; }


.dgt-nota {
  background: var(--gris-claro);
  border-top: 1px solid var(--gris-borde);
  padding: 18px 24px;
}
.dgt-nota-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.8rem;
  color: var(--gris-texto);
  line-height: 1.6;
}
.dgt-nota-inner svg { flex-shrink: 0; margin-top: 2px; color: var(--azul-medio); }


@media (max-width: 900px) {
  .dgt-cards-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .dgt-cards-grid { grid-template-columns: 1fr; }
  .dgt-cat-header { flex-direction: column; gap: 12px; }
}





.nav-dropdown {
  position: relative;
}


.nav-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  cursor: pointer;
}

.nav-chevron {
  transition: transform 0.22s ease;
  flex-shrink: 0;
  margin-top: 1px;
}
.nav-dropdown.abierto .nav-chevron {
  transform: rotate(180deg);
}


.nav-mega {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  left: auto;
  width: 500px;
  max-width: min(500px, calc(100vw - 32px));
  background: var(--blanco);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,.18);
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity .2s ease, transform .2s ease;
}
.nav-dropdown.abierto .nav-mega {
  display: block;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}


.nav-mega-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  padding: 10px;
}


.nav-mega-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 11px 12px;
  border-radius: 8px;
  text-decoration: none;
  color: inherit;
  transition: background .15s ease;
  min-width: 0;
  overflow: hidden;
}
.nav-mega-item:hover {
  background: var(--gris-claro);
}

.nav-mega-icono {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: rgba(47,90,173,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--azul-medio);
  transition: background .15s ease, color .15s ease;
}
.nav-mega-item:hover .nav-mega-icono {
  background: var(--azul-medio);
  color: var(--blanco);
}

.nav-mega-texto {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  overflow: hidden;
}
.nav-mega-texto strong {
  font-size: .84rem;
  font-weight: 600;
  color: var(--negro);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nav-mega-texto span {
  font-size: .75rem;
  color: var(--gris-texto);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}


.nav-mega-footer {
  border-top: 1px solid var(--gris-borde);
  padding: 10px 18px;
  text-align: right;
}
.nav-mega-footer a {
  font-size: .82rem;
  font-weight: 600;
  color: var(--azul-medio);
  text-decoration: none;
}
.nav-mega-footer a:hover { text-decoration: underline; }


.nav-mega--centros {
  width: 420px;
  max-width: min(420px, calc(100vw - 32px));
}
.nav-mega-inner--centros {
  grid-template-columns: 1fr;   
  gap: 1px;
  padding: 8px;
}
.nav-mega-item--centro {
  padding: 9px 12px;
  align-items: center;
}
.nav-mega-icono--pin {
  width: 30px;
  height: 30px;
  border-radius: 6px;
  background: rgba(192,39,45,.1);
  color: var(--rojo);
  flex-shrink: 0;
}
.nav-mega-item--centro:hover .nav-mega-icono--pin {
  background: var(--rojo);
  color: var(--blanco);
}
.nav-mega-item--centro .nav-mega-texto strong {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .85rem;
}
.nav-mega-item--centro .nav-mega-texto span {
  font-size: .73rem;
}


.centro-badge-mini {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  background: rgba(192,39,45,.12);
  color: var(--rojo);
  border: 1px solid rgba(192,39,45,.25);
  padding: 1px 6px;
  border-radius: 999px;
  white-space: nowrap;
}


@media (max-width: 640px) {
  .nav-mega--centros {
    width: 100%;
  }
  .nav-mega-inner--centros {
    grid-template-columns: 1fr;
  }
}
.nav-mega-footer a:hover { text-decoration: underline; }





header.header--scrolled {
  box-shadow: 0 4px 24px rgba(0,0,0,.4);
}


.form-error-msg {
  color: var(--rojo);
  font-size: 0.78rem;
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
}


/* ═══════════════════════════════════════════════════════
   BOTÓN HAMBURGUESA
   Igual que Vallesoft: display:none por defecto,
   visible solo en móvil via media query
════════════════════════════════════════════════════════ */

.mob-logo-nombre {
  font-family: 'Times New Roman', Times, serif;
  font-weight: 600;
  font-size: 1.25rem;
  color: var(--blanco);
  letter-spacing: .001px;
  text-transform: uppercase;
}

.mob-toggle {
  display: none;
  background: rgba(255,255,255,.1);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  padding: 8px 10px;
  flex-shrink: 0;
}
.mob-toggle:hover { background: rgba(255,255,255,.2); }
.mob-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--blanco);
  margin: 5px 0;
  border-radius: 2px;
  transition: transform .25s, opacity .25s;
}
.mob-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mob-toggle.open span:nth-child(2) { opacity: 0; }
.mob-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ═══════════════════════════════════════════════════════
   MENÚ MÓVIL (fuera del header, igual que Vallesoft)
   JS añade/quita clase "open"
════════════════════════════════════════════════════════ */
.mob-nav-jadi {
  display: none;
  position: fixed;
  top: var(--header-h, 152px);
  left: 0;
  width: 100%;
  background: var(--azul-marino);
  border-top: 3px solid var(--rojo);
  box-shadow: 0 8px 32px rgba(0,0,0,.5);
  z-index: 9999;
  padding: 8px 0 24px;
  max-height: calc(100vh - var(--header-h, 152px));
  overflow-y: auto;
  animation: slideDown .22s ease;
}
.mob-nav-jadi.open { display: block; }

@keyframes slideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.mob-nav-jadi ul { list-style: none; }

.mob-nav-jadi > ul > li > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 5vw;
  font-size: 1rem;
  font-weight: 700;
  font-family: var(--font-titulo);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #b0c8e8;
  border-bottom: 1px solid rgba(255,255,255,.07);
  transition: color .15s, background .15s;
}
.mob-nav-jadi > ul > li > a:hover { color: var(--blanco); background: rgba(255,255,255,.06); }
.mob-nav-jadi > ul > li:last-child > a { border-bottom: none; }

.mob-nav-jadi .mob-cta {
  color: var(--blanco) !important;
  background: var(--rojo);
  margin: 12px 5vw 0;
  border-radius: 8px;
  justify-content: center !important;
  border-bottom: none !important;
}
.mob-nav-jadi .mob-cta:hover { background: var(--rojo-osc) !important; }

/* Submenú desplegable en móvil */
.mob-nav-jadi .mob-sub {
  display: none;
  background: rgba(0,0,0,.2);
  list-style: none;
}
.mob-nav-jadi .mob-sub.open { display: block; }
.mob-nav-jadi .mob-sub li a {
  display: block;
  padding: 11px calc(5vw + 18px);
  font-size: .88rem;
  font-weight: 500;
  color: rgba(255,255,255,.6);
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: color .15s, background .15s;
}
.mob-nav-jadi .mob-sub li a:hover { color: var(--blanco); background: rgba(255,255,255,.05); }

/* Flecha del submenú */
.mob-nav-jadi .icon-svg { transition: transform .2s; flex-shrink: 0; }

/* ═══════════════════════════════════════════════════════
   OVERLAY oscuro detrás del menú
════════════════════════════════════════════════════════ */
.mob-overlay-jadi {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 9998;
}
.mob-overlay-jadi.open { display: block; }

/* ═══════════════════════════════════════════════════════
   MEDIA QUERIES
════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .header-inner { padding: 0 16px; }
  #desktopNav   { display: none; }
  .mob-toggle   { display: block; }
}

@media (max-width: 640px) {
  :root { --header-h: 76px; }
  .header-inner { height: 76px; padding: 0 12px; gap: 8px; }
  .logo         { gap: 8px; min-width: 0; overflow: hidden; }
  .logo-texto   { min-width: 0; overflow: hidden; }
  .logo-nombre  { font-size: 1.25rem; letter-spacing: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .logo-sub     { font-size: 0.52rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .logo img     { width: 32px !important; flex-shrink: 0; }
  .servicios-grid { grid-template-columns: 1fr; }
  .footer-top     { grid-template-columns: 1fr; }
  .stats-inner    { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 380px) {
  .logo-nombre  { font-size: 0.95rem; }
  .logo-sub     { display: none; }
}




.sedes-seccion {
  background: var(--gris-claro);
  padding: 80px 0 40px;
}

.carrusel-wrap {
  position: relative;
  max-width: 960px;
  margin: 40px auto 0;
  padding: 0 60px;
  
}


.carrusel-clip {
  overflow: hidden;
  border-radius: 16px;
}

.carrusel-track {
  display: flex;
  transition: transform .42s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}

.carrusel-slide {
  min-width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--blanco);
  box-shadow: 0 6px 32px rgba(27,45,94,.1);
}

.carrusel-mapa {
  position: relative;
  min-height: 320px;
}
.carrusel-mapa iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.carrusel-info {
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  border-left: 1px solid var(--gris-borde);
}

.carrusel-badge {
  display: inline-flex;
  align-self: flex-start;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: rgba(192,39,45,.1);
  color: var(--rojo);
  border: 1px solid rgba(192,39,45,.25);
  padding: 3px 10px;
  border-radius: 999px;
}

.carrusel-nombre {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1.05;
  margin: 0;
}

.carrusel-dir {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .85rem;
  color: var(--gris-texto);
  margin: 0;
}
.carrusel-dir svg { flex-shrink: 0; color: var(--rojo); }

.carrusel-horarios {
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: var(--gris-claro);
  border-radius: 10px;
  padding: 14px 16px;
}

.carrusel-horario-fila {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.ch-dia {
  font-size: .8rem;
  font-weight: 600;
  color: var(--azul-marino);
  white-space: nowrap;
}

.ch-hora {
  font-size: .8rem;
  color: var(--gris-texto);
  text-align: right;
}

.carrusel-acciones {
  display: flex;
  gap: 10px;
  margin-top: auto;
  flex-wrap: wrap;
}

.carrusel-btn-maps,
.carrusel-btn-tel {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 8px;
  text-decoration: none;
  transition: background .15s, color .15s, transform .15s;
}

.carrusel-btn-maps {
  background: rgba(27,45,94,.08);
  color: var(--azul-marino);
}
.carrusel-btn-maps:hover {
  background: var(--azul-marino);
  color: var(--blanco);
  transform: translateY(-1px);
}

.carrusel-btn-tel {
  background: rgba(192,39,45,.1);
  color: var(--rojo);
}
.carrusel-btn-tel:hover {
  background: var(--rojo);
  color: var(--blanco);
  transform: translateY(-1px);
}

.carrusel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 2px solid var(--gris-borde);
  background: var(--blanco);
  color: var(--azul-marino);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .18s, border-color .18s, color .18s, transform .15s;
  z-index: 10;
  box-shadow: 0 2px 10px rgba(0,0,0,.1);
}
.carrusel-btn:hover {
  background: var(--azul-marino);
  border-color: var(--azul-marino);
  color: var(--blanco);
  transform: translateY(-50%) scale(1.05);
}
.carrusel-btn--prev { left: 4px; }
.carrusel-btn--next { right: 4px; }

.carrusel-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 24px;
}

.carrusel-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: var(--gris-borde);
  cursor: pointer;
  padding: 0;
  transition: background .2s, transform .2s;
}
.carrusel-dot.activo {
  background: var(--azul-marino);
  transform: scale(1.4);
}

.carrusel-ver-todos {
  text-align: center;
  margin-top: 28px;
  padding-bottom: 40px;
}
.carrusel-ver-todos a {
  font-size: .88rem;
  font-weight: 600;
  color: var(--azul-medio);
  text-decoration: none;
}
.carrusel-ver-todos a:hover { text-decoration: underline; }

@media (max-width: 700px) {
  .carrusel-wrap { padding: 0 48px; }
  .carrusel-slide { grid-template-columns: 1fr; }
  .carrusel-mapa { min-height: 220px; }
  .carrusel-info {
    border-left: none;
    border-top: 1px solid var(--gris-borde);
    padding: 22px 20px;
  }
}

@media (max-width: 420px) {
  .carrusel-wrap { padding: 0 40px; }
  .carrusel-btn { width: 36px; height: 36px; }
}


#btn-subir {
  position: fixed;
  bottom: 28px;
  right: 24px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--azul-marino);
  color: var(--blanco);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(27,45,94,.35);
  z-index: 500;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .25s ease, transform .25s ease, background .18s;
  pointer-events: none;
}
#btn-subir.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
#btn-subir:hover {
  background: var(--azul-medio);
  transform: translateY(-2px);
}

@media (max-width: 640px) {
  #btn-subir { bottom: 20px; right: 16px; width: 44px; height: 44px; }
}

.privacidad-seccion {
  padding: 72px 24px 88px;
  background: var(--blanco);
}

.privacidad-inner {
  max-width: 860px;
  margin: 0 auto;
}

.privacidad-actualizado {
  display: inline-block;
  background: rgba(47,90,173,.08);
  color: var(--azul-medio);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 999px;
  margin-bottom: 36px;
  border: 1px solid rgba(47,90,173,.2);
}

.privacidad-contenido h2 {
  font-family: var(--font-titulo);
  font-weight: 800;
  font-size: 1.35rem;
  color: var(--azul-marino);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 52px;
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--gris-borde);
  position: relative;
}
.privacidad-contenido h2::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 48px;
  height: 2px;
  background: var(--rojo);
}

.privacidad-contenido p {
  color: var(--gris-texto);
  font-size: 0.95rem;
  line-height: 1.78;
  margin-bottom: 16px;
}

.privacidad-contenido ul {
  list-style: none;
  margin: 10px 0 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.privacidad-contenido ul li {
  color: var(--gris-texto);
  font-size: 0.92rem;
  line-height: 1.72;
  padding-left: 22px;
  position: relative;
}
.privacidad-contenido ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--rojo);
  flex-shrink: 0;
}
.privacidad-contenido ul li strong {
  color: var(--azul-marino);
  font-weight: 600;
}

.privacidad-contenido a {
  color: var(--azul-medio);
  font-weight: 500;
  transition: color .15s;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.privacidad-contenido a:hover {
  color: var(--azul-marino);
}

.privacidad-tabla {
  background: var(--gris-claro);
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio);
  overflow: hidden;
  margin: 20px 0 28px;
}
.privacidad-fila {
  display: grid;
  grid-template-columns: 180px 1fr;
  border-bottom: 1px solid var(--gris-borde);
}
.privacidad-fila:last-child { border-bottom: none; }

.privacidad-celda-key {
  background: rgba(27,45,94,.05);
  color: var(--azul-marino);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 13px 18px;
  border-right: 1px solid var(--gris-borde);
  display: flex;
  align-items: center;
}
.privacidad-celda-val {
  color: var(--gris-texto);
  font-size: 0.88rem;
  padding: 13px 18px;
  display: flex;
  align-items: center;
}
.privacidad-celda-val a {
  color: var(--azul-medio);
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.privacidad-celda-val a:hover { color: var(--azul-marino); }

@media (max-width: 640px) {
  .privacidad-seccion { padding: 48px 16px 64px; }

  .privacidad-fila {
    grid-template-columns: 1fr;
  }
  .privacidad-celda-key {
    border-right: none;
    border-bottom: 1px solid var(--gris-borde);
    padding: 10px 16px;
  }
  .privacidad-celda-val {
    padding: 10px 16px 14px;
  }

  .privacidad-contenido h2 { font-size: 1.15rem; margin-top: 38px; }
  .privacidad-contenido p,
  .privacidad-contenido ul li { font-size: 0.88rem; }
}
