/* ──────────────────────────────────────────────
 * CECA Header — Estilos con BEM
 * Medidas en px · Variables CSS3 · No rem
 * ──────────────────────────────────────────── */

/* ═══════════════════════════════════════════
 * RESET base
 * ═══════════════════════════════════════════ */
.ceca-header *,
.ceca-header *::before,
.ceca-header *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ═══════════════════════════════════════════
 * HEADER — contenedor global
 * ═══════════════════════════════════════════ */
.ceca-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  width: 100%;
  font-family: var(--ceca-font-family);
}

/* ═══════════════════════════════════════════
 * SUBCABECERA
 * ═══════════════════════════════════════════ */
.ceca-subheader {
  background-color: var(--ceca-primary);
  width: 100%;
}

.ceca-subheader__container {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  max-width: 1920px;
  margin: 0 auto;
  padding: 0 32px;
}

.ceca-subheader__item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  color: var(--ceca-white) !important;
  text-decoration: none;
  font-family: var(--ceca-font-family);
  font-size: 16px;
  font-weight: 400;
  line-height: 1;
  transition: opacity var(--ceca-transition);
  white-space: nowrap;
}

.ceca-subheader__item:hover {
  opacity: 0.8;
}

.ceca-subheader__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.ceca-subheader__text {
  font-size: 16px;
}

.ceca-subheader__funcas-logo {
  height: 26px;
  width: auto;
}

/* .ceca-subheader__item--funcas {
  border-left: 1px solid rgba(255, 255, 255, 0.25);
  border-right: 1px solid rgba(255, 255, 255, 0.25);
} */

/* ── Language Dropdown (Polylang) ── */
.ceca-lang-dropdown {
  position: relative;
}

.ceca-lang-dropdown__trigger {
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ceca-white);
  font-family: var(--ceca-font-family);
  font-size: 16px;
  font-weight: 400;
  line-height: 1;
  padding: 14px 16px;
  white-space: nowrap;
  transition: opacity var(--ceca-transition);
}

.ceca-lang-dropdown__trigger:hover {
  opacity: 0.8;
}

.ceca-lang-dropdown__trigger:focus-visible {
  outline: var(--ceca-focus-outline);
  outline-offset: var(--ceca-focus-offset);
}

.ceca-lang-dropdown__current {
  font-size: 16px;
  text-transform: uppercase;
  font-weight: 600;
}

.ceca-lang-dropdown__arrow {
  width: 10px;
  height: 6px;
  flex-shrink: 0;
  transition: transform 0.25s ease;
}

.ceca-lang-dropdown.is-open .ceca-lang-dropdown__arrow {
  transform: rotate(180deg);
}

.ceca-lang-dropdown__list {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 100;
  display: none;
  min-width: 160px;
  list-style: none;
  margin: 0;
  padding: 8px 0;
  background-color: var(--ceca-white);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  overflow: hidden;
  animation: cecaLangFadeIn 0.2s ease;
}

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

.ceca-lang-dropdown.is-open .ceca-lang-dropdown__list {
  display: block;
}

.ceca-lang-dropdown__list li {
  display: block;
}

