/* ==== Base / Reseteos ==== */
@font-face {
  font-family: "Acumin Variable Concept";
  src: url("/fonts/2025/Acumin-variable-concept.ttf") format("truetype");
  font-weight: 100 900;
  font-style: normal;
}
* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: "Acumin Variable Concept", sans-serif;
  background: #f7f9fb; color: #333; line-height: 1.5;
  padding-top: 0 !important; margin-top: 0 !important;
}
.body_container, main, #content, .container { margin-top: 0 !important; padding-top: 0 !important; }

.cst-header {
  width: 100%;
  background: url('/assets/menu-backgroud.png') repeat-x center top, #00754b;
  background-size: cover;
  box-shadow: 0 2px 4px rgba(0,0,0,.1);
  margin-bottom: 2rem;
}
.header-container {
  max-width: 1200px; margin: 0 auto; display: flex;
  justify-content: space-between; align-items: center; padding: 5px 16px;
}
.logo img { height: 65px; width: auto; padding: 2% 0; }

/* ==== Nav y botones ==== */
/* ==== Nav y botones ==== */
nav { 
  display: flex; 
  gap: 32px; 
  align-items: center; 
  flex-wrap: wrap; 
}

nav a, 
.dd > summary {
  color: #fff; 
  text-decoration: none; 
  display: flex; 
  align-items: center;
  font-size: 15px; 
  position: relative;
  padding: 10px 8px; /* mayor área táctil */
  transition: transform .3s ease, box-shadow .3s ease, color .3s ease;
  border-radius: 8px; /* esquinas redondeadas por defecto */
}

nav a:hover, 
.dd > summary:hover {
  transform: scale(1.1); 
  box-shadow: 0 4px 10px rgba(0,0,0,.2);
  z-index: 1; 
  color: #fff !important;
  background-color: transparent; /* sin fondo */
  border-radius: 8px; /* mantiene esquinas redondeadas */
}

nav .material-icons { 
  font-size: 18px; 
  margin-right: 6px; 
}

.badge {
  background: #dc2626; 
  color: #fff; 
  font-size: 11px; 
  border-radius: 9999px;
  min-width: 20px; 
  height: 20px; 
  padding: 0 6px; 
  display: inline-flex;
  align-items: center; 
  justify-content: center; 
  position: absolute; 
  top: 1px; 
  right: -4px;
}


/* ==== Dropdown (details/summary) ==== */
.dd { position: relative; }
.dd summary {
  list-style: none; cursor: pointer; display: flex; align-items: center; color: #fff;
  background: none; border: none; padding: 10px 8px; outline: none;
}
.dd summary:hover, .dd summary:focus { background: transparent; outline: none; }
.dd summary::-webkit-details-marker { display: none; }
.dd[open] > .dd-menu { display: block; }

.dd .chev { margin-left: 4px; }

.dd-menu {
  display: none; position: absolute; right: auto; left: -8px; top: calc(100% + 8px);
  background: #fff; color: #333; min-width: 260px; max-width: 320px;
  overflow: hidden; overflow-wrap: anywhere;
  border: 1px solid rgba(0,0,0,.06); border-radius: 10px;
  box-shadow: 0 10px 24px rgba(0,0,0,.12); padding: 8px 0; z-index: 50;
}
.dd-menu a, .dd-menu span.block {
  display: block; padding: 10px 14px; color: #333; text-decoration: none;
}
.dd-menu a:hover { background: #008345; transform: none !important; box-shadow: none !important; }
.dd-divider { height: 1px; background: #eee; margin: 6px 0; }

/* Cuando el dropdown está abierto, mantenerlo grande */
.dd[open] > summary {
  transform: scale(1.1) !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2) !important;
  z-index: 1;
  color: #fff !important;
}

/* Mientras el mouse está sobre el menú, mantener el trigger grande */
.dd[open]:hover > summary {
  transform: scale(1.1) !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2) !important;
  color: #fff !important;
}


/* iconos a la derecha en el dropdown */
.dd-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  line-height: 1.4;
}

