/* ===================================================
   Infierno Festival · Almacén — theme.css v2
   =================================================== */

:root {
  --bg:      #0b0b0d;
  --panel:   #121218;
  --panel2:  #171722;
  --text:    #e9e9ee;
  --muted:   #a8a8b3;
  --red:     #e10600;
  --red2:    #ff2a1a;
  --border:  rgba(255,255,255,.08);
  --shadow:  rgba(0,0,0,.6);
  --ok:      #22c55e;
  --warn:    #f59e0b;
}

/* ── Base ──────────────────────────────────────────── */

html, body {
  color: var(--text);
  background:
    linear-gradient(rgba(0,0,0,.72), rgba(0,0,0,.72)),
    url("/assets/img/fondo.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  min-height: 100vh;
}

body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  display: flex;
  flex-direction: column;
}

a { color: var(--red2); }
a:hover { color: #fff; }

/* ── Tipografía ────────────────────────────────────── */

.brand {
  font-family: "Oswald", system-ui, sans-serif;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #fff !important;
}

.small-muted {
  color: var(--muted);
  font-size: .9rem;
}

/* ── Navbar ────────────────────────────────────────── */

.navbar {
  background: rgba(0,0,0,.65);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(6px);
}

/* ── Cards ─────────────────────────────────────────── */

.card, .modal-content {
  background: linear-gradient(180deg, var(--panel), var(--panel2));
  border: 1px solid var(--border);
  box-shadow: 0 10px 30px var(--shadow);
}

/* ── Forms ─────────────────────────────────────────── */

.form-control, .form-select {
  background: rgba(0,0,0,.35) !important;
  color: #fff !important;
  border: 1px solid var(--border);
}

.form-control:focus, .form-select:focus {
  border-color: rgba(225,6,0,.55) !important;
  box-shadow: 0 0 0 .25rem rgba(225,6,0,.15) !important;
  background: rgba(0,0,0,.35) !important;
  color: #fff !important;
}

.form-control::placeholder {
  color: rgba(255,255,255,.4) !important;
}

.form-label { color: #fff !important; }

.form-check-input {
  background-color: rgba(0,0,0,.35);
  border-color: rgba(255,255,255,.25);
}

/* ── Buttons ───────────────────────────────────────── */

.btn-danger {
  background: linear-gradient(180deg, var(--red2), var(--red));
  border: 1px solid rgba(255,42,26,.35);
  color: #fff !important;
}

.btn-danger:hover {
  background: linear-gradient(180deg, #ff4433, var(--red2));
  color: #fff !important;
}

.btn-outline-light {
  border-color: var(--border);
  color: var(--text);
}

.btn-outline-light:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.25);
  color: #fff;
}

/* ── Badges ────────────────────────────────────────── */

.badge.bg-success  { background: rgba(34,197,94,.2)   !important; color: #86efac; border: 1px solid rgba(34,197,94,.35); }
.badge.bg-warning  { background: rgba(245,158,11,.2)  !important; color: #fcd34d; border: 1px solid rgba(245,158,11,.35); }
.badge.bg-secondary{ background: rgba(148,163,184,.16)!important; color: #d1d5db; border: 1px solid rgba(148,163,184,.25); }
.badge.bg-danger   { background: rgba(225,6,0,.2)     !important; color: #fca5a5; border: 1px solid rgba(225,6,0,.35); }
.text-bg-success   { background: rgba(34,197,94,.2)   !important; color: #86efac !important; }
.text-bg-danger    { background: rgba(225,6,0,.2)     !important; color: #fca5a5 !important; }
.text-bg-secondary { background: rgba(148,163,184,.16)!important; color: #d1d5db !important; }

/* ── Role badges ───────────────────────────────────── */

.user-role-badge {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .08em;
  padding: 2px 7px;
  border-radius: 4px;
  text-transform: uppercase;
  font-family: "Oswald", system-ui, sans-serif;
}

.badge-admin {
  background: rgba(225,6,0,.25);
  color: #fca5a5;
  border: 1px solid rgba(225,6,0,.4);
}

.badge-worker {
  background: rgba(148,163,184,.2);
  color: #d1d5db;
  border: 1px solid rgba(148,163,184,.3);
}

/* ── Tables ────────────────────────────────────────── */

.table {
  color: var(--text);
  --bs-table-bg: transparent;
  --bs-table-hover-bg: rgba(255,255,255,.04);
}

.table thead th {
  color: var(--muted);
  border-color: var(--border);
  font-size: .82rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.table td, .table th {
  border-color: var(--border);
  vertical-align: middle;
}

.table td { color: var(--text); }

.table .btn-sm {
  font-size: .78rem;
  padding: .2rem .55rem;
  border-color: var(--border);
  color: var(--text);
  background: rgba(255,255,255,.05);
}

.table .btn-sm:hover {
  background: rgba(255,255,255,.12);
  color: #fff;
}

.table .btn.btn-danger {
  color: #fff;
  background: var(--red);
  border-color: rgba(255,42,26,.35);
}

.table .btn.btn-danger:hover {
  background: var(--red2);
}

/* ── Dropdown dark ─────────────────────────────────── */

.dropdown-menu-dark {
  background: var(--panel2);
  border: 1px solid var(--border);
}

.dropdown-menu-dark .dropdown-item {
  color: var(--text);
}

.dropdown-menu-dark .dropdown-item:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
}

.dropdown-menu-dark .dropdown-item.text-danger {
  color: #fca5a5 !important;
}

.dropdown-menu-dark .dropdown-divider {
  border-color: var(--border);
}

/* ── KPIs ──────────────────────────────────────────── */

.kpi {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.kpi .k {
  min-width: 160px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(0,0,0,.25);
}

.kpi .k .v {
  font-size: 26px;
  font-weight: 700;
  font-family: "Oswald", system-ui, sans-serif;
}

.kpi .k .l {
  color: var(--muted);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}

/* ── Pulse dot ─────────────────────────────────────── */

.pulse-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--red2);
  box-shadow: 0 0 0 0 rgba(255,42,26,.45);
  animation: pulse 1.6s infinite;
  flex-shrink: 0;
}

@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(255,42,26,.45); }
  70%  { box-shadow: 0 0 0 14px rgba(255,42,26,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,42,26,0); }
}

/* ── Checklist materiales ──────────────────────────── */

.materials-checklist {
  display: grid;
  gap: 8px;
  max-height: 260px;
  overflow: auto;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(0,0,0,.2);
}

.materials-checklist .mc-item {
  display: grid;
  grid-template-columns: 22px 1fr 92px;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  background: rgba(0,0,0,.18);
}

.materials-checklist .mc-name { font-weight: 600; color: #fff; }
.materials-checklist .mc-qty  { text-align: center; }
.materials-checklist .form-check-input { width: 18px; height: 18px; }

/* ── Worker vinculado ──────────────────────────────── */

.linked-worker-box {
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: rgba(0,0,0,.2);
  color: var(--text);
  display: flex;
  align-items: center;
}

/* ── Layout ────────────────────────────────────────── */

body > .container.py-4 { flex: 1 0 auto; }

.site-footer {
  margin-top: auto;
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  color: var(--muted);
}

/* ── Login page ────────────────────────────────────── */

.login-body {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.login-card {
  width: 100%;
  max-width: 420px;
  background: linear-gradient(180deg, var(--panel), var(--panel2));
  border: 1px solid var(--border);
  box-shadow: 0 20px 60px rgba(0,0,0,.7);
  border-radius: 20px;
  overflow: hidden;
}

.login-header {
  padding: 32px 32px 20px;
  text-align: center;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.login-body-inner {
  padding: 28px 32px 32px;
}

/* ── Modal ─────────────────────────────────────────── */

.modal-header {
  border-bottom: 1px solid var(--border);
}

.modal-header .btn-close-white {
  filter: invert(1) grayscale(1);
}

/* ── Alerts ────────────────────────────────────────── */

.alert-danger  { background: rgba(225,6,0,.15);    border-color: rgba(225,6,0,.35);    color: #fca5a5; }
.alert-success { background: rgba(34,197,94,.15);  border-color: rgba(34,197,94,.35);  color: #86efac; }
.alert-info    { background: rgba(59,130,246,.15); border-color: rgba(59,130,246,.35); color: #93c5fd; }
.alert-warning { background: rgba(245,158,11,.15); border-color: rgba(245,158,11,.35); color: #fcd34d; }

.alert .btn-close { filter: invert(1) grayscale(1); }