.ceca-lang-dropdown__list li a {
  display: block;
  padding: 10px 20px;
  color: var(--ceca-text-secondary, #333);
  text-decoration: none;
  font-family: var(--ceca-font-family);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.4;
  transition:
    background-color 0.15s ease,
    color 0.15s ease;
}

.ceca-lang-dropdown__list li a:hover {
  background-color: var(--ceca-bg-light, #f5f5f5);
  color: var(--ceca-primary);
}

.ceca-lang-dropdown__list li a:focus-visible {
  outline: var(--ceca-focus-outline);
  outline-offset: -2px;
}

/* ── Mobile language dropdown ── */
.ceca-lang-dropdown--mobile .ceca-lang-dropdown__trigger {
  color: var(--ceca-primary);
  padding: 8px 0;
  gap: 8px;
}

.ceca-lang-dropdown--mobile .ceca-lang-dropdown__current {
  font-size: 14px;
}

.ceca-lang-dropdown--mobile .ceca-lang-dropdown__arrow {
  color: var(--ceca-primary);
}

.ceca-lang-dropdown--mobile .ceca-lang-dropdown__list {
  left: auto;
  right: 0;
  bottom: 100%;
  top: auto;
  min-width: 140px;
  animation-name: cecaLangFadeInUp;
}

@keyframes cecaLangFadeInUp {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ═══════════════════════════════════════════
 * CABECERA PRINCIPAL
 * ═══════════════════════════════════════════ */
.ceca-header__main {
  background-color: var(--ceca-white);
  border-bottom: 1px solid var(--ceca-border-color);
  width: 100%;
}

.ceca-header__container {
  display: flex;
  align-items: center;
  max-width: 1920px;
  margin: 0 auto;
  padding: 16px 32px;
  gap: 32px;
}

/* Logo */
.ceca-header__logo {
  flex-shrink: 0;
}

.ceca-header__logo a,
.ceca-header__logo-link {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.ceca-header__logo img,
.custom-logo {
  width: 136px;
  height: 37px;
  object-fit: contain;
}

/* Nav */
.ceca-header__nav {
  flex: 1;
  display: flex;
  align-items: center;
}

.ceca-nav__list {
  display: flex;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 0;
}

/* Nav items */
.ceca-nav__item {
  position: relative;
  list-style: none;
}

.ceca-nav__link {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 12px 16px;
  color: var(--ceca-text-dark);
  text-decoration: none;
  font-family: var(--ceca-font-family);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.2;
  white-space: nowrap;
  transition: color var(--ceca-transition);
}

.ceca-nav__link:hover {
  color: var(--ceca-primary);
  font-weight: 600;
}

.ceca-nav__link:focus-visible {
  outline: none;
  font-weight: 600;
  color: var(--ceca-primary);
}

/* Item activo */
.ceca-nav__item--active > .ceca-nav__link {
  font-weight: 600;
  color: var(--ceca-primary);
  position: relative;
}

/* Chevron */
.ceca-nav__chevron {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  transition: transform var(--ceca-transition);
  color: inherit;
}

.ceca-nav__item--has-children
  > .ceca-nav__link[aria-expanded="true"]
  .ceca-nav__chevron {
  transform: rotate(180deg);
}

/* Botón búsqueda */
.ceca-header__search {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ceca-text-dark);
  flex-shrink: 0;
  margin-left: auto;
  padding: 0;
  border-radius: var(--ceca-radius-sm);
  transition:
    background-color var(--ceca-transition),
    color var(--ceca-transition);
}

.ceca-header__search:hover {
  background-color: var(--ceca-bg-light);
  color: var(--ceca-primary);
}

.ceca-header__search svg {
  width: 24px;
  height: 24px;
}

/* Hamburguesa */
.ceca-header__hamburger {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ceca-text-dark);
  flex-shrink: 0;
  margin-left: 0;
  padding: 0;
}

.ceca-header__hamburger svg {
  width: 24px;
  height: 24px;
}

/* ═══════════════════════════════════════════
 * DROPDOWN SIMPLE
 * ═══════════════════════════════════════════ */
.ceca-nav__item--dropdown > .ceca-nav__submenu {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 287px;
  background-color: var(--ceca-white);
  box-shadow: var(--ceca-dropdown-shadow);
  border-radius: var(--ceca-radius-md);
  list-style: none;
  margin: 0;
  padding: 8px 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition:
    opacity var(--ceca-transition),
    transform var(--ceca-transition),
    visibility var(--ceca-transition);
  z-index: 100;
}

.ceca-nav__item--dropdown.is-open > .ceca-nav__submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Enlace padre resaltado cuando dropdown está abierto */
.ceca-nav__item--dropdown.is-open > .ceca-nav__link {
  color: var(--ceca-primary);
  background-color: var(--ceca-bg-light, #f5f5f5);
  border-radius: var(--ceca-radius-sm, 6px);
}

.ceca-nav__item--dropdown > .ceca-nav__submenu .ceca-nav__item {
  list-style: none;
}

.ceca-nav__item--dropdown > .ceca-nav__submenu .ceca-nav__link {
  display: block;
  padding: 12px 20px;
  font-size: 16px;
  font-weight: 400;
  color: var(--ceca-text-dark);
  text-decoration: none;
  border-radius: 0;
  background-color: transparent;
  transition:
    background-color 0.15s ease,
    color 0.15s ease;
}

.ceca-nav__item--dropdown > .ceca-nav__submenu .ceca-nav__link:hover {
  background-color: var(--ceca-bg-light, #f5f5f5);
  color: var(--ceca-primary);
}

.ceca-nav__item--dropdown > .ceca-nav__submenu .ceca-nav__link:focus-visible {
  outline: var(--ceca-focus-outline, 2px solid var(--ceca-primary));
  outline-offset: -2px;
}

/* ═══════════════════════════════════════════
 * MEGA MENU
 * ═══════════════════════════════════════════ */
.ceca-mega-menu {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  background-color: var(--ceca-mega-bg);
  box-shadow: var(--ceca-mega-shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition:
    opacity var(--ceca-transition),
    transform var(--ceca-transition),
    visibility var(--ceca-transition);
  z-index: 200;
}

.ceca-mega-menu.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.ceca-mega-menu__container {
  display: flex;
  max-width: 1920px;
  margin: 0 auto;
  padding: 32px 40px;
  gap: 32px;
  position: relative;
}

/* Featured section */
.ceca-mega-menu__featured {
  width: 411px;
  min-height: 400px;
  flex-shrink: 0;
  overflow: hidden;
  position: relative;
  background-color: var(--ceca-primary);
  background-size: cover;
  background-position: center;
  display: block;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.ceca-mega-menu__featured:hover {
  opacity: 0.92;
}

.ceca-mega-menu__featured[style*="pointer-events: none"] {
  cursor: default;
}

.ceca-mega-menu__featured[style*="pointer-events: none"]:hover {
  opacity: 1;
}

.ceca-mega-menu__featured-content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
  padding: 32px;
}

.ceca-mega-menu__featured-glass {
  height: 100%;
  background: rgba(227, 227, 227, 0.3);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  padding: 24px;
}

.ceca-mega-menu__featured-title {
  color: var(--ceca-white);
  font-family: var(--ceca-font-family);
  font-size: 32px;
  line-height: 1.2;
  margin-bottom: 12px;
}

.ceca-mega-menu__featured-title strong {
  font-weight: 700;
  display: block;
}

.ceca-mega-menu__featured-title em {
  font-weight: 200;
  font-style: italic;
}

.ceca-mega-menu__featured-desc {
  color: var(--ceca-white);
  font-family: var(--ceca-font-family);
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
}

/* Columns */
.ceca-mega-menu__columns {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-content: start;
}

.ceca-mega-menu__column {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ceca-mega-menu__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  text-decoration: none;
  border-radius: var(--ceca-radius-sm);
  transition: background-color var(--ceca-transition);
}

.ceca-mega-menu__item:hover {
  background-color: var(--ceca-bg-light);
}

.ceca-mega-menu__item-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background-color: var(--ceca-icon-wrapper-bg);
  flex-shrink: 0;
  padding: 8px;
}

.ceca-mega-menu__item-icon svg {
  width: 24px;
  height: 24px;
  color: var(--ceca-primary);
}

.ceca-mega-menu__item-icon-img {
  width: 24px;
  height: 24px;
  object-fit: contain;
  border-radius: 2px;
}

.ceca-mega-menu__item-text {
  font-family: var(--ceca-font-family);
  font-size: 16px;
  font-weight: 500;
  color: var(--ceca-primary);
  flex: 1;
}

.ceca-mega-menu__item-arrow {
  width: 16px;
  height: 16px;
  color: var(--ceca-secondary);
  flex-shrink: 0;
  transition: transform var(--ceca-transition);
}

.ceca-mega-menu__item.is-active {
  background-color: var(--ceca-icon-wrapper-bg);
}

.ceca-mega-menu__item.is-active .ceca-mega-menu__item-icon {
  background-color: transparent;
}

.ceca-mega-menu__item.is-active .ceca-mega-menu__item-arrow {
  transform: rotate(-45deg);
}

/* Enlace padre resaltado cuando mega-menu está abierto */
.ceca-nav__item--mega.is-open > .ceca-nav__link {
  color: var(--ceca-primary);
}

/* Submenu oculto en mega-menu items (renderizado por Walker) */
.ceca-nav__item--mega > .ceca-nav__submenu {
  display: none;
}

/* ═══════════════════════════════════════════
 * MOBILE NAV
 * ═══════════════════════════════════════════ */

/* Overlay */
.ceca-mobile-nav__overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9998;
  opacity: 0;
  transition: opacity var(--ceca-transition);
}

.ceca-mobile-nav__overlay.is-active {
  display: block;
  opacity: 1;
}

/* Panel */
.ceca-mobile-nav {
  position: fixed;
  top: 0;
  right: 0;
  width: 375px;
  max-width: 100vw;
  height: 100vh;
  height: 100dvh;
  background-color: var(--ceca-white);
  z-index: 9999;
  transform: translateX(100%);
  transition: transform var(--ceca-transition);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  filter: var(--ceca-mobile-shadow);
}

.ceca-mobile-nav.is-open {
  transform: translateX(0);
}

/* Header mobile */
.ceca-mobile-nav__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 52px;
  padding: 0 16px;
  border-bottom: 1px solid var(--ceca-border-color);
  flex-shrink: 0;
}

.ceca-mobile-nav__logo {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.ceca-mobile-nav__logo-img {
  width: 117px;
  height: 32px;
  object-fit: contain;
}

.ceca-mobile-nav__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ceca-text-dark);
  padding: 0;
}

/* Menu list (accordion) */
.ceca-mobile-nav__menu {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0;
}

.ceca-mobile-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.ceca-mobile-nav__list .ceca-nav__item {
  border-bottom: 1px solid var(--ceca-neutral-light);
}

.ceca-mobile-nav__list .ceca-nav__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 16px;
  font-size: 16px;
  font-weight: 500;
  color: var(--ceca-text-dark);
  text-decoration: none;
  font-family: var(--ceca-font-family);
}

