/* Paleta de colores */
:root {
  --violeta: #fafafa; /* acentos */
  --azul: #0b1631;    /* header/footer/botones */
  --azul-700: #2746b2;
  --blanco: #f5f7fb;
  --gris: #f5f7fb;
  --texto: #0f172a;   /* slate-900 */
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif;
  color: var(--texto);
  background: var(--blanco);
}

/* Contenedor principal */
.container {
  max-width: 1100px;
  margin: auto;
  padding: 0 16px;
}

/* Header y navegación */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--azul);
  color: var(--blanco);
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
.nav-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
  height: 64px;
}
.logo {
  color: var(--blanco);
  text-decoration: none;
  font-weight: 800;
  letter-spacing: .2px;
}
.logo strong { color: var(--violeta); }
.menu-toggle {
  display: none;
  margin-left: auto;
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 28px;
  cursor: pointer;
}
.main-nav ul {
  list-style: none;
  display: flex;
  gap: 16px;
  margin: 0;
  padding: 0;
}
.main-nav a {
  color: var(--blanco);
  text-decoration: none;
  font-weight: 600;
  opacity: .95;
}
.main-nav a:hover,
.main-nav a.active {
  opacity: 1;
  text-decoration: underline;
}
.btn-cta {
  margin-left: auto;
  background: var(--violeta);
  color: #fff;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 700;
  white-space: nowrap;
}
.btn-cta:hover { filter: brightness(1.05); }

@media (max-width: 960px) {
  .menu-toggle { display: block; }
  .main-nav {
    position: fixed;
    inset: 64px 0 auto 0;
    background: var(--azul);
    transform: translateY(-120%);
    transition: .25s;
    padding: 16px;
  }
  .main-nav.open { transform: translateY(0); }
  .main-nav ul { flex-direction: column; }
  .btn-cta { display: none; }
}

/* Hero */

