:root{
  --brand-blue:#0b2a4a;
  --brand-blue-600:#09365f;
  --brand-blue-light:#1f4f7a; /* barra informativa */
  --text:#111;
  --muted:#444;
  --bg:#fff;
  --bg-soft:#f6f8fb;
  --border:#d9d9d9;
}

/* Reset y base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:'Inter', system-ui, -apple-system, Arial, sans-serif;
  display:flex; flex-direction:column; min-height:100vh;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}

/* Barra superior */
.topbar{
  background:#000; color:#fff; padding:8px 14px;
  display:flex; align-items:center; justify-content:flex-start;
  font-size:clamp(12px, 3.3vw, 14px);
  position:relative; z-index:5;
}
.topbar button{
  background:none; border:none; color:var(--brand-blue-light);
  font-weight:700; cursor:pointer; padding:6px 8px; border-radius:6px;
}
.dropdown{
  position:absolute; left:0; top:100%;
  background:#222; color:#fff; width:min(92vw, 320px);
  padding:12px; border-radius:8px; box-shadow:0 6px 18px rgba(0,0,0,.3);
  display:none; font-size:clamp(12px, 3.4vw, 14px); line-height:1.5;
}

/* Header */
header{
  background:var(--brand-blue); height:64px;
  display:flex; align-items:center; padding:0 16px;
}
header img{height:40px; width:auto}