.dd-icon-right {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #333;              /* iconos en negro */
  vertical-align: middle;
}

.dd-item:hover .dd-icon-right {
  color: #ffffff;              /* mantiene negro al hover */
}

.dd-user { display:flex; align-items:center; gap:10px; padding:10px 14px; }


/* ==== Solo aplicar “zoom” en dispositivos con hover real ==== */
@media (hover: hover) {
  nav a:hover, .dd > summary:hover { transform: scale(1.1); }
}
@media (hover: none) {
  nav a, .dd > summary { transform: none !important; box-shadow: none !important; }
}


/* 13. Footer */
.footer {
  background-color: #fff;
  color: var(--color-environment);
  text-align: center;
  padding: 2rem 0;
}

.footer-logos {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  /* permite bajar a 2 o 1 columnas en pantallas estrechas */
  gap: 0;
  /* sin gap: usamos divisores en desktop */
  margin: 0 0 1.25rem 0;
}

/* Tamaño de logos con clamp para responsividad fluida */
.footer-logos img {
  height: clamp(40px, 6vw, 60px);
  width: auto;
  max-width: 100%;
  display: block;
}

/* Divisor vertical entre logos (solo cuando están en fila) */
.footer-logos img+img {
  margin-left: 2rem;
  padding-left: 2rem;
  border-left: 1px solid var(--color-environment);
}

.footer-copy {
  font-size: 0.95rem;
  line-height: 1.5;
  margin: 0;
  padding-top: 1rem;
  border-top: 1px solid var(--color-environment);
  color: var(--color-environment);
}

@media (max-width: 992px) {
  .footer-logos {
      row-gap: 0.75rem;
      /* un poco de espacio entre filas si hacen wrap */
  }

  .footer-logos img+img {
      margin-left: 1.25rem;
      padding-left: 1.25rem;
  }
}


@media (max-width: 768px) {

  .footer-logos {
      gap: 1rem;
      /* ahora sí usamos gap para espaciar uniformemente */
  }

  .footer-logos img+img {
      margin-left: 0;
      padding-left: 0;
      border-left: 0;
      /* sin divisor vertical en móvil */
  }

  .footer-copy {
      font-size: 0.9rem;
  }
}

@media (max-width: 480px) {

  .footer {
      padding: 1.5rem 0;
  }

  .footer-logos img {
      height: clamp(36px, 8vw, 48px);
  }
}

/* ==== Breakpoints ==== */

/* Laptops medianas (<=1200px): compactar un poco */
@media (max-width: 1200px) {
  .header-container { padding: 0 12px; }
  nav { gap: 24px; }
  .logo img { height: 58px; }
}

/* Tablets (<=992px): dos filas cómodas, dropdown ancho fijo */
@media (max-width: 992px) {
  .header-container { flex-wrap: wrap; gap: 10px; }
  .logo img { height: 54px; }
  nav { width: 100%; justify-content: flex-start; gap: 18px; }
  nav a, .dd > summary { font-size: 14px; padding: 10px 6px; }
  .dd-menu { right: 0; }
}

/* Móviles (<=768px): nav más compacto, dropdown a ancho de pantalla */
@media (max-width: 768px) {
  .logo img { height: 48px; }
  nav { gap: 12px; }
  nav a, .dd > summary { font-size: 14px; padding: 10px 6px; }
  /* Dropdown full-width y apilado bajo el trigger */
  .dd { width: 100%; }
  .dd-menu {
    position: static;
    width: calc(100vw - 24px);          /* respeta padding lateral */
    max-width: none; min-width: 0;
    margin: 6px 12px 0; border-radius: 10px;
    box-shadow: 0 8px 18px rgba(0,0,0,.12);
  }
}

/* Móviles pequeños (<=480px): aún más compacto, iconos más chicos */
@media (max-width: 480px) {
  .logo img { height: 42px; }
  nav { gap: 10px; }
  nav a, .dd > summary { font-size: 13px; padding: 8px 6px; }
  nav .material-icons { font-size: 16px; margin-right: 5px; }
  .badge { transform: translateY(-1px) scale(.9); }
}