.hero .container { padding: 64px 16px 80px; }
.hero h1 {
  font-size: clamp(28px, 4vw, 44px);
  margin: 0 0 12px;
  color: #d6dbe6;
}
.hero p {
  font-size: clamp(16px, 2.2vw, 20px);
  opacity: .95;
  max-width: 800px;
  color: #d6dbe6;
}
.hero-cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 16px;
}
.btn {
  display: inline-block;
  background: var(--violeta);
  color: #050633;
  text-decoration: none;
  padding: 12px 16px;
  border-radius: 12px;
  font-weight: 700;
}
.btn:hover { filter: brightness(1.05); }
.btn.ghost { background: transparent; border: 2px solid #fff; }

/* Áreas */
.areas { background: var(--gris); }
.areas h2,
.why h2,
.contacto h2 {
  font-size: clamp(22px, 3vw, 28px);
  margin: 0 0 16px;
}
.grid-areas {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
}
.card {
  background: #fff;
  border: 1px solid #eef1f6;
  border-radius: 14px;
  padding: 16px;
  text-decoration: none;
  color: var(--texto);
  box-shadow: 0 6px 18px rgba(0,0,0,.05);
}
.card h3 {
  margin: 0 0 6px;
  font-size: 18px;
  color: var(--azul);
}
.card p {
  margin: 0;
  color: #475569;
}
.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
}
@media (max-width: 900px) { .grid-areas { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .grid-areas { grid-template-columns: 1fr; } }

/* Why */
.why .benefits {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.why .benefits li {
  background: #fff;
  padding: 14px;
  border-radius: 12px;
  border: 1px solid #eef1f6;
}
@media (max-width: 900px) { .why .benefits { grid-template-columns: 1fr; } }

/* Contacto */
.contact-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.contact-form label {
  display: grid;
  gap: 6px;
  font-weight: 600;
}
.contact-form input,
.contact-form textarea {
  border: 1px solid #d6dbe6;
  border-radius: 10px;
  padding: 10px;
  font: inherit;
}
.contact-form textarea { grid-column: 1/-1; }
.contact-form .btn { grid-column: 1/2; }
@media (max-width:700px) {
  .contact-form { grid-template-columns: 1fr; }
  .contact-form .btn { grid-column: 1/-1; }
}

/* Página interna */
.page { padding: 32px 0 64px; }
.breadcrumbs {
  font-size: 14px;
  color: #64748b;
  margin: 8px 0 12px;
}
.breadcrumbs a { color: #64748b; }
.cta-panel {
  border: 1px solid #eef1f6;
  border-radius: 12px;
  padding: 16px;
  background: #fff;
  margin: 18px 0;
}
.related ul {
  display: flex;
  gap: 12px;
  list-style: none;
  padding: 0;
}
.related a {
  color: var(--azul);
  text-decoration: none;
}

/* Footer */
.site-footer {
  background: var(--azul);
  color: #fff;
  margin-top: 32px;
}
.footer-grid {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 0;
}
.site-footer a { color: #fff; }
.copy {
  background: #152a6a;
  text-align: center;
  padding: 10px 0;
  font-size: 14px;
}

/* WhatsApp flotante */
.wp-float {
  position: fixed;
  right: 16px;
  bottom: 16px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366 url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 32 32"><path fill="white" d="M19.11 17.26c-.3-.15-1.77-.87-2.05-.97-.28-.1-.49-.15-.7.15-.2.3-.8.97-.98 1.17-.18.2-.36.22-.66.07-.3-.15-1.25-.46-2.38-1.47-.88-.78-1.47-1.74-1.64-2.04-.17-.3-.02-.47.13-.62.13-.13.3-.33.45-.5.15-.17.2-.28.3-.48.1-.2.05-.37-.02-.52-.07-.15-.7-1.67-.96-2.29-.25-.6-.51-.52-.7-.53l-.6-.01c-.2 0-.52.07-.8.37-.28.3-1.06 1.03-1.06 2.5 0 1.47 1.08 2.89 1.23 3.09.15.2 2.13 3.25 5.16 4.55.72.31 1.29.49 1.73.63.73.23 1.4.2 1.93.12.59-.09 1.77-.72 2.02-1.41.25-.69.25-1.28.18-1.41-.07-.13-.25-.2-.55-.35zM16.1 28C9.98 28 5 23.02 5 16.9 5 10.78 9.98 5.8 16.1 5.8S27.2 10.78 27.2 16.9 22.22 28 16.1 28zm0-20.4c-5.31 0-9.6 4.29-9.6 9.6 0 5.31 4.29 9.6 9.6 9.6 5.31 0 9.6-4.29 9.6-9.6 0-5.31-4.29-9.6-9.6-9.6z"/></svg>') center/60% no-repeat;
  box-shadow: 0 8px 22px rgba(0,0,0,.18);
}
.wp-float:focus { outline: 3px solid #fff6; }

/* Contenedor principal del header */
.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  height: 70px;
}

/* Logo bien pegado a la izquierda */
.logo {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  white-space: nowrap;
  margin-right: auto;  /* fuerza que todo lo demás se corra a la derecha */
}
.logo img {
  height: 44px; /* un poco más compacto */
  width: auto;
}
.logo-text {
  font-size: 16px; /* achicado para que ocupe menos */
  font-weight: 700;
  color: var(--blanco);
  white-space: nowrap;
}

/* Menú ocupa el espacio central */
.main-nav {
  flex: 1; /* hace que el menú crezca en el centro */
}
.main-nav ul {
  display: flex;
  justify-content: center;
  gap: 14px; /* más ajustado para que entre todo */
  margin: 0;
  padding: 0;
  list-style: none;
  white-space: nowrap;
}
.main-nav a {
  color: var(--blanco);
  text-decoration: none;
  font-weight: 600;
  font-size: 15px;
}
.main-nav a:hover { color: var(--violeta); }

/* Botón CTA a la derecha */
.btn-cta {
  margin-left: auto;
  background: var(--violeta);
  color: #fff;
  padding: 8px 14px;
  border-radius: 6px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}




/* Responsive: menú hamburguesa */
@media (max-width: 960px) {
  .menu-toggle { display: block; margin-left: auto; }
  .main-nav {
    position: fixed;
    inset: 70px 0 auto 0;
    background: var(--azul);
    padding: 20px;
    transform: translateY(-120%);
    transition: .3s ease;
  }
  .main-nav.open { transform: translateY(0); }
  .main-nav ul {
    flex-direction: column;
    gap: 12px;
  }
  .btn-cta { display: none; }
}

/* Contenedor general */
.container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

/* En el header queremos que no tenga padding izquierdo */
.site-header .container {
  padding-left: 0px;   /* quita el espacio a la izquierda */
  padding-right: 50px; /* mantené un poco de aire a la derecha */
}

/* Logo bien pegado al borde */
.logo {
  margin-left: 0;
  padding-left: 8px; /* opcional: un respiro de 8px en lugar de 16px */
}
/* Header full-bleed (al ras del viewport) */
.site-header .container {
  max-width: none;   /* ignora el tope de 1100px en el header */
  width: 100%;
  margin: 0;         /* anula el margin:auto centrado */
  padding-left: 10px;   /* sin borde izquierdo */
  padding-right: 16px; /* dejá un poco a la derecha para el CTA */
}

/* Evitá cualquier desplazamiento del logo */
.logo {
  margin-left: 0 !important;
  padding-left: 0 !important; /* quitá ese 8px */
}

/* (Opcional) si querés que el menú quede más compacto */
.main-nav ul {
  gap: 12px;
}

/* Más espacio entre items del menú (solo escritorio) */
@media (min-width: 961px) {
  .main-nav ul {
    gap: 22px;              /* antes 14–16px */
  }
  .main-nav a {
    padding-inline: 2px;    /* agranda el área clickeable sin cambiar gap */
    white-space: nowrap;    /* sigue en una sola línea */
  }
}

/* === Altura del header (ajustá un solo valor) === */
:root { --header-h: 100px; } /* 84px o el valor que quieras */

/* Contenedor del header */
.nav-wrap {
  height: var(--header-h);
  align-items: center;
}

/* El logo crece en proporción a la nueva altura */
.logo img {
  height: calc(var(--header-h) - 32px); /* margen de respiro */
  width: auto;
}

/* Menú móvil: bajar el panel justo debajo del header nuevo */
@media (max-width: 960px) {
  .main-nav { inset: var(--header-h) 0 auto 0; }
}



@media (max-width: 480px) {
  :root { --header-h: 72px; }
}

/* HERO a pantalla completa menos el header */
/* HERO a pantalla completa con imagen de fondo + overlay */
.hero{
  position: relative;
  min-height: calc(100vh - var(--header-h));
  display: flex;
  align-items: center;

  /* imagen de fondo */
  background-image: url("/img/hero_hombre.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* overlay para mejorar contraste del texto */

.hero > *{ position: relative; } /* que el contenido quede encima del overlay */

/* padding del contenido */
.hero .container{ padding-block: 64px; }

@supports (height: 100svh){
  .hero{ min-height: calc(100svh - var(--header-h)); }
}

.hero{
  background-position: center 10%;  /* prueba 20%, 30%, 40% */
}

/* Contenido del hero alineado a la izquierda */
.hero .container{
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* izquierda */
  text-align: left;        /* por si algún estilo lo centraba */
  max-width: 1100px;       /* opcional: limita ancho de lectura */
}

.hero h1,
.hero p,
.hero .hero-cta{
  margin-left: -400px;
  text-align: left;
}

/* Botones en fila a la izquierda */
.hero .hero-cta{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-start;
}

/* En mobile, sigue a la izquierda */
@media (max-width: 600px){
  .hero .container{ align-items: flex-start; }
}

/* ===== Tarjetas pro con imagen ===== */
.grid-areas {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none;
  color: var(--texto);
  box-shadow: 0 8px 22px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  will-change: transform;
}

.card:hover,
.card:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,.1);
  border-color: #dbe3f2;
  outline: none;
}

.card-img {
  position: relative;
  aspect-ratio: 16 / 9; /* mantiene proporciones */
  overflow: hidden;
  background: #eef2ff; /* fallback mientras carga */
}

.card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform .5s ease;
}

.card:hover .card-img img { transform: scale(1.07); }

.card-body {
  padding: 16px 16px 18px;
  display: grid;
  gap: 6px;
}

.card-body h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.25;
  color: rgba(21, 42, 102, 0.76);
  font-weight: 800;
}

.card-body p {
  margin: 0;
  color: #475569;
  line-height: 1.45;
  min-height: 40px; /* mantiene altura parecida entre tarjetas */
}

/* Accesibilidad: Foco visible para teclado */
.card:focus-visible {
  box-shadow: 0 0 0 3px rgba(106,13,173,.35), 0 12px 26px rgba(0,0,0,.08);
}

/* Menos animación si el usuario lo prefiere */
@media (prefers-reduced-motion: reduce) {
  .card, .card-img img { transition: none; }
}

/* Responsivo */
@media (max-width: 1024px) {
  .grid-areas { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .grid-areas { grid-template-columns: 1fr; }
}

/* ===== Cards más altas con imagen arriba y texto abajo ===== */
:root { --card-h: 420px; } /* altura total deseada (ajustá a gusto) */

.card--taller{
  display: flex;
  flex-direction: column;
  height: var(--card-h);
  border-radius: 16px;
  overflow: hidden;           /* que la imagen no se salga */
}

/* La imagen ocupa la mitad superior */
.card--taller .card-img{
  flex: 0 0 50%;
  height: 50%;
  aspect-ratio: auto;         /* anulá el 16:9 si lo tenías */
  background: #eef2ff;
  overflow: hidden;
}
.card--taller .card-img img{
  width: 100%;
  height: 100%;
  object-fit: cover;          /* recorta sin deformar */
  transform: scale(1.02);
  transition: transform .5s ease;
}
.card--taller:hover .card-img img{ transform: scale(1.07); }

/* El cuerpo ocupa la mitad inferior */
.card--taller .card-body{
  flex: 1 0 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;    /* centra verticalmente el texto */
  gap: 6px;
  padding: 16px 16px 18px;
}

/* Ajustes responsivos (un poco menos alta en mobile) */
@media (max-width: 560px){
  :root { --card-h: 360px; }
}

/* --- Fix: que la imagen ocupe exactamente la mitad --- */
.card.card--taller { 
  padding: 0;                /* quita el padding que achica el alto útil */
}

/* El <figure> no debe aportar márgenes extra */
.card--taller .card-img { 
  margin: 0;                 /* elimina margen por defecto del figure */
  flex: 0 0 50%;
  height: 50%;
  aspect-ratio: auto;        /* anula el 16:9 anterior */
  overflow: hidden;
}

/* La imagen llena su contenedor */
.card--taller .card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* La mitad inferior (texto) */
.card--taller .card-body {
  flex: 1 0 50%;
  height: 50%;
  padding: 16px;             /* el padding va acá, no en .card */
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Centrar y dar más margen al título de Áreas */
.areas .container > h2{
  text-align: center;
  margin-top: 60px;    /* ajustá a gusto */
  margin-bottom: 60px; /* ajustá a gusto */
  line-height: 1.2;
  font-size: 40px;
  color: rgba(13, 13, 83, 0.719);
}

/* ===== WHY: tarjetas con icono, estilo similar a Áreas ===== */
.why { background: var(--gris); }

.why .container > h2{
  text-align: center;
  margin: 48px 0 28px;
  line-height: 1.2;
 
}

.why-grid{
  list-style: none;
  margin: 0;
  padding: 0 0 48px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.why-card{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  padding: 18px 16px 20px;
  box-shadow: 0 8px 22px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas:
    "icon title"
    "icon text";
  column-gap: 12px;
  row-gap: 6px;
  margin-top: 60px;
}

.why-card:hover,
.why-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,.1);
  border-color: #dbe3f2;
}

/* Ícono circular con color de marca */
.why-icon{
  grid-area: icon;
  align-self: start;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #fff;              /* color del ícono (SVG usa currentColor) */
  background: linear-gradient(135deg, var(--azul), var(--violeta));
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

.why-card h3{
  grid-area: title;
  margin: 0;
  font-size: 18px;
  color: rgba(13,13,83,.719);
  font-weight: 800;
  line-height: 1.25;
}

.why-card p{
  grid-area: text;
  margin: 0;
  color: #475569;
  line-height: 1.45;
}

/* Responsivo */
@media (max-width: 1024px){
  .why-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px){
  .why-grid{ grid-template-columns: 1fr; }
}

/* Tarjetas WHY más grandes */
.why-grid{
  gap: 22px;
  padding-bottom: 64px;
}
.why-card{
  padding: 24px 20px 24px;
  column-gap: 14px;
  row-gap: 8px;
}
.why-card h3{ font-size: 19px; }
.why-card p{ font-size: 15px; }

/* Icono un poco más grande */
.why-icon{
  width: 52px;
  height: 52px;
}
.why-icon svg{ width: 28px; height: 28px; }

/* OPCIÓN A: colores por clase (recomendado para control explícito) */
.why-card.is-experiencia .why-icon{
  background: linear-gradient(135deg, #6a0dad, #1e3a8a); /* violeta → azul */
  color: #fff;
}
.why-card.is-atencion .why-icon{
  background: linear-gradient(135deg, #2563eb, #22d3ee); /* azul → cian */
  color: #fff;
}
.why-card.is-honorarios .why-icon{
  background: linear-gradient(135deg, #9333ea, #f43f5e); /* violeta → coral */
  color: #fff;
}

/* OPCIÓN B: si no querés tocar HTML, por posición */
.why-card:nth-child(1) .why-icon{
  background: linear-gradient(135deg, #6a0dad, #1e3a8a);
  color: #fff;
}
.why-card:nth-child(2) .why-icon{
  background: linear-gradient(135deg, #2563eb, #22d3ee);
  color: #fff;
}
.why-card:nth-child(3) .why-icon{
  background: linear-gradient(135deg, #9333ea, #f43f5e);
  color: #fff;
}

/* Un poco más de aire arriba/abajo del título de sección */
.why .container > h2{
  margin: 56px 0 36px;
}


/* pegá ESTO al final del CSS */
.why .container > h2{
  margin-top: 60px !important;
  font-size: 36px;
  color: rgba(13,13,83,.719);
  text-align: center;
  font-weight: bold;
}

.why{
  padding-top: 100px; /* crea el espacio arriba sin colapso */
}

/* Divider sutil arriba de la sección WHY */
.why{
  position: relative;
}
.why::before{
  content:"";
  position: absolute;
  inset: 80px 0 auto 0;   /* sube la línea 24px sobre .why */
  height: 1px;
  background: linear-gradient(90deg, #0000, #c7d2fe, #0000); /* violeta-azulado suave */
  filter: blur(.2px);
}

/* Contacto pro: centrado, una sola columna, prolijo */
.contacto { background: var(--gris); }
.contacto .container { max-width: 720px; text-align: center; }
.contact-sub { color: #64748b; margin: 8px 0 20px; }

.contact-card{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  padding: 22px;
}

.contact-form.pro{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  text-align: left; /* los labels a la izquierda */
}

.contact-form.pro label{
  display: grid;
  gap: 6px;
  font-weight: 600;
  color: #1f2a44;
}

.contact-form.pro input,
.contact-form.pro textarea{
  border: 1px solid #d6dbe6;
  border-radius: 12px;
  padding: 12px 12px;
  font: inherit;
  background: #fff;
}

.contact-form.pro input::placeholder,
.contact-form.pro textarea::placeholder{ color: #94a3b8; }

.contact-form.pro input:focus,
.contact-form.pro textarea:focus{
  outline: none;
  border-color: var(--azul);
  box-shadow: 0 0 0 4px rgba(30,58,138,.12);
}

.contact-actions{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 6px;
}

.form-status{
  margin: 8px 0 0;
  font-size: 14px;
  color: #0f172a;
}

/* Mobile */
@media (max-width: 560px){
  .contact-card{ padding: 18px; }
  .contact-actions{ flex-direction: column; align-items: stretch; }
  .contact-actions .btn,
  .contact-actions .btn.ghost{ text-align: center; }
}

.contacto{
  padding-top: 120px; /* crea el espacio arriba sin colapso */
}

.contacto h2 {
    font-size: 45px;
    color:#524f79;
}
.contacto{
  position: relative;
}
.contacto::before{
  content:"";
  position: absolute;
  inset: 50px 0 auto 0;   /* sube la línea 24px sobre .why */
  height: 1px;
  background: linear-gradient(90deg, #0000, #c7d2fe, #0000); /* violeta-azulado suave */
  filter: blur(.2px);
}

/* ===== Sucursal ===== */
.sucursal { background: var(--gris); }
.sucursal .container > h2{
  text-align: center;
  margin: 48px 0 24px;
  margin-bottom: 60px;
}

.branch-wrap{
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 18px;
  align-items: start;
}

.branch-info{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  padding: 18px 16px 20px;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 12px;
  row-gap: 8px;
}

.branch-icon{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--azul), var(--violeta));
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

.branch-info h3{
  margin: 2px 0 6px;
  font-size: 18px;
  color: var(--azul);
  font-weight: 800;
}

.branch-address{
  margin: 0 0 10px;
  color: #475569;
  line-height: 1.45;
}

.btn.small{
  padding: 8px 12px;
  border-radius: 10px;
  font-weight: 700;
  text-decoration: none;
  display: inline-block;
  background: var(--violeta);
  color: #fff;
}

/* Mapa */
.branch-map{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  overflow: hidden;
  min-height: 320px;
}
.branch-map iframe{
  display: block;
  width: 100%;
  height: 100%;
  min-height: 320px;
  border: 0;
}

/* Responsive */
@media (max-width: 960px){
  .branch-wrap{
    grid-template-columns: 1fr;
  }
  .branch-map{ min-height: 280px; }
  .branch-map iframe{ min-height: 280px; }
}


.sucursal{
  padding-top: 120px; /* crea el espacio arriba sin colapso */
}

.sucursal{
  position: relative;
}
.sucursal::before{
  content:"";
  position: absolute;
  inset: 80px 0 auto 0;   /* sube la línea 24px sobre .why */
  height: 1px;
  background: linear-gradient(90deg, #0000, #c7d2fe, #0000); /* violeta-azulado suave */
  filter: blur(.2px);
}

.sucursal h2{
font-size: 40px;
color: #524f79;
}

/* ===== Footer pro con logo ===== */
.site-footer{
  background: var(--azul);
  color: #fff;
  margin-top: 32px;
}
.site-footer a{ color: #fff; text-decoration: none; }
.site-footer a:hover{ text-decoration: underline; }

.footer-grid{
  display: grid;
  grid-template-columns: 1.6fr 1fr; /* marca más ancha, links a la derecha */
  gap: 24px;
  padding: 28px 0;
  align-items: start;
}

/* Marca */
.footer-logo{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.footer-logo img{
  height: 44px;
  width: auto;
  display: block;
}
.footer-logo-text{
  font-weight: 800;
  font-size: 18px;
  white-space: nowrap;
}
.footer-contact{
  margin: 0;
  color: #e5e7eb;
  line-height: 1.5;
}

/* Links */
.footer-links h5{
  margin: 4px 0 10px;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .04em;
  opacity: .9;
}
.footer-links ul{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}
.footer-links a{
  opacity: .95;
}
.footer-links a:hover{ opacity: 1; }

/* Línea legal */
.copy{
  background: #152a6a;
  text-align: center;
  padding: 12px 0;
  font-size: 14px;
}

/* Responsive */
@media (max-width: 900px){
  .footer-grid{
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 22px 0;
  }
  .footer-logo img{ height: 40px; }
  .footer-logo-text{ font-size: 17px; }
}

/* Botón WhatsApp circular, sin background-image */
.wp-float{
  position: fixed;
  right: clamp(12px, 2vw, 22px);
  bottom: calc(16px + env(safe-area-inset-bottom));
  width: 64px; height: 64px;
  border-radius: 50%;
  background: #25D366;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 12px 28px rgba(0,0,0,.24);
  z-index: 999;
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;

  /* por si quedó alguna regla vieja de fondo */
  background-image: none !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

/* SVG centrado y nítido */
.wp-icon{
  width: 56%;
  height: auto;
  display: block;
}

/* Microajuste óptico (tocar solo si lo ves 1px corrido) */
/* .wp-icon{ transform: translateY(0.5%); } */

.wp-float:hover{ transform: translateY(-2px); box-shadow: 0 16px 34px rgba(0,0,0,.28); filter: brightness(1.03); }
.wp-float:active{ transform: translateY(0); }
.wp-float:focus-visible{ outline: none; box-shadow: 0 0 0 4px #ffffff99, 0 16px 34px rgba(0,0,0,.28); }

@media (max-width: 560px){
  .wp-float{ width: 56px; height: 56px; }
  .wp-icon{ width: 58%; }
}
@media (prefers-reduced-motion: reduce){
  .wp-float{ transition: none; }
}

/* Botón ghost del HERO con texto blanco */
.hero .btn.ghost{
  color: #fff !important;
  border-color: #fff;
}

/* Hover/focus sutil para mejor contraste */
.hero .btn.ghost:hover,
.hero .btn.ghost:focus-visible{
  background: rgba(255,255,255,.12);
  text-decoration: none;
  outline: none;
}



/* ===== HERO mobile: como desktop (texto a la izquierda + botones en línea) ===== */
@media (max-width: 600px){
  /* mantené la imagen mobile si ya la usás */
  .hero{
    background-image: url("/img/hero_resp.webp");
    background-position: center 30%;
    min-height: calc(100svh - var(--header-h));
    display: flex;
    justify-content: flex-end;  /* container abajo */
    align-items: stretch;
  }

  /* Contenido alineado a la izquierda, no centrado */
  .hero .container{
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;     /* IZQUIERDA */
    text-align: left;            /* IZQUIERDA */
    padding: 24px 16px 28px;
    max-width: 680px;
    margin: 0 auto;
    margin-top: 250px;
  }


  /* Quitamos desplazamientos previos */
  .hero h1,
  .hero p,
  .hero .hero-cta{
    margin-left: 0 !important;
    text-align: left;
  }

  /* Botones en una sola línea */
  .hero .hero-cta{
    display: flex;
    gap: 10px;
    flex-wrap: nowrap;           /* misma línea */
  }

  /* Si el ancho es MUY chico, comprimimos botones para que no bajen */
  .hero .hero-cta .btn{
    padding: 10px 12px;          /* un poco menos ancho */
    white-space: nowrap;         /* evita quiebres internos */
  }

  /* Solo si en algún teléfono ultra angosto no entra: permitir wrap */
  @media (max-width: 360px){
    .hero .hero-cta{ flex-wrap: wrap; }
  }
}

/* Menos zoom en el hero (mobile) */
@media (max-width: 600px){
  .hero{
    /* mostrará más área de la imagen que 'cover' */
    background-size: 100% auto;      /* probá 100% ó 105% */
    background-position: center 0%; /* ajustá el encuadre vertical */
  }
}

/* ===== HERO (mobile ≤600px): colores de textos y botones ===== */
@media (max-width: 600px){

  /* Refuerzo de contraste sobre la foto (opcional, pero recomendado) */
  .hero::before{
    content:"";
    position:absolute; inset:0;
    background: linear-gradient(to top, rgba(0,0,0,.45), rgba(0,0,0,.25) 40%, transparent);
    pointer-events: none;
  }

  /* Colores de texto */
  .hero h1{
    color: #ffffff;                 /* título blanco */
  }
  .hero p{
    color: #ffffff;                 /* texto gris muy claro */
  }

  /* Botón primario */
  .hero .btn{
    background: #ffffff;            /* botón blanco */
    color: var(--azul);             /* texto en azul de marca */
    border: 2px solid #ffffff00;    /* sin borde visible */
  }
  .hero .btn:hover,
  .hero .btn:focus-visible{
    filter: none;
    background: #f8fafc;            /* leve cambio en hover */
    text-decoration: none;
    outline: none;
  }

  /* Botón ghost (WhatsApp) */
  .hero .btn.ghost{
    color: #ffffff;                 /* texto blanco */
    border: 2px solid #ffffff;      /* borde blanco */
    background: transparent;
  }
  .hero .btn.ghost:hover,
  .hero .btn.ghost:focus-visible{
    background: rgba(255,255,255,.12);
    text-decoration: none;
    outline: none;
  }
}

/* === Hero más bajo (desktop) === */
@media (min-width: 601px){
  .hero{
    min-height: 68vh !important;     /* antes: calc(100vh - var(--header-h)) */
    background-position: center 20%;
  }
  .hero .container{ padding-block: 40px; }  /* menos padding vertical */
}

/* === Hero más bajo (mobile) === */
@media (max-width: 600px){
  .hero{
    min-height: 62svh !important;     /* usa svh para barras móviles */
    background-size: 100% auto;       /* menos “zoom” si querés */
    background-position: center 25%;
  }
  .hero .container{ padding-block: 24px; }
}

/* ===== Mobile drawer: izquierda → derecha ===== */
@media (max-width: 960px){
  .menu-toggle{ display:block; margin-left:auto; z-index:1001; }

  .main-nav{
    position: fixed;
    top: var(--header-h);   /* arranca debajo del header */
    left: 0;
    bottom: 0;
    width: min(86vw, 360px);
    background: var(--azul);
    padding: 18px 16px;
    overflow-y: auto;
    transform: translateX(-105%);     /* OCULTO a la izquierda */
    transition: transform .28s ease;
    box-shadow: 0 10px 30px rgba(0,0,0,.2);
    z-index: 1001;
  }
  .main-nav.open{ transform: translateX(0); }

  /* lista vertical */
  .main-nav ul{
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  /* backdrop */
  .nav-backdrop{
    position: fixed; inset: 0;
    background: rgba(15, 23, 42, .45);
    opacity: 0; pointer-events: none;
    transition: opacity .2s ease;
    z-index: 1000;
  }
  .nav-backdrop.show{
    opacity: 1;
    pointer-events: auto;
  }
}

/* Menos animación si el usuario lo prefiere */
@media (prefers-reduced-motion: reduce){
  .main-nav{ transition: none !important; }
  .nav-backdrop{ transition: none !important; }
}

/* ===== Menú móvil: items más estéticos + separador ===== */
@media (max-width: 960px){
  /* Aseguramos lista vertical y reseteos */
  .main-nav ul{
    display: flex !important;
    flex-direction: column !important;
    margin: 0 !important;
    padding: 8px 0 !important;
    list-style: none !important;
  }

  /* El link ocupa toda la fila (sirve si hay <li> o si no los hay) */
  .main-nav ul > li > a,
  .main-nav ul > * > a,
  .main-nav ul > a{
    display: block;
    padding: 14px 12px;
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    letter-spacing: .2px;
    border-radius: 8px;
    position: relative;            /* para el separador */
  }

  /* Separador (antes de cada ítem menos el primero) */
  .main-nav ul > li > a::before,
  .main-nav ul > * > a::before,
  .main-nav ul > a::before{
    content: "";
    position: absolute;
    left: 0; right: 0; top: -1px;
    height: 1px;
    background: rgba(255,255,255,.28);   /* más visible */
  }
  .main-nav ul > li:first-child > a::before,
  .main-nav ul > *:first-child > a::before,
  .main-nav ul > a:first-child::before{
    display: none;
  }

  /* Hover / activo / foco */
  .main-nav a:hover{ background: rgba(255,255,255,.10); }
  .main-nav a.active{ background: rgba(255,255,255,.16); }
  .main-nav a:focus-visible{
    outline: none;
    box-shadow: 0 0 0 3px rgba(255,255,255,.28) inset;
    background: rgba(255,255,255,.10);
  }
}
@media (max-width: 960px){
  /* Quitar recuadro al click/foco */
  .main-nav a:focus,
  .main-nav a:focus-visible,
  .main-nav a:active{
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important; /* sin highlight al click */
  }

  /* Conservá el hover si querés feedback al pasar el dedo/mouse */
  .main-nav a:hover{
    background: rgba(255,255,255,.10);
  }

  /* Estado activo (página actual) si lo usás */
  .main-nav a.active{
    background: rgba(255,255,255,.16);
  }
}

/* ===== Hero full-screen en escritorio ===== */
@media (min-width: 961px){
  .hero{
    min-height: calc(100vh - var(--header-h)) !important;
    background-size: cover;
    background-position: center 20%; /* ajustá el encuadre si querés */
  }
  .hero .container{
    padding-block: 64px; /* aire cómodo arriba/abajo */
  }
}
/* No subrayar el link activo del header (incluye "Inicio") */
.main-nav a.active{
  text-decoration: none !important;
}

/* Contacto: colores de botones */
.contacto .btn{
  background: var(--violeta);
  color: #0a1f3f !important;          /* texto blanco */
}

.contacto .btn.ghost{
  background: transparent;
  color: var(--azul) !important;    /* texto azul */
  border: 2px solid var(--azul);
}

/* Hover/focus sutil */
.contacto .btn:hover,
.contacto .btn:focus-visible{
  filter: brightness(1.06);
  text-decoration: none;
  outline: none;
}
.contacto .btn.ghost:hover,
.contacto .btn.ghost:focus-visible{
  background: color-mix(in oklab, var(--azul) 10%, white);
  text-decoration: none;
  outline: none;
}

/* ===== HERO más alto en mobile (ocupa toda la pantalla) ===== */
@media (max-width: 600px){
  /* Prioriza dvh/svh para barras del navegador móviles */
  .hero{
    min-height: calc(100dvh - var(--header-h)) !important; /* iOS/Android modernos */
    background-size: cover;
    background-position: center 25%;
  }
  /* Fallbacks por si el navegador no soporta dvh */
  @supports not (height: 100dvh){
    .hero{ min-height: calc(100svh - var(--header-h)) !important; }
  }
  @supports not (height: 100svh){
    .hero{ min-height: calc(100vh - var(--header-h)) !important; }
  }

  /* Un poco más de aire interno si hace falta */
  .hero .container{
    padding-block: 32px;
  }
}

/* ===== Footer centrado en mobile ===== */
@media (max-width: 900px){
  .footer-grid{
    grid-template-columns: 1fr;   /* ya lo tenés, lo reforzamos */
    justify-items: center;        /* centra columnas */
    text-align: center;           /* centra textos */
    gap: 18px;
    padding: 22px 0;
  }

  .footer-logo{ justify-content: center; }  /* logo + nombre centrados */
  .footer-contact{ text-align: center; }

  .footer-links{ width: 100%; }
  .footer-links h5{ text-align: center; margin-top: 6px; }
  .footer-links ul{
    display: grid;                /* mantiene lista prolija */
    justify-items: center;        /* centra cada ítem */
    gap: 10px;
    padding: 0;
  }
  .footer-links a{
    display: inline-block;
    padding: 6px 8px;             /* mejor “tap area” sin ocupar todo el ancho */
    border-radius: 8px;
  }
}

/* ===== Estilos base para páginas internas ===== */
.page-interna .page{
  padding-top: 28px;
}
.page-interna .breadcrumbs{
  margin: 8px 0 14px;
  font-size: 14px;
  color: #64748b;
}
.page-interna h1{
  font-size: clamp(24px, 3.6vw, 34px);
  line-height: 1.15;
  margin: 10px 0 12px;
  color: rgba(13,13,83,.9);
}
.page-interna h2{
  font-size: clamp(20px, 2.6vw, 24px);
  margin: 20px 0 10px;
  color: rgba(13,13,83,.82);
}
.page-interna ul{
  padding-left: 18px;
  margin: 0 0 14px;
}

/* Panel de llamada a la acción dentro de internas */
.page-interna .cta-panel{
  border: 1px solid #e8ecf4;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

/* ===== Específico de Accidentes (ART) ===== */
.page-accidentes .cta-panel{
  border-left: 4px solid var(--azul);
}
.page-accidentes .cta-panel .btn{
  background: var(--violeta);
  color: #fff;
}
.page-accidentes .related h2{
  margin-top: 18px;
}
.page-accidentes .related ul{
  display: flex;
  gap: 10px;
  padding: 0;
  list-style: none;
}
.page-accidentes .related a{
  color: var(--azul);
  text-decoration: none;
  padding: 8px 10px;
  border: 1px solid #e8ecf4;
  border-radius: 10px;
}
.page-accidentes .related a:hover{
  background: #f8fafc;
  text-decoration: none;
}

/* ===== HERO para páginas internas ===== */
.page-hero{
  position: relative;
  display: flex;
  align-items: center;
  min-height: 44vh;                /* alto cómodo en desktop */
  background-size: cover;
  background-position: center 35%;
  background-repeat: no-repeat;
  color: #fff;
}
.page-hero::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(
    to right,
    rgba(0,0,0,.45) 0%,
    rgba(0,0,0,.30) 40%,
    rgba(0,0,0,.15) 70%,
    rgba(0,0,0,0) 100%
  );
}
.page-hero .container{
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  padding-block: 36px;
  max-width: 1100px;
}
.page-hero h1{
  margin: 0;
  font-size: clamp(26px, 4vw, 40px);
  line-height: 1.15;
  color: #fff;
}
.page-hero p{
  margin: 0;
  font-size: clamp(15px, 2vw, 18px);
  color: #e5e7eb;
  max-width: 760px;
}

/* Imagen específica de esta page */
.page-accidentes .page-hero--accidentes{
  background-image: url("/img/hero_acc_lab1.webp");
}

/* Mobile: que ocupe bien la pantalla en teléfonos */
@media (max-width: 600px){
  .page-hero{
    min-height: 60svh;
    background-position: center 30%;
  }
  .page-hero::before{
    background: linear-gradient(to top, rgba(0,0,0,.45), rgba(0,0,0,.20) 50%, transparent);
  }
  .page-accidentes .page-hero--accidentes{
    background-image: url("/img/hero_acc_labres.PNG"); /* opcional: versión mobile */
  }
  .page-hero h1{
    margin-top: 160px;
    margin-bottom: 20px;
  }
}

/* ===== Todos los HERO internos a pantalla completa (desktop + mobile) ===== */
.page-hero{
  min-height: calc(100dvh - var(--header-h)) !important; /* ocupa todo menos el header fijo */
  background-size: cover;
  background-position: center 30%;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;  /* centra verticalmente el contenido */
}

@supports not (height: 100dvh){
  .page-hero{ min-height: calc(100svh - var(--header-h)) !important; }
}
@supports not (height: 100svh){
  .page-hero{ min-height: calc(100vh - var(--header-h)) !important; }
}

/* Contenido del hero (todas las pages) */
.page-hero .container{
  position: relative;
  z-index: 1;
  padding-block: 48px;   /* ajustá aire si querés */
}

/* (opcional) en mobile podés reencuadrar un poco */
@media (max-width: 600px){
  .page-hero{ background-position: center 35%; }
}

/* Espaciado del contenido posterior (breadcrumbs, etc.) */
.page .breadcrumbs{ scroll-margin-top: var(--header-h); }

/* ===== Pages: menos zoom en el HERO (solo escritorio) ===== */
@media (min-width: 961px){
  .page-hero{
    /* mostrará más área que 'cover' */
    background-size: 100% auto;   /* probá 95% o 105% según tu imagen */
    background-position: center 30%;
  }
}

/* ===== Page-hero: contenido a la DERECHA en escritorio ===== */
@media (min-width: 961px){
  .page-hero .container{
    margin-left: auto;        /* empuja el container hacia la derecha */
    max-width: 1100px;        /* tu ancho de lectura */
    display: flex;
    flex-direction: column;
    align-items: flex-end;    /* alinea h1/p a la derecha */
    text-align: right;        /* texto alineado a la derecha */
    gap: 10px;
    margin-left: 400px;
  }
}

/* ===== ¿Cómo trabajamos? → tarjetas con icono ===== */
.work-list{
  list-style: none;
  margin: 12px 0 24px;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 960px){ .work-list{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .work-list{ grid-template-columns: 1fr; } }

.work-card{
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas:
    "icon title"
    "icon text";
  column-gap: 12px;
  row-gap: 6px;

  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  padding: 18px 16px 20px;
  box-shadow: 0 8px 22px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.work-card:hover,
.work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,.1);
  border-color: #dbe3f2;
}

.work-icon{
  grid-area: icon;
  align-self: start;
  width: 48px; height: 48px;
  border-radius: 999px;
  display: grid; place-items: center;
  color: #fff; /* color del trazo del SVG */
  /* gradiente de marca */
  background: linear-gradient(135deg, var(--azul), var(--violeta));
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
.work-icon svg{ width: 26px; height: 26px; display: block; }

.work-body h3{
  grid-area: title;
  margin: 0;
  font-size: 18px;
  color: rgba(13,13,83,.9);
  font-weight: 800;
  line-height: 1.25;
}
.work-body p{
  grid-area: text;
  margin: 0;
  color: #475569;
  line-height: 1.45;
}

/* Paletas distintas por tarjeta (opcional) */
.work-card:nth-child(1) .work-icon{
  background: linear-gradient(135deg, #1e3a8a, #6a0dad);
}
.work-card:nth-child(2) .work-icon{
  background: linear-gradient(135deg, #2563eb, #22d3ee);
}
.work-card:nth-child(3) .work-icon{
  background: linear-gradient(135deg, #9333ea, #f43f5e);
}

/* ===== ¿Cómo trabajamos? (Accidentes): más altas + fondo oscuro ===== */
.page-accidentes .work-card{
  min-height: 180px;                    /* más altas en desktop */
  padding: 22px 18px 24px;              /* un poco más de aire */
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}

.page-accidentes .work-card:hover,
.page-accidentes .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}

/* Colores de texto sobre fondo oscuro */
.page-accidentes .work-body h3{
  color: #ffffff;
}
.page-accidentes .work-body p{
  color: #cbd5e1;   /* gris claro legible */
}

/* Ícono: resaltado sobre el fondo oscuro */
.page-accidentes .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}

/* Responsive: un poco menos altas en móvil */
@media (max-width: 560px){
  .page-accidentes .work-card{ min-height: 150px; }
}

/* H2 "¿Cómo trabajamos?" centrado y más grande (solo en Accidentes) */
.page-accidentes .page > h2:first-of-type{
  text-align: center;
  font-size: 40px; /* ajustá a gusto */
  line-height: 1.2;
  margin: 22px 0 16px;                 /* top/bottom */
  color: rgba(13,13,83,.9);
  margin-bottom: 50px;
}

/* ===== CTA dividida (tarjeta + imagen) ===== */
.cta-split{
  margin: 26px 0 18px;
  margin-top: 150px;
}
.cta-split__grid{
  display: grid;
  gap: 16px;
}

/* Mobile: apilado (tarjeta arriba, imagen abajo) */
.cta-card{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  padding: 22px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}
.cta-card h3{
  margin: 0 0 6px;
  font-size: 20px;
  color: rgba(13,13,83,.95);
  font-weight: 800;
}
.cta-card p{
  margin: 0 0 12px;
  color: #475569;
}
.cta-card .btn{
  background: var(--violeta);
  color: #fff;
}

/* Imagen responsiva */
.cta-media{
  margin: 0;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  border: 1px solid #e8ecf4;
}
.cta-media img{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 3 / 2; /* buena relación en mobile */
}

/* Desktop: dos columnas 48/52 (tarjeta izquierda, imagen derecha) */
@media (min-width: 961px){
  .cta-split__grid{
    grid-template-columns: 1fr 1.1fr;
    align-items: stretch;
    gap: 18px;
  }
  .cta-card{
    padding: 26px;
    display: grid;
    align-content: start;
    gap: 10px;
    border-left: 4px solid var(--azul); /* acento de marca */
  }
  .cta-media img{
    aspect-ratio: 16 / 10; /* más panorámica en desktop */
  }
}

/* (Opcional) versión oscura solo para la page de Accidentes */
.page-accidentes .cta-card{
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}
.page-accidentes .cta-card h3{ color:#fff; }
.page-accidentes .cta-card p{ color:#cbd5e1; }
.page-accidentes .cta-card .btn{ background: var(--violeta); color:#fff; }



/* Botón de la CTA con texto oscuro */
.cta-card .btn{
  margin-top: 30px;  
  color: #0f172a !important;           /* texto oscuro */
}

/* Botón de la CTA más corto en los laterales */
.cta-card .btn{
  display: inline-block;
  padding: 10px 10px;   /* ← antes era 10px 14/16px: bajá el segundo valor */
  inline-size: fit-content; /* evita que se estire */
}

/* Si lo querés aún más finito */
.cta-card .btn.btn-compact{
  padding: 8px 8px;     /* ultra corto a los lados */
  font-size: 14px;
}


/* CTA: centrar y agrandar un poco los elementos */
.cta-split .cta-card{
  text-align: center;
  display: grid;
  place-items: center;   /* centra contenido dentro de la tarjeta */
  gap: 10px;
}

.cta-split .cta-card h3{
  font-size: 30px;  /* más grande */
  line-height: 1.2;
  margin: 0;
  margin-top: 50px;
}

.cta-split .cta-card p{
  font-size: clamp(15px, 2.4vw, 17px);/* un toque más grande */
  line-height: 1.5;
  margin: 0 0 6px;
  margin-top: 20px;
}

/* botón centrado y con leve mejora de presencia */
.cta-split .cta-card .btn{
  margin: 0 auto;                /* centra el botón */
  display: inline-block;
  padding: 10px 10px;            /* corto a los costados, como pediste */
  font-size: 15px;               /* un poco más grande */
  border-radius: 10px;
  margin-top: 20px;
}

/* Separador al final de la lista "¿Cómo trabajamos?" */
.work-list{
  position: relative;
  margin-bottom: 48px;   /* aire antes de la línea */
  padding-bottom: 80px;  /* evita que tape contenido */
}

.work-list::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height: 2px; /* antes 1px */
  background: linear-gradient(90deg, #0000, #333b7c, #0000); /* más contraste */
  filter: none; /* quita el blur que la suavizaba */
  opacity: .9;  /* más visible */
}

@media (max-width: 600px){
  .related ul{
    flex-direction: column;       /* uno debajo del otro */
    align-items: stretch;
    gap: 10px;
  }
  .related a{
    display: block;
    white-space: nowrap;          /* no partir en varias líneas */
    overflow: hidden;             /* ocultar si no entra */
    text-overflow: ellipsis;      /* … si se recorta */
    font-size: 15px;              /* opcional: un toque más chico */
    padding: 10px 12px;           /* “pill” prolijo */
  }
}

/* ===== Fix header solo en Accidentes: centrar menú a la misma altura del logo ===== */
.page-accidentes .nav-wrap{
  height: var(--header-h);              /* usa la misma altura global */
  display: flex;
  align-items: center;                   /* centra verticalmente todo */
}

/* Asegura el centrado de los links del menú */
.page-accidentes .main-nav > ul{
  display: flex;
  align-items: center;                   /* centra el grupo */
  margin: 0; padding: 0;
}
.page-accidentes .main-nav > ul > li > a{
  display: flex;
  align-items: center;                   /* centra cada link */
  height: calc(var(--header-h) - 0px);   /* alto igual al header */
  line-height: 1;                        /* evita desajustes de baseline */
  padding-block: 0;                      /* sin padding vertical extra */
}

/* Logo: misma regla que el index para evitar desfasajes visuales */
.page-accidentes .logo{
  display: flex; align-items: center;
}
.page-accidentes .logo img{
  height: calc(var(--header-h) - 32px);  /* igual que en index */
  width: auto; vertical-align: middle;
}
.page-accidentes .logo-text{
  line-height: 1;                        /* evita “estirar” el header */
}

/* (Opcional) si ves el menú 1–2px bajo/alto, aplicá microajuste: */
@media (min-width: 961px){
  .page-accidentes .main-nav > ul > li > a{ transform: translateY(-1px); } /* ajustá a -1/0/1 */
}

/* ===== Específico de Tránsito (misma estética que ART) ===== */

/* Fix header: centrar menú a la misma altura del logo */
.page-transito .nav-wrap{
  height: var(--header-h);
  display: flex;
  align-items: center;
}
.page-transito .main-nav > ul{
  display: flex;
  align-items: center;
  margin: 0; padding: 0;
}
.page-transito .main-nav > ul > li > a{
  display: flex;
  align-items: center;
  height: calc(var(--header-h));
  line-height: 1;
  padding-block: 0;
}
.page-transito .logo{ display:flex; align-items:center; }
.page-transito .logo img{
  height: calc(var(--header-h) - 32px);
  width: auto; vertical-align: middle;
}
.page-transito .logo-text{ line-height: 1; }
@media (min-width: 961px){
  .page-transito .main-nav > ul > li > a{ transform: translateY(-1px); }
}

/* HERO de Tránsito (full screen, misma lógica que ART) */
.page-transito .page-hero--transito{
  background-image: url("/img/hero_acc_lab1.webp");
  /* si querés menos “zoom” en desktop como en ART: */
  background-size: 100% auto;
  background-position: center 30%;
 
}
@media (max-width: 600px){
  .page-transito .page-hero--transito{
    background-image: url("/img/hero_acc_labres.PNG"); /* versión mobile opcional */
    background-position: center 30%;
  }
}

/* ¿Cómo trabajamos? — mismas tarjetas oscuras que ART */
.page-transito .work-card{
  min-height: 180px;
  padding: 22px 18px 24px;
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}
.page-transito .work-card:hover,
.page-transito .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}
.page-transito .work-body h3{ color:#fff; }
.page-transito .work-body p{ color:#cbd5e1; }
.page-transito .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}
@media (max-width: 560px){
  .page-transito .work-card{ min-height: 150px; }
}

/* CTA dividida — misma variante oscura que ART */
.page-transito .cta-card{
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}
.page-transito .cta-card h3{ color:#fff; }
.page-transito .cta-card p{ color:#cbd5e1; }
.page-transito .cta-card .btn{
  background: var(--violeta);
  color:#fff;
}

/* H2 “¿Cómo trabajamos?” centrado y grande (igual que ART) */
.page-transito .page > h2:first-of-type{
  text-align: center;
  font-size: 40px;
  line-height: 1.2;
  margin: 22px 0 16px;
  color: rgba(13,13,83,.9);
  margin-bottom: 50px;
}

@media (min-width: 961px){
  .page-transito .page-hero .container{
    /* anula el empuje duro que tenés en otras pages */
    margin-left: auto;        /* pega el bloque hacia la derecha */
    margin-right: 48px;       /* aire respecto del borde derecho */
    max-width: 780px;         /* achica el ancho de lectura */
    padding-inline: 16px;     /* un poco de aire interno */
  }
}

/* ==== FIX: menú móvil en pages = igual que index (compacto + una línea) ==== */

/* Limitar a ESCRITORIO las reglas altas de los links en pages */
@media (min-width: 961px){
  .page-accidentes .main-nav > ul > li > a,
  .page-transito   .main-nav > ul > li > a{
    height: calc(var(--header-h));
    padding-block: 0;
    display: flex;
    align-items: center;
  }
}

/* MÓVIL: forzar el mismo estilo del index en TODAS las pages */
@media (max-width: 960px){
  /* lista vertical sin centrado ni gaps extra */
  .page-interna .main-nav > ul,
  .page-accidentes .main-nav > ul,
  .page-transito .main-nav > ul{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* cada link: compacto, a la izquierda, ancho completo */
  .page-interna .main-nav > ul > li > a,
  .page-accidentes .main-nav > ul > li > a,
  .page-transito .main-nav > ul > li > a{
    display: block !important;
    width: 100% !important;
    text-align: left !important;
    height: auto !important;            /* anula height grande de desktop */
    padding: 10px 8px !important;       /* separación mínima */
    line-height: 1.2 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    text-decoration: none !important;
    position: relative;
    box-sizing: border-box;
  }

  /* quitar pseudolíneas previas para evitar doble separador */
  .page-interna .main-nav > ul > li > a::before,
  .page-accidentes .main-nav > ul > li > a::before,
  .page-transito .main-nav > ul > li > a::before{
    content: none !important;
  }

  /* UNA sola línea entre opciones (como en index) */
  .page-interna .main-nav > ul > li > a,
  .page-accidentes .main-nav > ul > li > a,
  .page-transito .main-nav > ul > li > a{
    border-top: 1px solid rgba(255,255,255,.28) !important;
  }
  .page-interna .main-nav > ul > li:first-child > a,
  .page-accidentes .main-nav > ul > li:first-child > a,
  .page-transito .main-nav > ul > li:first-child > a{
    border-top: none !important;
  }

  /* estados sin modificar la altura */
  .page-interna .main-nav a:hover,
  .page-accidentes .main-nav a:hover,
  .page-transito .main-nav a:hover{
    background: rgba(255,255,255,.06) !important;
  }
  .page-interna .main-nav a.active,
  .page-accidentes .main-nav a.active,
  .page-transito .main-nav a.active{
    background: rgba(255,255,255,.10) !important;
  }
  .page-interna .main-nav a:focus,
  .page-accidentes .main-nav a:focus,
  .page-transito .main-nav a:focus{
    outline: none !important;
    box-shadow: none !important;
  }
}

/* === CLONAR ESTILO DEL TOGGLE DEL INDEX EN TODAS LAS PAGES (solo móvil) === */
@media (max-width: 960px){
  /* lista: columna, sin gaps ni padding extra */
  .page-interna .main-nav > ul,
  .page-accidentes .main-nav > ul,
  .page-transito .main-nav > ul{
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 8px 0 !important;  /* igual que index */
    list-style: none !important;
    align-items: stretch !important;
  }

  /* cada link ocupa todo el ancho, mismo padding que index */
  .page-interna .main-nav > ul > li > a,
  .page-accidentes .main-nav > ul > li > a,
  .page-transito .main-nav > ul > li > a{
    display: block !important;
    width: 100% !important;
    text-align: left !important;
    padding: 14px 12px !important;   /* ← tal cual index */
    margin: 0 !important;
    line-height: 1.2 !important;
    border-radius: 0 !important;
    text-decoration: none !important;
    position: relative !important;
    height: auto !important;         /* evita alturas grandes heredadas */
  }

  /* quitar cualquier borde-top anterior (para no duplicar líneas) */
  .page-interna .main-nav > ul > li > a,
  .page-accidentes .main-nav > ul > li > a,
  .page-transito .main-nav > ul > li > a{
    border: 0 !important;
  }

  /* separador: misma línea fina con ::before que usa el index */
  .page-interna .main-nav > ul > li > a::before,
  .page-accidentes .main-nav > ul > li > a::before,
  .page-transito .main-nav > ul > li > a::before{
    content: "" !important;
    position: absolute !important;
    left: 0; right: 0; top: -1px;
    height: 1px;
    background: rgba(255,255,255,.28);  /* igual que index */
  }
  .page-interna .main-nav > ul > li:first-child > a::before,
  .page-accidentes .main-nav > ul > li:first-child > a::before,
  .page-transito .main-nav > ul > li:first-child > a::before{
    display: none !important;
  }

  /* estados visuales (mismos del index) */
  .page-interna .main-nav a:hover,
  .page-accidentes .main-nav a:hover,
  .page-transito .main-nav a:hover{
    background: rgba(255,255,255,.10) !important;
  }
  .page-interna .main-nav a.active,
  .page-accidentes .main-nav a.active,
  .page-transito .main-nav a.active{
    background: rgba(255,255,255,.16) !important;
  }
  .page-interna .main-nav a:focus,
  .page-accidentes .main-nav a:focus,
  .page-transito .main-nav a:focus{
    outline: none !important;
    box-shadow: none !important;
  }
}
/* Pages (solo móvil): mismo tamaño de letra que el index en el toggle */
@media (max-width: 960px){
  .page-interna .main-nav > ul > li > a{
    font-size: 16px !important;  /* sube desde ~15px */
  }
}

/* Pages (solo móvil): un poco más de separación entre opciones del toggle */
@media (max-width: 960px){
  .page-interna .main-nav ul{ gap: 0 !important; } /* sin huecos extra */
  .page-interna .main-nav > ul > li > a{
    padding-block: 16px !important;   /* antes ~14px → un poco más alto */
    padding-inline: 12px !important;
    min-height: 44px;                  /* asegura tap target cómodo */
  }
  /* Línea separadora, igual que antes */
  .page-interna .main-nav ul > li > a::before{ top: 0; }
}

/* ===== FIX: limitar ajustes de header de pages a ESCRITORIO ===== */
@media (min-width: 961px){
  /* Accidentes laborales */
  .page-accidentes .main-nav > ul{
    display: flex;
    align-items: center;
    margin: 0; padding: 0;
  }
  .page-accidentes .main-nav > ul > li > a{
    display: flex;
    align-items: center;
    height: var(--header-h);
    line-height: 1;
    padding-block: 0;
    transform: translateY(-1px);
  }
  .page-accidentes .logo img{
    height: calc(var(--header-h) - 32px);
  }

  /* Accidentes de tránsito */
  .page-transito .main-nav > ul{
    display: flex;
    align-items: center;
    margin: 0; padding: 0;
  }
  .page-transito .main-nav > ul > li > a{
    display: flex;
    align-items: center;
    height: var(--header-h);
    line-height: 1;
    padding-block: 0;
    transform: translateY(-1px);
  }
  .page-transito .logo img{
    height: calc(var(--header-h) - 32px);
  }
}

/* ===== Unificar TOGGLE en TODAS las pages como el del index (solo móvil) ===== */
@media (max-width: 960px){
  /* Drawer como en index (ancho, posición, sin rarezas) */
  .page-interna .main-nav{
    top: var(--header-h);
    left: 0; bottom: 0;
    width: min(86vw, 360px);
    transform: translateX(-105%);
    padding: 16px;
  }
  .page-interna .main-nav.open{ transform: translateX(0); }

  /* Lista vertical alineada a la IZQUIERDA, sin gap extra */
  .page-interna .main-nav ul{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    margin: 0 !important;
    padding: 4px 0 !important;
    gap: 0 !important;
    list-style: none !important;
  }
  .page-interna .main-nav li{ margin: 0 !important; }

  /* Ítems: MISMO padding y tamaño que index + separador fino */
  .page-interna .main-nav ul > li > a,
  .page-interna .main-nav ul > * > a,
  .page-interna .main-nav ul > a{
    display: block !important;
    text-align: left !important;
    padding: 14px 12px !important;   /* alto compacto como en index */
    font-size: 16px !important;       /* mismo tamaño que index */
    font-weight: 600;
    line-height: 1.2 !important;
    border-radius: 0 !important;
    position: relative;
    height: auto !important;          /* anula alturas forzadas */
    transform: none !important;       /* anula microajustes de desktop */
  }

  /* Separador entre opciones (idéntico al index) */
  .page-interna .main-nav ul > li > a::before,
  .page-interna .main-nav ul > * > a::before,
  .page-interna .main-nav ul > a::before{
    content: "";
    position: absolute;
    left: 0; right: 0; top: 0;
    height: 1px;
    background: rgba(255,255,255,.22);
  }
  .page-interna .main-nav ul > li:first-child > a::before,
  .page-interna .main-nav ul > *:first-child > a::before,
  .page-interna .main-nav ul > a:first-child::before{
    display: none;
  }

  /* Estados sin agregar “espacio visual” extra */
  .page-interna .main-nav a:hover{ background: rgba(255,255,255,.08); }
  .page-interna .main-nav a.active{ background: rgba(255,255,255,.12); }
  .page-interna .main-nav a:focus,
  .page-interna .main-nav a:active,
  .page-interna .main-nav a:focus-visible{
    outline: none !important;
    box-shadow: none !important;
    background: transparent;
  }
}

/* ===== Seguridad extra: neutralizar overrides puntuales en móvil ===== */
@media (max-width: 960px){
  .page-accidentes .main-nav > ul > li > a,
  .page-transito   .main-nav > ul > li > a{
    height: auto !important;
    padding: 14px 12px !important;
    line-height: 1.2 !important;
    transform: none !important;
    border-radius: 0 !important;
  }
}

/* Paleta de colores */
:root {
  --violeta: #fafafa; /* acentos */
  --azul: #0b1631;    /* header/footer/botones */
  --azul-700: #2746b2;
  --blanco: #f5f7fb;
  --gris: #f5f7fb;
  --texto: #0f172a;   /* slate-900 */
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif;
  color: var(--texto);
  background: var(--blanco);
}

/* Contenedor principal */
.container {
  max-width: 1100px;
  margin: auto;
  padding: 0 16px;
}

/* Header y navegación */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--azul);
  color: var(--blanco);
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
.nav-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
  height: 64px;
}
.logo {
  color: var(--blanco);
  text-decoration: none;
  font-weight: 800;
  letter-spacing: .2px;
}
.logo strong { color: var(--violeta); }
.menu-toggle {
  display: none;
  margin-left: auto;
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 28px;
  cursor: pointer;
}
.main-nav ul {
  list-style: none;
  display: flex;
  gap: 16px;
  margin: 0;
  padding: 0;
}
.main-nav a {
  color: var(--blanco);
  text-decoration: none;
  font-weight: 600;
  opacity: .95;
}
.main-nav a:hover,
.main-nav a.active {
  opacity: 1;
  text-decoration: underline;
}
.btn-cta {
  margin-left: auto;
  background: var(--violeta);
  color: #fff;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 700;
  white-space: nowrap;
}
.btn-cta:hover { filter: brightness(1.05); }

@media (max-width: 960px) {
  .menu-toggle { display: block; }
  .main-nav {
    position: fixed;
    inset: 64px 0 auto 0;
    background: var(--azul);
    transform: translateY(-120%);
    transition: .25s;
    padding: 16px;
  }
  .main-nav.open { transform: translateY(0); }
  .main-nav ul { flex-direction: column; }
  .btn-cta { display: none; }
}

/* Hero */

.hero .container { padding: 64px 16px 80px; }
.hero h1 {
  font-size: clamp(28px, 4vw, 44px);
  margin: 0 0 12px;
  color: #d6dbe6;
}
.hero p {
  font-size: clamp(16px, 2.2vw, 20px);
  opacity: .95;
  max-width: 800px;
  color: #d6dbe6;
}
.hero-cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 16px;
}
.btn {
  display: inline-block;
  background: var(--violeta);
  color: #050633;
  text-decoration: none;
  padding: 12px 16px;
  border-radius: 12px;
  font-weight: 700;
}
.btn:hover { filter: brightness(1.05); }
.btn.ghost { background: transparent; border: 2px solid #fff; }

/* Áreas */
.areas { background: var(--gris); }
.areas h2,
.why h2,
.contacto h2 {
  font-size: clamp(22px, 3vw, 28px);
  margin: 0 0 16px;
}
.grid-areas {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
}
.card {
  background: #fff;
  border: 1px solid #eef1f6;
  border-radius: 14px;
  padding: 16px;
  text-decoration: none;
  color: var(--texto);
  box-shadow: 0 6px 18px rgba(0,0,0,.05);
}
.card h3 {
  margin: 0 0 6px;
  font-size: 18px;
  color: var(--azul);
}
.card p {
  margin: 0;
  color: #475569;
}
.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
}
@media (max-width: 900px) { .grid-areas { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .grid-areas { grid-template-columns: 1fr; } }

/* Why */
.why .benefits {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.why .benefits li {
  background: #fff;
  padding: 14px;
  border-radius: 12px;
  border: 1px solid #eef1f6;
}
@media (max-width: 900px) { .why .benefits { grid-template-columns: 1fr; } }

/* Contacto */
.contact-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.contact-form label {
  display: grid;
  gap: 6px;
  font-weight: 600;
}
.contact-form input,
.contact-form textarea {
  border: 1px solid #d6dbe6;
  border-radius: 10px;
  padding: 10px;
  font: inherit;
}
.contact-form textarea { grid-column: 1/-1; }
.contact-form .btn { grid-column: 1/2; }
@media (max-width:700px) {
  .contact-form { grid-template-columns: 1fr; }
  .contact-form .btn { grid-column: 1/-1; }
}

/* Página interna */
.page { padding: 32px 0 64px; }
.breadcrumbs {
  font-size: 14px;
  color: #64748b;
  margin: 8px 0 12px;
}
.breadcrumbs a { color: #64748b; }
.cta-panel {
  border: 1px solid #eef1f6;
  border-radius: 12px;
  padding: 16px;
  background: #fff;
  margin: 18px 0;
}
.related ul {
  display: flex;
  gap: 12px;
  list-style: none;
  padding: 0;
}
.related a {
  color: var(--azul);
  text-decoration: none;
}

/* Footer */
.site-footer {
  background: var(--azul);
  color: #fff;
  margin-top: 32px;
}
.footer-grid {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 0;
}
.site-footer a { color: #fff; }
.copy {
  background: #152a6a;
  text-align: center;
  padding: 10px 0;
  font-size: 14px;
}

/* WhatsApp flotante */
.wp-float {
  position: fixed;
  right: 16px;
  bottom: 16px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366 url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 32 32"><path fill="white" d="M19.11 17.26c-.3-.15-1.77-.87-2.05-.97-.28-.1-.49-.15-.7.15-.2.3-.8.97-.98 1.17-.18.2-.36.22-.66.07-.3-.15-1.25-.46-2.38-1.47-.88-.78-1.47-1.74-1.64-2.04-.17-.3-.02-.47.13-.62.13-.13.3-.33.45-.5.15-.17.2-.28.3-.48.1-.2.05-.37-.02-.52-.07-.15-.7-1.67-.96-2.29-.25-.6-.51-.52-.7-.53l-.6-.01c-.2 0-.52.07-.8.37-.28.3-1.06 1.03-1.06 2.5 0 1.47 1.08 2.89 1.23 3.09.15.2 2.13 3.25 5.16 4.55.72.31 1.29.49 1.73.63.73.23 1.4.2 1.93.12.59-.09 1.77-.72 2.02-1.41.25-.69.25-1.28.18-1.41-.07-.13-.25-.2-.55-.35zM16.1 28C9.98 28 5 23.02 5 16.9 5 10.78 9.98 5.8 16.1 5.8S27.2 10.78 27.2 16.9 22.22 28 16.1 28zm0-20.4c-5.31 0-9.6 4.29-9.6 9.6 0 5.31 4.29 9.6 9.6 9.6 5.31 0 9.6-4.29 9.6-9.6 0-5.31-4.29-9.6-9.6-9.6z"/></svg>') center/60% no-repeat;
  box-shadow: 0 8px 22px rgba(0,0,0,.18);
}
.wp-float:focus { outline: 3px solid #fff6; }

/* Contenedor principal del header */
.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  height: 70px;
}

/* Logo bien pegado a la izquierda */
.logo {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  white-space: nowrap;
  margin-right: auto;  /* fuerza que todo lo demás se corra a la derecha */
}
.logo img {
  height: 44px; /* un poco más compacto */
  width: auto;
}
.logo-text {
  font-size: 16px; /* achicado para que ocupe menos */
  font-weight: 700;
  color: var(--blanco);
  white-space: nowrap;
}

/* Menú ocupa el espacio central */
.main-nav {
  flex: 1; /* hace que el menú crezca en el centro */
}
.main-nav ul {
  display: flex;
  justify-content: center;
  gap: 14px; /* más ajustado para que entre todo */
  margin: 0;
  padding: 0;
  list-style: none;
  white-space: nowrap;
}
.main-nav a {
  color: var(--blanco);
  text-decoration: none;
  font-weight: 600;
  font-size: 15px;
}
.main-nav a:hover { color: var(--violeta); }

/* Botón CTA a la derecha */
.btn-cta {
  margin-left: auto;
  background: var(--violeta);
  color: #fff;
  padding: 8px 14px;
  border-radius: 6px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}




/* Responsive: menú hamburguesa */
@media (max-width: 960px) {
  .menu-toggle { display: block; margin-left: auto; }
  .main-nav {
    position: fixed;
    inset: 70px 0 auto 0;
    background: var(--azul);
    padding: 20px;
    transform: translateY(-120%);
    transition: .3s ease;
  }
  .main-nav.open { transform: translateY(0); }
  .main-nav ul {
    flex-direction: column;
    gap: 12px;
  }
  .btn-cta { display: none; }
}

/* Contenedor general */
.container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

/* En el header queremos que no tenga padding izquierdo */
.site-header .container {
  padding-left: 0px;   /* quita el espacio a la izquierda */
  padding-right: 50px; /* mantené un poco de aire a la derecha */
}

/* Logo bien pegado al borde */
.logo {
  margin-left: 0;
  padding-left: 8px; /* opcional: un respiro de 8px en lugar de 16px */
}
/* Header full-bleed (al ras del viewport) */
.site-header .container {
  max-width: none;   /* ignora el tope de 1100px en el header */
  width: 100%;
  margin: 0;         /* anula el margin:auto centrado */
  padding-left: 10px;   /* sin borde izquierdo */
  padding-right: 16px; /* dejá un poco a la derecha para el CTA */
}

/* Evitá cualquier desplazamiento del logo */
.logo {
  margin-left: 0 !important;
  padding-left: 0 !important; /* quitá ese 8px */
}

/* (Opcional) si querés que el menú quede más compacto */
.main-nav ul {
  gap: 12px;
}

/* Más espacio entre items del menú (solo escritorio) */
@media (min-width: 961px) {
  .main-nav ul {
    gap: 22px;              /* antes 14–16px */
  }
  .main-nav a {
    padding-inline: 2px;    /* agranda el área clickeable sin cambiar gap */
    white-space: nowrap;    /* sigue en una sola línea */
  }
}

/* === Altura del header (ajustá un solo valor) === */
:root { --header-h: 100px; } /* 84px o el valor que quieras */

/* Contenedor del header */
.nav-wrap {
  height: var(--header-h);
  align-items: center;
}

/* El logo crece en proporción a la nueva altura */
.logo img {
  height: calc(var(--header-h) - 32px); /* margen de respiro */
  width: auto;
}

/* Menú móvil: bajar el panel justo debajo del header nuevo */
@media (max-width: 960px) {
  .main-nav { inset: var(--header-h) 0 auto 0; }
}



@media (max-width: 480px) {
  :root { --header-h: 72px; }
}

/* HERO a pantalla completa menos el header */
/* HERO a pantalla completa con imagen de fondo + overlay */
.hero{
  position: relative;
  min-height: calc(100vh - var(--header-h));
  display: flex;
  align-items: center;

  /* imagen de fondo */
  background-image: url("/img/hero-estudiojur.png");
  background-size: 70% auto;   /* probá 110–140% */
    background-position: center 30%;
    background-repeat: no-repeat;
}

/* overlay para mejorar contraste del texto */

.hero > *{ position: relative; } /* que el contenido quede encima del overlay */

/* padding del contenido */
.hero .container{ padding-block: 64px; }

@supports (height: 100svh){
  .hero{ min-height: calc(100svh - var(--header-h)); }
}

.hero{
  background-position: center 10%;  /* prueba 20%, 30%, 40% */
}

/* Contenido del hero alineado a la izquierda */
.hero .container{
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* izquierda */
  text-align: left;        /* por si algún estilo lo centraba */
  max-width: 1100px;       /* opcional: limita ancho de lectura */
}

.hero h1,
.hero p,
.hero .hero-cta{
  margin-left: -400px;
  text-align: left;
}

/* Botones en fila a la izquierda */
.hero .hero-cta{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-start;
}

/* En mobile, sigue a la izquierda */
@media (max-width: 600px){
  .hero .container{ align-items: flex-start; }
}

/* ===== Tarjetas pro con imagen ===== */
.grid-areas {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none;
  color: var(--texto);
  box-shadow: 0 8px 22px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  will-change: transform;
}

.card:hover,
.card:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,.1);
  border-color: #dbe3f2;
  outline: none;
}

.card-img {
  position: relative;
  aspect-ratio: 16 / 9; /* mantiene proporciones */
  overflow: hidden;
  background: #eef2ff; /* fallback mientras carga */
}

.card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform .5s ease;
}

.card:hover .card-img img { transform: scale(1.07); }

.card-body {
  padding: 16px 16px 18px;
  display: grid;
  gap: 6px;
}

.card-body h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.25;
  color: rgba(21, 42, 102, 0.76);
  font-weight: 800;
}

.card-body p {
  margin: 0;
  color: #475569;
  line-height: 1.45;
  min-height: 40px; /* mantiene altura parecida entre tarjetas */
}

/* Accesibilidad: Foco visible para teclado */
.card:focus-visible {
  box-shadow: 0 0 0 3px rgba(106,13,173,.35), 0 12px 26px rgba(0,0,0,.08);
}

/* Menos animación si el usuario lo prefiere */
@media (prefers-reduced-motion: reduce) {
  .card, .card-img img { transition: none; }
}

/* Responsivo */
@media (max-width: 1024px) {
  .grid-areas { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .grid-areas { grid-template-columns: 1fr; }
}

/* ===== Cards más altas con imagen arriba y texto abajo ===== */
:root { --card-h: 420px; } /* altura total deseada (ajustá a gusto) */

.card--taller{
  display: flex;
  flex-direction: column;
  height: var(--card-h);
  border-radius: 16px;
  overflow: hidden;           /* que la imagen no se salga */
}

/* La imagen ocupa la mitad superior */
.card--taller .card-img{
  flex: 0 0 50%;
  height: 50%;
  aspect-ratio: auto;         /* anulá el 16:9 si lo tenías */
  background: #eef2ff;
  overflow: hidden;
}
.card--taller .card-img img{
  width: 100%;
  height: 100%;
  object-fit: cover;          /* recorta sin deformar */
  transform: scale(1.02);
  transition: transform .5s ease;
}
.card--taller:hover .card-img img{ transform: scale(1.07); }

/* El cuerpo ocupa la mitad inferior */
.card--taller .card-body{
  flex: 1 0 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;    /* centra verticalmente el texto */
  gap: 6px;
  padding: 16px 16px 18px;
}

/* Ajustes responsivos (un poco menos alta en mobile) */
@media (max-width: 560px){
  :root { --card-h: 360px; }
}

/* --- Fix: que la imagen ocupe exactamente la mitad --- */
.card.card--taller { 
  padding: 0;                /* quita el padding que achica el alto útil */
}

/* El <figure> no debe aportar márgenes extra */
.card--taller .card-img { 
  margin: 0;                 /* elimina margen por defecto del figure */
  flex: 0 0 50%;
  height: 50%;
  aspect-ratio: auto;        /* anula el 16:9 anterior */
  overflow: hidden;
}

/* La imagen llena su contenedor */
.card--taller .card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* La mitad inferior (texto) */
.card--taller .card-body {
  flex: 1 0 50%;
  height: 50%;
  padding: 16px;             /* el padding va acá, no en .card */
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Centrar y dar más margen al título de Áreas */
.areas .container > h2{
  text-align: center;
  margin-top: 60px;    /* ajustá a gusto */
  margin-bottom: 60px; /* ajustá a gusto */
  line-height: 1.2;
  font-size: 40px;
  color: rgba(13, 13, 83, 0.719);
}

/* ===== WHY: tarjetas con icono, estilo similar a Áreas ===== */
.why { background: var(--gris); }

.why .container > h2{
  text-align: center;
  margin: 48px 0 28px;
  line-height: 1.2;
 
}

.why-grid{
  list-style: none;
  margin: 0;
  padding: 0 0 48px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.why-card{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  padding: 18px 16px 20px;
  box-shadow: 0 8px 22px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas:
    "icon title"
    "icon text";
  column-gap: 12px;
  row-gap: 6px;
  margin-top: 60px;
}

.why-card:hover,
.why-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,.1);
  border-color: #dbe3f2;
}

/* Ícono circular con color de marca */
.why-icon{
  grid-area: icon;
  align-self: start;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #fff;              /* color del ícono (SVG usa currentColor) */
  background: linear-gradient(135deg, var(--azul), var(--violeta));
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

.why-card h3{
  grid-area: title;
  margin: 0;
  font-size: 18px;
  color: rgba(13,13,83,.719);
  font-weight: 800;
  line-height: 1.25;
}

.why-card p{
  grid-area: text;
  margin: 0;
  color: #475569;
  line-height: 1.45;
}

/* Responsivo */
@media (max-width: 1024px){
  .why-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px){
  .why-grid{ grid-template-columns: 1fr; }
}

/* Tarjetas WHY más grandes */
.why-grid{
  gap: 22px;
  padding-bottom: 64px;
}
.why-card{
  padding: 24px 20px 24px;
  column-gap: 14px;
  row-gap: 8px;
}
.why-card h3{ font-size: 19px; }
.why-card p{ font-size: 15px; }

/* Icono un poco más grande */
.why-icon{
  width: 52px;
  height: 52px;
}
.why-icon svg{ width: 28px; height: 28px; }

/* OPCIÓN A: colores por clase (recomendado para control explícito) */
.why-card.is-experiencia .why-icon{
  background: linear-gradient(135deg, #6a0dad, #1e3a8a); /* violeta → azul */
  color: #fff;
}
.why-card.is-atencion .why-icon{
  background: linear-gradient(135deg, #2563eb, #22d3ee); /* azul → cian */
  color: #fff;
}
.why-card.is-honorarios .why-icon{
  background: linear-gradient(135deg, #9333ea, #f43f5e); /* violeta → coral */
  color: #fff;
}

/* OPCIÓN B: si no querés tocar HTML, por posición */
.why-card:nth-child(1) .why-icon{
  background: linear-gradient(135deg, #6a0dad, #1e3a8a);
  color: #fff;
}
.why-card:nth-child(2) .why-icon{
  background: linear-gradient(135deg, #2563eb, #22d3ee);
  color: #fff;
}
.why-card:nth-child(3) .why-icon{
  background: linear-gradient(135deg, #9333ea, #f43f5e);
  color: #fff;
}

/* Un poco más de aire arriba/abajo del título de sección */
.why .container > h2{
  margin: 56px 0 36px;
}


/* pegá ESTO al final del CSS */
.why .container > h2{
  margin-top: 60px !important;
  font-size: 36px;
  color: rgba(13,13,83,.719);
  text-align: center;
  font-weight: bold;
}

.why{
  padding-top: 100px; /* crea el espacio arriba sin colapso */
}

/* Divider sutil arriba de la sección WHY */
.why{
  position: relative;
}
.why::before{
  content:"";
  position: absolute;
  inset: 80px 0 auto 0;   /* sube la línea 24px sobre .why */
  height: 1px;
  background: linear-gradient(90deg, #0000, #c7d2fe, #0000); /* violeta-azulado suave */
  filter: blur(.2px);
}

/* Contacto pro: centrado, una sola columna, prolijo */
.contacto { background: var(--gris); }
.contacto .container { max-width: 720px; text-align: center; }
.contact-sub { color: #64748b; margin: 8px 0 20px; }

.contact-card{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  padding: 22px;
}

.contact-form.pro{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  text-align: left; /* los labels a la izquierda */
}

.contact-form.pro label{
  display: grid;
  gap: 6px;
  font-weight: 600;
  color: #1f2a44;
}

.contact-form.pro input,
.contact-form.pro textarea{
  border: 1px solid #d6dbe6;
  border-radius: 12px;
  padding: 12px 12px;
  font: inherit;
  background: #fff;
}

.contact-form.pro input::placeholder,
.contact-form.pro textarea::placeholder{ color: #94a3b8; }

.contact-form.pro input:focus,
.contact-form.pro textarea:focus{
  outline: none;
  border-color: var(--azul);
  box-shadow: 0 0 0 4px rgba(30,58,138,.12);
}

.contact-actions{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 6px;
}

.form-status{
  margin: 8px 0 0;
  font-size: 14px;
  color: #0f172a;
}

/* Mobile */
@media (max-width: 560px){
  .contact-card{ padding: 18px; }
  .contact-actions{ flex-direction: column; align-items: stretch; }
  .contact-actions .btn,
  .contact-actions .btn.ghost{ text-align: center; }
}

.contacto{
  padding-top: 120px; /* crea el espacio arriba sin colapso */
}

.contacto h2 {
    font-size: 45px;
    color:#524f79;
}
.contacto{
  position: relative;
}
.contacto::before{
  content:"";
  position: absolute;
  inset: 50px 0 auto 0;   /* sube la línea 24px sobre .why */
  height: 1px;
  background: linear-gradient(90deg, #0000, #c7d2fe, #0000); /* violeta-azulado suave */
  filter: blur(.2px);
}

/* ===== Sucursal ===== */
.sucursal { background: var(--gris); }
.sucursal .container > h2{
  text-align: center;
  margin: 48px 0 24px;
  margin-bottom: 60px;
}

.branch-wrap{
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 18px;
  align-items: start;
}

.branch-info{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  padding: 18px 16px 20px;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 12px;
  row-gap: 8px;
}

.branch-icon{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--azul), var(--violeta));
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

.branch-info h3{
  margin: 2px 0 6px;
  font-size: 18px;
  color: var(--azul);
  font-weight: 800;
}

.branch-address{
  margin: 0 0 10px;
  color: #475569;
  line-height: 1.45;
}

.btn.small{
  padding: 8px 12px;
  border-radius: 10px;
  font-weight: 700;
  text-decoration: none;
  display: inline-block;
  background: var(--violeta);
  color: #fff;
}

/* Mapa */
.branch-map{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  overflow: hidden;
  min-height: 320px;
}
.branch-map iframe{
  display: block;
  width: 100%;
  height: 100%;
  min-height: 320px;
  border: 0;
}

/* Responsive */
@media (max-width: 960px){
  .branch-wrap{
    grid-template-columns: 1fr;
  }
  .branch-map{ min-height: 280px; }
  .branch-map iframe{ min-height: 280px; }
}


.sucursal{
  padding-top: 120px; /* crea el espacio arriba sin colapso */
}

.sucursal{
  position: relative;
}
.sucursal::before{
  content:"";
  position: absolute;
  inset: 80px 0 auto 0;   /* sube la línea 24px sobre .why */
  height: 1px;
  background: linear-gradient(90deg, #0000, #c7d2fe, #0000); /* violeta-azulado suave */
  filter: blur(.2px);
}

.sucursal h2{
font-size: 40px;
color: #524f79;
}

/* ===== Footer pro con logo ===== */
.site-footer{
  background: var(--azul);
  color: #fff;
  margin-top: 32px;
}
.site-footer a{ color: #fff; text-decoration: none; }
.site-footer a:hover{ text-decoration: underline; }

.footer-grid{
  display: grid;
  grid-template-columns: 1.6fr 1fr; /* marca más ancha, links a la derecha */
  gap: 24px;
  padding: 28px 0;
  align-items: start;
}

/* Marca */
.footer-logo{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.footer-logo img{
  height: 44px;
  width: auto;
  display: block;
}
.footer-logo-text{
  font-weight: 800;
  font-size: 18px;
  white-space: nowrap;
}
.footer-contact{
  margin: 0;
  color: #e5e7eb;
  line-height: 1.5;
}

/* Links */
.footer-links h5{
  margin: 4px 0 10px;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .04em;
  opacity: .9;
}
.footer-links ul{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}
.footer-links a{
  opacity: .95;
}
.footer-links a:hover{ opacity: 1; }

/* Línea legal */
.copy{
  background: #152a6a;
  text-align: center;
  padding: 12px 0;
  font-size: 14px;
}

/* Responsive */
@media (max-width: 900px){
  .footer-grid{
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 22px 0;
  }
  .footer-logo img{ height: 40px; }
  .footer-logo-text{ font-size: 17px; }
}

/* Botón WhatsApp circular, sin background-image */
.wp-float{
  position: fixed;
  right: clamp(12px, 2vw, 22px);
  bottom: calc(16px + env(safe-area-inset-bottom));
  width: 64px; height: 64px;
  border-radius: 50%;
  background: #25D366;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 12px 28px rgba(0,0,0,.24);
  z-index: 999;
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;

  /* por si quedó alguna regla vieja de fondo */
  background-image: none !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

/* SVG centrado y nítido */
.wp-icon{
  width: 56%;
  height: auto;
  display: block;
}

/* Microajuste óptico (tocar solo si lo ves 1px corrido) */
/* .wp-icon{ transform: translateY(0.5%); } */

.wp-float:hover{ transform: translateY(-2px); box-shadow: 0 16px 34px rgba(0,0,0,.28); filter: brightness(1.03); }
.wp-float:active{ transform: translateY(0); }
.wp-float:focus-visible{ outline: none; box-shadow: 0 0 0 4px #ffffff99, 0 16px 34px rgba(0,0,0,.28); }

@media (max-width: 560px){
  .wp-float{ width: 56px; height: 56px; }
  .wp-icon{ width: 58%; }
}
@media (prefers-reduced-motion: reduce){
  .wp-float{ transition: none; }
}

/* Botón ghost del HERO con texto blanco */
.hero .btn.ghost{
  color: #fff !important;
  border-color: #fff;
}

/* Hover/focus sutil para mejor contraste */
.hero .btn.ghost:hover,
.hero .btn.ghost:focus-visible{
  background: rgba(255,255,255,.12);
  text-decoration: none;
  outline: none;
}



/* ===== HERO mobile: como desktop (texto a la izquierda + botones en línea) ===== */
@media (max-width: 600px){
  /* mantené la imagen mobile si ya la usás */
  .hero{
    background-image: url("/img/hero-img-esc.png");
    background-position: center 30%;
    min-height: calc(100svh - var(--header-h));
    display: flex;
    justify-content: flex-end;  /* container abajo */
    align-items: stretch;
  }

  /* Contenido alineado a la izquierda, no centrado */
  .hero .container{
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;     /* IZQUIERDA */
    text-align: left;            /* IZQUIERDA */
    padding: 24px 16px 28px;
    max-width: 680px;
    margin: 0 auto;
    margin-top: 250px;
  }


  /* Quitamos desplazamientos previos */
  .hero h1,
  .hero p,
  .hero .hero-cta{
    margin-left: 0 !important;
    text-align: left;
  }

  /* Botones en una sola línea */
  .hero .hero-cta{
    display: flex;
    gap: 10px;
    flex-wrap: nowrap;           /* misma línea */
  }

  /* Si el ancho es MUY chico, comprimimos botones para que no bajen */
  .hero .hero-cta .btn{
    padding: 10px 12px;          /* un poco menos ancho */
    white-space: nowrap;         /* evita quiebres internos */
  }

  /* Solo si en algún teléfono ultra angosto no entra: permitir wrap */
  @media (max-width: 360px){
    .hero .hero-cta{ flex-wrap: wrap; }
  }
}

/* Menos zoom en el hero (mobile) */
@media (max-width: 600px){
  .hero{
    /* mostrará más área de la imagen que 'cover' */
    background-size: 100% auto;      /* probá 100% ó 105% */
    background-position: center 0%; /* ajustá el encuadre vertical */
  }
}

/* ===== HERO (mobile ≤600px): colores de textos y botones ===== */
@media (max-width: 600px){

  /* Refuerzo de contraste sobre la foto (opcional, pero recomendado) */
  .hero::before{
    content:"";
    position:absolute; inset:0;
    background: linear-gradient(to top, rgba(0,0,0,.45), rgba(0,0,0,.25) 40%, transparent);
    pointer-events: none;
  }

  /* Colores de texto */
  .hero h1{
    color: #ffffff;                 /* título blanco */
  }
  .hero p{
    color: #ffffff;                 /* texto gris muy claro */
  }

  /* Botón primario */
  .hero .btn{
    background: #ffffff;            /* botón blanco */
    color: var(--azul);             /* texto en azul de marca */
    border: 2px solid #ffffff00;    /* sin borde visible */
  }
  .hero .btn:hover,
  .hero .btn:focus-visible{
    filter: none;
    background: #f8fafc;            /* leve cambio en hover */
    text-decoration: none;
    outline: none;
  }

  /* Botón ghost (WhatsApp) */
  .hero .btn.ghost{
    color: #ffffff;                 /* texto blanco */
    border: 2px solid #ffffff;      /* borde blanco */
    background: transparent;
  }
  .hero .btn.ghost:hover,
  .hero .btn.ghost:focus-visible{
    background: rgba(255,255,255,.12);
    text-decoration: none;
    outline: none;
  }
}

/* === Hero más bajo (desktop) === */
@media (min-width: 601px){
  .hero{
    min-height: 68vh !important;     /* antes: calc(100vh - var(--header-h)) */
    background-position: center 20%;
  }
  .hero .container{ padding-block: 40px; }  /* menos padding vertical */
}

/* === Hero más bajo (mobile) === */
@media (max-width: 600px){
  .hero{
    min-height: 62svh !important;     /* usa svh para barras móviles */
    background-size: 100% auto;       /* menos “zoom” si querés */
    background-position: center 25%;
  }
  .hero .container{ padding-block: 24px; }
}

/* ===== Mobile drawer: izquierda → derecha ===== */
@media (max-width: 960px){
  .menu-toggle{ display:block; margin-left:auto; z-index:1001; }

  .main-nav{
    position: fixed;
    top: var(--header-h);   /* arranca debajo del header */
    left: 0;
    bottom: 0;
    width: min(86vw, 360px);
    background: var(--azul);
    padding: 18px 16px;
    overflow-y: auto;
    transform: translateX(-105%);     /* OCULTO a la izquierda */
    transition: transform .28s ease;
    box-shadow: 0 10px 30px rgba(0,0,0,.2);
    z-index: 1001;
  }
  .main-nav.open{ transform: translateX(0); }

  /* lista vertical */
  .main-nav ul{
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  /* backdrop */
  .nav-backdrop{
    position: fixed; inset: 0;
    background: rgba(15, 23, 42, .45);
    opacity: 0; pointer-events: none;
    transition: opacity .2s ease;
    z-index: 1000;
  }
  .nav-backdrop.show{
    opacity: 1;
    pointer-events: auto;
  }
}

/* Menos animación si el usuario lo prefiere */
@media (prefers-reduced-motion: reduce){
  .main-nav{ transition: none !important; }
  .nav-backdrop{ transition: none !important; }
}

/* ===== Menú móvil: items más estéticos + separador ===== */
@media (max-width: 960px){
  /* Aseguramos lista vertical y reseteos */
  .main-nav ul{
    display: flex !important;
    flex-direction: column !important;
    margin: 0 !important;
    padding: 8px 0 !important;
    list-style: none !important;
  }

  /* El link ocupa toda la fila (sirve si hay <li> o si no los hay) */
  .main-nav ul > li > a,
  .main-nav ul > * > a,
  .main-nav ul > a{
    display: block;
    padding: 14px 12px;
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    letter-spacing: .2px;
    border-radius: 8px;
    position: relative;            /* para el separador */
  }

  /* Separador (antes de cada ítem menos el primero) */
  .main-nav ul > li > a::before,
  .main-nav ul > * > a::before,
  .main-nav ul > a::before{
    content: "";
    position: absolute;
    left: 0; right: 0; top: -1px;
    height: 1px;
    background: rgba(255,255,255,.28);   /* más visible */
  }
  .main-nav ul > li:first-child > a::before,
  .main-nav ul > *:first-child > a::before,
  .main-nav ul > a:first-child::before{
    display: none;
  }

  /* Hover / activo / foco */
  .main-nav a:hover{ background: rgba(255,255,255,.10); }
  .main-nav a.active{ background: rgba(255,255,255,.16); }
  .main-nav a:focus-visible{
    outline: none;
    box-shadow: 0 0 0 3px rgba(255,255,255,.28) inset;
    background: rgba(255,255,255,.10);
  }
}
@media (max-width: 960px){
  /* Quitar recuadro al click/foco */
  .main-nav a:focus,
  .main-nav a:focus-visible,
  .main-nav a:active{
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important; /* sin highlight al click */
  }

  /* Conservá el hover si querés feedback al pasar el dedo/mouse */
  .main-nav a:hover{
    background: rgba(255,255,255,.10);
  }

  /* Estado activo (página actual) si lo usás */
  .main-nav a.active{
    background: rgba(255,255,255,.16);
  }
}

/* ===== Hero full-screen en escritorio ===== */
@media (min-width: 961px){
  .hero{
    min-height: calc(100vh - var(--header-h)) !important;
    background-size: cover;
    background-position: center 20%; /* ajustá el encuadre si querés */
  }
  .hero .container{
    padding-block: 64px; /* aire cómodo arriba/abajo */
  }
}
/* No subrayar el link activo del header (incluye "Inicio") */
.main-nav a.active{
  text-decoration: none !important;
}

/* Contacto: colores de botones */
.contacto .btn{
  background: var(--violeta);
  color: #0a1f3f !important;          /* texto blanco */
}

.contacto .btn.ghost{
  background: transparent;
  color: var(--azul) !important;    /* texto azul */
  border: 2px solid var(--azul);
}

/* Hover/focus sutil */
.contacto .btn:hover,
.contacto .btn:focus-visible{
  filter: brightness(1.06);
  text-decoration: none;
  outline: none;
}
.contacto .btn.ghost:hover,
.contacto .btn.ghost:focus-visible{
  background: color-mix(in oklab, var(--azul) 10%, white);
  text-decoration: none;
  outline: none;
}

/* ===== HERO más alto en mobile (ocupa toda la pantalla) ===== */
@media (max-width: 600px){
  /* Prioriza dvh/svh para barras del navegador móviles */
  .hero{
    min-height: calc(100dvh - var(--header-h)) !important; /* iOS/Android modernos */
    background-size: cover;
    background-position: center 25%;
  }
  /* Fallbacks por si el navegador no soporta dvh */
  @supports not (height: 100dvh){
    .hero{ min-height: calc(100svh - var(--header-h)) !important; }
  }
  @supports not (height: 100svh){
    .hero{ min-height: calc(100vh - var(--header-h)) !important; }
  }

  /* Un poco más de aire interno si hace falta */
  .hero .container{
    padding-block: 32px;
  }
}

/* ===== Footer centrado en mobile ===== */
@media (max-width: 900px){
  .footer-grid{
    grid-template-columns: 1fr;   /* ya lo tenés, lo reforzamos */
    justify-items: center;        /* centra columnas */
    text-align: center;           /* centra textos */
    gap: 18px;
    padding: 22px 0;
  }

  .footer-logo{ justify-content: center; }  /* logo + nombre centrados */
  .footer-contact{ text-align: center; }

  .footer-links{ width: 100%; }
  .footer-links h5{ text-align: center; margin-top: 6px; }
  .footer-links ul{
    display: grid;                /* mantiene lista prolija */
    justify-items: center;        /* centra cada ítem */
    gap: 10px;
    padding: 0;
  }
  .footer-links a{
    display: inline-block;
    padding: 6px 8px;             /* mejor “tap area” sin ocupar todo el ancho */
    border-radius: 8px;
  }
}

/* ===== Estilos base para páginas internas ===== */
.page-interna .page{
  padding-top: 28px;
}
.page-interna .breadcrumbs{
  margin: 8px 0 14px;
  font-size: 14px;
  color: #64748b;
}
.page-interna h1{
  font-size: clamp(24px, 3.6vw, 34px);
  line-height: 1.15;
  margin: 10px 0 12px;
  color: rgba(13,13,83,.9);
}
.page-interna h2{
  font-size: clamp(20px, 2.6vw, 24px);
  margin: 20px 0 10px;
  color: rgba(13,13,83,.82);
}
.page-interna ul{
  padding-left: 18px;
  margin: 0 0 14px;
}

/* Panel de llamada a la acción dentro de internas */
.page-interna .cta-panel{
  border: 1px solid #e8ecf4;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

/* ===== Específico de Accidentes (ART) ===== */
.page-accidentes .cta-panel{
  border-left: 4px solid var(--azul);
}
.page-accidentes .cta-panel .btn{
  background: var(--violeta);
  color: #fff;
}
.page-accidentes .related h2{
  margin-top: 18px;
}
.page-accidentes .related ul{
  display: flex;
  gap: 10px;
  padding: 0;
  list-style: none;
}
.page-accidentes .related a{
  color: var(--azul);
  text-decoration: none;
  padding: 8px 10px;
  border: 1px solid #e8ecf4;
  border-radius: 10px;
}
.page-accidentes .related a:hover{
  background: #f8fafc;
  text-decoration: none;
}

/* ===== HERO para páginas internas ===== */
.page-hero{
  position: relative;
  display: flex;
  align-items: center;
  min-height: 44vh;                /* alto cómodo en desktop */
  background-size: cover;
  background-position: center 35%;
  background-repeat: no-repeat;
  color: #fff;
}
.page-hero::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(
    to right,
    rgba(0,0,0,.45) 0%,
    rgba(0,0,0,.30) 40%,
    rgba(0,0,0,.15) 70%,
    rgba(0,0,0,0) 100%
  );
}
.page-hero .container{
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  padding-block: 36px;
  max-width: 1100px;
}
.page-hero h1{
  margin: 0;
  font-size: clamp(26px, 4vw, 40px);
  line-height: 1.15;
  color: #fff;
}
.page-hero p{
  margin: 0;
  font-size: clamp(15px, 2vw, 18px);
  color: #e5e7eb;
  max-width: 760px;
}

/* Imagen específica de esta page */
.page-accidentes .page-hero--accidentes{
  background-image: url("/img/hero_acc_labres.webp");
}

/* Mobile: que ocupe bien la pantalla en teléfonos */
@media (max-width: 600px){
  .page-hero{
    min-height: 60svh;
    background-position: center 30%;
  }
  .page-hero::before{
    background: linear-gradient(to top, rgba(0,0,0,.45), rgba(0,0,0,.20) 50%, transparent);
  }
  .page-accidentes .page-hero--accidentes{
    background-image: url("/img/hero_acc_labres1.webp"); /* opcional: versión mobile */
  }
  .page-hero h1{
    margin-top: 160px;
    margin-bottom: 20px;
  }
}

/* ===== Todos los HERO internos a pantalla completa (desktop + mobile) ===== */
.page-hero{
  min-height: calc(100dvh - var(--header-h)) !important; /* ocupa todo menos el header fijo */
  background-size: cover;
  background-position: center 30%;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;  /* centra verticalmente el contenido */
}

@supports not (height: 100dvh){
  .page-hero{ min-height: calc(100svh - var(--header-h)) !important; }
}
@supports not (height: 100svh){
  .page-hero{ min-height: calc(100vh - var(--header-h)) !important; }
}

/* Contenido del hero (todas las pages) */
.page-hero .container{
  position: relative;
  z-index: 1;
  padding-block: 48px;   /* ajustá aire si querés */
}

/* (opcional) en mobile podés reencuadrar un poco */
@media (max-width: 600px){
  .page-hero{ background-position: center 35%; }
}

/* Espaciado del contenido posterior (breadcrumbs, etc.) */
.page .breadcrumbs{ scroll-margin-top: var(--header-h); }

/* ===== Pages: menos zoom en el HERO (solo escritorio) ===== */
@media (min-width: 961px){
  .page-hero{
    /* mostrará más área que 'cover' */
    background-size: 100% auto;   /* probá 95% o 105% según tu imagen */
    background-position: center 30%;
  }
}

/* ===== Page-hero: contenido a la DERECHA en escritorio ===== */
@media (min-width: 961px){
  .page-hero .container{
    margin-left: auto;        /* empuja el container hacia la derecha */
    max-width: 1100px;        /* tu ancho de lectura */
    display: flex;
    flex-direction: column;
    align-items: flex-end;    /* alinea h1/p a la derecha */
    text-align: right;        /* texto alineado a la derecha */
    gap: 10px;
    margin-left: 400px;
  }
}

/* ===== ¿Cómo trabajamos? → tarjetas con icono ===== */
.work-list{
  list-style: none;
  margin: 12px 0 24px;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 960px){ .work-list{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .work-list{ grid-template-columns: 1fr; } }

.work-card{
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas:
    "icon title"
    "icon text";
  column-gap: 12px;
  row-gap: 6px;

  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  padding: 18px 16px 20px;
  box-shadow: 0 8px 22px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.work-card:hover,
.work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,.1);
  border-color: #dbe3f2;
}

.work-icon{
  grid-area: icon;
  align-self: start;
  width: 48px; height: 48px;
  border-radius: 999px;
  display: grid; place-items: center;
  color: #fff; /* color del trazo del SVG */
  /* gradiente de marca */
  background: linear-gradient(135deg, var(--azul), var(--violeta));
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
.work-icon svg{ width: 26px; height: 26px; display: block; }

.work-body h3{
  grid-area: title;
  margin: 0;
  font-size: 18px;
  color: rgba(13,13,83,.9);
  font-weight: 800;
  line-height: 1.25;
}
.work-body p{
  grid-area: text;
  margin: 0;
  color: #475569;
  line-height: 1.45;
}

/* Paletas distintas por tarjeta (opcional) */
.work-card:nth-child(1) .work-icon{
  background: linear-gradient(135deg, #1e3a8a, #6a0dad);
}
.work-card:nth-child(2) .work-icon{
  background: linear-gradient(135deg, #2563eb, #22d3ee);
}
.work-card:nth-child(3) .work-icon{
  background: linear-gradient(135deg, #9333ea, #f43f5e);
}

/* ===== ¿Cómo trabajamos? (Accidentes): más altas + fondo oscuro ===== */
.page-accidentes .work-card{
  min-height: 180px;                    /* más altas en desktop */
  padding: 22px 18px 24px;              /* un poco más de aire */
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}

.page-accidentes .work-card:hover,
.page-accidentes .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}

/* Colores de texto sobre fondo oscuro */
.page-accidentes .work-body h3{
  color: #ffffff;
}
.page-accidentes .work-body p{
  color: #cbd5e1;   /* gris claro legible */
}

/* Ícono: resaltado sobre el fondo oscuro */
.page-accidentes .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}

/* Responsive: un poco menos altas en móvil */
@media (max-width: 560px){
  .page-accidentes .work-card{ min-height: 150px; }
}

/* H2 "¿Cómo trabajamos?" centrado y más grande (solo en Accidentes) */
.page-accidentes .page > h2:first-of-type{
  text-align: center;
  font-size: 40px; /* ajustá a gusto */
  line-height: 1.2;
  margin: 22px 0 16px;                 /* top/bottom */
  color: rgba(13,13,83,.9);
  margin-bottom: 50px;
}

/* ===== CTA dividida (tarjeta + imagen) ===== */
.cta-split{
  margin: 26px 0 18px;
  margin-top: 150px;
}
.cta-split__grid{
  display: grid;
  gap: 16px;
}

/* Mobile: apilado (tarjeta arriba, imagen abajo) */
.cta-card{
  background: #fff;
  border: 1px solid #e8ecf4;
  border-radius: 16px;
  padding: 22px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}
.cta-card h3{
  margin: 0 0 6px;
  font-size: 20px;
  color: rgba(13,13,83,.95);
  font-weight: 800;
}
.cta-card p{
  margin: 0 0 12px;
  color: #475569;
}
.cta-card .btn{
  background: var(--violeta);
  color: #fff;
}

/* Imagen responsiva */
.cta-media{
  margin: 0;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
  border: 1px solid #e8ecf4;
}
.cta-media img{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 3 / 2; /* buena relación en mobile */
}

/* Desktop: dos columnas 48/52 (tarjeta izquierda, imagen derecha) */
@media (min-width: 961px){
  .cta-split__grid{
    grid-template-columns: 1fr 1.1fr;
    align-items: stretch;
    gap: 18px;
  }
  .cta-card{
    padding: 26px;
    display: grid;
    align-content: start;
    gap: 10px;
    border-left: 4px solid var(--azul); /* acento de marca */
  }
  .cta-media img{
    aspect-ratio: 16 / 10; /* más panorámica en desktop */
  }
}

/* (Opcional) versión oscura solo para la page de Accidentes */
.page-accidentes .cta-card{
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}
.page-accidentes .cta-card h3{ color:#fff; }
.page-accidentes .cta-card p{ color:#cbd5e1; }
.page-accidentes .cta-card .btn{ background: var(--violeta); color:#fff; }



/* Botón de la CTA con texto oscuro */
.cta-card .btn{
  margin-top: 30px;  
  color: #0f172a !important;           /* texto oscuro */
}

/* Botón de la CTA más corto en los laterales */
.cta-card .btn{
  display: inline-block;
  padding: 10px 10px;   /* ← antes era 10px 14/16px: bajá el segundo valor */
  inline-size: fit-content; /* evita que se estire */
}

/* Si lo querés aún más finito */
.cta-card .btn.btn-compact{
  padding: 8px 8px;     /* ultra corto a los lados */
  font-size: 14px;
}


/* CTA: centrar y agrandar un poco los elementos */
.cta-split .cta-card{
  text-align: center;
  display: grid;
  place-items: center;   /* centra contenido dentro de la tarjeta */
  gap: 10px;
}

.cta-split .cta-card h3{
  font-size: 30px;  /* más grande */
  line-height: 1.2;
  margin: 0;
  margin-top: 50px;
}

.cta-split .cta-card p{
  font-size: clamp(15px, 2.4vw, 17px);/* un toque más grande */
  line-height: 1.5;
  margin: 0 0 6px;
  margin-top: 20px;
}

/* botón centrado y con leve mejora de presencia */
.cta-split .cta-card .btn{
  margin: 0 auto;                /* centra el botón */
  display: inline-block;
  padding: 10px 10px;            /* corto a los costados, como pediste */
  font-size: 15px;               /* un poco más grande */
  border-radius: 10px;
  margin-top: 20px;
}

/* Separador al final de la lista "¿Cómo trabajamos?" */
.work-list{
  position: relative;
  margin-bottom: 48px;   /* aire antes de la línea */
  padding-bottom: 80px;  /* evita que tape contenido */
}

.work-list::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height: 2px; /* antes 1px */
  background: linear-gradient(90deg, #0000, #333b7c, #0000); /* más contraste */
  filter: none; /* quita el blur que la suavizaba */
  opacity: .9;  /* más visible */
}

@media (max-width: 600px){
  .related ul{
    flex-direction: column;       /* uno debajo del otro */
    align-items: stretch;
    gap: 10px;
  }
  .related a{
    display: block;
    white-space: nowrap;          /* no partir en varias líneas */
    overflow: hidden;             /* ocultar si no entra */
    text-overflow: ellipsis;      /* … si se recorta */
    font-size: 15px;              /* opcional: un toque más chico */
    padding: 10px 12px;           /* “pill” prolijo */
  }
}

/* ===== Fix header solo en Accidentes: centrar menú a la misma altura del logo ===== */
.page-accidentes .nav-wrap{
  height: var(--header-h);              /* usa la misma altura global */
  display: flex;
  align-items: center;                   /* centra verticalmente todo */
}

/* Asegura el centrado de los links del menú */
.page-accidentes .main-nav > ul{
  display: flex;
  align-items: center;                   /* centra el grupo */
  margin: 0; padding: 0;
}
.page-accidentes .main-nav > ul > li > a{
  display: flex;
  align-items: center;                   /* centra cada link */
  height: calc(var(--header-h) - 0px);   /* alto igual al header */
  line-height: 1;                        /* evita desajustes de baseline */
  padding-block: 0;                      /* sin padding vertical extra */
}

/* Logo: misma regla que el index para evitar desfasajes visuales */
.page-accidentes .logo{
  display: flex; align-items: center;
}
.page-accidentes .logo img{
  height: calc(var(--header-h) - 32px);  /* igual que en index */
  width: auto; vertical-align: middle;
}
.page-accidentes .logo-text{
  line-height: 1;                        /* evita “estirar” el header */
}

/* (Opcional) si ves el menú 1–2px bajo/alto, aplicá microajuste: */
@media (min-width: 961px){
  .page-accidentes .main-nav > ul > li > a{ transform: translateY(-1px); } /* ajustá a -1/0/1 */
}

/* ===== Específico de Tránsito (misma estética que ART) ===== */

/* Fix header: centrar menú a la misma altura del logo */
.page-transito .nav-wrap{
  height: var(--header-h);
  display: flex;
  align-items: center;
}
.page-transito .main-nav > ul{
  display: flex;
  align-items: center;
  margin: 0; padding: 0;
}
.page-transito .main-nav > ul > li > a{
  display: flex;
  align-items: center;
  height: calc(var(--header-h));
  line-height: 1;
  padding-block: 0;
}
.page-transito .logo{ display:flex; align-items:center; }
.page-transito .logo img{
  height: calc(var(--header-h) - 32px);
  width: auto; vertical-align: middle;
}
.page-transito .logo-text{ line-height: 1; }
@media (min-width: 961px){
  .page-transito .main-nav > ul > li > a{ transform: translateY(-1px); }
}

/* HERO de Tránsito (full screen, misma lógica que ART) */
.page-transito .page-hero--transito{
  background-image: url("/img/hero_acc_labres.webp");
  /* si querés menos “zoom” en desktop como en ART: */
  background-size: 100% auto;
  background-position: center 30%;
 
}
@media (max-width: 600px){
  .page-transito .page-hero--transito{
    background-image: url("/img/hero_acc_labres1.webp"); /* versión mobile opcional */
    background-position: center 30%;
  }
}

/* ¿Cómo trabajamos? — mismas tarjetas oscuras que ART */
.page-transito .work-card{
  min-height: 180px;
  padding: 22px 18px 24px;
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}
.page-transito .work-card:hover,
.page-transito .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}
.page-transito .work-body h3{ color:#fff; }
.page-transito .work-body p{ color:#cbd5e1; }
.page-transito .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}
@media (max-width: 560px){
  .page-transito .work-card{ min-height: 150px; }
}

/* CTA dividida — misma variante oscura que ART */
.page-transito .cta-card{
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}
.page-transito .cta-card h3{ color:#fff; }
.page-transito .cta-card p{ color:#cbd5e1; }
.page-transito .cta-card .btn{
  background: var(--violeta);
  color:#fff;
}

/* H2 “¿Cómo trabajamos?” centrado y grande (igual que ART) */
.page-transito .page > h2:first-of-type{
  text-align: center;
  font-size: 40px;
  line-height: 1.2;
  margin: 22px 0 16px;
  color: rgba(13,13,83,.9);
  margin-bottom: 50px;
}

@media (min-width: 961px){
  .page-transito .page-hero .container{
    /* anula el empuje duro que tenés en otras pages */
    margin-left: auto;        /* pega el bloque hacia la derecha */
    margin-right: 48px;       /* aire respecto del borde derecho */
    max-width: 780px;         /* achica el ancho de lectura */
    padding-inline: 16px;     /* un poco de aire interno */
  }
}

/* ==== FIX: menú móvil en pages = igual que index (compacto + una línea) ==== */

/* Limitar a ESCRITORIO las reglas altas de los links en pages */
@media (min-width: 961px){
  .page-accidentes .main-nav > ul > li > a,
  .page-transito   .main-nav > ul > li > a{
    height: calc(var(--header-h));
    padding-block: 0;
    display: flex;
    align-items: center;
  }
}

/* MÓVIL: forzar el mismo estilo del index en TODAS las pages */
@media (max-width: 960px){
  /* lista vertical sin centrado ni gaps extra */
  .page-interna .main-nav > ul,
  .page-accidentes .main-nav > ul,
  .page-transito .main-nav > ul{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* cada link: compacto, a la izquierda, ancho completo */
  .page-interna .main-nav > ul > li > a,
  .page-accidentes .main-nav > ul > li > a,
  .page-transito .main-nav > ul > li > a{
    display: block !important;
    width: 100% !important;
    text-align: left !important;
    height: auto !important;            /* anula height grande de desktop */
    padding: 10px 8px !important;       /* separación mínima */
    line-height: 1.2 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    text-decoration: none !important;
    position: relative;
    box-sizing: border-box;
  }

  /* quitar pseudolíneas previas para evitar doble separador */
  .page-interna .main-nav > ul > li > a::before,
  .page-accidentes .main-nav > ul > li > a::before,
  .page-transito .main-nav > ul > li > a::before{
    content: none !important;
  }

  /* UNA sola línea entre opciones (como en index) */
  .page-interna .main-nav > ul > li > a,
  .page-accidentes .main-nav > ul > li > a,
  .page-transito .main-nav > ul > li > a{
    border-top: 1px solid rgba(255,255,255,.28) !important;
  }
  .page-interna .main-nav > ul > li:first-child > a,
  .page-accidentes .main-nav > ul > li:first-child > a,
  .page-transito .main-nav > ul > li:first-child > a{
    border-top: none !important;
  }

  /* estados sin modificar la altura */
  .page-interna .main-nav a:hover,
  .page-accidentes .main-nav a:hover,
  .page-transito .main-nav a:hover{
    background: rgba(255,255,255,.06) !important;
  }
  .page-interna .main-nav a.active,
  .page-accidentes .main-nav a.active,
  .page-transito .main-nav a.active{
    background: rgba(255,255,255,.10) !important;
  }
  .page-interna .main-nav a:focus,
  .page-accidentes .main-nav a:focus,
  .page-transito .main-nav a:focus{
    outline: none !important;
    box-shadow: none !important;
  }
}


@media (max-width:600px){.page-transito .page-hero--transito{background-size:cover!important;min-height:calc(100dvh - var(--header-h))!important}}

/* Page-hero: subir 1px */
.page-hero h1 { font-size: clamp(27px, 4.1vw, 41px) !important;  }
.page-hero p  { font-size: clamp(16px, 2.1vw, 19px) !important; }


@media (max-width:600px){
  .page-hero h1{ margin-top: 250px !important; } /* antes tenías ~160px */
}

/* ===== Pólizas: mismas tarjetas oscuras que ART / Tránsito ===== */
.page-polizas .work-card{
  min-height: 180px;
  padding: 22px 18px 24px;
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}
.page-polizas .work-card:hover,
.page-polizas .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}
.page-polizas .work-body h3{ color:#fff; }
.page-polizas .work-body p{ color:#cbd5e1; }
.page-polizas .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}
@media (max-width: 560px){
  .page-polizas .work-card{ min-height: 150px; }
}

/* (Opcional) título centrado como en las otras internas */
.page-polizas .page > h2:first-of-type{
  text-align: center;
  font-size: 40px;
  line-height: 1.2;
  margin: 22px 0 16px;
  color: rgba(13,13,83,.9);
  margin-bottom: 50px;
}

/* ===== Específico de Pólizas (misma estética que ART/Tránsito) ===== */

/* Fix header: centrar menú a la misma altura del logo (ESCRITORIO) */
.page-polizas .nav-wrap{
  height: var(--header-h);
  display: flex;
  align-items: center;
}
.page-polizas .main-nav > ul{
  display: flex;
  align-items: center;
  margin: 0; padding: 0;
}
.page-polizas .main-nav > ul > li > a{
  display: flex;
  align-items: center;
  height: var(--header-h);
  line-height: 1;
  padding-block: 0;
  transform: translateY(-1px); /* microajuste como en otras pages */
}
.page-polizas .logo{ display:flex; align-items:center; }
.page-polizas .logo img{
  height: calc(var(--header-h) - 32px);
  width: auto; vertical-align: middle;
}
.page-polizas .logo-text{ line-height: 1; }

/* MÓVIL: forzar el mismo estilo del index (drawer compacto) */
@media (max-width: 960px){
  .page-polizas .main-nav{
    top: var(--header-h);
    left: 0; bottom: 0;
    width: min(86vw, 360px);
    transform: translateX(-105%);
    padding: 16px;
  }
  .page-polizas .main-nav.open{ transform: translateX(0); }

  .page-polizas .main-nav ul{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 8px 0 !important;
    list-style: none !important;
  }
  .page-polizas .main-nav ul > li > a{
    display: block !important;
    padding: 14px 12px !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
    height: auto !important;
    border-radius: 0 !important;
    position: relative !important;
  }
  .page-polizas .main-nav ul > li > a::before{
    content:"";
    position:absolute; left:0; right:0; top:0;
    height: 1px; background: rgba(255,255,255,.22);
  }
  .page-polizas .main-nav ul > li:first-child > a::before{ display:none; }
  .page-polizas .main-nav a:hover{ background: rgba(255,255,255,.08); }
  .page-polizas .main-nav a.active{ background: rgba(255,255,255,.12); }
  .page-polizas .main-nav a:focus,
  .page-polizas .main-nav a:active,
  .page-polizas .main-nav a:focus-visible{
    outline: none !important; box-shadow: none !important; background: transparent;
  }
}

/* HERO de Pólizas (full screen, misma lógica que ART) */
.page-polizas .page-hero--polizas{
  /* Si ya tenés imágenes específicas, actualizá las rutas abajo */
  background-image: url("/img/hero_acc_labres.webp");
  background-size: 100% auto;   /* menos “zoom” en desktop como hiciste en otras */
  background-position: center 30%;
}
@media (max-width: 600px){
  .page-polizas .page-hero--polizas{
    background-image: url("/img/hero_acc_labres1.webp"); /* versión mobile opcional */
    background-position: center 30%;
  }
}

/* “Casos frecuentes” — mismas tarjetas oscuras que en ART */
.page-polizas .work-card{
  min-height: 180px;
  padding: 22px 18px 24px;
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}
.page-polizas .work-card:hover,
.page-polizas .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}
.page-polizas .work-body h3{ color:#fff; }
.page-polizas .work-body p{ color:#cbd5e1; }
.page-polizas .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}
@media (max-width: 560px){
  .page-polizas .work-card{ min-height: 150px; }
}

/* CTA dividida — variante oscura como en las otras pages */
.page-polizas .cta-card{
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}
.page-polizas .cta-card h3{ color:#fff; }
.page-polizas .cta-card p{ color:#cbd5e1; }
.page-polizas .cta-card .btn{ background: var(--violeta); color:#fff; }

/* H2 inicial (igual que en otras pages internas) */
.page-polizas .page > h2:first-of-type{
  text-align: center;
  font-size: 40px;
  line-height: 1.2;
  margin: 22px 0 16px;
  color: rgba(13,13,83,.9);
  margin-bottom: 50px;
}

/* (Opcional) Ajuste mobile para bajar un poco el H1 del hero en pages */
@media (max-width: 600px){
  .page-polizas .page-hero h1{ margin-top: 12px; }
}

@media (min-width: 961px){
  .page-polizas .page-hero .container{
    max-width: 820px;      /* ancho de lectura */
    margin-left: auto;     /* empuja el bloque a la derecha */
    margin-right: 48px;    /* separacion del borde derecho */
    padding-inline: 16px;  /* aire interno lateral */
    display: flex;
    flex-direction: column;
    align-items: flex-end; /* alinea h1/p a la derecha */
    text-align: right;
  }
}
/* Pólizas: hero full screen en mobile */
@media (max-width: 600px){
  .page-polizas .page-hero{
    min-height: calc(100dvh - var(--header-h)) !important;
    background-size: cover;
    background-position: center 30%;
    display: flex;
    align-items: center;
  }
  @supports not (height: 100dvh){
    .page-polizas .page-hero{
      min-height: calc(100svh - var(--header-h)) !important;
    }
  }
  @supports not (height: 100svh){
    .page-polizas .page-hero{
      min-height: calc(100vh - var(--header-h)) !important;
    }
  }
}

/* ===== HERO de Sucesiones (full screen, misma lógica que ART/Pólizas) ===== */
.page-sucesiones .page-hero--sucesiones{
  /* Cambiá las rutas por las que uses realmente */
  background-image: url("/img/hero_acc_labres.webp");
  background-size: 100% auto;     /* menos “zoom” en desktop, como en otras */
  background-position: center 30%;
  background-repeat: no-repeat;
}
@media (max-width: 600px){
  .page-sucesiones .page-hero--sucesiones{
    background-image: url("/img/hero_acc_labres1.webp");
    background-position: center 30%;
  }
}

/* Sucesiones: hero full screen en mobile */
@media (max-width: 600px){
  .page-sucesiones .page-hero{
    min-height: calc(100dvh - var(--header-h)) !important;
    background-size: cover;
    background-position: center 30%;
    display: flex;
    align-items: center;
  }
  @supports not (height: 100dvh){
    .page-sucesiones .page-hero{
      min-height: calc(100svh - var(--header-h)) !important;
    }
  }
  @supports not (height: 100svh){
    .page-sucesiones .page-hero{
      min-height: calc(100vh - var(--header-h)) !important;
    }
  }
  /* micro-bajada del H1 si querés */
  .page-sucesiones .page-hero h1{ margin-top: 12px; }
}

/* ===== “Qué ofrecemos” con estética oscura (como Pólizas/ART) ===== */
.page-sucesiones .work-card{
  min-height: 180px;
  padding: 22px 18px 24px;
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}
.page-sucesiones .work-card:hover,
.page-sucesiones .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}
.page-sucesiones .work-body h3{ color:#fff; }
.page-sucesiones .work-body p{ color:#cbd5e1; }
.page-sucesiones .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}
@media (max-width: 560px){
  .page-sucesiones .work-card{ min-height: 150px; }
}

/* ===== CTA dividida — variante oscura ===== */
.page-sucesiones .cta-card{
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}
.page-sucesiones .cta-card h3{ color:#fff; }
.page-sucesiones .cta-card p{ color:#cbd5e1; }
.page-sucesiones .cta-card .btn{
  background: var(--violeta);
  color:#fff;
}

/* H2 inicial (misma tipografía/espaciado que en otras internas) */
.page-sucesiones .page > h2:first-of-type{
  text-align: center;
  font-size: 40px;
  line-height: 1.2;
  margin: 22px 0 16px;
  color: rgba(13,13,83,.9);
  margin-bottom: 50px;
}

/* ===== Desktop: ancho y alineación del contenido del HERO ===== */
@media (min-width: 961px){
  .page-sucesiones .page-hero .container{
    max-width: 820px;      /* ancho de lectura, igual criterio que Pólizas */
    margin-left: auto;     /* empuja el bloque a la derecha */
    margin-right: 48px;    /* separación del borde derecho */
    padding-inline: 16px;  /* aire interno lateral */
    display: flex;
    flex-direction: column;
    align-items: flex-end; /* h1/p a la derecha */
    text-align: right;
  }
}

/* ===== Header Sucesiones: menú centrado en escritorio (igual que index/otras) ===== */
.page-sucesiones .nav-wrap{
  height: var(--header-h);
  display: flex;
  align-items: center;
}
.page-sucesiones .main-nav > ul{
  display: flex;
  align-items: center;
  margin: 0; padding: 0;
}
.page-sucesiones .main-nav > ul > li > a{
  display: flex;
  align-items: center;
  height: calc(var(--header-h));
  line-height: 1;
  padding-block: 0;
  transform: translateY(-1px);
}
.page-sucesiones .logo{ display:flex; align-items:center; }
.page-sucesiones .logo img{
  height: calc(var(--header-h) - 32px);
  width: auto; vertical-align: middle;
}
.page-sucesiones .logo-text{ line-height: 1; }

/* ===========================
   JUBILACIONES Y PENSIONES
   =========================== */

/* HERO (desktop) */
.page-jubilaciones .page-hero--jubilaciones{
  /* Si tenés un arte propio, cambialo acá */
  background-image: url("/img/hero_acc_labres.webp");
  background-size: 100% auto;   /* menos “zoom” en desktop */
  background-repeat: no-repeat;
  background-position: center 30%;
  color: #fff;
}

/* Alineación y ancho de lectura del bloque de textos (desktop) */
@media (min-width: 961px){
  .page-jubilaciones .page-hero .container{
    max-width: 820px;
    margin-left: auto;     /* empuja a la derecha */
    margin-right: 48px;    /* separación del borde derecho */
    padding-inline: 16px;
    display: flex;
    flex-direction: column;
    align-items: flex-end; /* h1/p a la derecha */
    text-align: right;
  }
}

/* HERO (mobile full screen + imagen mobile) */
@media (max-width: 600px){
  .page-jubilaciones .page-hero--jubilaciones{
    background-image: url("/img/hero_acc_labres1.webp"); /* versión mobile opcional */
    background-size: cover;
    background-position: center 30%;
    display: flex;
    align-items: center; /* centra verticalmente el bloque de textos */
    min-height: calc(100dvh - var(--header-h)) !important;
  }
  @supports not (height: 100dvh){
    .page-jubilaciones .page-hero--jubilaciones{ min-height: calc(100svh - var(--header-h)) !important; }
  }
  @supports not (height: 100svh){
    .page-jubilaciones .page-hero--jubilaciones{ min-height: calc(100vh - var(--header-h)) !important; }
  }
}

/* Tipos del hero (suaves + 1/2px extra en mobile, como pediste antes) */
.page-jubilaciones .page-hero h1{
  text-shadow: 0 2px 16px rgba(0,0,0,.35);
}
.page-jubilaciones .page-hero p{
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}
@media (max-width: 600px){
  .page-jubilaciones .page-hero h1{ font-size: clamp(28px, 6.4vw, 34px); margin-top: 12px; }
  .page-jubilaciones .page-hero p{ font-size: clamp(16px, 4.3vw, 18px); }
}

/* H2 inicial centrado (igual que en otras internas) */
.page-jubilaciones .page > h2:first-of-type{
  text-align: center;
  font-size: 40px;
  line-height: 1.2;
  margin: 22px 0 50px;
  color: rgba(13,13,83,.9);
}

/* Tarjetas “Qué resolvemos” — misma estética oscura que en ART/Pólizas */
.page-jubilaciones .work-card{
  min-height: 180px;
  padding: 22px 18px 24px;
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.page-jubilaciones .work-card:hover,
.page-jubilaciones .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}
.page-jubilaciones .work-body h3{ color:#fff; }
.page-jubilaciones .work-body p{ color:#cbd5e1; }
.page-jubilaciones .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}
@media (max-width: 560px){
  .page-jubilaciones .work-card{ min-height: 150px; }
}

/* CTA dividida — variante oscura y botón violeta */
.page-jubilaciones .cta-card{
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}
.page-jubilaciones .cta-card h3{ color:#fff; }
.page-jubilaciones .cta-card p{ color:#cbd5e1; }
.page-jubilaciones .cta-card .btn{ background: var(--violeta); color:#fff; }

/* ===========================
   MENÚ CENTRADO (ESCRITORIO)
   como en el index
   =========================== */
@media (min-width: 961px){
  .site-header .nav-wrap{
    display: flex;
    align-items: center;
    gap: 16px;
  }
  .site-header .logo{ flex: 0 0 auto; }
  .site-header .main-nav{ flex: 1 1 auto; }
  .site-header .main-nav ul{
    display: flex;
    justify-content: center;  /* centra items del menú */
    align-items: center;
    gap: 20px;
  }
  /* Si existe un botón CTA a la derecha, quedará equilibrado */
  .site-header .btn-cta{ flex: 0 0 auto; }
}

/* =========================
   EJECUCIONES HIPOTECARIAS
   ========================= */

/* HERO (desktop: menos zoom; mismos colores/overlay que el resto) */
.page-ejecuciones .page-hero--ejecuciones{
  /* Actualizá estas rutas si tenés imágenes específicas */
  background-image: url("/img/hero_acc_labres.webp");
  background-size: 100% auto;         /* menos “zoom” en desktop */
  background-position: center 30%;
  color: #fff;
}

/* Full screen en mobile (+ leve ajuste tipográfico y margen del H1) */
@media (max-width: 600px){
  .page-ejecuciones .page-hero--ejecuciones{
    background-image: url("/img/hero_acc_labres1.webp"); /* versión mobile opcional */
    background-size: cover;
    background-position: center 30%;
    min-height: calc(100dvh - var(--header-h)) !important;
    display: flex;
    align-items: center;
  }
  @supports not (height: 100dvh){
    .page-ejecuciones .page-hero--ejecuciones{
      min-height: calc(100svh - var(--header-h)) !important;
    }
  }
  @supports not (height: 100svh){
    .page-ejecuciones .page-hero--ejecuciones{
      min-height: calc(100vh - var(--header-h)) !important;
    }
  }

  .page-ejecuciones .page-hero--ejecuciones h1{
    margin-top: 12px;            /* baja un poco el bloque de texto */
    /* +1/2px respecto a base mobile */
    font-size: clamp(26px, 6vw, 34px);
    line-height: 1.15;
  }
  .page-ejecuciones .page-hero--ejecuciones p{
    font-size: 17px;             /* +1/2px */
    line-height: 1.5;
  }
}

/* Opcional (desktop): alinear contenido del hero a la derecha como en otras */
@media (min-width: 961px){
  .page-ejecuciones .page-hero--ejecuciones .container{
    max-width: 820px;      
    margin-left: auto;    
    margin-right: 48px;   
    padding-inline: 16px; 
    display: flex;
    flex-direction: column;
    align-items: flex-end; 
    text-align: right;
  }
}

/* H2 inicial (igual que otras internas) */
.page-ejecuciones .page > h2:first-of-type{
  text-align: center;
  font-size: 40px;
  line-height: 1.2;
  margin: 22px 0 16px;
  color: rgba(13,13,83,.9);
  margin-bottom: 50px;
}

/* Tarjetas “Cómo trabajamos” — mismas tarjetas oscuras */
.page-ejecuciones .work-card{
  min-height: 180px;
  padding: 22px 18px 24px;
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.page-ejecuciones .work-card:hover,
.page-ejecuciones .work-card:focus-within{
  transform: translateY(-3px);
  box-shadow: 0 16px 38px rgba(0,0,0,.32);
  border-color: rgba(255,255,255,.12);
}
.page-ejecuciones .work-body h3{ color:#fff; }
.page-ejecuciones .work-body p{ color:#cbd5e1; }
.page-ejecuciones .work-icon{
  box-shadow: 0 6px 16px rgba(0,0,0,.35), 0 0 0 2px rgba(255,255,255,.08) inset;
}
@media (max-width: 560px){
  .page-ejecuciones .work-card{ min-height: 150px; }
}

/* CTA dividida — variante oscura y botón violeta como referencia */
.page-ejecuciones .cta-card{
  background: linear-gradient(180deg, #0f1d4a, #0b1433);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}
.page-ejecuciones .cta-card h3{ color:#fff; }
.page-ejecuciones .cta-card p{ color:#cbd5e1; }
.page-ejecuciones .cta-card .btn{ background: var(--violeta); color:#fff; }

/* ====== Menú centrado en desktop (igual al index) ====== */
@media (min-width: 961px){
  .site-header .nav-wrap{
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 16px;
  }
  .site-header .main-nav{
    justify-self: center;
  }
  .site-header .main-nav ul{
    display: flex;
    gap: 18px;
    justify-content: center;   /* centra opciones */
    align-items: center;
  }
}

/* === Línea decorativa dorada al final del HERO (todas las pages) === */
:root{
  /* Podés ajustar estos tonos si querés otro dorado */
  --gold-1: #d4af37; /* dorado base */
  --gold-2: #f0d68a; /* highlight */
  --gold-3: #b68c23; /* sombra */
}

.page-hero{
  position: relative; /* necesario para posicionar la línea */
  overflow: hidden;   /* evita solapes raros con la línea */
}

.page-hero::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 6px;                  /* grosor de la línea */
  pointer-events: none;
  z-index: 1;

  /* Efecto “metálico” suave */
  background:
    linear-gradient(90deg,
      var(--gold-3) 0%,
      var(--gold-1) 20%,
      var(--gold-2) 50%,
      var(--gold-1) 80%,
      var(--gold-3) 100%
    );
  box-shadow:
    0 0 0 1px rgba(0,0,0,.08) inset,  /* define borde interno sutil */
    0 2px 6px rgba(0,0,0,.15);         /* leve sombra hacia abajo */
}

/* Opcional: un poco más de presencia en desktop */
@media (min-width: 961px){
  .page-hero::after{
    height: 8px;
  }
}

/* Línea decorativa dorada al final del HERO (todas las páginas + index) */
:root{
  --gold-1: #d4af37;
  --gold-2: #f0d68a;
  --gold-3: #b68c23;
}

/* Aseguramos el posicionamiento en cualquier hero */
.page-hero,
.hero{
  position: relative;
  overflow: hidden;
}

/* La línea dorada */
.page-hero::after,
.hero::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 6px;
  pointer-events: none;
  z-index: 1;
  background: linear-gradient(90deg,
    var(--gold-3) 0%,
    var(--gold-1) 20%,
    var(--gold-2) 50%,
    var(--gold-1) 80%,
    var(--gold-3) 100%
  );
  box-shadow:
    0 0 0 1px rgba(0,0,0,.08) inset,
    0 2px 6px rgba(0,0,0,.15);
}

@media (min-width: 961px){
  .page-hero::after,
  .hero::after{ height: 8px; }
}

/* ====== Header: alineación SOLO escritorio (no toca el toggle) ====== */
@media (min-width: 961px){
  .site-header .nav-wrap{
    display: flex;          /* si ya era flex, lo reafirma */
    align-items: center;    /* centra verticalmente logo + menú */
    gap: 16px;
  }

  /* Logo alineado */
  .site-header .logo{
    display: inline-flex;
    align-items: center;
    gap: 10px;
  }

  /* Menú en línea y centrado con el logo */
  .site-header .main-nav ul{
    display: flex;          /* no cambiamos display del <nav>, solo la lista */
    align-items: center;
    gap: 22px;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .site-header .main-nav a{
    display: inline-flex;
    align-items: center;    /* centra el texto del link */
    line-height: 1.1;       /* evita que “baje” el texto */
    padding: 0;             /* evita empujes verticales raros */
  }

  /* Por si algún estilo heredado sube la altura del header */
  .site-header a{
    line-height: 1.1 !important;
  }
}

.hero{
  position: relative;
  min-height: calc(100vh - var(--header-h));
  display: flex;
  align-items: center;

  /* imagen de fondo */
  background-image: url("/img/hero-estudiojurid.webp");
  background-size: 100% auto;   /* probá 110–140% */
    background-position: center 65%;
    background-repeat: no-repeat;
}

@media (max-width: 600px){
  .hero{
    /* imagen mobile */
    background-image: url("/img/hero-responsive.webp");
    background-size: cover;              /* ocupa toda la pantalla */
    background-repeat: no-repeat;
    background-position: center 30%;
    min-height: calc(100dvh - var(--header-h)); /* resta header fijo */

    /* layout: contenido abajo */
    display: flex;
    align-items: flex-end;
    justify-content: center;

    /* opcional, evita scroll raro por sombras/márgenes internos */
    overflow: hidden;
  }

  /* un poco de aire al contenido dentro del hero */
  .hero .container{
    width: 100%;
    padding: 20px 16px 28px;
  }

  /* fallbacks si 100dvh no está disponible */
  @supports not (height: 100dvh){
    .hero{ min-height: calc(100svh - var(--header-h)); }
  }
  @supports not (height: 100svh){
    .hero{ min-height: calc(100vh - var(--header-h)); }
  }
}
@media (max-width: 600px){
  /* solo el <button> con clase .btn, no el <a> */
  .contact-actions button.btn{
    border: 1.5px solid #000;
  }

  /* accesibilidad/foco visible */
  .contact-actions button.btn:focus-visible{
    outline: 2px solid #000;
    outline-offset: 2px;
  }
}

/* Franja “Creado por” al final del footer */
.site-footer .made-by{
  margin-top: 12px;
  padding: 14px 0 18px;
  border-top: 1px solid rgba(255,255,255,.12);
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  color: #cbd5e1;
  font-size: 14px;
}

.site-footer .made-by a{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}

.site-footer .made-by img{
  height: 50px;
  width: auto;
  filter: brightness(1) contrast(1.05);
  transition: transform .2s ease, filter .2s ease;
}

.site-footer .made-by a:hover img,
.site-footer .made-by a:focus-visible img{
  transform: translateY(-1px);
  filter: brightness(1.1);
}

/* Detalle dorado sutil junto al texto */


@media (max-width: 600px){
  .site-footer .made-by{ font-size: 13px; }
  .site-footer .made-by img{ height: 50px; }
}
