:root {
  --bg: #f6f8fb;
  --surface: #ffffff;
  --surface-2: #f8fafc;
  --line: #e2e8f0;
  --line-strong: #cbd5e1;
  --text: #18212f;
  --muted: #64748b;
  --soft: #94a3b8;
  --brand: #9b5a31;
  --brand-2: #c87942;
  --brand-soft: #fff4ed;
  --ink: #1e293b;
  --good: #16825d;
  --warn: #b7791f;
  --bad: #be3a3a;
  --blue: #2563eb;
  --shadow: 0 22px 60px rgba(15, 23, 42, .08);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  font-family: Inter, "Segoe UI", Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
}

body {
  background:
    radial-gradient(circle at 10% -10%, rgba(200, 121, 66, .14), transparent 28rem),
    radial-gradient(circle at 100% 0%, rgba(37, 99, 235, .10), transparent 30rem),
    var(--bg);
}

button,
input,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

a {
  color: inherit;
  text-decoration: none;
}

.boot-screen,
.login-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px;
}

.boot-card,
.login-card {
  width: min(100%, 460px);
  background: rgba(255, 255, 255, .88);
  border: 1px solid rgba(226, 232, 240, .9);
  border-radius: 28px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}

.boot-card {
  padding: 32px;
  text-align: center;
}

.boot-card img,
.login-brand img {
  max-width: 245px;
}

.boot-card p {
  color: var(--muted);
  margin: 18px 0 0;
}

.login-wrap {
  width: min(1180px, 100%);
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 28px;
  align-items: stretch;
}

.login-hero {
  background: linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(248, 250, 252, .86));
  border: 1px solid rgba(226, 232, 240, .92);
  border-radius: 34px;
  padding: 40px 34px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 30px;
}

.login-hero h1 {
  max-width: 620px;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.04;
  letter-spacing: -0.04em;
  margin: 16px 0 14px;
  color: var(--ink);
}

.login-hero p {
  color: var(--muted);
  font-size: 17px;
  line-height: 1.55;
  max-width: 560px;
  margin: 0;
}

.login-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  color: var(--muted);
  border-radius: 999px;
  padding: 5px 11px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.login-hero__badge::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--brand-2);
}

.login-hero__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.login-hero__card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 15px;
}

.login-hero__card strong {
  display: block;
  font-size: 15px;
  font-weight: 850;
  letter-spacing: -0.01em;
  margin-bottom: 4px;
  color: var(--ink);
}

.login-hero__card span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

.login-tagline {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
  margin: 0 0 22px;
}

.password-field {
  position: relative;
  display: flex;
  align-items: center;
}

.password-field input {
  padding-right: 84px;
}

.password-toggle {
  position: absolute;
  right: 8px;
  border: 0;
  background: transparent;
  color: var(--brand);
  font-size: 12px;
  font-weight: 800;
  padding: 6px 8px;
  border-radius: 9px;
}

.password-toggle:hover {
  background: var(--brand-soft);
}

.btn-block {
  width: 100%;
  padding: 14px 16px;
  font-size: 15px;
}

.login-dev {
  margin-top: 24px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface-2);
}

.login-dev__summary {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  list-style: none;
  cursor: pointer;
  user-select: none;
  border-radius: 14px;
}

.login-dev__summary::-webkit-details-marker {
  display: none;
}

.login-dev__summary:hover {
  background: rgba(15, 23, 42, .03);
}

.login-dev__summary:focus-visible {
  outline: 2px solid rgba(200, 121, 66, .35);
  outline-offset: 2px;
}

.login-dev__badge {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  color: var(--muted);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.login-dev__title {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.login-dev__chevron {
  margin-left: auto;
  color: var(--soft);
  font-size: 13px;
  transition: transform .18s ease;
}

.login-dev[open] .login-dev__chevron {
  transform: rotate(180deg);
}

.login-dev__body {
  padding: 4px 14px 14px;
  border-top: 1px solid var(--line);
}

/* Cerrado por defecto: ocultar el cuerpo de forma explícita (no depender
   del render implícito de <details>, que varía entre navegadores). */
.login-dev:not([open]) .login-dev__body {
  display: none;
}

.login-dev__body .field {
  margin: 12px 0;
}

.eyebrow {
  display: inline-flex;
  width: fit-content;
  border: 1px solid #fed7aa;
  background: var(--brand-soft);
  color: #8a4a25;
  border-radius: 999px;
  padding: 8px 13px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.metric-card,
.panel,
.module-card,
.alert-row,
.action-row {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: 0 12px 34px rgba(15, 23, 42, .05);
}

.muted {
  color: var(--muted);
}

.login-card {
  padding: 30px;
}

.password-card {
  width: min(100%, 520px);
}

.login-brand {
  margin-bottom: 28px;
}

.login-card h2 {
  margin: 0 0 8px;
  font-size: 30px;
  letter-spacing: -0.04em;
}

.login-card p {
  color: var(--muted);
  margin: 0 0 24px;
  line-height: 1.5;
}

.field {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.field label {
  color: var(--ink);
  font-size: 13px;
  font-weight: 850;
}

.field-hint {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  border: 1px solid var(--line-strong);
  background: #fff;
  color: var(--text);
  border-radius: 14px;
  padding: 13px 14px;
  outline: none;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: var(--brand-2);
  box-shadow: 0 0 0 4px rgba(200, 121, 66, .12);
}

.field textarea {
  resize: vertical;
  min-height: 96px;
  line-height: 1.45;
}

.static-field {
  display: grid;
  gap: 7px;
  border: 1px solid var(--line);
  background: #f8fafc;
  border-radius: 14px;
  padding: 13px 14px;
  margin-bottom: 16px;
}

.static-field span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.static-field strong {
  font-size: 17px;
}

.calculated-input {
  border-color: #86efac !important;
  background: #ecfdf5 !important;
  color: #047857 !important;
  font-weight: 950;
}

.paste-box {
  font-family: Consolas, "Courier New", monospace;
  font-size: 13px;
}

.form-section {
  border: 1px solid var(--line);
  background: var(--surface-2);
  border-radius: 18px;
  padding: 16px;
  margin-bottom: 14px;
}

.form-section-title {
  font-size: 15px;
  font-weight: 950;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.compact-grid .field {
  margin-bottom: 0;
}

.btn {
  border: 0;
  border-radius: 14px;
  padding: 12px 16px;
  font-weight: 900;
  display: inline-flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
}

.btn-primary {
  background: var(--ink);
  color: #fff;
}

.btn-primary:hover {
  background: #0f172a;
}

/* Boton Tipo 1 - Accion principal compacta */
.btn-primary-compact {
  width: fit-content;
  max-width: 100%;
  border: 1px solid #3f556f;
  border-radius: 999px;
  background: #102033;
  color: #fff;
  padding: 10px 15px;
  font-size: 13px;
  line-height: 1.1;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .13);
  white-space: normal;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease;
}

.btn-primary-compact:hover {
  background: #0f2a3b;
  border-color: #6d8aa6;
  box-shadow: 0 14px 28px rgba(15, 23, 42, .17);
  transform: translateY(-1px);
}

.btn-primary-compact:focus-visible {
  outline: 3px solid rgba(37, 99, 235, .26);
  outline-offset: 3px;
}

.btn-ghost {
  background: #fff;
  color: var(--ink);
  border: 1px solid var(--line);
}

.btn-soft {
  background: var(--brand-soft);
  color: #7a4323;
  border: 1px solid #fed7aa;
}

.btn:disabled {
  opacity: .62;
  cursor: wait;
}

.btn-small {
  padding: 8px 10px;
  border-radius: 11px;
  font-size: 12px;
}

.btn-primary-compact.btn-small {
  border-radius: 999px;
  padding: 8px 12px;
}

/* Boton de pago - accion de dinero (verde), gemelo de la pildora compacta.
   Verde de marca (#16a34a) con texto blanco para maxima legibilidad. */
.btn-success {
  width: fit-content;
  max-width: 100%;
  border: 1px solid #15803d;
  border-radius: 999px;
  background: #16a34a;
  color: #fff;
  padding: 10px 15px;
  font-size: 13px;
  line-height: 1.1;
  box-shadow: 0 10px 22px rgba(16, 163, 74, .18);
  white-space: normal;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease;
}

.btn-success:hover {
  background: #15803d;
  border-color: #166534;
  box-shadow: 0 14px 28px rgba(16, 163, 74, .22);
  transform: translateY(-1px);
}

.btn-success:focus-visible {
  outline: 3px solid rgba(22, 163, 74, .28);
  outline-offset: 3px;
}

.btn-success.btn-small {
  border-radius: 999px;
  padding: 8px 12px;
}

/* Acciones de las tablas de nomina: una pildora por celda (columnas Pago / Firma),
   todas del mismo alto/forma y sin sombra, para que se vean homologadas y limpias. */
.payroll-action-cell .btn {
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  box-shadow: none;
}

.payroll-action-cell .muted {
  font-size: 12px;
}

/* Navegador de semanas del resumen de nomina: ir a semanas anteriores para
   pagar pendientes rezagados, volver a la semana vigente. */
.payroll-week-nav {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.payroll-week-nav__label {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
  text-align: center;
  min-width: 190px;
}

.payroll-week-nav__label .muted {
  font-size: 12px;
}

.payroll-week-nav__spacer {
  flex: 1 1 auto;
}

/* Aviso de pendientes accionable (texto + boton para saltar a esa semana). */
.payroll-warning {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.payroll-warning__text {
  flex: 1 1 auto;
}

.login-actions {
  display: grid;
  gap: 12px;
  margin-top: 8px;
}

.error-box,
.notice-box {
  display: none;
  border-radius: 16px;
  padding: 13px 14px;
  font-weight: 760;
  line-height: 1.42;
}

.error-box {
  background: #fff1f2;
  color: #9f1239;
  border: 1px solid #fecdd3;
}

.notice-box {
  background: #eff6ff;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
}

.error-box.active,
.notice-box.active {
  display: block;
}

.page-error {
  margin-bottom: 16px;
}

.layout {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 292px 1fr;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 16px 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(248, 250, 252, .88));
  border-right: 1px solid var(--line);
  backdrop-filter: blur(18px);
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.brand-box {
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 14px 14px 12px;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(200, 121, 66, .08), transparent 60%),
    linear-gradient(180deg, #fff, #f8fafc);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .6) inset, 0 6px 18px -12px rgba(15, 23, 42, .15);
}

.brand-box img {
  width: 200px;
  max-width: 100%;
  display: block;
}

.branch-select {
  margin-top: 12px;
}

.nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow: auto;
  padding: 4px 2px 8px;
  scrollbar-width: thin;
  scrollbar-color: var(--line-strong) transparent;
}

.nav::-webkit-scrollbar { width: 6px; }
.nav::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 99px; }

.nav-section {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: 10px;
}

.nav-section:first-of-type { margin-top: 4px; }

.nav-title {
  font-size: 10.5px;
  color: var(--soft);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 800;
  margin: 6px 12px 6px;
}

.nav-item-wrap {
  position: relative;
  border-radius: 12px;
}

.nav-item {
  position: relative;
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--muted);
  border-radius: 12px;
  padding: 10px 12px;
  display: grid;
  grid-template-columns: 22px 1fr auto;
  gap: 12px;
  align-items: center;
  text-align: left;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .005em;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}

.nav-item__icon {
  display: inline-flex;
  width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  color: var(--soft);
  transition: color .18s ease, transform .18s ease;
}

.nav-item__icon svg {
  width: 18px;
  height: 18px;
}

.nav-item__label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.nav-item__chevron {
  display: inline-flex;
  width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  color: var(--soft);
  transition: transform .22s ease, background .18s ease, color .18s ease;
}

.nav-item__chevron svg {
  width: 14px;
  height: 14px;
}

.nav-item__chevron:hover {
  background: rgba(15, 23, 42, .06);
  color: var(--ink);
}

.nav-item-wrap.is-open > .nav-item .nav-item__chevron {
  transform: rotate(90deg);
}

.nav-item:hover {
  background: rgba(15, 23, 42, .045);
  color: var(--ink);
}

.nav-item:hover .nav-item__icon {
  color: var(--brand);
}

.nav-item.active {
  color: #fff;
  background:
    linear-gradient(135deg, var(--ink) 0%, #2a3a52 100%);
  box-shadow:
    0 8px 20px -10px rgba(30, 41, 59, .55),
    inset 0 1px 0 rgba(255, 255, 255, .08);
}

.nav-item.active .nav-item__icon,
.nav-item.active .nav-item__chevron {
  color: #fff;
}

.nav-item.active::before {
  content: "";
  position: absolute;
  left: -14px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 22px;
  border-radius: 0 4px 4px 0;
  background: var(--brand-2);
  box-shadow: 0 0 12px rgba(200, 121, 66, .5);
}

.nav-sub {
  position: relative;
  margin: 2px 0 6px 22px;
  padding: 2px 0 2px 14px;
  display: flex;
  flex-direction: column;
  gap: 1px;
  animation: navSubReveal .22s ease;
}

.nav-sub::before {
  content: "";
  position: absolute;
  top: 6px;
  bottom: 6px;
  left: 0;
  width: 1px;
  background: linear-gradient(180deg, var(--line) 0%, var(--line-strong) 100%);
}

.nav-sub[hidden] {
  display: none;
}

@keyframes navSubReveal {
  from { opacity: 0; transform: translateY(-2px); }
  to { opacity: 1; transform: translateY(0); }
}

.nav-sub__item {
  position: relative;
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--muted);
  border-radius: 10px;
  padding: 8px 10px 8px 14px;
  display: flex;
  gap: 10px;
  align-items: center;
  text-align: left;
  font-weight: 600;
  font-size: 13px;
  transition: background .15s ease, color .15s ease, padding-left .15s ease;
}

.nav-sub__dot {
  width: 5px;
  height: 5px;
  border-radius: 99px;
  background: var(--line-strong);
  transition: background .15s ease, transform .15s ease, box-shadow .15s ease;
  flex-shrink: 0;
}

.nav-sub__item:hover {
  background: rgba(15, 23, 42, .04);
  color: var(--ink);
  padding-left: 16px;
}

.nav-sub__item:hover .nav-sub__dot {
  background: var(--brand);
}

.nav-sub__item.active {
  color: var(--ink);
  background: var(--brand-soft);
  font-weight: 800;
}

.nav-sub__item.active .nav-sub__dot {
  background: var(--brand-2);
  transform: scale(1.6);
  box-shadow: 0 0 0 3px rgba(200, 121, 66, .15);
}

.user-box {
  margin-top: auto;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 15px;
  background: #fff;
}

.user-name {
  font-weight: 950;
  margin-bottom: 3px;
}

.role-line {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.main {
  min-width: 0;
  padding: 28px;
}

.topbar {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-start;
  margin-bottom: 24px;
}

.page-title {
  margin: 0;
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1;
  letter-spacing: -0.055em;
}

.page-sub {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.5;
}

.page-breadcrumb {
  margin: 10px 0 2px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--soft);
  text-transform: uppercase;
}

/* Variante para el breadcrumb dentro del encabezado de sección homologado:
   discreto, sin saturar, justo encima del título. */
.page-breadcrumb--inline {
  margin: 0 0 6px;
}

.top-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.pill {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 999px;
  padding: 8px 12px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.grid {
  display: grid;
  gap: 16px;
}

.grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.grid-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.metric-card,
.panel,
.module-card {
  padding: 20px;
}

.metric-label {
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.metric-value {
  margin-top: 10px;
  font-size: 30px;
  font-weight: 950;
  letter-spacing: -0.055em;
}

.metric-note {
  margin-top: 6px;
  color: var(--soft);
  font-size: 13px;
}

.panel h3,
.module-card h3 {
  margin: 0 0 14px;
  font-size: 22px;
  letter-spacing: -0.04em;
}

.operation-grid {
  margin-top: 16px;
  align-items: start;
}

.operation-kpis .metric-card {
  border-color: #cbd5e1;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .08);
}

.operation-actions {
  margin-top: 22px;
}

.supplies-dashboard-kpis .metric-card-hero {
  border-color: #d69c62;
  background: #fff4e7;
  box-shadow: 0 18px 44px rgba(214, 156, 98, .18);
}

.metric-card-hero span {
  display: block;
  color: #8a4a25;
  font-size: 13px;
  font-weight: 900;
}

.metric-card-hero strong {
  display: block;
  margin-top: 10px;
  color: var(--ink);
  font-size: 36px;
  font-weight: 950;
  letter-spacing: 0;
}

.metric-card-hero small {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  line-height: 1.35;
}

.supplies-actions .modules {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.supplies-catalog-actions .modules {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.supplies-actions .operation-action-card {
  min-height: 210px;
}

.supplies-action-small {
  min-height: 150px;
  background: #fffdf9;
  box-shadow: none;
}

.supplies-mode-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 16px 0;
}

.supplies-catalog-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  gap: 16px;
  align-items: start;
}

.supplies-catalog-layout > .panel:first-child:only-child {
  grid-column: 1 / -1;
}

.supplies-count-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(340px, .75fr);
  gap: 16px;
  align-items: start;
  margin-top: 16px;
}

.tips-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  align-items: start;
  margin-top: 20px;
  max-width: 1480px;
}

.tips-followup-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
  margin-top: 22px;
  max-width: 1480px;
}

.general-expense-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  align-items: start;
  margin-top: 20px;
}

.general-expense-register-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 380px);
  gap: 16px;
  align-items: start;
  margin-top: 20px;
  max-width: 1320px;
}

.general-expense-catalog-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  gap: 16px;
  align-items: start;
  margin-top: 20px;
}

.general-expense-actions .modules {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.general-expense-actions .operation-action-card {
  min-height: 190px;
}

.general-expense-action-secondary {
  background: #fbfdff;
  box-shadow: none;
}

.general-expense-kpis .metric-card {
  border-color: #cbd5e1;
  box-shadow: 0 18px 38px rgba(15, 23, 42, .07);
}

.general-expense-main-panel,
.general-expense-detail-panel,
.general-expense-history-panel,
.general-expense-register-summary,
.general-expense-editor-panel {
  border-color: #cbd5e1;
  box-shadow: 0 18px 38px rgba(15, 23, 42, .07);
}

.general-expense-main-panel {
  min-width: 0;
}

.general-expense-form {
  display: grid;
  gap: 14px;
}

.general-expense-form-section {
  margin-bottom: 0;
}

.general-expense-base-grid,
.general-expense-form .form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.general-expense-concept-section {
  border-color: #a7c4ee;
  border-width: 2px;
  background: #f8fbff;
}

.general-expense-concept-field {
  margin-bottom: 0;
}

.general-expense-concept-field label {
  font-size: 15px;
  font-weight: 950;
}

.general-expense-concept-field input {
  min-height: 56px;
  border-color: #93c5fd;
  border-width: 2px;
  font-size: 17px;
  font-weight: 800;
}

.general-expense-support-section {
  background: #fbfdff;
}

.general-expense-notes-field textarea {
  min-height: 74px;
  font-size: 13px;
}

.general-expense-impact-box {
  display: grid;
  gap: 10px;
  border-color: #bbf7d0;
  background: #f8fffb;
}

.general-expense-impact-list {
  display: grid;
  gap: 7px;
}

.general-expense-impact-list span {
  color: #166534;
  font-size: 13px;
  font-weight: 850;
}

.general-expense-submit-row {
  border-top: 1px solid var(--line);
  padding-top: 16px;
  display: flex;
  justify-content: flex-end;
}

.general-expense-submit-button {
  min-height: 46px;
  min-width: min(100%, 220px);
}

.general-expense-register-summary {
  position: sticky;
  top: 18px;
  background: #fbfdff;
}

.general-expense-register-summary-list .detail-line {
  grid-template-columns: 1fr;
  gap: 4px;
}

.general-expense-history-panel {
  min-width: 0;
}

.general-expense-history-panel .table-wrap {
  overflow-x: auto;
}

.general-expense-history-panel table {
  min-width: 1200px;
}

.general-expense-detail-panel {
  background: #fbfdff;
  box-shadow: 0 12px 26px rgba(15, 23, 42, .06);
}

/* ── Detalle del gasto seleccionado (rediseño con jerarquía) ───────────── */
.gx-detail {
  display: grid;
  gap: 18px;
}

.gx-detail__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}

