/* password-security.css - revised and aligned with NexumBite styles */

/* tokens reused */
:root{
  --accent: #8A0100;
  --muted: #bdbdbd;
  --offwhite: #C9C8C9;
  --card-bg: rgba(19,18,19,0.98);
  --max-width: 1200px;
}

/* PAGE LAYOUT */
.password-panel{ padding:72px 0; background:linear-gradient(180deg, rgba(6,6,7,0.02), transparent); }
.container{ max-width:var(--max-width); margin:0 auto; padding:0 20px; }

/* Header text aligned with checker card */
.ps-header-row{ display:flex; justify-content:flex-start; gap:24px; align-items:flex-start; margin-bottom:18px; }
.ps-title-wrap{ max-width:520px; }
.ps-title{ font-family:'Poppins',sans-serif; font-weight:900; font-size:1.9rem; margin:0; color:var(--offwhite); text-transform:uppercase; }
.ps-lead{ color:var(--muted); margin-top:8px; font-size:0.98rem; }

/* GRID */
.ps-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:22px; align-items:start; }
@media (max-width:980px){ .ps-grid{ grid-template-columns:1fr; } }

/* CARDS */
.ps-card{
  background:var(--card-bg);
  border-radius:12px;
  padding:20px;
  box-shadow:0 12px 40px rgba(0,0,0,0.6);
}
.card-title{ margin:0 0 10px; font-family:'Poppins',sans-serif; color:var(--offwhite); font-weight:900; font-size:1.05rem; }

/* CHECKER */
.checker-card .label-required{ font-weight:700; color:var(--offwhite); margin-top:8px; display:block; }
.pwd-row{ display:flex; gap:8px; margin-top:8px; align-items:center; }
.pwd-row input[type="password"], .pwd-row input[type="text"]{
  flex:1; padding:12px; border-radius:8px; border:1px solid rgba(255,255,255,0.06); background:#0f0f0f; color:var(--offwhite);
}
.eye-btn{ background:transparent; border:0; padding:8px; border-radius:8px; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; }
.eye-btn img{ display:block; }

