:root {
  --bg: #0b0f1a;
  --surface: #0b0f1a;
  --surface-2: #24478a;
  --border: #24478a;
  --royal: #1b48c2;
  --royal-2: #24478a;
  --link: #4da3ff;
  --text: #ffffff;
  --muted: #ffffff;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}

/* Base */
html,body{background:var(--bg);color:var(--text)}
body{font-synthesis-weight:none;text-rendering:optimizeLegibility}
/* Forzar texto blanco por requerimiento del cliente */
body, body :where(p, h1, h2, h3, h4, h5, h6, label, input, select, textarea, table, th, td, small, span, li, div, article, nav, header, footer){
  color: var(--text) !important;
}
/* Enlaces también en blanco; los botones mantienen azul rey */
a{color:var(--text) !important}
/* Sobrescribir utilidades grises frecuentes (Tailwind/Welcome) */
.text-gray-400,.text-gray-500,.text-gray-600,.text-gray-900{color:var(--text) !important}
.dark\:text-gray-400,.dark\:text-white{color:var(--text) !important}
.hover\:text-gray-900:hover,.dark\:hover\:text-white:hover{color:var(--text) !important}
/* Pico componentes que tienden a atenuar */
small,.secondary,.muted,article.contrast{color:var(--text) !important}

/* Utilidades */
.container{max-width:1100px;margin:0 auto;padding:1rem}
.wrap{max-width:1080px;margin:0 auto;padding:1rem}
.title{font-weight:800;letter-spacing:.4px}
.badge,.pill{background:var(--royal-2);color:var(--text);border-radius:999px;padding:.25rem .6rem;font-size:.75rem}
.pill{font-size:.8rem}

/* Header / Hero */
.site-header{padding:2rem 1rem;text-align:center;background:linear-gradient(135deg,var(--bg) 0%,var(--surface-2) 100%);border-bottom:1px solid var(--border)}

/* Tarjetas y paneles */
.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.card .content{padding:1rem}
.card img{width:100%;height:180px;object-fit:cover}

/* Botones */
button,.button,.btn{background:var(--royal);color:#fff;border:1px solid transparent;border-radius:12px;padding:.65rem 1rem;cursor:pointer;transition:transform .15s ease,filter .15s ease,background .15s ease}
button:hover,.button:hover,.btn:hover{filter:brightness(1.05)}
button:active,.button:active,.btn:active{transform:translateY(1px)}
.btn-outline{background:transparent;border-color:var(--royal);color:var(--link)}

/* Formularios */
input[type="text"],input[type="email"],input[type="number"],input[type="datetime-local"],input[type="file"],textarea,select{
  background:rgba(18,25,43,.65);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:.6rem .75rem;outline:none
}
input::placeholder,textarea::placeholder{color:var(--muted)}
label{display:block;margin:.5rem 0}
fieldset{border:1px solid var(--border);border-radius:12px;padding:.75rem}

/* Tabla */
table{width:100%;border-collapse:separate;border-spacing:0;background:transparent;border:1px solid var(--border);border-radius:12px;overflow:hidden}
th,td{padding:.75rem;border-bottom:1px solid var(--border)}
thead tr{background:rgba(15,30,70,.6)}
tbody tr:nth-child(even){background:rgba(18,25,43,.35)}

/* Grids reutilizables */
.grid{display:grid;gap:1rem}
.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.grid-2{grid-template-columns:1fr 1fr;gap:2rem}

/* Números de rifa */
.numbers{display:grid;grid-template-columns:repeat(8,1fr);gap:.5rem;max-height:420px;overflow:auto}
.num{padding:.5rem;text-align:center;border-radius:10px;border:1px solid var(--border);cursor:pointer}
.num.available{background:#12213b}
.num.reserved{background:#2a2540;opacity:.6;cursor:not-allowed}
.num.sold{background:#3a1f2b;opacity:.6;cursor:not-allowed}
.num.selected{outline:2px solid var(--link)}

/* Galería */
.gallery{display:grid;grid-template-columns:1fr;gap:1rem}
.gallery img{width:100%;border-radius:16px;border:1px solid var(--border)}

/* Paginación básica */
.pagination{display:flex;gap:.5rem;justify-content:center;margin:1.25rem 0}
.pagination a,.pagination span{padding:.4rem .65rem;border:1px solid var(--border);border-radius:8px;background:rgba(18,25,43,.5)}

/* Footer meta */
.meta{color:var(--muted)}