.ceca-mobile-nav__list .ceca-nav__link:hover {
  color: var(--ceca-primary);
}

.ceca-mobile-nav__list .ceca-nav__item--active > .ceca-nav__link,
.ceca-nav__item.ceca-nav__item--active > .ceca-nav__link {
  color: var(--ceca-primary);
  font-weight: 600;
}

/* Accordion submenu */
.ceca-mobile-nav__list .ceca-nav__submenu {
  list-style: none;
  margin: 0;
  padding: 0 0 0 16px;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}

/* Reset dropdown/mega estilos dentro del mobile nav */
.ceca-mobile-nav__list .ceca-nav__item--dropdown > .ceca-nav__submenu,
.ceca-mobile-nav__list .ceca-nav__item--mega > .ceca-nav__submenu {
  position: static;
  opacity: 1;
  visibility: visible;
  display: block;
  transform: none;
  min-width: 0;
  background-color: transparent;
  box-shadow: none;
  border-radius: 0;
  pointer-events: auto;
}

.ceca-mobile-nav__list
  .ceca-nav__item--has-children.is-expanded
  > .ceca-nav__submenu {
  max-height: 2000px;
}

.ceca-mobile-nav__list .ceca-nav__submenu .ceca-nav__link {
  padding: 12px 16px;
  font-weight: 400;
  font-size: 15px;
  gap: 12px;
}

