/* ===========================
   WIDGET IDIOMA (panel lateral)
   =========================== */

.langFab{
  position: fixed;
  left: 18px;     /* antes right */
  bottom: 18px;
  right: auto;    /* añade esto */
  z-index: 9998;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #111;
  color:#fff;
  font-weight: 950;
  cursor: pointer;
  box-shadow: 0 18px 45px rgba(0,0,0,.18);
  transition: transform .12s ease, opacity .12s ease;
}

.langFab:hover{ transform: translateY(-1px); }

.langFab__flag{
  width: 22px;
  height: 16px;
  border-radius: 5px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 8px 18px rgba(0,0,0,.22);
  flex: 0 0 auto;
  display:block;
}

/* Panel */
.langPanel{
  position: fixed;
  right: 0;
  top: 0;
  height: 100vh;
  width: min(360px, 92vw);
  background: #fff;
  border-left: 1px solid rgba(0,0,0,.08);
  box-shadow: -18px 0 55px rgba(0,0,0,.22);
  z-index: 9999;

  transform: translateX(110%);
  transition: transform .18s ease;
  display:flex;
  flex-direction: column;
}
.langPanel.isOpen{ transform: translateX(0); }

/* Fondo oscuro */
.langBackdrop{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.35);
  z-index: 9997;
  display:none;
}
.langBackdrop.isOpen{ display:block; }

/* Cabecera panel */
.langPanel__head{
  background: linear-gradient(135deg, #1f2937, #111);
  color: #fff;
  padding: 16px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap:12px;
}
.langPanel__title{
  font-weight: 950;
  font-size: 1.05rem;
  display:flex;
  align-items:center;
  gap:10px;
}
.langPanel__close{
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.10);
  color: #fff;
  border-radius: 12px;
  padding: 8px 10px;
  cursor:pointer;
  font-weight: 900;
}

/* Body */
.langPanel__body{
  padding: 16px;
  overflow:auto;
}
.langCard{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
  box-shadow: 0 14px 40px rgba(0,0,0,.06);
}
.langCard p{
  margin: 0 0 12px;
  color:#6b7280;
  font-weight: 700;
}

.langOptions{ display:grid; gap:10px; }

.langBtn{
  display:flex;
  justify-content: space-between;
  align-items:center;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.12);
  background:#fff;
  cursor:pointer;
  font-weight: 950;
}
.langBtn:hover{ background: rgba(0,0,0,.03); }

.langBtn.isActive{
  border-color: rgba(37,99,235,.35);
  box-shadow: 0 10px 30px rgba(37,99,235,.12);
}
.langBadge{
  font-weight: 900;
  color:#111;
  opacity: .75;
  font-size: .95rem;
}
