/* === Botón flotante de idiomas (UI/hover + selección) === */
:root {
  --lf-size: 52px;           /* tamaño del botón principal */
  --lf-item: 44px;           /* tamaño de cada idioma */
  --lf-gap: 10px;            /* separación entre idiomas */
  --lf-shadow: 0 10px 22px rgba(0,0,0,.18), 0 6px 8px rgba(0,0,0,.12);
  --lf-bg: #111;             /* fondo del botón cuando no hay bandera */
  --lf-fg: #fff;
}

/* Contenedor fijo a la izquierda, centrado verticalmente */
.lang-float {
  position: fixed;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 9999;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

/* Botón principal (siempre muestra una bandera circular) */
.lang-float__fab {
  width: var(--lf-size);
  height: var(--lf-size);
  border-radius: 9999px;
  display: grid;
  place-items: center;
  background: var(--lf-bg);
  color: var(--lf-fg);
  box-shadow: var(--lf-shadow);
  cursor: pointer;
  user-select: none;
  outline: none;
  border: none;
  line-height: 1;
  padding: 0;
}

/* La bandera que va dentro del FAB y de cada ítem */
.flag {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  display: block;
  border-radius: 50%;
  overflow: hidden;
}

/* Contenedor de idiomas (se ubica a la derecha del FAB) */
.lang-float__list {
  position: absolute;
  top: 50%;
  left: calc(var(--lf-size) + 8px);
  transform: translateY(-50%);
  display: flex;
  gap: var(--lf-gap);
  pointer-events: none; /* deshabilita interacción mientras está colapsado */
}

/* Cada opción de idioma */
.lang-float__item {
  width: var(--lf-item);
  height: var(--lf-item);
  border-radius: 9999px;
  overflow: hidden;
  display: inline-block;
  box-shadow: var(--lf-shadow);
  border: 2px solid #fff;
  cursor: pointer;
  transform: translateX(-16px) scale(0.8);
  opacity: 0;
  transition: transform .25s ease, opacity .25s ease;
  will-change: transform, opacity;
  padding: 0;
}

/* Foco accesible */
.lang-float__item:focus-visible,
.lang-float__fab:focus-visible {
  outline: 3px solid #4c9ffe;
  outline-offset: 2px;
}

/* Expandir al hover o focus */
.lang-float:hover .lang-float__item,
.lang-float:focus-within .lang-float__item {
  opacity: 1;
  transform: translateX(0) scale(1);
  pointer-events: auto;
}

/* Aparición escalonada */
.lang-float__item:nth-child(1) { transition-delay: 40ms; }
.lang-float__item:nth-child(2) { transition-delay: 80ms; }
.lang-float__item:nth-child(3) { transition-delay: 120ms; }
.lang-float__item:nth-child(4) { transition-delay: 160ms; }

/* Zoom sutil al pasar por cada bandera */
.lang-float__item:hover { transform: translateX(0) scale(1.08); }

/* ===================== Banderas 100% CSS ===================== */
/* 🇪🇸 España */
.flag-es {
  background: linear-gradient(to bottom,
    #AA151B 0% 33%,
    #F1BF00 33% 66%,
    #AA151B 66% 100%
  );
}

/* 🇬🇧 Reino Unido (para inglés) – versión simplificada con gradientes */
/* 🇬🇧 Reino Unido — versión mejorada para ícono circular */
.flag-gb {
  position: relative;
  border-radius: 50%;
  background:
    /* Cruz roja (vertical y horizontal) */
    linear-gradient(to right, transparent 40%, #cf142b 40% 60%, transparent 60%),
    linear-gradient(to bottom, transparent 40%, #cf142b 40% 60%, transparent 60%),

    /* Cruz blanca (más ancha, debajo de la roja) */
    linear-gradient(to right, transparent 32%, #ffffff 32% 68%, transparent 68%),
    linear-gradient(to bottom, transparent 32%, #ffffff 32% 68%, transparent 68%),

    /* Diagonales rojas (estrechas) */
    linear-gradient(45deg, transparent 48%, #cf142b 48% 52%, transparent 52%),
    linear-gradient(-45deg, transparent 48%, #cf142b 48% 52%, transparent 52%),

    /* Diagonales blancas (más anchas) */
    linear-gradient(45deg, transparent 42%, #ffffff 42% 58%, transparent 58%),
    linear-gradient(-45deg, transparent 42%, #ffffff 42% 58%, transparent 58%),

    /* Fondo azul */
    #012169;
  background-size: 100% 100%;
  background-repeat: no-repeat;
}


/* 🇮🇹 Italia */
.flag-it {
  background: linear-gradient(to right,
    #009246 0% 33.33%,
    #FFFFFF 33.33% 66.66%,
    #CE2B37 66.66% 100%
  );
}

/* 🇫🇷 Francia */
.flag-fr {
  background: linear-gradient(to right,
    #0055A4 0% 33.33%,
    #FFFFFF 33.33% 66.66%,
    #EF4135 66.66% 100%
  );
}