/* RESULT */
.result-block{ margin-top:14px; color:var(--offwhite); font-weight:700; }
.result-line{ margin:8px 0; font-weight:800; color:var(--offwhite); }
.meter{ height:12px; background:#0b0b0b; border-radius:8px; overflow:hidden; margin:8px 0; border:1px solid rgba(255,255,255,0.03); }
.meter > span{ display:block; height:100%; width:0; transition:width 260ms ease; background:linear-gradient(90deg,#33c37d 0%, #ffb74d 60%, #ff4d4d 100%); }

/* ESTIMATED TIME & BREACH */
.small-heading{ margin:12px 0 6px; font-size:0.95rem; color:var(--offwhite); font-weight:800; }
#pwnedInfo{ color:var(--muted); font-weight:700; margin-top:6px; }

/* ACTIONS */
.ps-actions{ margin-top:12px; display:flex; gap:12px; align-items:center; justify-content:space-between; }
.realtime-note{ display:flex; gap:12px; align-items:center; justify-content:space-between; width:100%; }
.muted{ color:var(--muted); font-weight:700; }

/* GENERATOR */
.gen-result.top{ display:flex; gap:8px; align-items:center; margin-bottom:14px; }
.gen-result.top input{ flex:1; padding:12px; border-radius:8px; background:#0f0f0f; border:1px solid rgba(255,255,255,0.06); color:var(--offwhite); }
.gen-buttons{ display:flex; gap:8px; align-items:center; }
.generator-card .modes{ display:flex; gap:12px; align-items:center; margin-bottom:12px; }
.gen-mode{ display:inline-flex; gap:8px; align-items:center; font-weight:700; background:transparent; padding:6px 8px; border-radius:8px; cursor:pointer; }
.gen-mode input{ margin:0; transform:translateY(1px); }
.gen-options-grid{ display:flex; gap:12px; flex-direction:column; }
@media (min-width:981px){ .gen-options-grid{ flex-direction:row; } }
.gen-options{ background:transparent; display:flex; flex-direction:column; gap:8px; flex:1; }
.gen-opts-row{ display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.opt-inline{ display:inline-flex; gap:8px; align-items:center; font-weight:700; }
.gen-result{ display:flex; gap:8px; align-items:center; margin-top:12px; }
.gen-result input{ flex:1; padding:12px; border-radius:8px; background:#0f0f0f; border:1px solid rgba(255,255,255,0.06); color:var(--offwhite); }

/* quick utilities */
.btn.primary{ background:var(--accent); color:white; border-radius:8px; padding:8px 12px; font-weight:800; border:0; cursor:pointer; }
.btn.outline{ background:transparent; border:1px solid rgba(255,255,255,0.06); color:var(--offwhite); border-radius:8px; padding:8px 12px; cursor:pointer; }

/* MOBILE PANEL (right slide) */
.mobile-panel{ display:none; }
.mobile-panel.open{ display:block; position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,0.5); }
.mobile-panel-inner{
  position:fixed; top:0; right:0; width:320px; height:100%; background:#0b0b0b; box-shadow:-24px 0 48px rgba(0,0,0,0.6); padding:18px; overflow:auto;
}
.mobile-panel-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.logo-img-mobile{ height:32px; }
.mobile-close{ background:transparent; border:0; color:var(--offwhite); font-size:22px; cursor:pointer; }

/* quick actions top of panel */
.mobile-quick{ display:flex; flex-direction:column; gap:8px; margin-bottom:12px; }

/* Sign-in (red) */
.mobile-login-btn{ background:var(--accent); color:white; border-radius:8px; padding:10px; font-weight:900; border:0; cursor:pointer; text-align:left; width:100%; font-family:'Montserrat',sans-serif; font-size:.95rem; }

/* generic quick button */
.mobile-quick-btn{ display:inline-flex; align-items:center; gap:8px; padding:10px; background:rgba(255,255,255,0.02); border-radius:8px; color:var(--offwhite); text-decoration:none; font-weight:800; text-align:left; border:0; width:100%; cursor:pointer; font-family:'Montserrat',sans-serif; font-size:.9rem;}
.mobile-quick-btn img { flex-shrink: 0; }

/* === NUEVO: Estilos para el desplegable de idiomas móvil === */
.mobile-lang-list {
  display: none; /* Oculto por defecto */
  flex-direction: column;
  gap: 8px;
  background: rgba(255, 255, 255, 0.03);
  padding: 12px;
  border-radius: 8px;
  margin-top: 4px;
}
.mobile-lang-list.open {
  display: flex; /* Se muestra con JS */
}
.mobile-lang-list .lang-row{ display:flex; gap:8px; flex-wrap:wrap; }
.lang-select-mobile{ color:var(--muted); text-decoration:none; font-weight:700; padding:6px 10px; border-radius:6px; background:rgba(255,255,255,0.02); }
.lang-select-mobile:hover { color: var(--offwhite); }

/* === MODIFICADO: Navegación móvil principal === */
.mobile-nav{
  display:flex;
  flex-direction:column;
  margin-top:16px;
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 8px;
}
.mobile-item{
  background:transparent;
  border:0;
  border-bottom: 1px solid rgba(255,255,255,0.08); /* Línea divisora */
  color:var(--offwhite);
  text-align:left;
  padding: 14px 8px; /* Padding unificado */
  font-weight:700;
  font-size: 1rem;
  font-family: 'Montserrat', sans-serif; /* Tipografía consistente */
  text-transform:uppercase;
  cursor:pointer;
  text-decoration: none; /* Quitar subrayado por defecto */
  transition: color 150ms ease, text-decoration-color 150ms ease;
}
.mobile-nav > .mobile-item:last-child {
  border-bottom: none; /* Quitar última línea divisora */
}
/* Efecto hover: solo en hover (no en focus/click) */
.mobile-item:hover {
  color: var(--accent); /* Color rojo */
  text-decoration: underline; /* Subrayado */
  outline: none;
}
.mobile-item:focus-visible {
  /* Keep keyboard focus visible but neutral color: use subtle outline only */
  outline:2px solid rgba(138,1,0,0.12);
  outline-offset:2px;
}

/* submenus */
.mobile-submenu{ display:none; padding-left:12px; flex-direction:column; gap:6px; margin-bottom:8px; }
.mobile-submenu a{ color:var(--muted); text-decoration:none; padding:6px 0; font-weight:700; }
/* submenu hover effect */
.mobile-submenu a:hover{ color:var(--accent); text-decoration:underline; }

/* DROPDOWNS (desktop) - MATCH REFERENCE ANIMATION & PLACEMENT */
.main-bubble{ position:relative; display:inline-flex; gap:10px; align-items:center; }

/* LA REGLA QUE ARREGLA TODO */
.bubble {
  position: relative;
}

/* Important: use opacity+transform transitions (not display:none) to allow consistent animation */
.dropdown{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  min-width:160px;
  background:rgba(18,18,18,0.86);
  color:var(--offwhite);
  border-radius:10px;
  padding:6px 6px;
  box-shadow:0 18px 40px rgba(0,0,0,0.6);
  opacity:0;
  pointer-events:none;
  transform:translateY(6px);
  transition:opacity 160ms ease, transform 200ms ease;
  z-index:1000;
}
.dropdown.open{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.dropdown .dropdown-item{
  display:block;
  padding:10px 14px;
  margin:0;
  color:var(--offwhite);
  text-decoration:none;
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  border:none;
  background:transparent;
  border-radius:8px;
}
/* hover-only behaviour: red + underline on hover */
.dropdown .dropdown-item:hover{
  background: rgba(255,255,255,0.04);
  color:var(--accent);
  text-decoration: underline;
}

/* prevent :active or :focus from forcing hover styles to stick */
.nav-item:focus, .nav-item:active, .dropdown-item:focus {
  color: inherit;
  text-decoration: none;
}

/* FOOTER responsiveness */
@media (max-width:980px){
  .footer-grid{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .site-footer{ padding:18px 0; }
  .footer-copyright{ text-align:center; margin-top:12px; font-size:13px; }
  .mobile-panel-inner{ width:92%; }
  .header-center,
  .header-right .shop-btn,
  .header-right .bubble {
    display: none;
  }
  .site-header .nav-toggle {
    display: inline-flex;
  }
  .header-left {
    flex: 1;
  }
}

/* small accessibility focus: show only when keyboard focus is used */
:focus-visible { outline:2px solid rgba(138,1,0,0.22); outline-offset:2px; border-radius:6px; }

/* small helper */
.small-help{ font-size:0.92rem; margin-top:6px; color:var(--muted); }
.label-required::after{ content:""; }

/* ======================================================= */
/* === FIX FINAL DE ALINEACIÓN DE COLUMNA DE TEXTO === */
/* ======================================================= */
@media (max-width: 768px) {

  /* Los contenedores principales se mantienen simples */
  .generator-card .modes,
  .gen-opts-row {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }

  /* --- LA CORRECCIÓN DE ALINEACIÓN FINAL --- */
  /* Convertimos cada opción en una cuadrícula de 2 columnas */
  .gen-mode,
  .opt-inline {
    display: grid;
    /* Columna 1: 30px fijos para el botón. Columna 2: el resto para el texto. */
    grid-template-columns: 30px auto; 
    align-items: center;
    gap: 8px; /* Reducimos el gap para un look más limpio */
  }

  /* Centramos el botón/checkbox dentro de su columna de 30px */
  .gen-mode input,
  .opt-inline input {
    margin: 0;
    justify-self: center;
  }
}