/* Barra informativa */
.promo{
  background:var(--brand-blue-light); padding:12px 20px;
  font-weight:700; font-size:clamp(14px, 3.8vw, 16px);
  text-align:left; color:#fff;
}
.promo a{color:#fff; text-decoration:underline}

/* Sección principal */
.intro{
  background:var(--bg-soft); text-align:center; padding:24px 16px;
}
.intro h1{
  margin:10px 0 8px;
  font-size:clamp(20px, 6vw, 32px);
  color:var(--brand-blue);
  font-weight:800;
}
.intro p{
  margin:0 auto; max-width:58ch;
  font-size:clamp(14px, 3.8vw, 16px);
  line-height:1.7; color:#333;
}
.card{
  background:#fff; color:var(--text);
  border-radius:12px; box-shadow:0 8px 30px rgba(0,0,0,.12);
  margin:16px auto 28px; padding:18px;
  width:min(92vw, 720px);
}
.card h2{
  text-align:center; margin:0 0 12px;
  color:var(--brand-blue);
  font-size:clamp(18px, 5.4vw, 26px);
}
.field-hint{
  text-align:center; margin:0 0 10px;
  font-size:clamp(13px, 3.6vw, 15px);
}
.field-hint .required{ color:#c40000; margin-left:.25rem }

/* Inputs */
.code-inputs{
  display:flex; justify-content:center; gap:clamp(6px, 2.5vw, 12px);
  margin:16px 0 18px; flex-wrap:nowrap; /* 🔥 en una sola fila */
  overflow-x:auto; -webkit-overflow-scrolling:touch;
}
.code-inputs input{
  width:clamp(36px, 9.5vw, 52px);
  height:clamp(44px, 11vw, 62px);
  text-align:center; font-size:clamp(18px, 6vw, 26px);
  border:2px solid var(--border); border-radius:8px; outline:none;
}
.code-inputs input:focus{ border-color:var(--brand-blue) }

/* Botón */
.btn{
  width:100%; max-width:520px; display:block; margin:0 auto;
  padding:14px 18px; font-size:clamp(15px, 4.5vw, 17px);
  border-radius:10px; border:none; font-weight:700;
  background:#ccc; color:#fff; cursor:not-allowed;
}
.btn.enabled{ background:var(--brand-blue); cursor:pointer }

/* Info */
.info{
  margin-top:12px; font-size:clamp(12px, 3.5vw, 15px);
  color:var(--muted); display:flex; gap:8px; align-items:flex-start;
}

/* Footer */
footer{
  background:var(--brand-blue); color:#fff; text-align:center; padding:20px;
  font-size:clamp(12px, 3.3vw, 14px);
}

/* Modal */
.modal{
  position:fixed; inset:0; background:rgba(0,0,0,.85);
  display:flex; align-items:center; justify-content:center; z-index:9999;
  padding:16px;
}
.modal-content{
  background:#fff; border-radius:12px; width:100%;
  max-width:900px; padding:20px;
  display:grid; gap:16px; grid-template-columns:1fr;
}
.modal h2{
  margin:0 0 8px; color:var(--brand-blue);
  font-size:clamp(18px, 5.4vw, 26px);
}
.modal p{
  margin:0 0 14px; color:#333; line-height:1.7;
  font-size:clamp(14px, 3.8vw, 16px); text-align:justify;
}
.modal .btn-accept{
  background:var(--brand-blue-light); color:#fff; border:none;
  padding:12px 18px; border-radius:10px; font-weight:700;
  font-size:clamp(14px, 4.2vw, 16px); cursor:pointer;
}
.modal .img-wrap{display:none}

@media (min-width:768px){
  header{height:80px; padding:0 30px}
  header img{height:50px}
  .card{padding:24px}
  .modal-content{grid-template-columns:1fr 1fr; padding:24px}
  .modal .img-wrap{display:flex; align-items:center; justify-content:center}
}
/* Dropdown corregido para móvil */
.dropdown{
  position:absolute; 
  top:100%; 
  left:0; 
  background:#222; 
  color:#fff; 
  padding:12px; 
  border-radius:8px; 
  box-shadow:0 6px 18px rgba(0,0,0,.3);
  display:none; 
  font-size:clamp(12px, 3.4vw, 14px); 
  line-height:1.5;

  /* 🔥 ajustes para móvil */
  max-width:90vw;      /* nunca excede ancho pantalla */
  width:auto;          /* se adapta al contenido */
  word-wrap:break-word; /* corta palabras largas si hace falta */
  z-index:999;
}
/* ===== CÓDIGO DE INGRESO (desktop/base) ===== */
.code-inputs{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  flex-wrap: nowrap;         /* no permitir salto de línea */
}
.code-inputs input{
  width: 48px;
  height: 56px;
  text-align: center;
  font-size: 20px;           /* >=16px para evitar zoom en iOS */
  border: 2px solid #ccc;
  border-radius: 6px;
  outline: none;
}
.code-inputs input:focus{
  border-color: var(--brand-blue, #0a58ca);
}

/* ===== MÓVIL: todas en una fila ajustando ancho automáticamente ===== */
@media (max-width: 480px){
  .code-inputs{
    gap: 6px;
    padding: 0 16px; /* margen lateral para el cálculo */
  }
  /* 
     ancho = (ancho viewport - paddings laterales - total de gaps) / 9
     gaps: 8 separaciones de 6px = 48px
  */
  .code-inputs input{
    width: calc((100vw - 32px - 48px) / 9);
    height: clamp(40px, 12vw, 56px);
    font-size: clamp(16px, 4.2vw, 18px);
  }
}

/* opcional: bloquear zoom doble-tap en iOS (si usas botón) */
button, .code-inputs input {
  touch-action: manipulation;
}
/* ===== Sección de bienvenida/consulta ===== */
.left {
  background: var(--brand-blue, #0a2a43); /* azul corporativo */
  color: #fff;                            /* texto en blanco */
  text-align: center;
  padding: 2rem;
  border-radius: 8px;
}

.left h1 {
  color: #fff;
  font-size: 2rem;
  margin-bottom: 1rem;
}

.left p {
  color: #f0f0f0; /* un blanco suave para legibilidad */
  font-size: 1.1rem;
  line-height: 1.6;
}
/* === Forzar estilo de la sección "Consulta el estado de tu caso" === */
.main-section .left {
  background: var(--brand-blue, #0a2a43) !important; /* azul corporativo */
  color: #fff !important;
  text-align: center;
  padding: 2rem;
  border-radius: 8px; /* opcional */
}

.main-section .left h1,
.main-section .left p,
.main-section .left a,
.main-section .left span {
  color: #fff !important;
}

.main-section .left p {
  color: #f0f0f0 !important; /* blanco suave para texto largo */
}

/* si tienes un contenedor interno, asegúrate de que no imponga fondo */
.main-section .left > div {
  background: transparent !important;
}
/* ===== Barras superiores: forzar texto en una sola línea ===== */
.topbar,
.promo {
  white-space: nowrap;      /* evita saltos de línea */
  overflow: hidden;         /* oculta lo que se desborda */
  text-overflow: ellipsis;  /* agrega "..." si no cabe */
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.topbar span,
.promo a {
  flex-shrink: 1;           /* que el texto pueda encogerse */
  min-width: 0;             /* necesario para que ellipsis funcione en flex */
}
/* ===== Header ===== */
header {
  background-color: #111;  /* mismo color que ya usas */
  height: 160px;           /* más alto (antes eran ~80px) */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 0;         /* espacio extra arriba/abajo */
}

header img {
  height: 70px;            /* aumenta el logo acorde */
}
.code-inputs {
  display: flex;
  justify-content: space-between;
  gap: 6px;
  width: 100%;
}

.code-inputs input {
  flex: 1;                       /* todos iguales */
  max-width: 40px;               /* ancho fijo máximo */
  aspect-ratio: 1/1.2;           /* proporción cuadrada alta */
  font-size: 1.2rem;
  text-align: center;
  border: 2px solid #ccc;
  border-radius: 6px;
}

/* ===== MENSAJES DE ESTADO ===== */
/* Base: error (rojo) */
#status {
  border: 1px solid #e0b4b4 !important;
  background: #fff6f6 !important;
  color: #9f3a38 !important;
  display: none;
  margin: 10px 0;
  padding: 10px;
  border-radius: 8px;
}

/* Éxito (verde): fuerza sobre estilos inline */
html body #status.success,
#status.success[style] {
  border: 1px solid #b7e1cd !important;
  background: #f0fff4 !important;
  color: #1e4620 !important;
}