.gx-detail__folio {
  display: grid;
  gap: 2px;
}

.gx-detail__folio-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}

.gx-detail__folio strong {
  font-size: 18px;
  font-weight: 950;
  letter-spacing: -0.01em;
  color: var(--ink);
}

.gx-detail__header-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.gx-detail__chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  font-size: 12px;
  font-weight: 800;
  color: var(--ink);
}

/* Bloque protagonista: descripción grande + tarjeta de importe */
.gx-detail__hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(170px, 200px);
  gap: 14px;
  align-items: stretch;
}

.gx-detail__concept {
  display: grid;
  gap: 10px;
  align-content: start;
}

.gx-detail__eyebrow {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}

.gx-detail__concept-text {
  margin: 0;
  font-size: 20px;
  line-height: 1.3;
  font-weight: 900;
  letter-spacing: -0.01em;
  color: var(--ink);
  overflow-wrap: anywhere;
}

.gx-detail__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.gx-detail__tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 8px;
  background: var(--brand-soft);
  border: 1px solid #f0d8c6;
  font-size: 12px;
  font-weight: 850;
  color: var(--brand);
}

.gx-detail__amount-card {
  display: grid;
  gap: 2px;
  align-content: center;
  justify-items: end;
  text-align: right;
  padding: 14px 16px;
  border-radius: 14px;
  background: linear-gradient(160deg, #fff6ef, #fdece0);
  border: 1px solid #f0d8c6;
}

.gx-detail__amount-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--brand);
}

.gx-detail__amount {
  font-size: 27px;
  line-height: 1.1;
  font-weight: 950;
  letter-spacing: -0.02em;
  color: var(--brand);
}

.gx-detail__amount-foot {
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
}

.gx-detail__amount-card--cancelled {
  background: var(--surface-2);
  border-color: var(--line);
}

.gx-detail__amount-card--cancelled .gx-detail__amount-label,
.gx-detail__amount-card--cancelled .gx-detail__amount {
  color: var(--bad);
}

.gx-detail__amount-card--cancelled .gx-detail__amount {
  text-decoration: line-through;
  text-decoration-thickness: 2px;
}

/* Bloques secundarios (tesorería, notas, cancelación) */
.gx-detail__block {
  display: grid;
  gap: 10px;
}

.gx-detail__block-title {
  margin: 0;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .02em;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 8px;
}

.gx-detail__rows {
  display: grid;
  gap: 8px;
}

.gx-detail__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
}

.gx-detail__row-label {
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
  flex: 0 0 auto;
}

.gx-detail__row-value {
  font-size: 13px;
  font-weight: 850;
  color: var(--ink);
  text-align: right;
  overflow-wrap: anywhere;
}

.gx-detail__flag {
  display: inline-flex;
  align-items: center;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 850;
}

.gx-detail__flag--out {
  background: #fdeaea;
  color: var(--bad);
}

.gx-detail__block--alert .gx-detail__row {
  background: #fdf4f4;
  border-color: #f3d3d3;
}

.gx-detail__notes {
  margin: 0;
  padding: 11px 13px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  font-size: 13px;
  line-height: 1.5;
  color: var(--text);
  overflow-wrap: anywhere;
}

.gx-detail__notes--empty {
  background: transparent;
  border-style: dashed;
  color: var(--muted);
  font-style: italic;
  font-weight: 700;
}

.gx-detail__actions {
  border-top: 1px solid var(--line);
  padding-top: 14px;
  display: flex;
  justify-content: flex-end;
}

.gx-detail__cancel-btn {
  border: 1px solid #fecaca;
  color: #991b1b;
}

/* Bloque de evidencia */
.gx-evidence__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.gx-evidence__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--brand-soft);
  color: var(--brand);
  font-size: 12px;
  font-weight: 900;
}

.gx-evidence__empty {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  border: 1px dashed var(--line-strong);
  border-radius: 12px;
  background: var(--surface-2);
}

.gx-evidence__empty-icon {
  font-size: 22px;
  line-height: 1;
}

.gx-evidence__empty-text {
  display: grid;
  gap: 2px;
  flex: 1 1 auto;
  min-width: 0;
}

.gx-evidence__empty-text strong {
  font-size: 14px;
  font-weight: 900;
  color: var(--ink);
}

.gx-evidence__empty-text span {
  font-size: 12px;
}

.gx-evidence__upload-btn {
  background: var(--brand);
  color: #fff;
  border: 1px solid var(--brand);
  white-space: nowrap;
  flex: 0 0 auto;
}

.gx-evidence__upload-btn:hover:not(:disabled) {
  background: var(--brand-2);
  border-color: var(--brand-2);
}

.gx-evidence__upload-btn:disabled {
  opacity: .6;
  cursor: progress;
}

.gx-evidence__upload-btn--sm {
  padding: 7px 12px;
  font-size: 13px;
  border-radius: 10px;
}

/* Acción rápida de evidencia en la tabla */
.gx-table-evidence {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.gx-table-evidence__upload {
  border: 1px solid var(--line-strong);
  background: var(--surface);
  color: var(--brand);
  border-radius: 8px;
  padding: 3px 8px;
  font-size: 12px;
  font-weight: 850;
  cursor: pointer;
}

.gx-table-evidence__upload:hover {
  background: var(--brand-soft);
  border-color: var(--brand);
}

.general-expense-evidence-section {
  border-top: 1px solid var(--line);
  margin-top: 16px;
  padding-top: 16px;
}

.general-expense-evidence-section h4 {
  color: var(--ink);
  font-size: 15px;
  margin: 0 0 10px;
}

.general-expense-evidence-list {
  display: grid;
  gap: 10px;
}

.general-expense-evidence-item {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  display: grid;
  gap: 12px;
  grid-template-columns: 76px minmax(0, 1fr) auto;
  padding: 10px;
}

.general-expense-evidence-thumb,
.general-expense-evidence-icon {
  align-items: center;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--muted);
  display: flex;
  font-size: 12px;
  font-weight: 950;
  height: 58px;
  justify-content: center;
  overflow: hidden;
  width: 76px;
}