.ceca-mobile-nav__list .ceca-nav__submenu .ceca-nav__link::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background-image: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 4L10 8L6 12' stroke='%23797979' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
}

/* Chevron rotate in mobile accordion */
.ceca-mobile-nav__list .ceca-nav__chevron {
  transition: transform var(--ceca-transition);
}

.ceca-mobile-nav__list
  .ceca-nav__item--has-children.is-expanded
  > .ceca-nav__link
  .ceca-nav__chevron {
  transform: rotate(180deg);
}

/* Footer section */
.ceca-mobile-nav__footer {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 16px;
  border-top: 1px solid var(--ceca-border-color);
  flex-shrink: 0;
}

.ceca-mobile-nav__lang {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  color: var(--ceca-text-dark);
  text-decoration: none;
  font-family: var(--ceca-font-family);
  font-size: 16px;
  font-weight: 400;
}

.ceca-mobile-nav__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.ceca-mobile-nav__acceso {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 20px;
  background-color: var(--ceca-primary);
  color: var(--ceca-white);
  text-decoration: none;
  font-family: var(--ceca-font-family);
  font-size: 16px;
  font-weight: 500;
  border-radius: var(--ceca-radius-md);
  transition: background-color var(--ceca-transition);
}

.ceca-mobile-nav__acceso:hover {
  background-color: #02394d;
}