.general-expense-evidence-thumb img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.general-expense-evidence-meta {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.general-expense-evidence-meta strong {
  color: var(--ink);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.general-expense-evidence-meta span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.general-expense-evidence-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.general-expense-history-button {
  min-height: 40px;
  padding-inline: 16px;
}

.general-expense-filters {
  display: grid;
  grid-template-columns: minmax(220px, 1.2fr) minmax(180px, .8fr) minmax(160px, .7fr) minmax(150px, .65fr) minmax(150px, .65fr) auto auto;
  gap: 12px;
  align-items: end;
  margin-bottom: 14px;
}

.general-expense-summary {
  margin: 14px 0;
}

.table-sort-button {
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  font-weight: 800;
  padding: 0;
  text-align: left;
}

.table-sort-button.active {
  color: var(--accent);
}

tr.cancelled-row {
  background: #fff1f2;
}

tr.cancelled-row:hover {
  background: #ffe4e6;
}

tr.cancelled-row.selected-row {
  background: #ffe4e6;
}

.general-expense-pagination {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 14px;
}

.payroll-kpis .metric-card {
  border-color: #d8c5aa;
  box-shadow: 0 18px 38px rgba(80, 46, 24, .07);
}

.payroll-actions .modules {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.payroll-actions .operation-action-card,
.payroll-action-card {
  min-height: 170px;
}

.payroll-panel,
.payroll-history-panel,
.payroll-detail-panel,
.payroll-editor-panel,
.payroll-total-box {
  border-color: #d8c5aa;
  box-shadow: 0 18px 38px rgba(80, 46, 24, .07);
}

.payroll-payment-layout,
.payroll-collaborators-layout,
.payroll-history-layout {
  display: grid;
  gap: 16px;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  margin-top: 20px;
}

.payroll-history-layout {
  grid-template-columns: minmax(0, .9fr) minmax(360px, 1.1fr);
}

.payroll-panel,
.payroll-history-panel,
.payroll-detail-panel,
.payroll-editor-panel {
  min-width: 0;
}

.payroll-form {
  display: grid;
  gap: 16px;
}

.payroll-form-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.payroll-total-box {
  background: #fffaf3;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 10px;
  padding: 14px;
}

.payroll-payment-summary {
  position: sticky;
  top: 18px;
}

.payroll-week-group {
  border: 1px solid var(--line);
  border-radius: 8px;
  margin-bottom: 12px;
  overflow: hidden;
}

.payroll-week-group-head,
.payroll-week-group-totals {
  align-items: center;
  background: #fff7ed;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: space-between;
  padding: 12px 14px;
}

.payroll-week-group-totals {
  background: #fff;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.payroll-subhead {
  align-items: flex-end;
  display: flex;
  gap: 14px;
  justify-content: space-between;
  margin: 18px 0 14px;
}

.payroll-subhead h2 {
  margin: 0;
}

.payroll-admin-filters {
  align-items: end;
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(160px, .75fr) repeat(3, minmax(160px, 1fr)) auto;
  margin-bottom: 14px;
}

.payroll-warning {
  margin: 14px 0;
}

.payroll-panel .table-wrap,
.payroll-history-panel .table-wrap,
.payroll-detail-panel .table-wrap {
  overflow-x: auto;
}

/* ── Registrar pago de nómina: contexto, ficha, conceptos, resumen ────────── */
.payroll-context {
  align-items: center;
  background: var(--brand-soft);
  border: 1px solid #e9d8c4;
  border-radius: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  justify-content: space-between;
  padding: 10px 14px;
}

.payroll-context__info {
  align-items: center;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  font-size: 13px;
  gap: 8px;
}

.payroll-context__chip {
  background: #fff;
  border: 1px solid #e9d8c4;
  border-radius: 999px;
  color: var(--brand);
  font-weight: 700;
  padding: 3px 12px;
}

.payroll-context__dot { color: var(--soft); }
.payroll-context__week { color: var(--ink); font-weight: 700; }

.payroll-context__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.payroll-context-editor {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.payroll-context-editor[hidden] { display: none; }

/* Cambiar sucursal en el formulario de evento nuevo (mismo patrón que nómina). */
.event-branch-context { margin-bottom: 14px; }
.event-branch-editor { margin-bottom: 16px; grid-template-columns: minmax(0, 360px); }

.payroll-block {
  display: grid;
  gap: 14px;
}

.payroll-block__title {
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .01em;
  margin: 0;
  padding-bottom: 8px;
}

.payroll-collab-field label { font-weight: 700; }

.payroll-collab-card {
  background: #fffaf3;
  border: 1px solid #e9d8c4;
  border-radius: 10px;
  display: grid;
  gap: 14px;
  padding: 16px;
}

.payroll-collab-card__hero {
  align-items: center;
  display: flex;
  gap: 14px;
}

.payroll-collab-card__avatar {
  align-items: center;
  background: var(--brand);
  border-radius: 50%;
  color: #fff;
  display: flex;
  flex: 0 0 auto;
  font-size: 16px;
  font-weight: 800;
  height: 46px;
  justify-content: center;
  width: 46px;
}

.payroll-collab-card__headline {
  display: grid;
  gap: 4px;
  min-width: 0;
}

/* Primera jerarquía: nombre grande. */
.payroll-collab-card__name {
  color: var(--ink);
  font-size: 20px;
  font-weight: 800;
  line-height: 1.15;
}

/* Segunda jerarquía: sueldo base resaltado. */
.payroll-collab-card__base {
  align-items: baseline;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.payroll-collab-card__base-label {
  color: var(--muted);
  font-size: 12px;
}

.payroll-collab-card__base-value {
  color: var(--brand);
  font-size: 17px;
  font-weight: 800;
}

/* Tercera jerarquía: puesto, hora extra y bono como chips. */
.payroll-collab-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.payroll-chip {
  background: #fff;
  border: 1px solid #e9d8c4;
  border-radius: 999px;
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 5px 12px;
}

.payroll-chip__label {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.payroll-chip__value {
  color: var(--ink);
  font-size: 13px;
  font-weight: 700;
}

.payroll-chip__value--muted {
  color: var(--soft);
  font-weight: 600;
}

/* ── Asistencia / días pagados ────────────────────────────────────────────── */
.payroll-attendance {
  background: #fff;
  border: 1px solid #e9d8c4;
  border-radius: 10px;
  padding: 0;
  gap: 0;
  overflow: hidden;
}

.payroll-attendance__head {
  align-items: center;
  background: none;
  border: 0;
  cursor: pointer;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
  justify-content: space-between;
  padding: 14px 16px;
  text-align: left;
  width: 100%;
}

.payroll-attendance__title {
  color: var(--ink);
  font-size: 14px;
  font-weight: 800;
}

.payroll-attendance__summary {
  color: var(--muted);
  flex: 1 1 auto;
  font-size: 13px;
  text-align: right;
}

.payroll-attendance__chevron {
  color: var(--soft);
  transition: transform .15s;
}

.payroll-attendance--open .payroll-attendance__chevron {
  transform: rotate(180deg);
}

.payroll-attendance__body {
  border-top: 1px solid var(--line);
  display: grid;
  gap: 14px;
  padding: 14px 16px;
}

/* El display:grid de arriba gana sobre el [hidden] del navegador; lo reinstauramos. */
.payroll-attendance__body[hidden] {
  display: none;
}

.payroll-attendance__days {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.payroll-day {
  align-items: center;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 4px;
  text-align: center;
}

.payroll-day:has(input:checked) {
  background: #ecfdf5;
  border-color: var(--good);
}

.payroll-day:has(input:not(:checked)) {
  background: #fef2f2;
  border-color: var(--bad);
}

.payroll-day input { accent-color: var(--good); margin: 0; }
.payroll-day:has(input:not(:checked)) input { accent-color: var(--bad); }

.payroll-day__label {
  color: var(--ink);
  font-size: 11px;
  font-weight: 700;
  text-transform: capitalize;
}

.payroll-attendance__facts {
  border-top: 1px dashed var(--line);
  display: grid;
  gap: 6px;
  padding-top: 12px;
}

.payroll-attendance__note {
  color: var(--bad);
  font-size: 12px;
  font-weight: 600;
  margin: 4px 0 0;
}

.payroll-segment--disabled {
  opacity: .55;
  pointer-events: none;
}

.payroll-bonus-forced {
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 8px;
  color: var(--bad);
  font-size: 12px;
  font-weight: 600;
  margin: 0;
  padding: 8px 10px;
}

.payroll-bonus-control {
  background: #fff;
  border: 1px solid #e9d8c4;
  border-radius: 10px;
  display: grid;
  gap: 10px;
  padding: 14px 16px;
}

.payroll-bonus-control--none { background: var(--surface-2); }

.payroll-bonus-control__head {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: space-between;
}

.payroll-bonus-control__label {
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}

.payroll-bonus-control__amount {
  color: var(--brand);
  font-size: 18px;
  font-weight: 800;
}

.payroll-bonus-control__note {
  color: var(--muted);
  font-size: 12px;
  margin: 0;
}

.payroll-segment {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.payroll-segment__option {
  align-items: center;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  font-size: 13px;
  font-weight: 600;
  gap: 8px;
  justify-content: center;
  padding: 10px 8px;
  text-align: center;
  transition: border-color .12s, background .12s, color .12s;
}

.payroll-segment__option input { accent-color: var(--brand); margin: 0; }

.payroll-segment__option:has(input:checked) {
  border-color: var(--brand);
  box-shadow: 0 0 0 1px var(--brand) inset;
  color: var(--brand);
}

.payroll-segment__option--yes:has(input:checked) {
  background: #ecfdf5;
  border-color: var(--good);
  box-shadow: 0 0 0 1px var(--good) inset;
  color: var(--good);
}

.payroll-segment__option--no:has(input:checked) {
  background: #fef2f2;
  border-color: var(--bad);
  box-shadow: 0 0 0 1px var(--bad) inset;
  color: var(--bad);
}

.payroll-hint {
  color: var(--muted);
  font-size: 12px;
}

.payroll-summary-body {
  display: grid;
  gap: 14px;
}

.payroll-summary-period {
  display: grid;
  gap: 2px;
}

.payroll-summary-period__label {
  color: var(--muted);
  font-size: 12px;
}

.payroll-summary-period__value {
  color: var(--ink);
  font-weight: 700;
}

.payroll-summary-lines {
  display: grid;
  gap: 8px;
}

.payroll-summary-row {
  align-items: center;
  color: var(--muted);
  display: flex;
  font-size: 14px;
  justify-content: space-between;
}

.payroll-summary-row strong { color: var(--ink); }
.payroll-summary-pending { color: var(--warn) !important; }
.payroll-summary-muted { color: var(--soft) !important; font-weight: 600; }

.payroll-summary-total {
  align-items: baseline;
  background: var(--brand-soft);
  border: 1px solid #e9d8c4;
  border-radius: 10px;
  display: flex;
  justify-content: space-between;
  padding: 12px 14px;
}

.payroll-summary-total--zero {
  background: var(--surface-2);
  border-color: var(--line);
}

.payroll-summary-total--zero span,
.payroll-summary-total--zero strong {
  color: var(--muted);
}

.payroll-summary-info {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--muted);
  font-size: 12px;
  margin: 0;
  padding: 8px 10px;
}

.payroll-summary-total span {
  color: var(--brand);
  font-size: 14px;
  font-weight: 700;
}

.payroll-summary-total strong {
  color: var(--brand);
  font-size: 24px;
  font-weight: 800;
}

.payroll-summary-source {
  display: grid;
  gap: 2px;
}

.payroll-summary-source__label {
  color: var(--muted);
  font-size: 12px;
}

.payroll-summary-source__value {
  color: var(--ink);
  font-weight: 700;
}

.payroll-summary-warn {
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 8px;
  color: var(--warn);
  font-size: 12px;
  margin: 0;
  padding: 8px 10px;
}

/* Pantalla de pago en una sola columna (sin sidebar derecho). */
.payroll-payment-single {
  margin-top: 20px;
}

.payroll-summary-card {
  background: #fffaf3;
  border: 1px solid #e9d8c4;
  border-radius: 10px;
  padding: 16px;
}

.payroll-summary-card__head {
  align-items: baseline;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 10px;
  justify-content: space-between;
  margin-bottom: 14px;
}

.payroll-summary-card__head .payroll-block__title {
  border-bottom: 0;
  padding-bottom: 0;
}

.payroll-summary-card__name {
  color: var(--brand);
  font-weight: 700;
}

/* Campo atenuado cuando no aplica (p. ej. fuente del dinero en semana sin pago). */
.payroll-field--muted {
  opacity: .5;
}

/* ── Ficha de solo lectura del colaborador (detalle inferior) ──────────────── */
.collab-detail {
  margin-top: 16px;
  display: grid;
  gap: 18px;
}

.collab-detail__head {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: space-between;
}

.collab-detail__identity {
  align-items: center;
  display: flex;
  gap: 14px;
  min-width: 0;
}

.collab-detail__avatar {
  align-items: center;
  background: var(--brand);
  border-radius: 50%;
  color: #fff;
  display: flex;
  flex: 0 0 auto;
  font-size: 18px;
  font-weight: 800;
  height: 54px;
  justify-content: center;
  width: 54px;
}

/* Primer nivel: identidad dominante. */
.collab-detail__name {
  color: var(--ink);
  font-size: 24px;
  font-weight: 800;
  line-height: 1.1;
  margin: 0;
}

.collab-detail__meta {
  color: var(--muted);
  font-size: 14px;
  margin: 4px 0 0;
}

.collab-detail__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

/* Segundo nivel: contacto de emergencia, destacado en rojo tenue. */
.collab-detail__emergency {
  background: #fff5f5;
  border: 1px solid #f7caca;
  border-radius: 12px;
  display: grid;
  gap: 10px;
  padding: 16px 18px;
}

.collab-detail__emergency--missing {
  background: var(--surface-2);
  border-color: var(--line);
}

.collab-detail__emergency-head {
  align-items: center;
  display: flex;
  gap: 8px;
}

.collab-detail__emergency-icon { font-size: 18px; }

.collab-detail__emergency-title {
  color: #b42318;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.collab-detail__emergency--missing .collab-detail__emergency-title {
  color: var(--muted);
}

.collab-detail__emergency-body {
  align-items: baseline;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 18px;
}

.collab-detail__emergency-name {
  color: var(--ink);
  font-size: 16px;
  font-weight: 700;
}

.collab-detail__emergency-phone {
  color: #b42318;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: .02em;
  text-decoration: none;
}

.collab-detail__emergency-warn {
  color: var(--muted);
  font-size: 13px;
  margin: 0;
}

/* Tercer nivel: datos completos en retícula de 2 columnas. */
.collab-detail__grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.collab-detail__card {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  display: grid;
  gap: 10px;
  padding: 14px 16px;
}

.collab-detail__card--notes {
  grid-column: 1 / -1;
}

.collab-detail__card-title {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  margin: 0 0 2px;
  text-transform: uppercase;
}

.collab-detail__fact {
  align-items: baseline;
  border-bottom: 1px dashed var(--line);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding-bottom: 8px;
}

.collab-detail__fact:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.collab-detail__fact-label {
  color: var(--muted);
  font-size: 13px;
}

.collab-detail__fact-value {
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  text-align: right;
}

.collab-detail__notes {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.5;
  margin: 0;
  white-space: pre-wrap;
}

.tips-section-panel {
  border-color: #cbd5e1;
  box-shadow: 0 18px 38px rgba(15, 23, 42, .07);
}

.tips-section-panel > .panel-head {
  border-bottom: 1px solid var(--line);
  margin: -2px -2px 18px;
  padding: 2px 2px 16px;
}

.tips-section-panel .panel-head h3 {
  margin-bottom: 4px;
}

.supplies-count-main-panel,
.supplies-count-summary-panel,
.tips-main-panel {
  border-color: #d7dde8;
}

.supplies-count-summary-panel {
  position: sticky;
  top: 18px;
}

.supplies-count-form {
  display: grid;
  gap: 16px;
}

.supplies-count-base-cards {
  margin-top: 0;
}

.supplies-count-base-cards .mini-box {
  padding: 16px;
  box-shadow: none;
}

.supplies-count-base-cards .mini-box strong {
  font-size: 25px;
}

.supplies-count-base-cards .supplies-expected-card {
  border-width: 2px;
  box-shadow: 0 14px 32px rgba(22, 101, 52, .12);
  transform: translateY(-2px);
}

.supplies-count-board {
  border-radius: 14px;
}

.supplies-count-board .cash-board-head {
  background: #f8fafc;
}

.supplies-count-board .cash-board-head strong {
  color: var(--ink);
}

.supplies-count-board .cash-line {
  padding: 8px 14px;
}

.supplies-count-board .cash-line input {
  min-height: 38px;
}

.tips-cash-board {
  margin-bottom: 0;
}

.tips-form {
  display: grid;
  gap: 22px;
}

.tips-form-section {
  border-color: #cbd5e1;
  background: #fbfdff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .85);
}

.tips-form-section .form-section-title,
.tips-members-section .form-section-title,
.tips-inline-summary .form-section-title {
  margin-bottom: 5px;
  color: var(--ink);
  font-size: 16px;
}

.tips-members-section .panel-head {
  margin-bottom: 16px;
}

.tips-members-section {
  border-color: #a7c4ee;
  border-width: 2px;
  background: #f8fbff;
  box-shadow: 0 12px 28px rgba(37, 99, 235, .08);
}

.tips-members-section .panel-head,
.tips-inline-summary .panel-head {
  align-items: center;
}

.tips-add-person-btn {
  flex-shrink: 0;
  min-height: 40px;
  white-space: normal;
}

.tips-inline-summary {
  border-color: #bbf7d0;
  border-width: 2px;
  background: #f8fffb;
  box-shadow: 0 12px 28px rgba(22, 163, 74, .08);
}

.tips-inline-summary .panel-head {
  margin-bottom: 16px;
}

.tips-participants-table table {
  min-width: 760px;
}

.tips-participants-table {
  border: 1px solid #dbeafe;
  border-radius: 14px;
  background: #fff;
}

.tips-participants-table input[type="text"],
.tips-participants-table select {
  width: 100%;
  min-width: 170px;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  padding: 9px 10px;
  background: #fff;
}

.tips-participants-table input[type="checkbox"] {
  width: 18px;
  height: 18px;
}

.tips-live-hero-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}

.tips-live-hero-grid .supplies-live-hero {
  padding: 14px;
}

.tips-live-hero-grid .supplies-live-hero strong {
  font-size: 26px;
}

.tips-history-grid {
  align-items: start;
}

.tips-detail-panel,
.tips-history-panel {
  width: 100%;
}

.tips-notes-field {
  max-width: none;
}

.cash-line-head {
  background: #f8fafc;
  color: #64748b;
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.cash-line-head span:last-child {
  text-align: right;
}

.supplies-count-result {
  border: 2px solid #cbd5e1;
  border-radius: 18px;
  padding: 18px;
  background: #f8fafc;
}

.supplies-result-comparison,
.supplies-result-main {
  display: grid;
  gap: 12px;
}

.supplies-result-comparison {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 16px;
}

.supplies-result-comparison div,
.supplies-result-difference,
.supplies-result-status {
  border-radius: 14px;
  background: rgba(255, 255, 255, .72);
  padding: 14px;
}

.supplies-result-comparison span,
.supplies-result-main span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
  margin-bottom: 7px;
  text-transform: uppercase;
}

.supplies-result-comparison strong {
  color: var(--ink);
  font-size: 25px;
  letter-spacing: 0;
}

.supplies-result-main {
  grid-template-columns: 1.35fr .85fr;
}

.supplies-result-main strong {
  font-size: 38px;
  letter-spacing: 0;
}

.supplies-count-result-good {
  border-color: #86efac;
  background: #f0fdf4;
}

.supplies-count-result-good .supplies-result-main strong,
.supplies-count-result-good > strong,
.supplies-count-result-good b {
  color: #166534;
}

.supplies-count-result-warn {
  border-color: #fcd34d;
  background: #fffbeb;
}

.supplies-count-result-warn .supplies-result-main strong,
.supplies-count-result-warn > strong,
.supplies-count-result-warn b {
  color: #92400e;
}

.supplies-count-result-bad {
  border-color: #fca5a5;
  background: #fff1f2;
}

.supplies-count-result-bad .supplies-result-main strong,
.supplies-count-result-bad > strong,
.supplies-count-result-bad b {
  color: #b91c1c;
}

.supplies-live-summary {
  display: grid;
  gap: 16px;
}

.supplies-live-hero {
  border: 2px solid #cbd5e1;
  border-radius: 18px;
  padding: 18px;
}

.supplies-live-hero span,
.supplies-live-hero small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.supplies-live-hero strong {
  display: block;
  color: var(--ink);
  font-size: 38px;
  line-height: 1;
  margin: 8px 0 10px;
}

.supplies-live-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.supplies-live-item {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 11px 12px;
  background: #fff;
}

.supplies-live-item span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0;
  margin-bottom: 5px;
  text-transform: uppercase;
}

.supplies-live-item strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.supplies-live-item-strong {
  border-color: #bbf7d0;
  background: #f8fffb;
}

.supplies-live-item-strong strong {
  color: #166534;
  font-size: 18px;
}

.supplies-considered-expenses {
  border-top: 1px solid var(--line);
  padding-top: 14px;
}

.supplies-considered-head,
.supplies-considered-total,
.supplies-expense-mini-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.supplies-considered-head h4 {
  margin: 0;
  color: var(--ink);
  font-size: 15px;
}

.supplies-considered-head span,
.supplies-expense-mini-row span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.supplies-expense-mini-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.supplies-expense-mini-row {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px;
  background: #fff;
}

.supplies-expense-mini-row strong {
  display: block;
  color: var(--ink);
  font-size: 13px;
  margin-bottom: 3px;
}

.supplies-expense-mini-row b {
  color: var(--ink);
  white-space: nowrap;
}

.supplies-considered-total {
  border-top: 1px solid var(--line);
  margin-top: 12px;
  padding-top: 12px;
}

.supplies-considered-total span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.supplies-considered-total strong {
  color: var(--ink);
  font-size: 18px;
}

.supplies-count-submit {
  justify-self: start;
  min-width: min(100%, 280px);
}

.supplies-editor-panel {
  position: sticky;
  top: 20px;
}

.row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.supplies-static-branch {
  margin-bottom: 14px;
}

.operation-actions > h3,
.close-screen h2 {
  margin: 0 0 14px;
  font-size: 28px;
  letter-spacing: -0.04em;
}

.operation-action-card {
  min-height: 224px;
  position: relative;
  gap: 18px;
  padding: 22px;
  border-color: #d8e0ea;
  border-radius: 18px;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .055);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}

.operation-action-card[role="button"] {
  cursor: pointer;
}

.operation-action-card:hover {
  border-color: #b9c8d8;
  box-shadow: 0 18px 38px rgba(15, 23, 42, .085);
  transform: translateY(-2px);
}

.operation-action-card:focus-visible {
  outline: 3px solid rgba(37, 99, 235, .22);
  outline-offset: 4px;
}

.operation-action-card .btn-primary-compact,
.operation-action-card .btn-ghost {
  align-self: flex-end;
  margin-top: auto;
}

.operation-card-topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.operation-action-card .module-icon {
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4f78;
  box-shadow: inset 0 0 0 1px #dbeafe;
}

.operation-action-card-featured {
  border-color: #93c5fd;
  background: linear-gradient(180deg, #fff, #f8fbff);
  box-shadow: 0 18px 42px rgba(37, 99, 235, .11);
}

.operation-action-badge {
  flex-shrink: 0;
  box-shadow: none;
}

.operation-open-panel {
  margin-top: 16px;
}

.close-screen {
  max-width: 1480px;
}

.close-block {
  border: 1px solid #d5b797;
  background: rgba(255, 255, 255, .92);
  border-radius: 20px;
  padding: 22px;
  margin-bottom: 18px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, .07);
}

.close-block-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.close-block h3 {
  margin: 5px 0 0;
  font-size: 22px;
  letter-spacing: -0.035em;
}

.fund-controls {
  display: grid;
  grid-template-columns: 180px 180px 220px 1fr;
  gap: 12px;
  align-items: end;
  border: 1px solid #bfdbfe;
  background: #f8fbff;
  border-radius: 18px;
  padding: 14px;
  margin: 14px 0;
}

.fund-controls .field {
  margin-bottom: 0;
}

.fund-controls .field label {
  color: #1e40af;
}

.fund-controls .field input {
  border-color: #bfdbfe;
  background: #f8fbff;
}

.fund-auto-note {
  align-self: stretch;
  display: flex;
  align-items: center;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1e3a8a;
  border-radius: 14px;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 850;
}

.cash-dual-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.cash-board {
  border: 1px solid var(--line);
  border-radius: 20px;
  overflow: hidden;
  background: #fff;
}

.cash-board-counted {
  border-color: #bbf7d0;
}

.cash-board-fund {
  border-color: #bfdbfe;
}

.cash-board-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  background: #f0fdf4;
}

.cash-board-fund .cash-board-head {
  background: #eff6ff;
}

.cash-board-counted .cash-board-head strong {
  color: #166534;
}

.cash-board-fund .cash-board-head strong {
  color: #1e40af;
}

.cash-board-head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.cash-lines {
  display: grid;
}

.cash-line {
  display: grid;
  grid-template-columns: minmax(110px, 1fr) 92px minmax(110px, 1fr);
  gap: 12px;
  align-items: center;
  padding: 10px 14px;
  border-top: 1px solid var(--line);
}

.cash-line:first-child {
  border-top: 0;
}

.cash-line input {
  padding: 8px 10px;
  border-radius: 10px;
  text-align: center;
  font-weight: 850;
}

.cash-line strong {
  text-align: right;
}

.cash-board-fund .cash-line-muted:not(.cash-total-line) {
  background: #f8fafc;
  color: #94a3b8;
}

.cash-board-fund .cash-line-muted:not(.cash-total-line) input {
  border-color: #e2e8f0;
  background: #f8fafc;
  color: #94a3b8;
}

.cash-board-fund .cash-line-muted:not(.cash-total-line) strong {
  color: #94a3b8;
}

.cash-board-fund .cash-line-active:not(.cash-total-line) {
  background: #fff;
  color: var(--ink);
}

.cash-board-fund .cash-line-active:not(.cash-total-line) input {
  border-color: #bfdbfe;
  background: #fff;
  color: var(--ink);
}

.cash-total-line {
  background: #f8fafc;
  font-weight: 950;
  padding-top: 14px;
  padding-bottom: 14px;
}

.cash-total-line span {
  font-size: 15px;
}

.cash-total-line strong {
  font-size: 20px;
}

.cash-board-counted .cash-total-line {
  background: #f0fdf4;
  color: #166534;
}

.cash-board-counted .cash-total-line strong {
  color: #166534;
}

.cash-board-fund .cash-total-line {
  background: #eff6ff;
  color: #1e40af;
}

.cash-board-fund .cash-total-line strong {
  color: #1e40af;
}

.cash-board-fund .cash-total-line .fund-total-input {
  width: 100%;
  text-align: right;
  font-size: 18px;
  font-weight: 950;
  color: #1e40af;
  background: #fff;
  border: 1px dashed #93c5fd;
  border-radius: 10px;
  padding: 8px 10px;
}

.cash-board-fund .cash-total-line .fund-total-input:focus {
  outline: none;
  border-style: solid;
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15);
}

.cash-board-fund .cash-line-off:not(.cash-total-line) {
  background: #f1f5f9;
}

.cash-board-fund .cash-line-off:not(.cash-total-line) input {
  background: #e2e8f0;
  border-color: #cbd5e1;
  color: #94a3b8;
  cursor: pointer;
  opacity: 0.7;
}

.fund-manual-hint {
  padding: 8px 14px;
  font-size: 12.5px;
  line-height: 1.4;
  color: #1e40af;
  background: #eff6ff;
  border-top: 1px solid var(--line);
}

.fund-manual-hint-warn {
  color: #b45309;
  background: #fffbeb;
}

.block2-duplicate-summary,
.block2-fund-note {
  display: none;
}

.mini-box {
  border: 1px solid #d5b797;
  background: #fffdf9;
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .06);
}

.mini-box-green {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.mini-box-blue {
  border-color: #bfdbfe;
  background: #f8fbff;
}

.mini-box-amber {
  border-color: #fcd34d;
  background: #fffdf3;
}

.mini-box-red {
  border-color: #fca5a5;
  background: #fff1f2;
}

.mini-box > span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  margin-bottom: 8px;
}

.mini-box strong {
  color: var(--ink);
  font-size: 34px;
  letter-spacing: 0;
}

.mini-box strong span {
  font: inherit;
  color: inherit;
}

.mini-box-green strong {
  color: #166534;
}

.mini-box-blue strong {
  color: #1e40af;
}

.mini-box-amber strong {
  color: #92400e;
}

.mini-box-red strong {
  color: #b91c1c;
}

.close-mini-metrics {
  margin-top: 14px;
}

.notice-line,
.warning-line {
  border-radius: 16px;
  padding: 13px 14px;
  margin-top: 14px;
  line-height: 1.45;
}

.notice-line {
  border: 1px solid #fed7aa;
  background: #fff7ed;
  color: #8a4a25;
}

.supplies-total-summary {
  margin-top: 16px;
  border: 1px solid #fcd34d;
  background: #fffbeb;
  color: #854d0e;
  border-radius: 16px;
  padding: 18px 20px;
  font-size: 18px;
  font-weight: 950;
  box-shadow: 0 12px 30px rgba(245, 158, 11, .08);
}

.money-field input[readonly] {
  background: #f8fafc;
  color: #475569;
}

.money-field-supplies input {
  border-color: #fcd34d;
  background: #fffdf3;
}

.money-input-readout {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.35;
}

.warning-line {
  border: 1px solid #fde68a;
  background: #fffbeb;
  color: #854d0e;
}

.fudo-executive-block {
  display: grid;
  gap: 14px;
}

.fudo-executive-grid {
  display: grid;
  grid-template-columns: 1.55fr 1fr 1fr;
  gap: 14px;
}

.fudo-hero-card,
.fudo-validation-card,
.fudo-compare-card,
.fudo-secondary-metric {
  border: 1px solid #e2e8f0;
  background: #fff;
  border-radius: 16px;
  padding: 16px;
}

.fudo-hero-card {
  display: grid;
  align-content: start;
  min-height: 132px;
}

.fudo-hero-card > span,
.fudo-validation-card > span,
.fudo-compare-card header span,
.fudo-secondary-metric > span,
.fudo-meta-item > span {
  color: #64748b;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0;
}

.fudo-hero-card strong span,
.fudo-secondary-metric strong span,
.fudo-meta-item strong span {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
}

.fudo-hero-card strong {
  display: block;
  margin-top: 12px;
  color: #0f172a;
  font-size: 34px;
  line-height: 1;
  letter-spacing: 0;
}

.fudo-hero-card small {
  margin-top: 10px;
  color: #64748b;
  font-weight: 700;
  line-height: 1.35;
}

.fudo-hero-primary {
  border-color: #86efac;
  background: linear-gradient(180deg, #ecfdf5 0%, #ffffff 100%);
  box-shadow: 0 18px 44px rgba(22, 101, 52, .11);
}

.fudo-hero-primary > span {
  color: #166534;
  font-size: 13px;
}

.fudo-hero-primary strong {
  color: #14532d;
  font-size: clamp(44px, 4vw, 58px);
  font-weight: 950;
}

.fudo-hero-warning {
  border-color: #fde68a;
  background: #fffdf3;
}

.fudo-hero-warning.state-ok {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.fudo-hero-warning.state-ok strong {
  color: #166534;
}

.fudo-hero-warning.state-warn strong {
  color: #92400e;
}

.fudo-validation-card {
  display: grid;
  gap: 12px;
  background: #f8fafc;
}

.validation-status-row,
.fudo-compare-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.validation-status-row small,
.fudo-compare-row span {
  color: #475569;
  font-weight: 800;
}

.validation-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 950;
}

.validation-pill.neutral {
  background: #f1f5f9;
  color: #64748b;
}

.validation-pill.ok {
  background: #dcfce7;
  color: #166534;
}

.validation-pill.warn {
  background: #fef3c7;
  color: #92400e;
}

.fudo-compare-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.fudo-compare-card {
  display: grid;
  gap: 12px;
  background: #fff;
}

.fudo-compare-card header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid #edf2f7;
}

.fudo-compare-row strong {
  color: #0f172a;
  font-size: 17px;
  font-weight: 950;
}

.fudo-compare-card.state-warn {
  border-color: #fde68a;
  background: #fffdf3;
}

.fudo-compare-card.state-ok {
  border-color: #bbf7d0;
}

.fudo-compare-fund {
  border-color: #bfdbfe;
  background: linear-gradient(180deg, #eff6ff 0%, #ffffff 100%);
}

.fudo-compare-fund header {
  border-bottom-color: #dbeafe;
}

.fudo-compare-fund header span,
.fudo-compare-fund .fudo-compare-row span {
  color: #1e40af;
}

.fudo-compare-fund .fudo-compare-row strong {
  color: #1e3a8a;
}

.fudo-compare-fund.state-warn,
.fudo-compare-fund.state-ok {
  border-color: #93c5fd;
  background: linear-gradient(180deg, #eff6ff 0%, #ffffff 100%);
}

.fudo-compare-cash {
  border-color: #bbf7d0;
  background: linear-gradient(180deg, #f0fdf4 0%, #ffffff 100%);
}

.fudo-compare-cash header {
  border-bottom-color: #dcfce7;
}

.fudo-compare-cash header span,
.fudo-compare-cash .fudo-compare-row span {
  color: #166534;
}

.fudo-compare-cash .fudo-compare-row strong {
  color: #14532d;
}

.fudo-compare-cash.state-warn,
.fudo-compare-cash.state-ok {
  border-color: #86efac;
  background: linear-gradient(180deg, #f0fdf4 0%, #ffffff 100%);
}

.fudo-secondary-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.fudo-secondary-metric {
  background: #f8fafc;
  padding: 13px 14px;
}

.fudo-secondary-metric strong {
  display: block;
  margin-top: 8px;
  color: #334155;
  font-size: 19px;
  font-weight: 950;
}

.fudo-meta-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  border-radius: 14px;
  padding: 10px;
}

.fudo-meta-item {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.fudo-meta-item strong {
  color: #334155;
  font-size: 13px;
  overflow-wrap: anywhere;
}

.fudo-paste-field {
  margin-top: 2px;
}

.fudo-paste-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.fudo-paste-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.fudo-paste-field textarea {
  min-height: 96px;
  background: #f8fafc;
}

.fudo-paste-field textarea[readonly] {
  border-color: #bfdbfe;
  background: #eff6ff;
  color: #334155;
}

.fudo-paste-status {
  margin-top: 10px;
  border-radius: 14px;
  padding: 11px 12px;
  font-size: 13px;
  font-weight: 850;
  line-height: 1.35;
}

.fudo-paste-status.neutral {
  border: 1px solid #dbeafe;
  background: #f8fbff;
  color: #1e40af;
}

.fudo-paste-status.success {
  border: 1px solid #bbf7d0;
  background: #f0fdf4;
  color: #166534;
}

.fudo-paste-status.error {
  border: 1px solid #fecdd3;
  background: #fff1f2;
  color: #9f1239;
}

.fudo-paste-toolbar .btn:disabled,
.fudo-paste-actions .btn:disabled {
  cursor: not-allowed;
}

.fudo-readout {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}

.fudo-readout-section {
  border: 1px solid #dbe6f2;
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
}

.fudo-readout-section h4 {
  margin: 0;
  padding: 12px 14px;
  border-bottom: 1px solid #dbe6f2;
  color: #0f172a;
  font-size: 14px;
  background: #f8fafc;
}

.fudo-readout-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  border-top: 1px solid #edf2f7;
  font-size: 13px;
}

.fudo-readout-line:first-of-type {
  border-top: 0;
}

.fudo-readout-line span {
  color: var(--muted);
  font-weight: 800;
}

.fudo-readout-line strong {
  white-space: nowrap;
}

.fudo-readout-zero span,
.fudo-readout-zero strong {
  color: #94a3b8;
}

.fudo-readout-total {
  background: #f8fafc;
}

.fudo-readout-total strong {
  color: #166534;
}

.manual-correction-grid {
  display: grid;
  gap: 14px;
}

.manual-correction-section {
  border: 1px solid #e2e8f0;
  background: #fff;
  border-radius: 16px;
  padding: 16px;
}

.manual-correction-section h4 {
  margin: 0 0 12px;
  color: #334155;
  font-size: 15px;
}

.manual-correction-section .field input {
  background: #fff;
}

.manual-correction-section .calculated-input {
  border-color: #e2e8f0 !important;
  background: #f8fafc !important;
  color: #475569 !important;
}

.manual-result-metrics {
  margin-top: 16px;
}

.close-details summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  list-style: none;
}

.close-details summary::-webkit-details-marker {
  display: none;
}

.close-details summary strong {
  display: block;
  margin-top: 5px;
  font-size: 20px;
}

.close-details summary small {
  color: var(--muted);
  font-weight: 800;
}

.close-details[open] summary {
  margin-bottom: 16px;
}

.cash-to-safe {
  margin-top: 16px;
  border: 1px solid #0f766e;
  border-radius: 18px;
  padding: 28px;
  color: #ecfeff;
  background: linear-gradient(135deg, #0f766e 0%, #155e75 100%);
  box-shadow: 0 18px 44px rgba(15, 118, 110, .22);
}

.cash-to-safe span,
.cash-to-safe small {
  display: block;
  font-weight: 850;
  color: #ccfbf1;
}

.cash-to-safe strong {
  display: block;
  font-size: clamp(46px, 5vw, 60px);
  line-height: 1;
  letter-spacing: 0;
  margin: 10px 0;
  color: #ffffff;
}

.cash-to-safe-negative {
  border-color: #fca5a5;
  background: #fff1f2;
  color: #7f1d1d;
  box-shadow: 0 16px 38px rgba(185, 28, 28, .10);
}

.cash-to-safe-negative span,
.cash-to-safe-negative small,
.cash-to-safe-negative strong {
  color: #991b1b;
}

.final-close-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.final-close-summary article {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 14px;
  padding: 14px 16px;
}

.final-close-summary span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  margin-bottom: 6px;
}

.final-close-summary strong {
  color: var(--ink);
  font-size: 22px;
  font-weight: 950;
  letter-spacing: 0;
}

.close-submit-area {
  display: grid;
  gap: 12px;
  justify-items: end;
  margin-top: 4px;
  margin-bottom: 18px;
}

.ticket-preview-details {
  margin-top: 18px;
  border-top: 1px solid var(--line);
  padding-top: 18px;
}

.ticket-preview-details summary {
  justify-content: flex-start;
}

.ticket-preview-details summary strong {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 15px;
  margin: 0;
}

.ticket-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.paper-ticket {
  background: #fff;
  color: #111827;
  border: 1px dashed #b99476;
  border-radius: 16px;
  padding: 15px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 12px;
}

.ticket-center {
  text-align: center;
}

.ticket-head {
  font-weight: 950;
}

.ticket-sep {
  border-top: 1px dashed #9ca3af;
  margin: 10px 0;
}

.ticket-line {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  line-height: 1.45;
}

.ticket-wide-preview {
  width: 100%;
  max-width: 1100px;
}

.ticket-section-title {
  text-align: center;
  font-weight: 950;
  margin: 8px 0;
}

.help-dot {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  margin-left: 6px;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 950;
  cursor: help;
}

.form-error {
  margin-bottom: 16px;
}

[data-close-submit-error-anchor] .form-error {
  margin: 0 0 12px;
}

.ticket-big {
  text-align: center;
  font-size: 30px;
  font-weight: 950;
  margin: 10px 0;
}

.ticket-blank-line {
  border-bottom: 1px solid #111827;
  height: 18px;
  margin: 6px 0;
}

.money-bad {
  color: var(--bad);
}

.money-warn {
  color: var(--warn);
}

.operation-summary {
  display: grid;
  gap: 6px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1e3a8a;
  border-radius: 16px;
  padding: 14px;
  margin: 14px 0;
  line-height: 1.35;
}

.operation-summary span {
  font-size: 13px;
}

.denom-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.denom-item {
  display: grid;
  gap: 7px;
  margin: 0;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 14px;
  padding: 10px;
}

.denom-item span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.denom-item input {
  padding: 9px 10px;
  border-radius: 10px;
}

.table-wrap {
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 18px;
}

table {
  width: 100%;
  min-width: 920px;
  border-collapse: collapse;
}

th,
td {
  padding: 12px 14px;
  text-align: left;
  border-top: 1px solid var(--line);
  vertical-align: middle;
  white-space: nowrap;
}

th {
  border-top: 0;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.panel-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.panel-actions,
.detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.detail-actions {
  margin-top: 14px;
}

.detail-subtable {
  margin-top: 16px;
}

.detail-subtable h4 {
  color: var(--ink);
  font-size: 14px;
  margin: 0 0 8px;
}

.detail-list {
  display: grid;
  gap: 8px;
}

.detail-line {
  display: grid;
  grid-template-columns: minmax(120px, .8fr) minmax(0, 1.2fr);
  gap: 10px;
  align-items: start;
  border-bottom: 1px solid var(--line);
  padding: 8px 0;
}

.detail-line span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.detail-line strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.35;
  white-space: normal;
  overflow-wrap: anywhere;
}

.selected-row {
  background: #fff7ed;
}

.supplies-summary {
  margin-bottom: 14px;
}

/* ---- Captura de gastos de insumos: jerarquia visual y "Pagado desde" ---- */
.field--prominent label {
  font-size: 15px;
}

.field--prominent input {
  font-size: 16px;
  padding: 15px 16px;
  border-width: 2px;
}

.field__help {
  color: var(--muted);
  font-size: 12px;
}

.funding-field__label {
  display: block;
  font-weight: 850;
  margin-bottom: 8px;
}

.funding-choice {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 12px;
}

@media (max-width: 560px) {
  .funding-choice {
    grid-template-columns: 1fr;
  }
}

.funding-option {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border: 2px solid var(--line-strong);
  border-radius: 12px;
  cursor: pointer;
  background: #fff;
  transition: border-color .12s ease, background .12s ease, box-shadow .12s ease;
}

.funding-option input[type="radio"] {
  margin-top: 3px;
  width: 18px;
  height: 18px;
  accent-color: var(--brand-2);
  flex: 0 0 auto;
}

.funding-option__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.funding-option__title {
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.funding-option__hint {
  font-size: 12px;
  color: var(--muted);
}

.funding-option:has(input:checked) {
  border-color: var(--brand-2);
  box-shadow: inset 0 0 0 1px var(--brand-2);
}

.funding-option--drawer {
  border-color: #fed7aa;
  background: #fffaf4;
}

.funding-option--drawer:has(input:checked) {
  border-color: #f59e0b;
  background: #fff7ed;
  box-shadow: inset 0 0 0 1px #f59e0b;
}

.funding-note[hidden],
.funding-alert[hidden] {
  display: none;
}

.funding-note {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 11px 13px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  border-radius: 10px;
  margin-bottom: 14px;
  font-size: 13px;
}

.funding-alert {
  padding: 12px 14px;
  border: 2px solid #f59e0b;
  background: #fff7ed;
  border-radius: 10px;
  margin-bottom: 14px;
  color: #8a4a25;
}

.funding-alert__head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 850;
  font-size: 14px;
  margin-bottom: 6px;
}

.funding-alert__icon {
  font-size: 16px;
  line-height: 1;
}

.funding-alert__list {
  margin: 0;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 13px;
}

.funding-alert__cta {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed #f59e0b;
  font-size: 13px;
  color: #8a4a25;
}

/* Error inline para campos individuales (textarea de notas).
   Rojo claro, aparece tras intentar guardar y se limpia al corregir. */
.field__error {
  margin-top: 6px;
  color: #b91c1c;
  font-size: 12.5px;
  font-weight: 700;
  line-height: 1.35;
}
.field__error[hidden] { display: none; }

.field__required {
  color: #b91c1c;
  font-weight: 900;
  margin-left: 2px;
}

/* ---- KPIs en vivo de captura (gasto libre y recurrentes) ---- */
.supplies-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}

.supplies-kpi {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--line-strong);
  background: #fff;
}

.supplies-kpi__label {
  font-size: 11.5px;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1.2;
}

.supplies-kpi__value {
  font-size: 19px;
  font-weight: 950;
  letter-spacing: -0.03em;
  color: var(--ink);
}

.supplies-kpi--blue { border-color: #bfdbfe; background: #eff6ff; }
.supplies-kpi--blue .supplies-kpi__value { color: #1d4ed8; }
.supplies-kpi--teal { border-color: #99f6e4; background: #f0fdfa; }
.supplies-kpi--teal .supplies-kpi__value { color: #0f766e; }
.supplies-kpi--green { border-color: #bbf7d0; background: #f0fdf4; }
.supplies-kpi--green .supplies-kpi__value { color: #15803d; }
.supplies-kpi--orange { border-color: #fed7aa; background: #fff7ed; }
.supplies-kpi--orange .supplies-kpi__value { color: #c2410c; }
.supplies-kpi--gray { border-color: var(--line-strong); background: #f8fafc; }
.supplies-kpi--gray .supplies-kpi__value { color: #64748b; }

@media (max-width: 720px) {
  .supplies-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ---- Alerta contextual (solo cuando se usa caja del turno) ---- */
.supplies-context-alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid #f59e0b;
  background: #fff7ed;
  border-radius: 12px;
  margin: 4px 0 14px;
  color: #8a4a25;
  font-size: 13px;
  line-height: 1.45;
}

.supplies-context-alert[hidden] { display: none; }

.supplies-context-alert__icon {
  font-size: 16px;
  line-height: 1.3;
  flex: 0 0 auto;
}

/* ---- Tarjeta de resumen de captura ---- */
.supplies-summary-card {
  border: 1px solid var(--line-strong);
  border-radius: 14px;
  background: #fff;
  padding: 14px 16px;
  margin-bottom: 14px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .05);
}

.supplies-summary-card__title {
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
  margin-bottom: 10px;
}

.supplies-summary-card__rows {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.supplies-summary-card__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  font-size: 13.5px;
  color: var(--soft);
}

.supplies-summary-card__row span:last-child,
.supplies-summary-card__row strong {
  font-variant-numeric: tabular-nums;
  font-weight: 800;
  color: var(--ink);
}

.supplies-summary-card__row--total {
  padding-bottom: 8px;
  margin-bottom: 4px;
  border-bottom: 1px dashed var(--line-strong);
  font-size: 15px;
}

.supplies-summary-card__row--total span:first-child { font-weight: 850; color: var(--ink); }
.supplies-summary-card__row--total strong { font-size: 18px; letter-spacing: -0.03em; }

.supplies-summary-card__row[data-recurring-turno-row].is-active span:last-child { color: #c2410c; }

.supplies-summary-card__hint {
  display: block;
  margin-top: 10px;
  color: var(--muted);
  font-size: 12px;
}

/* ---- Tabla recurrente compacta ---- */
.recurring-expense-table input {
  width: 100%;
  min-width: 0;
}

.table-money-input {
  max-width: 120px;
  margin-left: auto;
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.recurring-col-amount { width: 130px; text-align: right; }
.recurring-col-origin { width: 150px; }
.recurring-col-evidence { width: 150px; }

/* Adjuntar evidencia por renglón: control compacto (icono + estado) que no
   ensancha la tabla. El input file real va oculto. */
.recurring-evidence {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.recurring-expense-table .recurring-evidence__btn {
  flex: 0 0 auto;
  width: auto;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 8px;
  padding: 4px 8px;
  font-size: 12px;
  line-height: 1.1;
  cursor: pointer;
  white-space: nowrap;
}

.recurring-expense-table .recurring-evidence__btn:hover { background: #f4f6f8; }

.recurring-evidence__state {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  color: var(--muted);
}

.recurring-evidence__state--ready {
  color: #1f9d57;
  font-weight: 600;
}

/* ---- Evidencia en el detalle del gasto de insumos (ficha gx-detail) ---- */
.sx-evidence__head { margin-bottom: 8px; }

.sx-evidence__empty {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 14px;
  border: 1px dashed var(--line);
  border-radius: 12px;
  background: var(--surface);
}

.sx-evidence__empty-icon { font-size: 22px; }

.sx-evidence__empty-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1 1 200px;
  min-width: 0;
}

.sx-evidence__upload { margin-left: auto; }

.sx-evidence__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  flex-wrap: wrap;
}

.sx-evidence__icon { font-size: 24px; flex: 0 0 auto; }

.sx-evidence__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1 1 200px;
  min-width: 0;
  font-size: 12.5px;
}

.sx-evidence__name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sx-evidence__actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}

/* ---- Modal de confirmación de reemplazo de evidencia ---- */
.sx-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 1000;
}

.sx-modal {
  background: #fff;
  border-radius: 14px;
  max-width: 440px;
  width: 100%;
  padding: 22px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.25);
}

.sx-modal__title { margin: 0 0 10px; font-size: 17px; }
.sx-modal__body { margin: 0 0 18px; color: var(--soft); line-height: 1.45; }

.sx-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

/* Botón destructivo (modal de reemplazo + limpieza documental). */
.btn-danger {
  background: #dc2626;
  border-color: #dc2626;
  color: #fff;
}
.btn-danger:hover { background: #b91c1c; border-color: #b91c1c; }

.recurring-meta-cell {
  font-size: 12.5px;
  line-height: 1.3;
  color: var(--soft);
}

.recurring-meta-sep { color: var(--muted); }
.recurring-meta-category { color: var(--muted); }

.recurring-note-input {
  font-size: 12.5px;
}

.recurring-origin-detail {
  display: block;
  margin-top: 3px;
  font-size: 11px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

/* Captura de gastos de insumos: formulario y "Detalle reciente" apilados
   verticalmente (el detalle queda abajo, no a la derecha) en cualquier ancho. */
.supplies-capture-stack {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.supplies-replenish-panel {
  display: grid;
  gap: 12px;
}

.supplies-replenish-panel[hidden] {
  display: none;
}

.list {
  display: grid;
  gap: 10px;
}

.alert-row,
.action-row {
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  box-shadow: none;
}

.alert-row strong,
.action-row strong {
  display: block;
}

.alert-row span,
.action-row span {
  color: var(--muted);
  font-size: 13px;
}

.badge {
  display: inline-flex;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 950;
}

.badge.good {
  background: #ecfdf5;
  color: var(--good);
}

.badge.warn {
  background: #fffbeb;
  color: var(--warn);
}

.badge.bad {
  background: #fff1f2;
  color: var(--bad);
}

.badge.blue {
  background: #eff6ff;
  color: var(--blue);
}

.badge.muted {
  background: var(--surface-2);
  color: var(--muted);
}

.modules {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.module-card {
  min-height: 178px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.module-icon {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: var(--brand-soft);
  color: #8a4a25;
  font-size: 22px;
}

.module-card p {
  color: var(--muted);
  line-height: 1.45;
  margin: 8px 0 0;
}

.placeholder {
  border: 1px dashed var(--line-strong);
  background: rgba(255, 255, 255, .72);
  border-radius: 24px;
  padding: 32px;
  max-width: 980px;
}

.placeholder h2 {
  margin: 0 0 8px;
  font-size: 30px;
  letter-spacing: -0.04em;
}

.placeholder p {
  color: var(--muted);
  line-height: 1.55;
}

.mobile-bar {
  display: none;
}

@media (max-width: 1100px) {
  .login-wrap,
  .layout {
    grid-template-columns: 1fr;
  }

  /* En tablet/celular: primero el formulario, el panel informativo abajo. */
  .login-card {
    order: 1;
  }

  .login-hero {
    order: 2;
    min-height: auto;
  }

  .login-hero__cards {
    grid-template-columns: 1fr;
  }

  .grid-5,
  .grid-4,
  .grid-3,
  .grid-2,
  .form-grid,
  .final-close-summary,
  .fund-controls,
  .cash-dual-grid,
  .fudo-executive-grid,
  .fudo-compare-grid,
  .fudo-secondary-metrics,
  .fudo-meta-strip,
  .fudo-readout,
  .ticket-grid,
  .modules,
  .supplies-actions .modules,
  .supplies-catalog-actions .modules,
  .supplies-catalog-layout,
  .supplies-count-layout,
  .general-expense-layout,
  .general-expense-register-layout,
  .general-expense-catalog-layout,
  .general-expense-actions .modules,
  .general-expense-filters,
  .payroll-actions .modules,
  .payroll-payment-layout,
  .payroll-collaborators-layout,
  .payroll-history-layout,
  .payroll-admin-filters,
  .tips-layout {
    grid-template-columns: 1fr;
  }

  .general-expense-register-summary,
  .payroll-payment-summary,
  .supplies-editor-panel,
  .supplies-count-summary-panel {
    position: static;
  }

  .sidebar {
    position: static;
    height: auto;
  }

  .nav {
    max-height: none;
  }

  .main {
    padding: 20px;
  }

  .topbar {
    flex-direction: column;
  }
}

@media (max-width: 720px) {
  .general-expense-base-grid,
  .general-expense-form .form-grid,
  .payroll-form-grid,
  .payroll-context-editor,
  .payroll-collab-card__grid,
  .payroll-segment,
  .collab-detail__grid {
    grid-template-columns: 1fr;
  }

  /* Los 7 días de asistencia en dos filas para que no queden minúsculos. */
  .payroll-attendance__days {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .payroll-attendance__summary {
    text-align: left;
  }

  .gx-detail__hero {
    grid-template-columns: 1fr;
  }

  .gx-detail__amount-card {
    justify-items: start;
    text-align: left;
  }

  .general-expense-evidence-item {
    grid-template-columns: 1fr;
  }

  .general-expense-evidence-actions {
    justify-content: flex-start;
  }

  .payroll-subhead,
  .payroll-week-group-head,
  .payroll-week-group-totals {
    align-items: stretch;
    flex-direction: column;
  }
}

@media (max-width: 780px) {
  .denom-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .supplies-result-comparison,
  .supplies-result-main,
  .supplies-live-grid,
  .tips-live-hero-grid {
    grid-template-columns: 1fr;
  }

  .tips-section-panel > .panel-head,
  .tips-members-section .panel-head,
  .tips-inline-summary .panel-head {
    align-items: stretch;
    flex-direction: column;
  }

  .tips-add-person-btn,
  .tips-section-panel .panel-head .btn {
    width: 100%;
    justify-content: center;
  }

  .supplies-result-main strong,
  .supplies-live-hero strong {
    font-size: 30px;
  }

  .cash-line {
    grid-template-columns: minmax(90px, 1fr) 78px minmax(90px, 1fr);
    gap: 8px;
    padding-left: 10px;
    padding-right: 10px;
  }

  .detail-line {
    grid-template-columns: 1fr;
    gap: 4px;
  }
}

@media (max-width: 680px) {
  .login-screen {
    padding: 14px;
  }

  .login-hero,
  .login-card {
    padding: 22px;
    border-radius: 24px;
  }
}

/* ─── MÓDULO DE EVENTOS ──────────────────────────────────────────────────────── */

.event-kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}

/* Shared card pattern used inside events */
article.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 16px;
}

article.card h3 {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 6px;
}

.card-note {
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 12px;
  line-height: 1.5;
}

.close-flow-note {
  background: rgba(var(--accent-rgb, 234, 88, 12), 0.07);
  border: 1px solid rgba(var(--accent-rgb, 234, 88, 12), 0.2);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.5;
}

.close-flow-note strong { color: var(--text); }

.events-preview-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.event-kpi-grid--6 {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.event-kpi {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: left;
  font: inherit;
  color: inherit;
  cursor: pointer;
  width: 100%;
  transition: transform 0.08s, box-shadow 0.12s, border-color 0.12s;
}

button.event-kpi { appearance: none; }

.event-kpi:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.event-kpi--active {
  box-shadow: 0 0 0 2px var(--accent, #ea580c) inset;
}

/* KPI "todos" — neutro/gris, mantiene la línea visual del módulo */
.event-kpi--all {
  background: var(--surface);
  border-color: var(--border);
}
.event-kpi--all .event-kpi__label { color: var(--text-muted); }
.event-kpi--all .event-kpi__value { color: var(--text); }
.event-kpi--all .event-kpi__sub   { color: var(--text-muted); }

.event-dashboard-table th,
.event-dashboard-table td {
  font-size: 13px;
  padding: 8px 10px;
}

.event-dashboard-table th.qlist-th-sort {
  cursor: pointer;
  user-select: none;
}
.event-dashboard-table th.qlist-th-sort:hover { color: var(--accent); }

.event-dashboard-pager {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 4px 2px;
  flex-wrap: wrap;
  font-size: 12px;
}

.event-dashboard-pager__nav {
  display: flex;
  align-items: center;
  gap: 8px;
}

.event-kpi__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 2px;
}

.event-kpi__icon { font-size: 18px; }

.event-kpi__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-weight: 600;
}

.event-kpi__value {
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
  color: var(--text);
}

.event-kpi__sub {
  font-size: 12px;
  color: var(--text-muted);
}

/* KPI hoy — rojo tenue */
.event-kpi--today {
  background: #fff1f0;
  border-color: #fca5a5;
}
.event-kpi--today .event-kpi__label { color: #c0403a; }
.event-kpi--today .event-kpi__value { color: #dc2626; }
.event-kpi--today .event-kpi__sub   { color: #c0403a; }

/* KPI mañana — naranja tenue */
.event-kpi--tomorrow {
  background: #fff7ed;
  border-color: #fdba74;
}
.event-kpi--tomorrow .event-kpi__label { color: #c2580f; }
.event-kpi--tomorrow .event-kpi__value { color: #ea580c; }
.event-kpi--tomorrow .event-kpi__sub   { color: #c2580f; }

/* KPI semana — morado tenue */
.event-kpi--week {
  background: #f5f3ff;
  border-color: #c4b5fd;
}
.event-kpi--week .event-kpi__label { color: #6d28d9; }
.event-kpi--week .event-kpi__value { color: #7c3aed; }
.event-kpi--week .event-kpi__sub   { color: #6d28d9; }

/* KPI mes — azul tenue */
.event-kpi--month {
  background: #eff6ff;
  border-color: #93c5fd;
}
.event-kpi--month .event-kpi__label { color: #1d4ed8; }
.event-kpi--month .event-kpi__value { color: #2563eb; }
.event-kpi--month .event-kpi__sub   { color: #1d4ed8; }

/* KPI vencidos — amarillo/ámbar tenue */
.event-kpi--overdue {
  background: #fffbeb;
  border-color: #fcd34d;
}
.event-kpi--overdue .event-kpi__label { color: #b45309; }
.event-kpi--overdue .event-kpi__value { color: #d97706; }
.event-kpi--overdue .event-kpi__sub   { color: #b45309; }

.event-menu-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}

.event-menu-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px 18px;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: left;
}

.event-menu-card:hover {
  border-color: var(--accent);
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.event-menu-card--disabled {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}

.event-menu-card__icon {
  font-size: 22px;
  margin-bottom: 4px;
}

.event-menu-card__title {
  font-weight: 700;
  font-size: 14px;
  color: var(--text);
}

.event-menu-card__desc {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
}

.event-preview-section {
  margin-top: 4px;
}

.event-preview-section h3 {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: 10px;
}

.event-preview-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 8px;
  background: var(--surface);
  border: 1px solid var(--border);
  font-size: 13px;
}

.event-preview-row--today { border-left: 3px solid var(--blue); }
.event-preview-row--tomorrow { border-left: 3px solid var(--accent); }
.event-preview-row--week { border-left: 3px solid var(--text-muted); }
.event-preview-row--overdue { border-left: 3px solid var(--red); }

.event-preview-row__folio {
  font-weight: 700;
  font-family: monospace;
  font-size: 12px;
  color: var(--accent);
}

.event-preview-row__title {
  color: var(--text);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.event-preview-row__date {
  color: var(--text-muted);
  font-size: 12px;
  white-space: nowrap;
}

/* Status badges */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.badge--draft { background: var(--border); color: var(--text-muted); }
.badge--confirmed { background: rgba(59,130,246,0.12); color: var(--blue); }
.badge--closed { background: rgba(16,185,129,0.12); color: var(--green); }
.badge--cancelled { background: rgba(239,68,68,0.12); color: var(--red); }
.badge--reviewing { background: rgba(245,158,11,0.12); color: var(--yellow); }
.badge--accepted { background: rgba(59,130,246,0.12); color: var(--blue); }
.badge--rejected { background: rgba(239,68,68,0.12); color: var(--red); }
.badge--converted { background: rgba(16,185,129,0.12); color: var(--green); }
.badge--active { background: rgba(16,185,129,0.12); color: var(--green); }
.badge--disabled { background: rgba(239,68,68,0.12); color: var(--red); }
.badge--today { background: rgba(59,130,246,0.12); color: var(--blue); }
.badge--tomorrow { background: rgba(245,158,11,0.12); color: var(--yellow); }
.badge--week { background: var(--border); color: var(--text-muted); }
.badge--month { background: var(--border); color: var(--text-muted); }
.badge--overdue { background: rgba(239,68,68,0.12); color: var(--red); }
.badge--reversed { background: rgba(239,68,68,0.12); color: var(--red); }

/* Badges de lista de precios aplicada (forma de pago) — tono sobrio */
.badge--price-cash { background: rgba(16,185,129,0.12); color: var(--green); }
.badge--price-digital { background: rgba(100,116,139,0.14); color: #475569; }

/* Variante compacta del badge, para listados y barras de total */
.badge--sm {
  padding: 2px 7px;
  font-size: 10px;
  letter-spacing: 0.04em;
}

/* Línea de lista aplicada bajo el total (texto sobrio, no badge) */
.event-price-list-line {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  font-size: 11px;
  color: var(--text-muted, #6b7280);
}

.event-price-list-line__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
}

.event-price-list-line__dot--cash { background: var(--green); }
.event-price-list-line__dot--digital { background: #64748b; }

/* Status flow */
.event-status-flow {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 20px;
}

.event-status-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  position: relative;
}

.event-status-step::before {
  content: '';
  position: absolute;
  top: 10px;
  left: 50%;
  right: -50%;
  height: 2px;
  background: var(--border);
  z-index: 0;
}

.event-status-step:last-child::before { display: none; }

.event-status-step__dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--border);
  border: 2px solid var(--border);
  z-index: 1;
  transition: background 0.2s;
}

.event-status-step--done .event-status-step__dot { background: var(--green); border-color: var(--green); }
.event-status-step--current .event-status-step__dot { background: var(--accent); border-color: var(--accent); }
.event-status-step--cancelled .event-status-step__dot { background: var(--red); border-color: var(--red); }

.event-status-step__label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.event-status-step--done .event-status-step__label,
.event-status-step--current .event-status-step__label { color: var(--text); }

/* Ledger / financial cards */
.event-ledger-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}

.event-ledger-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.event-ledger-card__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-weight: 600;
}

.event-ledger-card__value {
  font-size: 22px;
  font-weight: 700;
  color: var(--text);
}

.event-ledger-card--payments .event-ledger-card__value { color: var(--green); }
.event-ledger-card--expenses .event-ledger-card__value { color: var(--red); }
.event-ledger-card--balance .event-ledger-card__value { color: var(--blue); }
.event-ledger-card--utility .event-ledger-card__value { color: var(--accent); }

/* Detail layout */
.event-detail-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 20px;
  align-items: start;
}

.panel-head-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.panel-head-row h3 {
  font-size: 14px;
  font-weight: 700;
  margin: 0;
}

/* Tab navigation */
.tab-nav {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}

.tab-btn {
  padding: 8px 16px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}

.tab-btn.active,
.tab-btn:hover {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.action-row {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

/* Quote items table */
.event-quote-items-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.event-quote-items-table th {
  text-align: left;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  font-weight: 600;
  padding: 6px 8px;
  border-bottom: 1px solid var(--border);
}

.event-quote-items-table td {
  padding: 8px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.event-quote-items-table input[type="number"],
.event-quote-items-table input[type="text"] {
  width: 100%;
  min-width: 60px;
}

.event-quote-items-table tfoot td {
  font-weight: 700;
  border-top: 2px solid var(--border);
  border-bottom: none;
}

/* Incidents / alerts */
.event-incident-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 8px;
  font-size: 13px;
}

.event-incident-row--high { border-left: 3px solid var(--red); }
.event-incident-row--medium { border-left: 3px solid var(--yellow); }
.event-incident-row--low { border-left: 3px solid var(--blue); }

.event-incident-row__icon { font-size: 18px; flex-shrink: 0; }
.event-incident-row__body { flex: 1; }
.event-incident-row__title { font-weight: 700; color: var(--text); }
.event-incident-row__detail { color: var(--text-muted); font-size: 12px; margin-top: 2px; }

/* Safe balance */
.event-safe-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}

/* Financial dashboard */
.event-finance-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 20px;
}

/* Responsive */
@media (max-width: 1300px) {
  .event-menu-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .event-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .event-menu-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .event-ledger-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .event-detail-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 780px) {
  .event-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .event-menu-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .event-finance-grid {
    grid-template-columns: 1fr;
  }
  .event-safe-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .event-kpi-grid,
  .event-menu-grid {
    grid-template-columns: 1fr;
  }
  .event-ledger-grid {
    grid-template-columns: 1fr;
  }
}

/* Utility color helpers */
.text-good { color: var(--green); }
.text-bad  { color: var(--red); }

/* Success notice banner (catalog confirm) */
.page-success {
  margin-bottom: 16px;
  background: #f0fdf4;
  color: #166534;
  border: 1px solid #bbf7d0;
  border-radius: 10px;
  padding: 12px 16px;
  font-weight: 500;
}

/* ── Pantalla de producto (nuevo / editar) ──────────────────────────── */
.event-product-screen {
  max-width: 780px;
  margin: 0 auto;
}

.event-product-screen__header {
  margin-bottom: 24px;
}

.event-product-screen__title {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 12px 0 4px;
  color: var(--text);
}

.event-product-screen__subtitle {
  color: var(--muted);
  margin: 0;
}

.event-product-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.event-product-form__name-field {
  margin-bottom: 4px;
}

.event-product-form__name-label {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 6px;
}

.event-product-form__name-input {
  font-size: 1.1rem;
  padding: 12px 14px;
  border-radius: 10px;
}

.actions-cell {
  white-space: nowrap;
}

/* ── Formularios de evento y cotización ─────────────────────────────── */
.event-form-panel {
  max-width: 900px;
}

.event-form-section {
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--border, #e5e7eb);
}

.event-form-section:last-of-type {
  border-bottom: none;
  margin-bottom: 0;
}

.event-form-section__title {
  font-size: .85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted, #6b7280);
  margin: 0 0 14px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--accent, #f59e0b);
  display: inline-block;
}

.event-price-label-output {
  display: block;
  padding: 8px 12px;
  background: var(--surface-alt, #f5f5f5);
  border-radius: 8px;
  font-weight: 600;
  color: var(--text, #111);
  border: 1px solid var(--border, #e5e7eb);
}

.event-form-price-note {
  margin-top: 10px;
  font-size: 12px;
  color: var(--muted, #6b7280);
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 8px;
  padding: 8px 12px;
}

/* ── Tabla de conceptos ─────────────────────────────────────────────── */
.event-items-table-wrap {
  margin-bottom: 0;
  border-radius: 10px;
  border: 1px solid var(--border, #e5e7eb);
  overflow-x: auto; /* permite scroll horizontal si el viewport se aprieta */
}

.event-items-table {
  width: 100%;
  min-width: 640px; /* asegura legibilidad mínima antes de scrollear */
  border-collapse: collapse;
  font-size: 13px;
  table-layout: fixed;
}

.event-items-table thead th {
  background: var(--surface-alt, #f5f5f5);
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 8px 6px;
  border-bottom: 1px solid var(--border, #e5e7eb);
  color: var(--muted, #6b7280);
  white-space: nowrap;
}

.event-items-table__col-concept { width: auto; }
.event-items-table__col-qty     { width: 78px; text-align: center; }
.event-items-table__col-price   { width: 108px; text-align: right; }
.event-items-table__col-total   { width: 104px; text-align: right; }
.event-items-table__col-del     { width: 48px; text-align: center; }

.event-items-table__row td {
  padding: 6px 6px;
  vertical-align: middle;
  border-bottom: 1px solid var(--border, #e5e7eb);
}

.event-items-table__row:last-child td {
  border-bottom: none;
}

.event-items-table__cell-concept {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* Fix: table cells don't support flex — use a wrapper div instead */
.event-items-table__row td.event-items-table__cell-concept {
  display: table-cell;
}

.event-items-table__product-select {
  width: 100%;
  font-size: 12px;
  margin-bottom: 4px;
}

.event-items-table__desc-input {
  width: 100%;
  font-size: 12px;
}

.event-items-table__qty-input {
  width: 100%;
  text-align: right;
  font-size: 13px;
  padding-left: 4px;
  padding-right: 4px;
}

.event-items-table__price-input {
  width: 100%;
  text-align: right;
  font-size: 13px;
}

.event-items-table__cell-qty,
.event-items-table__cell-price,
.event-items-table__cell-total {
  text-align: right;
}

.event-items-table__cell-del {
  text-align: center;
}

.event-items-table__del-btn {
  padding: 2px 7px;
  font-size: 11px;
  opacity: .7;
}

.event-items-table__del-btn:hover {
  opacity: 1;
}

.event-items-table tfoot td {
  padding: 8px 6px;
  background: var(--surface-alt, #f5f5f5);
  font-size: 13px;
}

.event-items-table__subtotal-label {
  text-align: right;
  font-weight: 700;
  color: var(--text, #111);
}

.event-items-table__subtotal-value {
  font-weight: 700;
  color: var(--accent, #f59e0b);
}

.event-items-add-btn {
  margin-top: 10px;
}

/* ── Resumen de cotización ───────────────────────────────────────────── */
.event-form-summary-grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-width: 380px;
  margin-left: auto;
}

.event-form-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 14px;
  color: var(--text, #111);
}

.event-form-summary-row--total {
  background: var(--surface-alt, #f5f5f5);
  border: 1px solid var(--border, #e5e7eb);
  font-weight: 700;
  font-size: 16px;
  padding: 10px 14px;
  border-radius: 10px;
}

/* ── Total bar de nuevo evento directo ───────────────────────────────── */
.event-form-total-bar {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 14px;
  padding: 14px 16px;
  background: var(--surface-alt, #f5f5f5);
  border-radius: 10px;
  border: 1px solid var(--border, #e5e7eb);
}

.event-form-total-bar__label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted, #6b7280);
  white-space: nowrap;
}

.event-form-total-bar__input {
  flex: 1;
  font-size: 22px;
  font-weight: 700;
  border: none;
  background: transparent;
  color: var(--accent, #f59e0b);
  min-width: 0;
}

.event-form-total-bar__hint {
  font-size: 11px;
  color: var(--muted, #6b7280);
  max-width: 220px;
  line-height: 1.4;
}

/* Concept cell: select + free-text input stacked inside a table cell */
.concept-cell {
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 100%;
}

.concept-cell__select {
  width: 100%;
  font-size: 12px;
  padding: 4px 6px;
  border: 1px solid var(--border, #ddd);
  border-radius: 4px;
  background: var(--surface, #fff);
  color: var(--text, #111);
}

.concept-cell__desc {
  width: 100%;
  font-size: 12px;
  padding: 4px 6px;
  border: 1px solid var(--border, #ddd);
  border-radius: 4px;
  background: var(--surface, #fff);
  color: var(--text, #111);
}

.concept-cell__desc::placeholder {
  color: var(--muted, #9ca3af);
}

/* Precio de catálogo bloqueado */
.event-items-table__price-input.readonly,
.event-items-table__price-input[readonly] {
  background: var(--surface-alt, #f3f4f6);
  color: var(--muted, #6b7280);
  cursor: not-allowed;
  border-color: transparent;
}

/* Sección anticipo */
.event-form-section--anticipo {
  border-top: 2px solid var(--accent, #2563eb);
  background: var(--surface, #fff);
}

.event-form-section--anticipo .event-form-section__title {
  color: var(--accent, #2563eb);
}

.event-advance-dest {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  padding: 8px 14px;
  background: var(--surface-alt, #f0f9ff);
  border: 1px solid var(--border, #bfdbfe);
  border-radius: 6px;
  font-size: 13px;
  color: var(--text, #111);
}

/* Resumen de anticipo en vivo */
.event-advance-summary {
  margin-top: 18px;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  overflow: hidden;
  max-width: 420px;
}

.event-advance-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  font-size: 13px;
  border-bottom: 1px solid var(--border, #f0f0f0);
  color: var(--text-muted, #555);
}

.event-advance-summary__row:last-child {
  border-bottom: none;
}

.event-advance-summary__row--pending {
  background: var(--surface-alt, #f9fafb);
  font-weight: 700;
  font-size: 14px;
  color: var(--text, #111);
}

.event-advance-summary__row--pending span:last-child {
  color: var(--warning, #d97706);
  font-size: 16px;
}

.event-adv-pending--zero {
  color: var(--success, #16a34a) !important;
}

.event-adv-pending--has {
  color: var(--warning, #d97706) !important;
}

/* ═══════════════════════════════════════════════════════════════
   REGISTRAR PAGO DE EVENTO (.epay-*)
   ═══════════════════════════════════════════════════════════════ */

.epay-summary {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.epay-summary__card {
  flex: 1;
  min-width: 140px;
  background: var(--surface, #fff);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 10px;
  padding: 14px 18px;
}

.epay-summary__card--paid {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.epay-summary__card--pending {
  border-color: #fde68a;
  background: #fffbeb;
}

.epay-summary__card--available {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.epay-summary__card--overdrawn {
  border-color: #fecaca;
  background: #fef2f2;
}

.notice-box--warn {
  background: #fffbeb;
  border-color: #fde68a;
  color: #92400e;
}

.epay-summary__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted, #6b7280);
  margin-bottom: 4px;
}

.epay-summary__value {
  font-size: 20px;
  font-weight: 700;
  color: var(--text, #111);
}

.epay-form-panel {
  background: var(--surface, #fff);
}

.epay-form-note {
  padding: 10px 14px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 6px;
  font-size: 13px;
  color: #1d4ed8;
  margin-bottom: 20px;
}

.epay-form-sections {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.epay-form-section__title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-muted, #6b7280);
  margin-bottom: 14px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border, #f3f4f6);
}

.epay-dest-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: var(--surface-alt, #f9fafb);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 10px;
}

.epay-dest-card__icon {
  font-size: 28px;
  line-height: 1;
}

.epay-dest-card__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted, #6b7280);
}

.epay-dest-card__name {
  font-size: 15px;
  font-weight: 700;
  color: var(--text, #111);
  margin-top: 2px;
}

.field-hint {
  display: block;
  font-size: 11px;
  color: var(--text-muted, #6b7280);
  margin-top: 4px;
}

/* ═══════════════════════════════════════════════════════════════
   DETALLE DE EVENTO (.edet-*)
   ═══════════════════════════════════════════════════════════════ */

/* Header */
.edet-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  padding: 20px 0 16px;
  border-bottom: 1px solid var(--border, #e5e7eb);
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.edet-header__left {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.edet-header__folio {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--primary, #3b82f6);
  margin-bottom: 2px;
}

.edet-header__title {
  font-size: 20px;
  font-weight: 700;
  color: var(--text, #111);
  line-height: 1.2;
  margin-bottom: 4px;
}

.edet-header__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 13px;
  color: var(--text-muted, #6b7280);
  align-items: center;
}

.edet-header__right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

/* Status flow */
.edet-status-flow {
  display: flex;
  align-items: center;
  gap: 0;
}

.edet-status-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--text-muted, #9ca3af);
  min-width: 64px;
  text-align: center;
}

.edet-status-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--border, #d1d5db);
  display: block;
}

.edet-status-step--current .edet-status-dot {
  background: var(--primary, #3b82f6);
  box-shadow: 0 0 0 3px #bfdbfe;
}

.edet-status-step--current {
  color: var(--primary, #3b82f6);
  font-weight: 600;
}

.edet-status-step--done .edet-status-dot {
  background: var(--success, #16a34a);
}

.edet-status-step--done {
  color: var(--success, #16a34a);
}

.edet-status-step--cancelled .edet-status-dot {
  background: var(--danger, #dc2626);
}

.edet-status-step--cancelled {
  color: var(--danger, #dc2626);
}

.edet-status-line {
  flex: 1;
  height: 2px;
  background: var(--border, #e5e7eb);
  margin-bottom: 16px;
  min-width: 32px;
}

.edet-status-line--done {
  background: var(--success, #16a34a);
}

/* Finance cards */
.edet-finance-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.edet-finance-card {
  flex: 1;
  min-width: 120px;
  background: var(--surface, #fff);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 10px;
  padding: 14px 16px;
}

.edet-finance-card--paid {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.edet-finance-card--pending {
  border-color: #fde68a;
  background: #fffbeb;
}

.edet-finance-card--zero {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.edet-finance-card--costs {
  border-color: #fecaca;
  background: #fff5f5;
}

.edet-finance-card--profit {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.edet-finance-card--loss {
  border-color: #fecaca;
  background: #fef2f2;
}

.edet-finance-card__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted, #6b7280);
  margin-bottom: 4px;
}

.edet-finance-card__value {
  font-size: 18px;
  font-weight: 700;
  color: var(--text, #111);
}

/* Actions bar */
.edet-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 12px 0;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border, #f3f4f6);
}

.edet-actions__primary {
  background: var(--primary, #3b82f6);
  color: #fff;
  font-weight: 700;
}

.edet-actions__close {
  background: var(--success, #16a34a);
  color: #fff;
  border-color: var(--success, #16a34a);
}

.edet-actions__spacer {
  flex: 1;
  min-width: 16px;
}

/* Tab count badge */
.tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--border, #e5e7eb);
  color: var(--text-muted, #374151);
  font-size: 10px;
  font-weight: 700;
  border-radius: 10px;
  padding: 1px 6px;
  margin-left: 4px;
  line-height: 1.4;
}

.tab-btn.active .tab-count {
  background: var(--primary, #3b82f6);
  color: #fff;
}

/* Overview tab grid */
.edet-overview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  align-items: start;
}

.edet-overview-section {
  margin: 0;
}

.edet-overview-section--full {
  grid-column: 1 / -1;
}

.edet-overview-section--info {
  border-left: 3px solid var(--success, #16a34a);
}

.edet-overview-section--danger {
  border-left: 3px solid var(--danger, #dc2626);
}

.edet-fields {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.edet-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.edet-field__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted, #9ca3af);
  font-weight: 600;
}

.edet-field__value {
  font-size: 14px;
  color: var(--text, #111);
}

.edet-field__value--strong {
  font-weight: 700;
  font-size: 15px;
}

.edet-field__value--discount {
  color: var(--danger, #dc2626);
  font-weight: 600;
}

.edet-field__value a {
  color: var(--primary, #3b82f6);
  text-decoration: none;
}

.edet-field__value a:hover {
  text-decoration: underline;
}

.edet-notes {
  font-size: 14px;
  color: var(--text, #333);
  line-height: 1.6;
  white-space: pre-wrap;
  margin: 0;
}

/* Empty state in tabs */
.edet-empty {
  text-align: center;
  padding: 40px 20px;
  color: var(--text-muted, #6b7280);
}

.edet-empty__icon {
  font-size: 36px;
  margin-bottom: 8px;
}

.edet-empty__text {
  font-size: 14px;
  margin-bottom: 16px;
}

/* ── Documentos del evento (confirmación firmada) ───────────────────────── */
.edoc-hidden-input {
  display: none;
}

.edoc-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.edoc-card__hint {
  margin: 2px 0 0;
  font-size: 13px;
}

.edoc-card__file {
  margin-top: 14px;
  padding: 14px 16px;
  background: var(--surface-2, #f8fafc);
  border: 1px solid var(--line, #e5e7eb);
  border-radius: 10px;
}

.edoc-card__filename {
  font-weight: 600;
  word-break: break-word;
}

.edoc-card__facts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px 18px;
  margin: 12px 0 0;
}

.edoc-card__facts > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.edoc-card__facts dt {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted, #6b7280);
}

.edoc-card__facts dd {
  margin: 0;
  font-size: 14px;
  color: var(--text, #18212f);
}

.edoc-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.edoc-card__empty {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}

.edoc-history {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--line, #e5e7eb);
}

.edoc-history__title {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted, #6b7280);
  margin-bottom: 8px;
}

.edoc-history__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.edoc-history__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 0;
}

.edoc-history__name {
  flex: 1;
  min-width: 0;
  word-break: break-word;
}

.edoc-card__file--purged {
  background: var(--surface-2, #f8fafc);
  border-style: dashed;
}

/* Limpieza de documentos (retención) */
.docret-summary {
  margin-top: 14px;
  padding: 12px 14px;
  background: var(--surface-2, #f8fafc);
  border: 1px solid var(--line, #e5e7eb);
  border-radius: 10px;
}

.docret-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

/* Reversed row */
.row-reversed {
  opacity: .55;
}

.line-through {
  text-decoration: line-through;
}

/* Badge de tipo de pago de evento (tabla de pagos) */
.ept-badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.5;
  white-space: nowrap;
  border: 1px solid transparent;
}
.ept-badge--anticipo {
  background: rgba(59,130,246,0.12);
  color: #1d4ed8;
  border-color: rgba(59,130,246,0.30);
}
.ept-badge--abono {
  background: rgba(100,116,139,0.12);
  color: #475569;
  border-color: rgba(100,116,139,0.30);
}
.ept-badge--liquidacion {
  background: rgba(16,185,129,0.12);
  color: #047857;
  border-color: rgba(16,185,129,0.30);
}
.ept-badge--unico {
  background: rgba(201,148,46,0.14);
  color: #9a6b12;
  border-color: rgba(201,148,46,0.35);
}
.ept-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* Acciones rápidas tras registrar un pago */
.edet-post-payment {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 10px 0 4px;
  padding: 10px 14px;
  background: rgba(201,148,46,0.08);
  border: 1px solid rgba(201,148,46,0.30);
  border-radius: 8px;
}
.edet-post-payment__label {
  font-size: 13px;
  font-weight: 600;
  color: #9a6b12;
}

/* ═══════════════════════════════════════════════════════════════
   EDITAR EVENTO — Condiciones comerciales de solo lectura
   ═══════════════════════════════════════════════════════════════ */

.event-form-section--readonly {
  background: var(--surface-alt, #f9fafb);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 10px;
  padding: 20px;
  margin-bottom: 0;
}

.event-form-readonly-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.event-form-readonly-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #fef3c7;
  color: #92400e;
  border: 1px solid #fde68a;
  border-radius: 20px;
  padding: 2px 10px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.event-form-readonly-note {
  font-size: 12px;
  color: var(--text-muted, #6b7280);
  margin: 0 0 16px;
  line-height: 1.5;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  padding: 10px 14px;
}

.event-form-readonly-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.event-form-readonly-field {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.event-form-readonly-field__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted, #9ca3af);
  font-weight: 600;
}

.event-form-readonly-field__value {
  font-size: 15px;
  font-weight: 600;
  color: var(--text, #111);
}

.event-form-readonly-field__value--money {
  font-size: 18px;
  color: var(--text, #111);
}

.event-form-readonly-field__value--discount {
  color: var(--danger, #dc2626);
}

/* ═══════════════════════════════════════════════════════════════
   CONCEPTOS VENDIDOS — Tabla de ítems de cotización
   ═══════════════════════════════════════════════════════════════ */

.edet-sale-quote-ref {
  font-size: 12px;
  font-weight: 400;
  color: var(--text-muted, #9ca3af);
  margin-left: 8px;
  background: var(--surface-alt, #f3f4f6);
  padding: 2px 8px;
  border-radius: 12px;
}

.edet-sale-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-muted, #6b7280);
}

.edet-sale-summary strong {
  color: var(--text, #111);
  font-weight: 700;
}

.edet-sale-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.edet-sale-table th {
  text-align: left;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted, #6b7280);
  padding: 8px 12px;
  border-bottom: 2px solid var(--border, #e5e7eb);
  background: var(--surface-alt, #f9fafb);
}

.edet-sale-table th.num,
.edet-sale-table td.num {
  text-align: right;
}

.edet-sale-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border, #f3f4f6);
  color: var(--text, #111);
  vertical-align: middle;
}

.edet-sale-table tbody tr:last-child td {
  border-bottom: none;
}

.edet-sale-table tbody tr:hover {
  background: var(--surface-alt, #f9fafb);
}

.edet-sale-table__concept {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.edet-sale-table__product-tag {
  font-size: 11px;
  font-weight: 700;
  color: var(--primary, #3b82f6);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.edet-sale-table__subtotal {
  font-weight: 600;
}

.edet-sale-table__total-row td {
  border-top: 2px solid var(--border, #e5e7eb);
  border-bottom: none;
  padding: 12px;
  background: var(--surface-alt, #f9fafb);
}

.edet-sale-table__grand-total {
  font-size: 16px;
  font-weight: 700;
  color: var(--text, #111);
}

/* ═══════════════════════════════════════════════════════════════
   MEJORA DE TABS EN DETALLE DE EVENTO
   ═══════════════════════════════════════════════════════════════ */

/* Override de tab-nav específico para el detalle de evento */
.edet-header ~ .edet-finance-row ~ .edet-actions ~ .tab-nav,
.edet-header ~ .edet-finance-row ~ .tab-nav {
  margin-top: 24px;
  border-bottom: 2px solid var(--border, #e5e7eb);
  display: flex;
  gap: 0;
  padding: 0;
  background: transparent;
}

/* Asegurar que los tab-btn en contexto de eventos se vean bien */
.tab-nav .tab-btn {
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-muted, #6b7280);
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: color .15s, border-color .15s;
  white-space: nowrap;
}

.tab-nav .tab-btn:hover {
  color: var(--text, #111);
  border-bottom-color: var(--border, #d1d5db);
}

.tab-nav .tab-btn.active {
  color: var(--primary, #3b82f6);
  border-bottom-color: var(--primary, #3b82f6);
  font-weight: 700;
}

/* ── Módulo Administración: tarjetas de hub ─────────────────────────────── */
.admin-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 8px;
}

.admin-card-grid--list {
  grid-template-columns: 1fr;
  max-width: 720px;
}

.admin-settings-group {
  max-width: 720px;
  margin: 22px 0 10px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted, #6b7280);
}

.admin-settings-group:first-of-type {
  margin-top: 6px;
}

.admin-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  background: var(--surface, #fff);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 12px;
  text-align: left;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  font-family: inherit;
}

.admin-card:not(.admin-card--disabled):hover {
  border-color: var(--primary, #3b82f6);
  box-shadow: 0 6px 18px rgba(15, 23, 42, .06);
  transform: translateY(-1px);
}

.admin-card--disabled {
  cursor: not-allowed;
  opacity: .55;
}

.admin-card__icon {
  flex: 0 0 44px;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: var(--brand-soft, #fef3c7);
  display: grid;
  place-items: center;
  font-size: 22px;
}

.admin-card__body {
  flex: 1;
  min-width: 0;
}

.admin-card__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text, #111);
  margin-bottom: 2px;
}

.admin-card__desc {
  margin: 0;
  font-size: 12.5px;
  color: var(--text-muted, #6b7280);
  line-height: 1.4;
}

.admin-card__chev {
  flex: 0 0 auto;
  font-size: 24px;
  color: var(--text-muted, #9ca3af);
  font-weight: 300;
}

.admin-card__soon {
  flex: 0 0 auto;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--border, #e5e7eb);
  color: var(--text-muted, #6b7280);
}

/* ── Listado de cotizaciones: KPI-chips, búsqueda, filtros, sort ────────── */
.qlist-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}

/* Chip base. Las variantes --pending/--converted/--rejected/--all aportan
   color; la paleta se alinea con los badges de estado de la tabla:
     • pendiente  → azul   (rgb 59,130,246)  — coincide con .badge--accepted
     • convertida → verde  (rgb 16,185,129)  — coincide con .badge--converted
     • rechazada  → rojo   (rgb 239,68,68)   — coincide con .badge--rejected
     • todas      → violeta(rgb 139,92,246) — neutro distintivo

   Estado inactivo: fondo blanco, borde tintado suave, número en el color.
   Estado activo  : fondo tintado, borde sólido del color, halo (box-shadow). */
.qlist-tab {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  background: var(--surface, #fff);
  border: 1px solid var(--line, #e5e7eb);
  border-radius: 14px;
  cursor: pointer;
  font-family: inherit;
  transition: border-color .15s ease, background .15s ease, box-shadow .15s ease, transform .15s ease;
  min-width: 160px;
}

.qlist-tab:hover {
  transform: translateY(-1px);
}

.qlist-tab__count {
  font-size: 22px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.02em;
}

.qlist-tab__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted, #64748b);
  font-weight: 700;
}

/* ── Variante: PENDIENTES (azul) ──────────────────────────────────────── */
.qlist-tab--pending {
  border-color: rgba(59,130,246,0.22);
  background: rgba(59,130,246,0.04);
}
.qlist-tab--pending .qlist-tab__count { color: #2563eb; }
.qlist-tab--pending:hover { border-color: rgba(59,130,246,0.5); }
.qlist-tab--pending.qlist-tab--active {
  background: rgba(59,130,246,0.10);
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59,130,246,0.16);
}
.qlist-tab--pending.qlist-tab--active .qlist-tab__label { color: #1d4ed8; }

/* ── Variante: CONVERTIDAS A EVENTO (verde) ───────────────────────────── */
.qlist-tab--converted {
  border-color: rgba(16,185,129,0.22);
  background: rgba(16,185,129,0.04);
}
.qlist-tab--converted .qlist-tab__count { color: #059669; }
.qlist-tab--converted:hover { border-color: rgba(16,185,129,0.5); }
.qlist-tab--converted.qlist-tab--active {
  background: rgba(16,185,129,0.10);
  border-color: #10b981;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.16);
}
.qlist-tab--converted.qlist-tab--active .qlist-tab__label { color: #047857; }

/* ── Variante: RECHAZADAS (rojo) ──────────────────────────────────────── */
.qlist-tab--rejected {
  border-color: rgba(239,68,68,0.22);
  background: rgba(239,68,68,0.04);
}
.qlist-tab--rejected .qlist-tab__count { color: #dc2626; }
.qlist-tab--rejected:hover { border-color: rgba(239,68,68,0.5); }
.qlist-tab--rejected.qlist-tab--active {
  background: rgba(239,68,68,0.10);
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,0.16);
}
.qlist-tab--rejected.qlist-tab--active .qlist-tab__label { color: #b91c1c; }

/* ── Variante: TODAS (violeta suave) ──────────────────────────────────── */
.qlist-tab--all {
  border-color: rgba(139,92,246,0.22);
  background: rgba(139,92,246,0.04);
}
.qlist-tab--all .qlist-tab__count { color: #7c3aed; }
.qlist-tab--all:hover { border-color: rgba(139,92,246,0.5); }
.qlist-tab--all.qlist-tab--active {
  background: rgba(139,92,246,0.10);
  border-color: #8b5cf6;
  box-shadow: 0 0 0 3px rgba(139,92,246,0.16);
}
.qlist-tab--all.qlist-tab--active .qlist-tab__label { color: #6d28d9; }

/* ── Variante: CAJA DEL TURNO (ámbar) ─────────────────────────────────── */
.qlist-tab--funding-turno {
  border-color: rgba(217,119,6,0.28);
  background: rgba(245,158,11,0.06);
}
.qlist-tab--funding-turno .qlist-tab__count { color: #d97706; }
.qlist-tab--funding-turno:hover { border-color: rgba(217,119,6,0.55); }
.qlist-tab--funding-turno.qlist-tab--active {
  background: rgba(245,158,11,0.12);
  border-color: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245,158,11,0.18);
}
.qlist-tab--funding-turno.qlist-tab--active .qlist-tab__label { color: #b45309; }

.qlist-tab__sub {
  font-size: 12px;
  font-weight: 700;
  color: var(--muted, #64748b);
  letter-spacing: -.01em;
}

/* Mini-KPI con etiqueta + monto apilados a la derecha del número. */
.qlist-tab__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: flex-start;
}

/* ── Barra de periodo (corte mensual) de Gastos generales ─────────────────── */
.gx-period-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.gx-period-bar__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted, #64748b);
  font-weight: 700;
}
.gx-period-bar__input {
  padding: 7px 10px;
  border: 1px solid var(--line, #e5e7eb);
  border-radius: 10px;
  font-family: inherit;
  font-size: 13px;
  background: var(--surface, #fff);
}
.gx-period-bar__step {
  min-width: 34px;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
.gx-period-bar__current {
  font-size: 14px;
  font-weight: 800;
  color: var(--text, #0f172a);
  letter-spacing: -.01em;
}
.gx-overlimit-note {
  margin: 4px 0 12px;
  font-size: 12px;
}

/* ── Badge "Caja del turno" (ámbar, egreso Fudo) ──────────────────────── */
.badge.badge-funding-turno {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  background: #fffbeb;
  color: #b45309;
  border: 1px solid rgba(217,119,6,0.35);
  font-weight: 700;
}
.badge-funding-turno__sub {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: #d97706;
  opacity: .85;
}

/* ── Resalte sutil de filas pagadas desde caja del turno ──────────────── */
tr.supplies-row--turno {
  background: rgba(245,158,11,0.05);
  box-shadow: inset 3px 0 0 #f59e0b;
}

/* ── Badge "Mixto" (gasto pagado parcialmente desde dos cajas) ────────── */
.badge-funding-mixed {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  padding: 4px 8px;
  background: linear-gradient(90deg, #eff6ff 0%, #fff7ed 100%);
  border: 1px solid #c4b5fd;
  border-radius: 8px;
  line-height: 1.2;
}
.badge-funding-mixed__title {
  font-size: 11.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #6d28d9;
}
.badge-funding-mixed__split {
  font-size: 11px;
  font-weight: 600;
  color: #4b5563;
}

/* Resalte sutil de filas mixtas (combina los dos tonos: azul + ámbar). */
tr.supplies-row--mixed {
  background: linear-gradient(90deg, rgba(59,130,246,0.04) 0%, rgba(245,158,11,0.04) 100%);
  box-shadow: inset 3px 0 0 #8b5cf6;
}

.supplies-row__sibling {
  display: block;
  margin-top: 2px;
  font-size: 10.5px;
  font-weight: 600;
  color: #6b7280;
  letter-spacing: 0.02em;
}

.qlist-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.qlist-head-actions {
  display: flex;
  gap: 8px;
}

.qlist-count {
  font-weight: 400;
  font-size: .78em;
  margin-left: .6em;
}

.qlist-toolbar {
  display: flex;
  gap: 10px;
  align-items: center;
  margin: 12px 0;
  flex-wrap: wrap;
}

.qlist-search {
  flex: 1;
  min-width: 240px;
}

.qlist-search input[type="search"] {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  font-size: 14px;
  font-family: inherit;
  background: #fff;
}

.qlist-search input[type="search"]:focus {
  outline: none;
  border-color: var(--primary, #3b82f6);
  box-shadow: 0 0 0 3px rgba(59,130,246,.12);
}

.qlist-toolbar-actions {
  display: flex;
  gap: 6px;
}

.qlist-toolbar-actions .is-active {
  background: rgba(59,130,246,.08);
  border-color: var(--primary, #3b82f6);
  color: var(--primary, #3b82f6);
}

.qlist-filter-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--primary, #3b82f6);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  margin-left: 4px;
}

.qlist-filters {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin-bottom: 14px;
  padding: 14px;
  background: var(--surface-alt, #f9fafb);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 10px;
}

.qlist-filter-group label {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-muted, #6b7280);
  font-weight: 600;
  margin-bottom: 4px;
}

.qlist-filter-group input,
.qlist-filter-group select {
  width: 100%;
  padding: 7px 10px;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 6px;
  font-size: 13px;
  background: #fff;
  font-family: inherit;
}

.qlist-th-sort {
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}

.qlist-th-sort:hover {
  background: rgba(59,130,246,.05);
}

.qlist-sort-arrow {
  display: inline-block;
  width: 12px;
  color: var(--primary, #3b82f6);
  font-weight: 700;
}

.qlist-empty {
  padding: 36px 16px;
  text-align: center;
}

/* ============================================================================
   SISTEMA VISUAL NEUTRAL (ui-*) — FASE 1
   Réplica del lenguaje visual del módulo Eventos para reutilizar en
   Operación y Nómina. Bloques INDEPENDIENTES: no comparten selector con
   .event-* (Eventos queda 100% intacto) ni con .badge / tablas.
   Nada cambia visualmente hasta que estas clases se usen (Fase 2+).
   Nota: se replican a propósito las mismas referencias var(--border) /
   var(--text-muted) / var(--accent) que usa Eventos. Hoy esas variables
   no están definidas, por lo que (igual que en Eventos) el borde no se
   pinta y el look queda aireado. NO definir esas variables globalmente:
   eso alteraría Eventos.
   ============================================================================ */

/* ---- Grids ---- */
.ui-kpi-grid  { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; margin-bottom: 20px; }
.ui-card-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; margin-bottom: 24px; }

/* ---- KPI card (valores idénticos a .event-kpi) ---- */
.ui-kpi-card { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 16px; display: flex; flex-direction: column; gap: 4px; }
.rk-clickable { cursor: pointer; transition: border-color .12s ease, box-shadow .12s ease, background .12s ease; }
.ui-kpi-card.rk-clickable:hover { border-color: var(--brand-2); box-shadow: 0 4px 14px rgba(15,23,42,.08); }
.ui-kpi-card.rk-clickable[aria-expanded="true"] { border-color: var(--brand); }
tr.rk-clickable:hover > td { background: var(--surface-2); }
.ui-kpi-card__top   { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 2px; }
.ui-kpi-card__icon  { font-size: 18px; }
.ui-kpi-card__label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); font-weight: 600; }
.ui-kpi-card__value { font-size: 28px; font-weight: 700; line-height: 1; color: var(--text); }
.ui-kpi-card__sub   { font-size: 12px; color: var(--text-muted); }

.ui-kpi-card--danger  { background: #fff1f0; border-color: #fca5a5; }
.ui-kpi-card--danger  .ui-kpi-card__label,
.ui-kpi-card--danger  .ui-kpi-card__sub   { color: #c0403a; }
.ui-kpi-card--danger  .ui-kpi-card__value { color: #dc2626; }

.ui-kpi-card--warning { background: #fff7ed; border-color: #fdba74; }
.ui-kpi-card--warning .ui-kpi-card__label,
.ui-kpi-card--warning .ui-kpi-card__sub   { color: #c2580f; }
.ui-kpi-card--warning .ui-kpi-card__value { color: #ea580c; }

.ui-kpi-card--accent  { background: #f5f3ff; border-color: #c4b5fd; }
.ui-kpi-card--accent  .ui-kpi-card__label,
.ui-kpi-card--accent  .ui-kpi-card__sub   { color: #6d28d9; }
.ui-kpi-card--accent  .ui-kpi-card__value { color: #7c3aed; }

.ui-kpi-card--info    { background: #eff6ff; border-color: #93c5fd; }
.ui-kpi-card--info    .ui-kpi-card__label,
.ui-kpi-card--info    .ui-kpi-card__sub   { color: #1d4ed8; }
.ui-kpi-card--info    .ui-kpi-card__value { color: #2563eb; }

.ui-kpi-card--amber   { background: #fffbeb; border-color: #fcd34d; }
.ui-kpi-card--amber   .ui-kpi-card__label,
.ui-kpi-card--amber   .ui-kpi-card__sub   { color: #b45309; }
.ui-kpi-card--amber   .ui-kpi-card__value { color: #d97706; }

/* ---- Action card clic (valores idénticos a .event-menu-card) — sin botón barra interno ---- */
.ui-action-card { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 20px 18px; cursor: pointer; transition: border-color 0.15s, box-shadow 0.15s; display: flex; flex-direction: column; gap: 6px; }
.ui-action-card:hover { border-color: var(--accent); box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08); }
.ui-action-card--disabled { opacity: 0.45; cursor: not-allowed; pointer-events: none; }
.ui-action-card__icon  { font-size: 22px; margin-bottom: 4px; }
.ui-action-card__title { font-weight: 700; font-size: 14px; color: var(--text); }
.ui-action-card__desc  { font-size: 12px; color: var(--text-muted); line-height: 1.4; }

/* ---- Section header (nuevo, mejor estructurado): título/desc a la izquierda,
        botones de navegación superior alineados a la derecha ---- */
.ui-section-header { max-width: 1480px; margin-bottom: 16px; }
.ui-section-header__bar { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.ui-section-header__titles h2 { margin: 0 0 4px; font-size: 28px; letter-spacing: -0.04em; }
.ui-section-header__titles p  { margin: 0; color: var(--muted); }
.ui-section-header__actions   { display: flex; align-items: center; gap: 8px; flex-shrink: 0; flex-wrap: wrap; }

/* ---- Botones — lenguaje limpio/discreto de Eventos, con jerarquía sutil.
        Uso: class="ui-action-button ui-primary-action".
        Secundario y ghost van en la MISMA fila, antes del principal. ---- */
.ui-action-button { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 14px; cursor: pointer; text-decoration: none; transition: background 0.15s, border-color 0.15s, color 0.15s; }

/* Principal: mayor jerarquía, limpio, fondo muy tenue + borde suave, tamaño cómodo */
.ui-primary-action { background: var(--surface-2); border: 1px solid var(--line-strong); color: var(--text); padding: 12px 16px; font-weight: 900; }
.ui-primary-action:hover { background: #eef2f7; border-color: var(--muted); }

/* Secundario: más pequeño, menos padding, outline ligero, texto discreto */
.ui-secondary-action { background: transparent; border: 1px solid var(--line); color: var(--muted); padding: 8px 12px; border-radius: 12px; font-weight: 700; font-size: 13px; }
.ui-secondary-action:hover { border-color: var(--line-strong); color: var(--text); }

/* Ghost: mínimo, para navegación superior del header (← Inicio / Volver / Actualizar) */
.ui-ghost-button { background: transparent; border: 0; color: var(--muted); padding: 8px 12px; border-radius: 12px; font-weight: 700; font-size: 13px; cursor: pointer; }
.ui-ghost-button:hover { color: var(--text); }

.ui-action-button:focus-visible,
.ui-ghost-button:focus-visible { outline: 3px solid rgba(37, 99, 235, 0.22); outline-offset: 3px; }

/* ---- Responsive (mismos breakpoints que Eventos) ---- */
@media (max-width: 1280px) { .ui-card-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 1100px) { .ui-kpi-grid, .ui-card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 760px)  { .ui-kpi-grid, .ui-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 480px)  { .ui-kpi-grid, .ui-card-grid { grid-template-columns: 1fr; } }

/* ---- Filas de panel (alertas / acciones rápidas) — limpias y clickeables ---- */
.ui-list-row {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  text-align: left;
  font: inherit;
  color: var(--text);
}
.ui-list-row__icon { font-size: 20px; flex-shrink: 0; }
.ui-list-row__body { flex: 1; min-width: 0; }
.ui-list-row__title { font-weight: 700; font-size: 14px; }
.ui-list-row__sub { font-size: 12px; color: var(--muted); margin-top: 2px; }
.ui-list-row__end { flex-shrink: 0; display: flex; align-items: center; gap: 8px; }
.ui-list-row__chevron { color: var(--soft); font-size: 16px; }
button.ui-list-row { cursor: pointer; transition: border-color .15s, box-shadow .15s, background .15s; }
button.ui-list-row:hover { border-color: var(--line-strong); box-shadow: 0 2px 8px rgba(15, 23, 42, .06); }
button.ui-list-row:focus-visible { outline: 3px solid rgba(37, 99, 235, .22); outline-offset: 2px; }
.ui-list-row--disabled { opacity: .55; }

/* ── Calendario de eventos (submódulo Eventos / Calendario) ─────────────── */
/* Franja compacta de resumen de ocupación del mes (reemplaza tarjetas KPI). */
.evcal-summary {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 18px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 13px;
  color: var(--muted);
}
.evcal-summary__month {
  font-weight: 700;
  color: var(--text);
  font-size: 14px;
  padding-right: 6px;
  border-right: 1px solid var(--line);
}
.evcal-summary__item { display: inline-flex; align-items: center; gap: 6px; }
.evcal-summary__item strong { color: var(--text); font-weight: 700; }
.evcal-summary__item--total { margin-left: auto; color: var(--text); }
.evcal-summary__dot { width: 8px; height: 8px; border-radius: 50%; background: #cbd5e1; flex: none; }
.evcal-summary__dot--green  { background: #16a34a; }
.evcal-summary__dot--yellow { background: #d4a017; }
.evcal-summary__dot--orange { background: #ea7c2b; }
.evcal-summary__dot--red    { background: #dc2626; }

/* Por defecto el calendario ocupa todo el ancho; el drawer abre una 2ª columna. */
.evcal-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
}
.evcal-layout--with-drawer { grid-template-columns: minmax(0, 1fr) 360px; }
.evcal-main { padding: 18px; }

.evcal-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.evcal-nav { display: flex; align-items: center; gap: 8px; }
.evcal-month {
  font-size: 18px; font-weight: 700; color: var(--text);
  min-width: 150px; text-align: center;
}
.evcal-filters { display: inline-flex; gap: 6px; background: var(--surface-2); padding: 4px; border-radius: 10px; }
.evcal-chip {
  border: 0; background: transparent; cursor: pointer;
  padding: 6px 12px; border-radius: 8px;
  font-size: 13px; font-weight: 600; color: var(--muted);
  transition: background .15s, color .15s;
}
.evcal-chip:hover { color: var(--text); }
.evcal-chip.is-active { background: var(--surface); color: var(--brand); box-shadow: 0 1px 2px rgba(15, 23, 42, .08); }

.evcal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.evcal-grid--heads { margin-bottom: 8px; }
.evcal-weekday {
  text-align: left; padding: 0 6px;
  font-size: 11.5px; font-weight: 700; letter-spacing: .04em;
  color: var(--soft);
}

.evcal-cell {
  display: flex; flex-direction: column;
  text-align: left; cursor: pointer;
  min-height: 118px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 8px 9px;
  background: var(--surface);
  transition: border-color .15s, box-shadow .15s, transform .05s;
  overflow: hidden;
}
.evcal-cell:hover { border-color: var(--line-strong); box-shadow: 0 4px 12px rgba(15, 23, 42, .08); }
.evcal-cell:active { transform: translateY(1px); }
.evcal-cell--out { background: var(--surface-2); }
.evcal-cell--out .evcal-cell__day { color: var(--soft); font-weight: 600; }
.evcal-cell--out .evcal-ev,
.evcal-cell--out .evcal-cell__badge { opacity: .65; }
.evcal-cell--today { box-shadow: 0 0 0 2px var(--blue); border-color: var(--blue); }
/* Día seleccionado: anillo marrón más grueso + sombra exterior sutil. Se aplica
   por box-shadow para no tapar el color del semáforo (que va por border/fondo). */
.evcal-cell--selected {
  box-shadow: 0 0 0 3px var(--brand), 0 8px 18px rgba(155, 90, 49, .20);
  border-color: var(--brand);
}
.evcal-cell--today.evcal-cell--selected {
  box-shadow: 0 0 0 3px var(--brand), 0 0 0 5px rgba(37, 99, 235, .3), 0 8px 18px rgba(155, 90, 49, .20);
}

.evcal-cell__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 6px; }
.evcal-cell__daywrap { display: inline-flex; align-items: center; gap: 6px; min-width: 0; }
/* El número del día es el elemento dominante de la celda. */
.evcal-cell__day { font-size: 20px; font-weight: 700; line-height: 1; color: var(--text); }
.evcal-cell__today {
  font-size: 9px; font-weight: 700; letter-spacing: .04em;
  color: #fff; background: var(--blue);
  padding: 2px 6px; border-radius: 999px;
}
/* Conteo como badge secundario, claro pero sin competir con el día. */
.evcal-cell__badge {
  flex: none;
  font-size: 10.5px; font-weight: 600;
  padding: 2px 7px; border-radius: 999px;
  background: var(--surface-2); color: var(--muted);
  border: 1px solid var(--line);
  white-space: nowrap;
}
/* Badges con contraste progresivo: amarillo < naranja < rojo. */
.evcal-cell__badge--green  { background: #eef9f1; color: #15803d; border-color: #cdeed7; }
.evcal-cell__badge--yellow { background: #f6df93; color: #79520a; border-color: #e7cd72; font-weight: 700; }
.evcal-cell__badge--orange { background: #f9cb9f; color: #a6480a; border-color: #efb486; font-weight: 700; }
.evcal-cell__badge--red    { background: #f8c7c7; color: #a01515; border-color: #efa9a9; font-weight: 700; }

/* Semáforo: fondo + borde con perceptibilidad creciente. El verde se mantiene
   limpio; amarillo, naranja y rojo suman un acento de borde izquierdo
   (border-box, sin descuadrar la grilla) para que "1 evento" deje de
   confundirse con un día libre y la carga media/saturación se lean de inmediato. */
.evcal-cell--green:not(.evcal-cell--out)  { background: #f6fbf8; border-color: #dcefe3; }
.evcal-cell--yellow:not(.evcal-cell--out) {
  background: #fff4cf; border-color: #e4cd80;
  border-left: 3px solid #e3ad2e;
}
.evcal-cell--orange:not(.evcal-cell--out) {
  background: #ffe6c9; border-color: #eab784;
  border-left: 3px solid #e07d2c;
}
.evcal-cell--red:not(.evcal-cell--out) {
  background: #fdeaea; border-color: #eeb0b0;
  border-left: 4px solid #d05a5a;
}

.evcal-cell__events { margin-top: 6px; display: flex; flex-direction: column; gap: 3px; min-height: 0; }
.evcal-ev { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--ink); }
.evcal-ev__dot { width: 5px; height: 5px; border-radius: 50%; background: var(--brand-2); flex: none; }
.evcal-ev__txt { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.evcal-ev--more { color: var(--muted); font-size: 10.5px; padding-left: 10px; }

/* Drawer lateral de detalle del día */
.evcal-drawer { padding: 0; position: sticky; top: 16px; overflow: hidden; }
.evcal-drawer--empty { padding: 24px; }
.evcal-drawer__head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 16px 18px; border-bottom: 1px solid var(--line);
}
.evcal-drawer__date { font-size: 15px; font-weight: 700; color: var(--text); }
.evcal-drawer__count { font-size: 12.5px; color: var(--muted); margin-top: 2px; }
.evcal-drawer__close {
  border: 0; background: var(--surface-2); cursor: pointer;
  width: 28px; height: 28px; border-radius: 8px; color: var(--muted); font-size: 14px;
}
.evcal-drawer__close:hover { background: var(--line); color: var(--text); }
.evcal-drawer__body { padding: 14px 18px; display: flex; flex-direction: column; gap: 12px; max-height: 62vh; overflow-y: auto; }
.evcal-drawer__empty { padding: 8px 0; }

.evcal-card { border: 1px solid var(--line); border-radius: 12px; padding: 12px 13px; background: var(--surface); }
.evcal-card__top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 6px; }
.evcal-card__folio { font-size: 11.5px; color: var(--muted); }
.evcal-card__title { font-size: 14px; font-weight: 700; color: var(--text); }
.evcal-card__cust { font-size: 12.5px; color: var(--muted); margin-bottom: 8px; }
.evcal-card__meta { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 12px; margin: 0 0 10px; }
.evcal-card__meta dt { font-size: 10.5px; color: var(--soft); text-transform: uppercase; letter-spacing: .03em; }
.evcal-card__meta dd { margin: 1px 0 0; font-size: 13px; font-weight: 600; color: var(--text); }

.evcal-drawer__foot { padding: 14px 18px; border-top: 1px solid var(--line); background: var(--surface-2); }
.evcal-drawer__foot > div { display: flex; align-items: center; justify-content: space-between; font-size: 13px; color: var(--muted); }
.evcal-drawer__foot > div + div { margin-top: 4px; }
.evcal-drawer__foot strong { color: var(--text); font-size: 14px; }

@media (max-width: 1080px) {
  .evcal-layout--with-drawer { grid-template-columns: 1fr; }
  .evcal-drawer { position: static; }
}
@media (max-width: 720px) {
  .evcal-grid { gap: 4px; }
  .evcal-cell { min-height: 64px; padding: 6px; }
  .evcal-cell__day { font-size: 16px; }
  .evcal-cell__badge { padding: 1px 5px; font-size: 9.5px; }
  .evcal-cell__events { display: none; }
  .evcal-weekday { font-size: 10px; padding: 0 2px; }
  .evcal-month { min-width: 110px; font-size: 16px; }
  .evcal-summary__item--total { margin-left: 0; }
  .evcal-toolbar { gap: 10px; }
  .evcal-filters { width: 100%; justify-content: space-between; }
}

/* ── Toast / alerta flotante (avisos operativos) ────────────────────────── */
.toast-host {
  position: fixed;
  z-index: 1000;
  right: 20px;
  bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: min(420px, calc(100vw - 40px));
}
.toast {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-left: 4px solid var(--soft);
  border-radius: 12px;
  padding: 12px 14px;
  box-shadow: var(--shadow);
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.45;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .2s ease, transform .2s ease;
}
.toast.is-visible { opacity: 1; transform: translateY(0); }
.toast__icon { font-size: 16px; line-height: 1.3; flex: none; }
.toast__msg { flex: 1; }
.toast__close {
  border: 0;
  background: transparent;
  cursor: pointer;
  color: var(--soft);
  font-size: 13px;
  line-height: 1.3;
  padding: 0 2px;
  flex: none;
}
.toast__close:hover { color: var(--text); }
.toast--warning { border-left-color: var(--warn); }
.toast--error   { border-left-color: var(--bad); }
.toast--success { border-left-color: var(--good); }
.toast--info    { border-left-color: var(--blue); }
@media (max-width: 520px) {
  .toast-host { left: 16px; right: 16px; bottom: 16px; max-width: none; }
}

/* ---- Admin · Usuarios (FASE 7.5) ---- */
.field-error { color: var(--bad); font-size: 12px; font-weight: 700; margin: 2px 0 0; }

.admin-users-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px;
  margin-bottom: 16px;
}
.admin-users-filters .field { margin-bottom: 0; min-width: 160px; }
.admin-users-filters__search { flex: 1 1 220px; }
.admin-users-filters__actions { display: flex; gap: 8px; }

.admin-users-email { font-size: 12px; }
.admin-users-row-actions { white-space: nowrap; }
.admin-users-row-actions .btn-small { margin-left: 4px; }

.admin-user-checkgrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px 16px;
}
.admin-user-check {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
}
.admin-user-check input { width: auto; }

.admin-user-form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
  flex-wrap: wrap;
}

/* Pista por rol junto al checkbox (alta/edición) */
.admin-user-check--role { align-items: flex-start; }
.admin-user-check__text { display: grid; gap: 2px; }
.admin-user-check__label { font-weight: 800; color: var(--ink); }
.admin-user-check__hint { font-size: 12px; font-weight: 400; color: var(--muted); }

/* Panel plegable "¿Qué hace cada rol?" */
.admin-roles-help {
  border: 1px solid var(--line);
  background: var(--surface-2);
  border-radius: 14px;
  padding: 12px 16px;
  margin-bottom: 16px;
}
.admin-roles-help > summary {
  cursor: pointer;
  font-weight: 900;
  color: var(--ink);
  list-style: none;
}
.admin-roles-help > summary::-webkit-details-marker { display: none; }
.admin-roles-help > summary::before { content: '▸ '; color: var(--muted); }
.admin-roles-help[open] > summary::before { content: '▾ '; }
.admin-roles-help__list {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: grid;
  gap: 10px;
}
.admin-roles-help__head { display: flex; align-items: center; gap: 8px; margin-bottom: 2px; }
.admin-roles-help__desc { margin: 0; color: var(--text); font-size: 13px; line-height: 1.4; }

/* ── Roles y permisos: matriz (FASE 7.5-Roles) ── */
.admin-roles-note { margin: 0 0 12px; }
.admin-perm-matrix {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
  margin-top: 16px;
}
.admin-perm-group {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface-2);
  padding: 12px 14px;
}
.admin-perm-group__title {
  margin: 0 0 8px;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--muted);
}
.admin-perm-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 6px; }
.admin-perm-item { display: flex; align-items: flex-start; gap: 8px; padding: 6px 4px; border-radius: 8px; }
.admin-perm-item--on .admin-perm-item__mark { color: var(--good, #16a34a); font-weight: 900; }
.admin-perm-item--off { opacity: 0.55; }
.admin-perm-item--off .admin-perm-item__mark { color: var(--muted); }
.admin-perm-item__mark { width: 16px; text-align: center; flex: 0 0 auto; }
.admin-perm-item__body { display: grid; gap: 1px; }
.admin-perm-item__name { font-weight: 700; color: var(--ink); font-size: 13px; }
.admin-perm-item__code { font-size: 11px; color: var(--muted); font-family: ui-monospace, monospace; }
.admin-perm-item--edit label { display: flex; align-items: flex-start; gap: 8px; cursor: pointer; width: 100%; }
.admin-perm-item--edit input[type="checkbox"] { margin-top: 2px; flex: 0 0 auto; }
.admin-perm-item--locked label { cursor: not-allowed; opacity: 0.6; }

/* ── Catálogos admin (FASE 7.5-Catálogos) ── */
.admin-catalog-tabs { flex-wrap: wrap; margin-bottom: 16px; }
.admin-catalog-list-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.admin-catalog-list-head h3 { margin: 0; font-size: 16px; font-weight: 900; color: var(--ink); }
.admin-catalog-form .field-error { color: var(--bad, #dc2626); font-size: 12px; margin: 4px 0 0; }

/* ── Tesorería (FASE 7.6) ── */
.treasury-kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-bottom: 16px; }
.treasury-kpi { border: 1px solid var(--line); border-radius: 14px; background: var(--surface-2); padding: 14px 16px; display: grid; gap: 4px; }
.treasury-kpi--accent { background: var(--surface-accent, #eef2ff); border-color: var(--accent, #6366f1); }
.treasury-kpi--neg .treasury-kpi__value { color: var(--bad, #dc2626); }
.treasury-kpi__label { font-size: 12px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.03em; }
.treasury-kpi__value { font-size: 22px; font-weight: 900; color: var(--ink); }
.treasury-global h3 { margin: 0 0 12px; font-size: 16px; font-weight: 900; color: var(--ink); }
.treasury-neg { color: var(--bad, #dc2626); font-weight: 800; }
.treasury-pos { color: var(--good, #16a34a); font-weight: 700; }
.treasury-warning { background: #fef3c7; border: 1px solid #f59e0b; color: #92400e; border-radius: 10px; padding: 8px 12px; margin: 10px 0; font-size: 13px; }
.treasury-form-hint { margin: 8px 0 12px; }

/* ── Tesorería: movimientos de cuentas (saldos en vivo + proyección) ── */
.treasury-balances { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 10px; margin: 0 0 14px; }
.treasury-balance-card { border: 1px solid var(--line); border-radius: 12px; background: var(--surface-2); padding: 10px 12px; display: grid; gap: 2px; transition: border-color 0.15s, box-shadow 0.15s; }
.treasury-balance-card--active { border-color: var(--accent, #6366f1); box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.18); }
.treasury-balance-card__name { font-size: 12px; font-weight: 800; color: var(--ink); }
.treasury-balance-card__meta { font-size: 11px; color: var(--muted); }
.treasury-balance-card__value { font-size: 17px; font-weight: 900; color: var(--ink); }
.treasury-balance-card__after { font-size: 12px; font-weight: 700; min-height: 16px; }
.treasury-balance-card__after--idle { color: transparent; user-select: none; }
.treasury-projection { border: 1px dashed var(--line); border-radius: 12px; background: var(--surface-2); padding: 12px 14px; margin: 14px 0 0; }
.treasury-projection__title { margin: 0 0 8px; font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.03em; color: var(--muted); }
.treasury-projection__hint { margin: 0; font-size: 13px; color: var(--muted); }
.treasury-projection__row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; padding: 4px 0; font-size: 14px; flex-wrap: wrap; }
.treasury-projection__name { font-weight: 700; color: var(--ink); }
.treasury-projection__delta { font-weight: 800; }

/* ── Tesorería: mejoras de claridad (vista financiera + reservas) ── */
.treasury-kpi__sub { font-size: 11px; color: var(--muted); }
.treasury-kpi__value--sm { font-size: 16px; }
.treasury-kpi--btn { text-align: left; cursor: pointer; font: inherit; transition: border-color 0.15s, box-shadow 0.15s; }
.treasury-kpi--btn:hover { border-color: var(--accent, #6366f1); }
.treasury-kpi--active { border-color: var(--accent, #6366f1); box-shadow: 0 0 0 2px var(--accent, #6366f1) inset; }
.treasury-global__hint { margin: 0 0 12px; font-size: 12px; color: var(--muted); }
.treasury-reserved { color: var(--accent, #6366f1); font-weight: 800; }
.treasury-filter-note { margin: 8px 0; font-size: 13px; color: var(--muted); }
.btn-link { background: none; border: none; padding: 0; color: var(--accent, #6366f1); font-weight: 700; cursor: pointer; text-decoration: underline; }
/* Periodo */
.treasury-period { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.treasury-period__label { font-size: 12px; font-weight: 800; color: var(--ink); text-transform: uppercase; letter-spacing: 0.03em; }
.treasury-period__btns { display: flex; flex-wrap: wrap; gap: 6px; }
.treasury-period__btn { padding: 7px 14px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); font-size: 13px; font-weight: 700; color: var(--ink); cursor: pointer; transition: border-color 0.15s, background 0.15s; }
.treasury-period__btn:hover { border-color: var(--accent, #6366f1); background: var(--surface-2); }
.treasury-period__btn.active { background: var(--accent, #6366f1); border-color: var(--accent, #6366f1); color: #fff; box-shadow: 0 1px 3px rgba(99,102,241,0.35); }
.treasury-period__custom { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 8px; }
/* Barra de herramientas de movimientos (periodo + buscador, pegada a la tabla) */
.treasury-mov-toolbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 12px; margin: 0 0 12px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 12px; }
.treasury-mov-search { position: relative; display: flex; align-items: center; flex: 1 1 240px; max-width: 360px; }
.treasury-mov-search__icon { position: absolute; left: 10px; font-size: 13px; opacity: 0.6; pointer-events: none; }
.treasury-mov-search input { width: 100%; padding: 8px 30px 8px 30px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); font-size: 13px; color: var(--ink); }
.treasury-mov-search input:focus { outline: none; border-color: var(--accent, #6366f1); box-shadow: 0 0 0 2px rgba(99,102,241,0.18); }
.treasury-mov-search__clear { position: absolute; right: 8px; border: none; background: none; cursor: pointer; color: var(--muted); font-size: 13px; line-height: 1; padding: 4px; }
.treasury-mov-search__clear:hover { color: var(--bad, #dc2626); }
/* Celda cuenta / origen→destino */
.treasury-loc { display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.treasury-loc__arrow { color: var(--accent, #6366f1); font-weight: 900; }
.treasury-loc__tag { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; }
/* Ubicación física (reservas) */
.treasury-loc-cell { display: grid; gap: 2px; }
.treasury-loc-line { font-size: 13px; }
.treasury-loc-line--financed { color: var(--bad, #dc2626); }

/* ── Reportes (hub de exportables) ── */
.reports-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
.reports-card { display: flex; gap: 14px; align-items: flex-start; border: 1px solid var(--line); border-radius: 14px; background: var(--surface-2); padding: 16px; }
.reports-card__icon { font-size: 28px; flex: 0 0 auto; }
.reports-card__body { flex: 1; }
.reports-card__body h4 { margin: 0 0 4px; font-size: 15px; font-weight: 900; color: var(--ink); }
.reports-card__body p { margin: 0; font-size: 13px; line-height: 1.4; }
.reports-card__actions { display: flex; flex-direction: column; gap: 8px; flex: 0 0 auto; }

/* Reporte administrativo de Nómina restaurante (dentro de Reportes). */
.qlist-tab.is-active { border-color: #2563eb; background: #eff6ff; color: #1d4ed8; font-weight: 700; }
.reports-card--alert-danger { border-color: rgba(239,68,68,0.45); background: rgba(239,68,68,0.06); }
.reports-card--alert-warning { border-color: rgba(245,158,11,0.45); background: rgba(245,158,11,0.06); }
.reports-card--alert-amber { border-color: rgba(217,119,6,0.4); background: rgba(217,119,6,0.05); }

/* ── Verificación en dos pasos (2FA) ────────────────────────────────────── */
.checkbox-line {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13.5px;
  color: var(--text, #111);
  margin: 4px 0 12px;
  cursor: pointer;
  text-align: left;
}
.checkbox-line input { margin-top: 2px; }

.setup-steps {
  text-align: left;
  margin: 8px 0 14px;
  padding-left: 20px;
  font-size: 13.5px;
  color: var(--text, #111);
  line-height: 1.5;
}
.setup-steps li { margin-bottom: 4px; }

.recovery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin: 10px 0;
}
.recovery-grid code {
  font-family: ui-monospace, "SFMono-Regular", Menlo, monospace;
  font-size: 14px;
  letter-spacing: .04em;
  padding: 6px 10px;
  background: var(--surface-alt, #f9fafb);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 6px;
  text-align: center;
}

.twofa-qr {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin: 6px 0 14px;
}
.twofa-qr img {
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  padding: 8px;
  background: #fff;
}
.twofa-qr .muted { font-size: 12.5px; }

/* ─── Notificaciones ─────────────────────────────────────── */

.notif-bell-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.notif-bell-btn {
  position: relative;
  padding: 6px 8px;
  display: flex;
  align-items: center;
  gap: 4px;
}

.notif-bell-btn svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.notif-badge-count {
  position: absolute;
  top: 2px;
  right: 2px;
  background: var(--brand);
  color: #fff;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  line-height: 1;
  border: 2px solid var(--surface, #fff);
}

.notif-panel {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  width: 340px;
  max-height: 440px;
  overflow-y: auto;
  background: var(--surface, #fff);
  border: 1px solid var(--line, #e2e8f0);
  border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.13);
  z-index: 1000;
  display: flex;
  flex-direction: column;
}

.notif-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line, #e2e8f0);
  font-size: 13px;
  flex-shrink: 0;
}

.notif-panel__header strong {
  font-size: 14px;
  font-weight: 700;
}

.notif-panel__list {
  flex: 1;
  overflow-y: auto;
}

.notif-panel__empty {
  padding: 24px 16px;
  text-align: center;
  color: var(--muted, #64748b);
  font-size: 13px;
}

.notif-panel__item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 11px 16px;
  border-bottom: 1px solid var(--line, #e2e8f0);
  cursor: pointer;
  transition: background 0.12s;
}

.notif-panel__item:last-child {
  border-bottom: none;
}

.notif-panel__item:hover {
  background: var(--surface-2, #f8fafc);
}

.notif-panel__item.unread {
  background: #f9f5ff;
}

.notif-panel__item.unread:hover {
  background: #f0eaff;
}

.notif-type-tag {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.03em;
  padding: 2px 7px;
  border-radius: 4px;
  background: var(--surface-2, #f8fafc);
  color: var(--muted, #64748b);
  border: 1px solid var(--line, #e2e8f0);
  margin-top: 2px;
  text-transform: uppercase;
}

.notif-body {
  flex: 1;
  min-width: 0;
}

.notif-desc {
  font-size: 13px;
  color: var(--text, #18212f);
  line-height: 1.4;
  word-break: break-word;
}

.notif-time {
  font-size: 11px;
  color: var(--soft, #94a3b8);
  margin-top: 3px;
}

.notif-unread-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand);
  flex-shrink: 0;
  margin-top: 5px;
}

.notif-panel__footer {
  border-top: 1px solid var(--line, #e2e8f0);
  padding: 8px 10px;
  flex-shrink: 0;
}

.notif-panel__footer .btn {
  width: 100%;
  font-size: 13px;
}

/* Página completa de notificaciones */

.notif-row-unread td {
  background: #f9f5ff;
}

.notif-desc-cell {
  font-size: 13px;
  line-height: 1.4;
}

.status-badge {
  display: inline-flex;
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}

.notif-status-unread {
  background: #f0eaff;
  color: #6d28d9;
}

.notif-status-read {
  background: var(--surface-2, #f8fafc);
  color: var(--muted, #64748b);
}

.btn-xs {
  font-size: 11px;
  padding: 4px 8px;
}

/* ─── Fin notificaciones ─────────────────────────────────── */