.ceca-mobile-nav__acceso .ceca-mobile-nav__icon {
  color: var(--ceca-white);
}

.ceca-mobile-nav__funcas {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 0;
  text-decoration: none;
}

/* ═══════════════════════════════════════════
 * RESPONSIVE — Tablet (≤ 1200px)
 * ═══════════════════════════════════════════ */
@media (max-width: 1200px) {
  /* Ocultar nav desktop */
  .ceca-header__nav {
    display: none;
  }

  /* Mostrar hamburguesa */
  .ceca-header__hamburger {
    display: flex;
  }

  /* Ocultar mega menu en tablet/mobile */
  .ceca-mega-menu {
    display: none;
  }

  /* Ajustar contenedor header */
  .ceca-header__container {
    padding: 12px 16px;
    justify-content: space-between;
  }

  /* Ajustar subheader */
  .ceca-subheader__container {
    padding: 0 16px;
  }

  .ceca-subheader__item {
    padding: 10px 12px;
    font-size: 14px;
  }
}

/* ═══════════════════════════════════════════
 * RESPONSIVE — Mobile (≤ 768px)
 * ═══════════════════════════════════════════ */
/* ═══════════════════════════════════════════
 * ACCESIBILIDAD — Focus visible
 * ═══════════════════════════════════════════ */
.ceca-subheader__item:focus-visible,
.ceca-header__logo a:focus-visible,
.ceca-header__logo .custom-logo-link:focus-visible,
.ceca-header__search:focus-visible,
.ceca-header__hamburger:focus-visible,
.ceca-mega-menu__item:focus-visible,
.ceca-mega-menu__featured:focus-visible,
.ceca-mobile-nav__close:focus-visible,
.ceca-mobile-nav__logo:focus-visible,
.ceca-mobile-nav__lang:focus-visible,
.ceca-mobile-nav__acceso:focus-visible,
.ceca-mobile-nav__funcas:focus-visible {
  outline: var(--ceca-focus-outline);
  outline-offset: var(--ceca-focus-offset);
  border-radius: var(--ceca-radius-sm);
}

@media (max-width: 768px) {
  /* Subcabecera compacta en mobile */
  .ceca-subheader__container {
    padding: 0 12px;
    justify-content: center;
    flex-wrap: wrap;
  }

  .ceca-subheader__item {
    padding: 6px 8px;
    font-size: 12px;
    gap: 4px;
  }

  .ceca-subheader__icon {
    width: 16px;
    height: 16px;
  }

  .ceca-subheader__text {
    font-size: 12px;
  }

  .ceca-subheader__funcas-logo {
    height: 22px;
  }

  .ceca-lang-dropdown__current {
    font-size: 12px;
  }

  /* Logo más pequeño */
  .ceca-header__logo img,
  .custom-logo {
    width: 100px;
    height: auto;
  }

  /* Panel mobile full width */
  .ceca-mobile-nav {
    width: 100%;
  }

  .ceca-header__container {
    padding: 10px 16px;
  }
}

button:focus {
  color: inherit;
}
