
/* V11.6 - Acceso y limpieza para publicación */
body:not(.is-authenticated) { overflow: hidden; }
body:not(.is-authenticated) .app-shell { display: none; }
body.is-authenticated .login-screen { display: none; }
.login-screen { min-height: 100vh; display: grid; place-items: center; padding: 24px; background: linear-gradient(135deg, #071427 0%, #0d2b45 52%, #f6f8fb 52%, #fff 100%); }
.login-card { width: min(460px, 100%); background: #fff; border: 1px solid #dbe5f0; border-radius: 28px; box-shadow: 0 30px 90px rgba(6, 17, 34, .24); padding: 32px; display: grid; gap: 16px; }
.login-brand { display: flex; align-items: center; gap: 14px; margin-bottom: 6px; }
.login-brand strong { display: block; color: #0d1b2f; font-weight: 950; letter-spacing: .02em; }
.login-brand span { display: block; color: #66758a; font-weight: 750; font-size: .88rem; }
.login-card h1 { margin: 0; color: #0d1b2f; font-size: clamp(1.7rem, 4vw, 2.35rem); }
.login-card p { margin: 0 0 8px; color: #66758a; line-height: 1.45; }
.login-card label { display: grid; gap: 8px; color: #52627a; font-weight: 900; }
.login-card input { width: 100%; min-height: 52px; border: 1px solid #d7e2ef; border-radius: 14px; padding: 0 14px; font: inherit; color: #0d1b2f; background: #f8fafc; }
.login-card input:focus { outline: 3px solid rgba(26, 75, 140, .18); border-color: #1a4b8c; background: #fff; }
.login-error { min-height: 18px; color: #a83232; font-weight: 850; }
:root {
  --bg: #f3f5f7;
  --surface: #ffffff;
  --surface-2: #f8fafc;
  --ink: #111827;
  --muted: #64748b;
  --line: #d9e2ec;
  --primary: #0f2f3f;
  --accent: #2e7d63;
  --accent-soft: #e8f5ef;
  --gold: #b88a2c;
  --gold-soft: #fff7df;
  --danger: #a83232;
  --danger-soft: #fff1f1;
  --shadow: 0 18px 44px rgba(15, 23, 42, .08);
  --shadow-soft: 0 10px 24px rgba(15, 23, 42, .06);
}

* { box-sizing: border-box; }

*,
*::before,
*::after {
  min-width: 0;
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--bg);
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  overflow-wrap: anywhere;
  line-height: 1.35;
  font-size: 14px;
}

button, input, select, textarea {
  font: inherit;
}

button {
  line-height: 1.15;
}

.app-header {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 10;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 22px;
  width: 286px;
  height: 100vh;
  align-items: start;
  padding: 22px 18px;
  border-right: 1px solid var(--line);
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(18px);
  overflow-y: auto;
}

.header-actions {
  display: grid;
  width: 100%;
  gap: 10px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  width: 100%;
}

.brand-mark {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: var(--primary);
  color: #fff;
  font-weight: 950;
}

.brand strong,
.brand span {
  display: block;
  overflow-wrap: anywhere;
}

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

.tabs {
  display: grid;
  gap: 6px;
  width: 100%;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow: visible;
}

.tab {
  min-height: 40px;
  border: 0;
  border-radius: 12px;
  padding: 10px 12px;
  background: transparent;
  color: var(--muted);
  font-size: 14px;
  font-weight: 850;
  line-height: 1.15;
  text-align: left;
  white-space: normal;
  cursor: pointer;
}

.tab.active {
  background: var(--primary);
  color: #fff;
}

.workspace {
  display: grid;
  gap: 20px;
  margin-left: 286px;
  padding: 20px;
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, .28fr);
  gap: 18px;
  align-items: stretch;
  padding: 26px;
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(15,47,63,.96), rgba(46,125,99,.86)),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.2), transparent 30%);
  color: #fff;
  box-shadow: var(--shadow);
}

.eyebrow,
.section-label {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.hero .eyebrow { color: rgba(255,255,255,.7); }
.hero h1 {
  max-width: 820px;
  margin: 8px 0;
  color: #fff;
  font-size: 34px;
  line-height: 1.12;
}

.hero p {
  max-width: 720px;
  color: rgba(255,255,255,.76);
  line-height: 1.55;
}

.period-card {
  display: grid;
  align-content: center;
  gap: 8px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.1);
}

.period-card span,
.period-card small { color: rgba(255,255,255,.72); }
.period-card strong { font-size: 28px; }

.view { display: none; }
.view.active { display: grid; gap: 20px; }

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

.kpi,
.panel {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface);
  box-shadow: var(--shadow-soft);
}

.kpi {
  display: grid;
  gap: 8px;
  padding: 18px;
  align-content: start;
}

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

.kpi strong {
  color: var(--primary);
  font-size: 26px;
}

.dashboard-grid,
.split-layout {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(360px, .72fr);
  gap: 18px;
  align-items: start;
}

.panel {
  overflow: visible;
}

.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #fff, var(--surface-2));
}

.panel-head > div {
  min-width: min(100%, 220px);
}

h2, h3 {
  margin: 4px 0 0;
  letter-spacing: 0;
  line-height: 1.18;
  overflow-wrap: anywhere;
}

.stack,
.employee-list,
.document-list,
.receipt-list,
.timeline,
.ranking-list,
.notification-list,
.profit-report {
  display: grid;
  gap: 12px;
  padding: 18px;
}

.quick-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  padding: 18px;
}

.employee-card .quick-actions,
.approval-card .quick-actions,
.receipt-preview .quick-actions {
  padding: 0;
}

.employee-card .quick-actions,
.approval-card .quick-actions {
  grid-template-columns: repeat(auto-fit, minmax(112px, 1fr));
}

.receipt-preview .quick-actions {
  grid-template-columns: repeat(auto-fit, minmax(160px, 220px));
}

.head-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
  min-width: 0;
}

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

.full { grid-column: 1 / -1; }

label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  line-height: 1.25;
}

input, select, textarea {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 11px 13px;
  background: #fff;
  color: var(--ink);
  text-transform: none;
  overflow-wrap: anywhere;
}

textarea { resize: vertical; }
input:focus, select:focus, textarea:focus {
  outline: 3px solid rgba(46,125,99,.2);
  border-color: var(--accent);
}

.photo-field {
  grid-row: span 2;
  min-height: 132px;
  padding: 14px;
  border: 1px dashed #cbd5e1;
  border-radius: 14px;
  background: var(--surface-2);
}

.photo-field span {
  color: var(--muted);
  font-size: 12px;
  text-transform: none;
}

.document-form,
.payroll-controls {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 18px;
  border-bottom: 1px solid var(--line);
}

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

.approval-note {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
  padding: 0 18px 18px;
  border-bottom: 1px solid var(--line);
}

.compact-form {
  border-top: 1px solid var(--line);
}

.primary-button,
.secondary-button,
.soft-button,
.danger-button {
  min-height: 42px;
  border-radius: 12px;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
  white-space: normal;
  overflow-wrap: anywhere;
  text-align: center;
}

.primary-button {
  border: 0;
  background: linear-gradient(135deg, var(--accent), #1f6b55);
  color: #fff;
}

.secondary-button,
.soft-button {
  border: 1px solid var(--line);
  background: #fff;
  color: var(--primary);
}

.danger-button {
  border: 1px solid rgba(168,50,50,.22);
  background: var(--danger-soft);
  color: var(--danger);
}

.search {
  max-width: 260px;
}

.employee-card {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
}

.employee-card .quick-actions {
  grid-column: 1 / -1;
}

.avatar {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 16px;
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 950;
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.avatar.large {
  width: 82px;
  height: 82px;
  border-radius: 22px;
  font-size: 24px;
}

.employee-card strong,
.employee-card span,
.employee-card small {
  display: block;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.employee-card span,
.employee-card small {
  color: var(--muted);
}

.badge {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  border-radius: 999px;
  padding: 6px 11px;
  border: 1px solid #cde9df;
  background: var(--accent-soft);
  color: #1f6b55;
  font-size: 12px;
  font-weight: 950;
  line-height: 1.15;
  white-space: normal;
  max-width: 100%;
}

.badge.good {
  border-color: #bfe7d9;
  background: var(--accent-soft);
  color: #1f6b55;
}

.badge.warning {
  border-color: #f0dca5;
  background: var(--gold-soft);
  color: #7a5b19;
}

.badge.danger {
  border-color: rgba(168,50,50,.25);
  background: var(--danger-soft);
  color: var(--danger);
}

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

.document-row,
.alert-row,
.receipt-row,
.payroll-row,
.profit-card {
  display: grid;
  gap: 5px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface-2);
  align-content: start;
}

.document-row strong,
.alert-row strong,
.receipt-row strong,
.timeline-item strong,
.approval-card strong,
.period-row strong {
  overflow-wrap: anywhere;
  line-height: 1.2;
}

.alert-row.warning {
  border-color: #f0dca5;
  background: var(--gold-soft);
}

.payroll-table {
  display: grid;
  gap: 10px;
  padding: 18px;
  overflow-x: auto;
}

.payroll-row {
  min-width: 1160px;
  grid-template-columns: minmax(220px, 1.25fr) minmax(150px, .78fr) minmax(110px, .6fr) repeat(6, minmax(105px, .55fr)) minmax(120px, .65fr);
  align-items: center;
}

.payroll-row.header {
  background: var(--primary);
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.payroll-row input {
  min-height: 38px;
}

.payroll-row input:disabled {
  background: #eef2f6;
  color: #94a3b8;
  cursor: not-allowed;
}

.payroll-breakdown {
  grid-column: 1 / -1;
  color: var(--muted);
  font-weight: 800;
}

.receipt-layout {
  display: grid;
  grid-template-columns: minmax(260px, .42fr) minmax(0, 1fr);
  gap: 18px;
  padding: 18px;
}

.receipt-list {
  padding: 0;
}

.receipt-row {
  cursor: pointer;
}

.receipt-row.active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.receipt-preview {
  min-height: 620px;
  padding: 30px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
}

.receipt-preview h2 {
  color: var(--primary);
  font-size: 26px;
  line-height: 1.15;
}

.receipt-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 22px 0;
}

.receipt-box {
  padding: 14px;
  border-radius: 14px;
  background: var(--surface-2);
  border: 1px solid var(--line);
}

.receipt-box strong,
.kpi strong,
.profit-card strong,
.profile-grid strong,
.flow-step strong,
.period-card strong {
  overflow-wrap: anywhere;
  line-height: 1.12;
}

.receipt-total {
  margin-top: 20px;
  padding: 16px;
  border-radius: 16px;
  background: var(--primary);
  color: #fff;
  font-size: 22px;
  font-weight: 950;
  overflow-wrap: anywhere;
}

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

.profit-card strong {
  color: var(--primary);
  font-size: 24px;
}

.finance-flow {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
  padding: 18px;
}

.flow-step {
  position: relative;
  min-height: 112px;
  display: grid;
  align-content: start;
  gap: 16px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface-2);
}

.flow-step:not(:last-child)::after {
  content: "";
  position: absolute;
  right: -11px;
  top: 50%;
  width: 12px;
  height: 1px;
  background: var(--line);
}

.flow-step span,
.profile-grid span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.flow-step strong {
  color: var(--primary);
  font-size: 18px;
}

.flow-step.good {
  border-color: #bfe7d9;
  background: var(--accent-soft);
}

.flow-step.risk {
  border-color: rgba(168,50,50,.25);
  background: var(--danger-soft);
}

.risk-row {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface-2);
}

.risk-row strong {
  color: var(--primary);
  font-size: 24px;
}

.employee-profile,
.portal-content {
  display: grid;
  gap: 16px;
  padding: 18px;
}

.profile-hero,
.portal-hero {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(180deg, #fff, var(--surface-2));
}

.profile-hero h3,
.portal-hero h3 {
  margin: 4px 0;
  color: var(--primary);
  font-size: 24px;
  line-height: 1.15;
}

.profile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

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

.profile-grid article {
  display: grid;
  gap: 7px;
  min-height: 96px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: var(--surface-2);
}

.profile-grid strong {
  color: var(--primary);
  font-size: 17px;
}

.profile-notes {
  display: grid;
  gap: 6px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
}

.profile-notes p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.timeline-item {
  display: grid;
  gap: 8px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface-2);
}

.timeline-item p {
  margin: 0;
  color: var(--muted);
}

.portal-columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}

.portal-columns h3 {
  margin: 0 0 10px;
  color: var(--primary);
}

.report-grid,
.org-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  padding: 18px;
}

.report-card,
.org-card,
.ranking-row,
.notification-item {
  display: grid;
  gap: 10px;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface-2);
}

.report-card span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.report-card strong {
  color: var(--primary);
  font-size: 24px;
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.ranking-row {
  grid-template-columns: 44px minmax(0, 1fr) auto;
  align-items: center;
}

.ranking-row > strong {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: var(--primary);
  color: #fff;
}

.ranking-row b,
.org-person strong,
.notification-item strong {
  display: block;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.org-card {
  align-content: start;
}

.org-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}

.org-person {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.org-person .avatar {
  width: 48px;
  height: 48px;
  border-radius: 14px;
}

.notification-item {
  grid-template-columns: minmax(120px, .28fr) minmax(0, 1fr);
  align-items: start;
}

.notification-item p {
  margin: 4px 0 0;
  color: var(--muted);
}

.notification-item.danger {
  border-color: rgba(168,50,50,.25);
  background: var(--danger-soft);
}

.notification-item.warning {
  border-color: #f0dca5;
  background: var(--gold-soft);
}

.approval-board,
.period-history {
  display: grid;
  gap: 12px;
  padding: 18px;
}

.approval-card {
  display: grid;
  grid-template-columns: minmax(200px, .5fr) minmax(260px, 1fr);
  gap: 14px;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
}

.approval-card .quick-actions {
  grid-column: 1 / -1;
}

.approval-card strong,
.approval-card span {
  display: block;
}

.approval-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: 8px;
}

.approval-metrics span,
.period-row span {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--surface-2);
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  white-space: normal;
  line-height: 1.15;
}

.period-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
}

.period-row small {
  grid-column: 1 / -1;
}

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

.empty {
  padding: 18px;
  border: 1px dashed #cbd5e1;
  border-radius: 14px;
  background: var(--surface-2);
}

.toast {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 20;
  max-width: min(420px, calc(100vw - 44px));
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--primary);
  color: #fff;
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: .2s ease;
}

.toast.show {
  opacity: 1;
  transform: translateY(0);
}

@media print {
  .app-header,
  .hero,
  .receipt-list {
    display: none !important;
  }

  body,
  .workspace {
    background: #fff;
    margin-left: 0;
    padding: 0;
  }

  .panel {
    border: 0;
    box-shadow: none;
  }

  .receipt-layout {
    display: block;
  }

  .receipt-preview {
    border: 0;
    padding: 0;
  }
}

@media (max-width: 1120px) {
  .hero,
  .dashboard-grid,
  .split-layout,
  .receipt-layout,
  .approval-card {
    grid-template-columns: 1fr;
  }

  .app-header {
    position: sticky;
    inset: auto;
    top: 0;
    width: 100%;
    height: auto;
    grid-template-columns: minmax(220px, .35fr) minmax(0, 1fr) auto;
    grid-template-rows: auto;
    align-items: center;
    padding: 14px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
    overflow: visible;
  }

  .workspace {
    margin-left: 0;
  }

  .tabs {
    display: flex;
    gap: 6px;
    padding: 4px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--surface-2);
    overflow-x: auto;
    scrollbar-width: thin;
  }

  .tab {
    flex: 0 0 auto;
    min-height: 36px;
    padding: 9px 11px;
    font-size: 13px;
    text-align: center;
    white-space: nowrap;
  }

  .header-actions {
    justify-content: flex-start;
  }

  .kpi-grid,
  .profit-report,
  .approval-metrics,
  .finance-flow,
  .profile-grid,
  .portal-columns,
  .report-grid,
  .org-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero h1 {
    font-size: 30px;
  }

  .app-header {
    align-items: start;
  }

  .payroll-row {
    min-width: 0;
    grid-template-columns: 1fr;
  }

  .flow-step::after {
    display: none;
  }
}

@media (max-width: 720px) {
  .workspace,
  .app-header {
    padding: 14px;
  }

  .app-header {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .tabs,
  .header-actions,
  .quick-actions,
  .head-actions,
  .form-grid,
    .document-form,
    .payroll-controls,
    .approval-note,
  .kpi-grid,
  .profit-report,
    .receipt-grid,
    .approval-metrics,
    .period-row,
    .finance-flow,
    .profile-grid,
    .profile-grid.tight,
    .portal-columns,
    .report-grid,
    .org-grid,
    .ranking-row,
    .notification-item,
    .risk-row,
    .profile-hero,
    .portal-hero {
    grid-template-columns: 1fr;
  }

  .hero {
    padding: 20px;
  }

  .hero h1 {
    font-size: 30px;
    line-height: 1.12;
  }

  .kpi strong,
  .profit-card strong {
    font-size: 22px;
  }

  .period-card strong,
  .receipt-total {
    font-size: 20px;
  }

  .receipt-preview {
    padding: 18px;
  }

  .profile-hero h3,
  .portal-hero h3,
  .receipt-preview h2 {
    font-size: 22px;
  }

  .tabs {
    border-radius: 16px;
    align-items: stretch;
    flex-direction: row;
  }

  .tab {
    width: auto;
  }

  .panel-head,
  .employee-card {
    align-items: flex-start;
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .avatar.large {
    width: 68px;
    height: 68px;
  }
}

/* Mejoras V2 - Diseño principal Rvargas */
.nav-group {
  display: grid;
  gap: 6px;
  padding: 10px;
  border: 1px solid rgba(217, 226, 236, .82);
  border-radius: 16px;
  background: linear-gradient(180deg, #fff, var(--surface-2));
}

.nav-group > span {
  padding: 0 4px 4px;
  color: var(--gold);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.brand-mark {
  background: linear-gradient(135deg, #0f2f3f, #2e7d63);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.12), 0 12px 24px rgba(15,47,63,.16);
}

.security-note {
  display: grid;
  gap: 4px;
  padding: 12px 16px;
  border: 1px solid #f0dca5;
  border-radius: 16px;
  background: var(--gold-soft);
  color: #7a5b19;
  box-shadow: var(--shadow-soft);
}

.security-note strong {
  color: #65470e;
}

body:not([data-view="dashboard"]) .hero {
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 16px 18px;
  border-radius: 18px;
}

body:not([data-view="dashboard"]) .hero h1 {
  margin: 4px 0;
  font-size: 22px;
}

body:not([data-view="dashboard"]) .hero p {
  margin: 0;
  font-size: 13px;
}

body:not([data-view="dashboard"]) .period-card {
  min-width: 220px;
  padding: 12px 14px;
}

body:not([data-view="dashboard"]) .period-card strong {
  font-size: 20px;
}

.employee-form-shell {
  display: grid;
  gap: 0;
}

.employee-form-tabs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  padding: 16px 18px 0;
}

.employee-form-tab {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 9px 10px;
  background: #fff;
  color: var(--muted);
  font-weight: 900;
  cursor: pointer;
}

.employee-form-tab.active {
  border-color: rgba(46,125,99,.3);
  background: var(--accent-soft);
  color: #1f6b55;
}

.employee-form-page {
  display: none;
  padding: 18px;
}

.employee-form-page.active {
  display: block;
}

.form-grid.no-pad {
  padding: 0;
}

.form-actions-sticky {
  display: flex;
  justify-content: flex-end;
  padding: 16px 18px 18px;
  border-top: 1px solid var(--line);
  background: linear-gradient(180deg, #fff, var(--surface-2));
}

.form-actions-sticky .primary-button {
  min-width: 190px;
}

@media (max-width: 1120px) {
  .nav-group {
    display: flex;
    flex: 0 0 auto;
    align-items: center;
    gap: 6px;
    padding: 6px;
  }

  .nav-group > span {
    padding: 0 6px;
    white-space: nowrap;
  }

  body:not([data-view="dashboard"]) .hero {
    grid-template-columns: 1fr;
  }

  body:not([data-view="dashboard"]) .period-card {
    min-width: 0;
  }
}

@media (max-width: 720px) {
  .employee-form-tabs {
    grid-template-columns: 1fr 1fr;
  }

  .form-actions-sticky {
    display: grid;
  }

  .form-actions-sticky .primary-button {
    min-width: 0;
    width: 100%;
  }
}

/* V3: tablero ejecutivo y expediente premium */
.executive-command {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.command-card {
  display: grid;
  gap: 7px;
  min-height: 118px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.command-card span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.command-card strong {
  color: var(--primary);
  font-size: 30px;
  line-height: 1;
}

.command-card small { color: var(--muted); font-weight: 750; }
.command-card.good { border-color: #bfe7d9; background: var(--accent-soft); }
.command-card.warning { border-color: #f0dca5; background: var(--gold-soft); }
.command-card.danger { border-color: rgba(168,50,50,.25); background: var(--danger-soft); }

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

.profile-columns .profile-notes p {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
}

.profile-columns .profile-notes p:last-child { border-bottom: 0; }

.disciplinary-item {
  background: linear-gradient(180deg, #fff, var(--surface-2));
}

.disciplinary-item .danger-button {
  justify-self: start;
  margin-top: 6px;
}

@media (max-width: 1100px) {
  .executive-command { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .profile-columns { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .executive-command { grid-template-columns: 1fr; }
}

/* V4 - Planilla empresarial por facturación, rebajos y utilidad */
.payroll-summary-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
}

.payroll-summary-strip article,
.payroll-help,
.employee-payroll-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-2);
  padding: 14px;
}

.payroll-summary-strip article span,
.employee-payroll-result span,
.payroll-field-grid label span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.payroll-summary-strip article strong,
.employee-payroll-result strong {
  display: block;
  margin-top: 4px;
  font-size: 18px;
}

.payroll-summary-strip article.good {
  border-color: rgba(23, 129, 91, .3);
  background: rgba(23, 129, 91, .08);
}

.payroll-summary-strip article.risk {
  border-color: rgba(180, 83, 9, .35);
  background: rgba(180, 83, 9, .08);
}

.payroll-help {
  color: var(--muted);
  line-height: 1.45;
}

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

.employee-payroll-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
  border-bottom: 1px solid var(--line);
  padding-bottom: 12px;
}

.employee-payroll-head strong {
  display: block;
  font-size: 16px;
}

.employee-payroll-result {
  text-align: right;
  min-width: 210px;
}

.employee-payroll-result small,
.payroll-mini-ledger {
  color: var(--muted);
  font-size: 12px;
}

.payroll-field-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.payroll-field-grid label {
  display: grid;
  gap: 5px;
}

.payroll-field-grid input {
  min-height: 40px;
}

.payroll-mini-ledger {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  padding-top: 4px;
}

.payroll-mini-ledger span {
  padding: 6px 10px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
}

@media (max-width: 720px) {
  .employee-payroll-head {
    display: grid;
  }

  .employee-payroll-result {
    text-align: left;
    min-width: 0;
  }
}

/* V5 - flujo de planilla por pestañas y comprobante PDF/WhatsApp */
.payroll-wizard-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 12px 0 16px;
}

.payroll-step-tab {
  border: 1px solid var(--line);
  background: var(--surface-2);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  color: var(--muted);
  cursor: pointer;
}

.payroll-step-tab.active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.payroll-step-panel {
  display: none;
}

.payroll-step-panel.active {
  display: grid;
  gap: 14px;
}

.employee-payroll-selector {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto;
  gap: 12px;
  align-items: end;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
}

.employee-payroll-selector label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.employee-payroll-selector select {
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 0 12px;
  font-weight: 800;
}

.selected-payroll-status {
  border-radius: 16px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  padding: 10px 14px;
  min-width: 190px;
}

.selected-payroll-status span,
.selected-payroll-status small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.selected-payroll-status strong {
  display: block;
  font-size: 20px;
  margin: 3px 0;
}

.payroll-employee-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

@media (max-width: 720px) {
  .employee-payroll-selector {
    grid-template-columns: 1fr;
  }

  .payroll-employee-actions button {
    width: 100%;
  }
}

/* V6: tarjetas de planilla navegables y resumen por empleado */
.command-card,
.flow-step,
.alert-row,
.risk-row,
.payroll-person-chip {
  cursor: pointer;
}

.command-card:focus,
.flow-step:focus,
.alert-row:focus,
.risk-row:focus,
.payroll-person-chip:focus {
  outline: 3px solid rgba(37, 99, 235, 0.28);
  outline-offset: 3px;
}

.payroll-employee-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin: 14px 0;
}

.payroll-person-chip {
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
  display: grid;
  gap: 5px;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.06);
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.payroll-person-chip:hover,
.payroll-person-chip.selected {
  transform: translateY(-1px);
  border-color: rgba(37, 99, 235, 0.42);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.1);
}

.payroll-person-chip span {
  font-size: 0.86rem;
  color: #475569;
}

.payroll-person-chip strong {
  font-size: 1.2rem;
  color: #0f172a;
}

.payroll-person-chip small {
  color: #64748b;
  line-height: 1.35;
}

.field-help {
  display: block;
  margin-top: 6px;
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.35;
}

.payroll-breakdown {
  margin-top: 14px;
  display: grid;
  gap: 8px;
}

.payroll-breakdown > strong {
  color: var(--text);
  font-size: 0.9rem;
}

.payroll-breakdown-row {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fff;
  padding: 10px 12px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 12px;
  align-items: center;
  text-align: left;
  cursor: pointer;
}

.payroll-breakdown-row span {
  font-weight: 800;
}

.payroll-breakdown-row strong {
  color: var(--accent);
}

.payroll-breakdown-row small {
  grid-column: 1 / -1;
  color: var(--muted);
}

/* V8 - resumen de planilla simplificado */
.payroll-simple-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 12px;
}

.payroll-simple-summary article {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-2);
  padding: 16px;
  min-height: 132px;
  display: grid;
  gap: 8px;
  align-content: start;
}

.payroll-simple-summary article span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}

.payroll-simple-summary article strong {
  display: block;
  font-size: clamp(22px, 3vw, 30px);
  line-height: 1.08;
  color: var(--text);
}

.payroll-simple-summary article small {
  color: var(--muted);
  line-height: 1.35;
}

.payroll-simple-summary article.good {
  border-color: rgba(23, 129, 91, .35);
  background: rgba(23, 129, 91, .08);
}

.payroll-simple-summary article.risk {
  border-color: rgba(180, 83, 9, .35);
  background: rgba(180, 83, 9, .08);
}

.payroll-formula-box {
  border: 1px solid rgba(37, 99, 235, .22);
  border-radius: 16px;
  background: rgba(37, 99, 235, .06);
  padding: 14px;
  display: grid;
  gap: 6px;
  color: var(--text);
}

.payroll-formula-box span {
  font-weight: 850;
  overflow-wrap: anywhere;
}

.payroll-breakdown-row:hover {
  border-color: rgba(37, 99, 235, .45);
  box-shadow: 0 10px 24px rgba(15, 23, 42, .08);
}

/* V9 - Planilla guiada paso a paso */
.payroll-wizard-tabs {
  align-items: stretch;
}

.payroll-step-tab {
  flex: 1 1 180px;
  text-align: center;
}

.payroll-step-intro {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.04), rgba(148, 163, 184, 0.08));
  margin-bottom: 16px;
}

.payroll-step-intro strong {
  color: var(--ink);
  font-size: 1rem;
}

.payroll-step-intro span {
  color: var(--muted);
  line-height: 1.5;
}

.payroll-step-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.payroll-subtitle {
  margin: 20px 0 12px;
  font-size: 1rem;
  color: var(--ink);
}

.responsive-table {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
}

.payroll-review-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.payroll-review-table th,
.payroll-review-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  white-space: nowrap;
}

.payroll-review-table th {
  color: var(--muted);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: rgba(248, 250, 252, 0.9);
}

.payroll-review-table tfoot td {
  font-weight: 800;
  color: var(--ink);
  background: rgba(15, 23, 42, 0.03);
}

.payroll-validation {
  margin-top: 16px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--border);
}

.payroll-validation.ok {
  background: rgba(16, 185, 129, 0.08);
  border-color: rgba(16, 185, 129, 0.25);
}

.payroll-validation.has-issues {
  background: rgba(245, 158, 11, 0.1);
  border-color: rgba(245, 158, 11, 0.25);
}

.payroll-validation ul {
  margin: 10px 0 0;
  padding-left: 20px;
  color: var(--ink);
}

.payroll-receipt-list {
  display: grid;
  gap: 12px;
  margin-top: 16px;
}

.payroll-receipt-card {
  display: grid;
  grid-template-columns: 1.4fr 0.8fr auto auto;
  align-items: center;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
}

.payroll-receipt-card div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.payroll-receipt-card span {
  color: var(--muted);
  font-size: 0.86rem;
}

.mini {
  padding: 8px 12px !important;
  min-height: auto !important;
}

@media (max-width: 760px) {
  .payroll-receipt-card {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .payroll-step-actions .primary-button,
  .payroll-step-actions .secondary-button,
  .payroll-step-actions .soft-button {
    width: 100%;
  }
}

/* V10 cierre mensual y claridad operativa */
.expense-breakdown-card {
  grid-column: 1 / -1;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px;
  background: #f8fbff;
}
.expense-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.expense-grid label {
  display: grid;
  gap: 6px;
  font-size: .82rem;
  font-weight: 800;
  color: var(--muted);
}
.expense-detail-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 14px 0;
}
.expense-detail-list span {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: .86rem;
}
.premium-history-row {
  grid-template-columns: 1.1fr .9fr 1.3fr 1.1fr 1.1fr 1.1fr .8fr auto auto;
  align-items: center;
}
.premium-history-row .mini {
  padding: 8px 12px;
  font-size: .78rem;
}
@media (max-width: 900px) {
  .premium-history-row {
    grid-template-columns: 1fr;
  }
}

/* V10.1 campo editable de gastos */
.company-expense-box {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 18px;
  background: #f8fbff;
  margin: 18px 0;
}
.expense-box-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
}
.expense-box-head h3 {
  margin: 0 0 6px;
  font-size: 1rem;
}
.expense-box-head p {
  margin: 0;
  color: var(--muted);
}
@media (max-width: 760px) {
  .expense-box-head {
    flex-direction: column;
  }
  .expense-box-head .soft-button {
    width: 100%;
  }
}

.company-revenue-box {
  margin: 1rem 0;
  border: 1px solid rgba(15, 42, 76, 0.14);
  border-radius: 20px;
  padding: 1.1rem;
  background: #fffdf8;
}

.revenue-box-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}

.revenue-box-head h3 {
  margin: 0 0 0.25rem;
  color: var(--ink);
}

.revenue-box-head p {
  margin: 0;
  color: var(--muted);
}

.revenue-source-list {
  display: grid;
  gap: 0.75rem;
}

.revenue-source-row {
  display: grid;
  grid-template-columns: 1fr 1.25fr 1.5fr 1fr 1fr auto;
  gap: 0.65rem;
  align-items: end;
  padding: 0.8rem;
  border: 1px solid rgba(15, 42, 76, 0.12);
  border-radius: 16px;
  background: #ffffff;
}

.revenue-source-row label {
  display: grid;
  gap: 0.35rem;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.revenue-source-row input,
.revenue-source-row select {
  min-height: 42px;
}

.revenue-source-total,
.revenue-detail-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
}

.revenue-source-total {
  justify-content: space-between;
  padding: 0.8rem 1rem;
  border-radius: 14px;
  background: rgba(207, 165, 77, 0.12);
  color: var(--ink);
}

.revenue-source-total strong {
  font-size: 1.15rem;
}

.revenue-source-total small {
  width: 100%;
  color: var(--muted);
}

.revenue-detail-list {
  margin: 0.75rem 0;
}

.revenue-detail-list span {
  border: 1px solid rgba(207, 165, 77, 0.22);
  background: rgba(207, 165, 77, 0.08);
  color: var(--ink);
  padding: 0.45rem 0.65rem;
  border-radius: 999px;
  font-size: 0.86rem;
}

.empty.compact {
  padding: 0.9rem;
  font-size: 0.9rem;
}

@media (max-width: 980px) {
  .revenue-source-row {
    grid-template-columns: 1fr 1fr;
  }
  .revenue-source-row .mini {
    grid-column: 1 / -1;
  }
}

@media (max-width: 620px) {
  .revenue-box-head {
    display: grid;
  }
  .revenue-source-row {
    grid-template-columns: 1fr;
  }
}

/* V10.7 empresa más clara: ingresos por origen y gastos por categoría */
.company-month-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 1.3rem;
  align-items: stretch;
  border: 1px solid rgba(15, 42, 76, 0.12);
  border-radius: 22px;
  background: #fff;
  padding: 1.2rem;
  margin: 1.2rem 0;
}
.month-summary-main h3,
.company-ledger-box h3 {
  margin: 0 0 .25rem;
  color: var(--ink);
}
.month-summary-main p,
.company-ledger-box p {
  margin: 0;
  color: var(--muted);
}
.month-summary-fields {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: 1fr 1.35fr .9fr;
  gap: 1rem;
}
.month-summary-fields label,
.month-revenue-summary {
  display: grid;
  gap: .45rem;
}
.month-summary-fields label {
  color: var(--muted);
  font-size: .86rem;
  font-weight: 800;
}
.month-summary-fields input,
.month-revenue-summary input {
  min-height: 54px;
  border-radius: 14px;
  border: 1px solid var(--line);
  padding: 0 1rem;
  font-weight: 800;
  color: var(--ink);
  background: #fff;
}
.month-revenue-summary {
  border-left: 1px solid rgba(15, 42, 76, 0.12);
  padding-left: 1.3rem;
  align-content: center;
}
.month-revenue-summary span {
  font-weight: 900;
  color: var(--ink);
  font-size: 1rem;
}
.month-revenue-summary small {
  color: var(--muted);
}
.month-revenue-summary input {
  border: none;
  padding: 0;
  font-size: 1.6rem;
  background: transparent;
}
.month-revenue-summary em {
  justify-self: start;
  font-style: normal;
  border: 1px solid rgba(30, 124, 89, 0.25);
  background: rgba(30, 124, 89, 0.08);
  color: var(--green);
  border-radius: 999px;
  padding: .25rem .6rem;
  font-weight: 900;
  font-size: .78rem;
}
.company-ledger-box {
  border: 1px solid rgba(15, 42, 76, 0.12);
  border-radius: 22px;
  background: #fff;
  padding: 1rem;
  margin: 1rem 0 1.25rem;
}
.company-ledger-tabs {
  display: inline-flex;
  gap: .5rem;
  background: #f6f8fb;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: .35rem;
  margin-bottom: 1rem;
}
.company-ledger-tab {
  border: none;
  border-radius: 10px;
  background: transparent;
  padding: .7rem 1rem;
  font-weight: 900;
  color: var(--muted);
  cursor: pointer;
}
.company-ledger-tab.active {
  color: #fff;
  background: var(--ink);
}
.company-ledger-panel {
  display: none;
}
.company-ledger-panel.active {
  display: block;
}
.compact-actions {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
}
.expense-entry-row {
  grid-template-columns: 1.05fr 1.7fr .9fr 1fr auto;
}
.danger-mini {
  color: #9c1c1c;
  border-color: rgba(156, 28, 28, .2);
  background: rgba(156, 28, 28, .04);
}
@media (max-width: 1050px) {
  .company-month-summary {
    grid-template-columns: 1fr;
  }
  .month-revenue-summary {
    border-left: none;
    border-top: 1px solid rgba(15, 42, 76, 0.12);
    padding-left: 0;
    padding-top: 1rem;
  }
  .month-summary-fields,
  .expense-entry-row {
    grid-template-columns: 1fr;
  }
}

/* V12 - Reporte de planillas con calendario */
.payroll-report-panel {
  margin-bottom: 22px;
}
.report-filters {
  display: flex;
  align-items: end;
  gap: 12px;
}
.report-filters label {
  display: grid;
  gap: 6px;
  color: var(--muted, #64748b);
  font-weight: 700;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.payroll-calendar-layout {
  display: grid;
  grid-template-columns: minmax(360px, 0.85fr) minmax(420px, 1.15fr);
  gap: 20px;
  margin-top: 18px;
  align-items: start;
}
.payroll-calendar,
.payroll-calendar-summary {
  border: 1px solid #d9e3ef;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.04);
  padding: 18px;
}
.calendar-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  text-transform: capitalize;
  color: #0f172a;
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
}
.calendar-grid.weekdays {
  margin-bottom: 8px;
}
.calendar-weekday {
  text-align: center;
  font-size: 0.78rem;
  font-weight: 800;
  color: #64748b;
}
.calendar-day {
  min-height: 72px;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #f8fafc;
  color: #0f172a;
  text-align: left;
  padding: 10px;
  cursor: default;
  transition: 160ms ease;
  display: grid;
  align-content: start;
  gap: 5px;
}
.calendar-day strong {
  font-size: 0.96rem;
}
.calendar-day span {
  width: fit-content;
  border-radius: 999px;
  padding: 4px 8px;
  background: #dcfce7;
  color: #166534;
  font-size: 0.72rem;
  font-weight: 900;
}
.calendar-day small {
  color: #166534;
  font-weight: 800;
}
.calendar-day.has-payroll {
  background: linear-gradient(180deg, #f0fdf4, #ffffff);
  border-color: #86efac;
  box-shadow: inset 0 0 0 1px rgba(22, 101, 52, 0.08);
  cursor: pointer;
}
.calendar-day.has-payroll:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(22, 101, 52, 0.12);
}
.calendar-day.empty {
  background: transparent;
  border-color: transparent;
}
.calendar-legend {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #64748b;
  font-size: 0.9rem;
  margin-top: 12px;
  padding-left: 4px;
}
.legend-dot {
  width: 12px;
  height: 12px;
  display: inline-block;
  border-radius: 50%;
}
.legend-dot.planilla {
  background: #22c55e;
  box-shadow: 0 0 0 4px #dcfce7;
}
.calendar-summary-head {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: space-between;
  border-bottom: 1px solid #e2e8f0;
  padding-bottom: 12px;
  margin-bottom: 14px;
}
.calendar-summary-head h3 {
  margin: 0;
  flex: 1;
  color: #0f172a;
}
.calendar-summary-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.calendar-summary-kpis article {
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 12px;
  background: #f8fafc;
}
.calendar-summary-kpis article span {
  color: #64748b;
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
}
.calendar-summary-kpis article strong {
  display: block;
  margin-top: 6px;
  font-size: 1rem;
  color: #0f172a;
}
.calendar-summary-kpis article.good {
  background: #f0fdf4;
  border-color: #bbf7d0;
}
.calendar-summary-kpis article.risk {
  background: #fff1f2;
  border-color: #fecdd3;
}
.calendar-summary-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
.calendar-summary-columns h4 {
  margin: 0 0 8px;
  color: #0f172a;
}
.calendar-summary-columns ul {
  margin: 0;
  padding: 0;
  list-style: none;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  overflow: hidden;
}
.calendar-summary-columns li {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-bottom: 1px solid #e2e8f0;
  font-size: .9rem;
}
.calendar-summary-columns li:last-child {
  border-bottom: 0;
}
.calendar-payroll-table {
  margin-bottom: 14px;
}
@media (max-width: 980px) {
  .payroll-calendar-layout,
  .calendar-summary-columns {
    grid-template-columns: 1fr;
  }
  .calendar-summary-kpis {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 640px) {
  .calendar-summary-kpis {
    grid-template-columns: 1fr;
  }
  .calendar-day {
    min-height: 58px;
    padding: 7px;
  }
}


/* V11.3 - Tarjetas inteligentes */
.smart-card,
.kpi[data-goto],
.command-card[data-goto],
.risk-row[data-goto],
.alert-row[data-goto],
.report-card[data-goto],
.profit-card[data-goto],
.payroll-simple-summary article[data-goto] {
  cursor: pointer;
  position: relative;
}
.smart-card::after,
.kpi[data-goto]::after,
.command-card[data-goto]::after::after,
.report-card[data-goto]::after,
.profit-card[data-goto]::after,
.payroll-simple-summary article[data-goto]::after {
  content: "Ver detalle →";
  display: block;
  margin-top: 0.45rem;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--primary);
  opacity: 0.78;
}
.smart-card:hover,
.kpi[data-goto]:hover,
.command-card[data-goto]:hover:hover,
.risk-row[data-goto]:hover,
.alert-row[data-goto]:hover,
.report-card[data-goto]:hover,
.profit-card[data-goto]:hover,
.payroll-simple-summary article[data-goto]:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.12);
  border-color: rgba(26, 75, 140, 0.32);
}
.smart-card:focus,
.kpi[data-goto]:focus,
.command-card[data-goto]:focus:focus,
.risk-row[data-goto]:focus,
.alert-row[data-goto]:focus,
.report-card[data-goto]:focus,
.profit-card[data-goto]:focus,
.payroll-simple-summary article[data-goto]:focus {
  outline: 3px solid rgba(26, 75, 140, 0.22);
  outline-offset: 3px;
}


.smart-detail-modal { position: fixed; inset: 0; display: none; z-index: 1000; }
.smart-detail-modal.show { display: block; }
.smart-detail-backdrop { position: absolute; inset: 0; background: rgba(6, 17, 34, 0.45); backdrop-filter: blur(3px); }
.smart-detail-panel { position: relative; width: min(1040px, calc(100vw - 32px)); max-height: calc(100vh - 48px); overflow: auto; margin: 24px auto; background: #fff; border: 1px solid #d8e2ef; border-radius: 26px; box-shadow: 0 24px 70px rgba(11, 31, 59, 0.25); padding: 26px; }
.smart-detail-head { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; border-bottom: 1px solid #e7edf5; padding-bottom: 18px; margin-bottom: 18px; }
.smart-detail-head h2 { margin: 4px 0 6px; color: #0d1b2f; }
.smart-detail-head p { margin: 0; color: #66758a; }
.smart-detail-summary { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin-bottom: 16px; }
.smart-detail-summary article { border: 1px solid #dbe5f0; border-radius: 18px; padding: 16px; background: #f8fafc; }
.smart-detail-summary span { display: block; color: #66758a; font-weight: 800; font-size: .82rem; text-transform: uppercase; }
.smart-detail-summary strong { display: block; margin-top: 6px; color: #0d1b2f; font-size: 1.25rem; }
.smart-detail-table { border: 1px solid #dbe5f0; border-radius: 18px; overflow: hidden; background: #fff; }
.smart-detail-row { display: grid; grid-template-columns: 1.1fr 1.4fr 1fr .75fr; gap: 12px; align-items: center; padding: 14px 16px; border-bottom: 1px solid #edf2f7; }
.smart-detail-row:last-child { border-bottom: 0; }
.smart-detail-header { background: #0d1b2f; color: #fff; font-weight: 900; text-transform: uppercase; font-size: .78rem; letter-spacing: .04em; }
.smart-detail-row strong { text-align: right; color: #0d1b2f; }
.smart-detail-actions { display: flex; justify-content: flex-end; gap: 12px; margin-top: 18px; flex-wrap: wrap; }
@media (max-width: 760px) { .smart-detail-summary { grid-template-columns: 1fr; } .smart-detail-row { grid-template-columns: 1fr; } .smart-detail-row strong { text-align: left; } .smart-detail-head { flex-direction: column; } }

/* V11.6 - Corrección de tarjetas financieras */
.flow-step { min-width: 0; overflow: hidden; }
.flow-step .card-action { display: inline-flex; align-items: center; width: max-content; max-width: 100%; margin-top: 4px; color: var(--primary); font-size: .78rem; font-weight: 900; text-transform: none; letter-spacing: 0; white-space: nowrap; }
.flow-step strong, .smart-card strong, .report-card strong, .profit-card strong { overflow-wrap: anywhere; }
.finance-flow { grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); align-items: stretch; }
.smart-card::after, .kpi[data-goto]::after, .command-card[data-goto]::after, .report-card[data-goto]::after, .profit-card[data-goto]::after, .payroll-simple-summary article[data-goto]::after { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@media (max-width: 900px) { .finance-flow { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); } }


/* V12.1 - Panel administrativo protegido */
.admin-panel { border-color: rgba(168, 50, 50, .22); }
.admin-warning { background: #fff7ed; border: 1px solid #fed7aa; color: #7c2d12; align-items: flex-start; }
.admin-tools-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-top: 22px; }
.admin-tool-card { display: grid; gap: 12px; padding: 18px; border: 1px solid #dbe5f0; border-radius: 22px; background: #f8fafc; }
.admin-tool-card h3 { margin: 0; color: #0d1b2f; font-size: 1rem; }
.admin-tool-card p { margin: 0; color: #66758a; line-height: 1.45; }
.admin-tool-card select,
.admin-tool-card input { min-height: 46px; border: 1px solid #d7e2ef; border-radius: 14px; padding: 0 12px; font: inherit; background: #fff; color: #0d1b2f; }
.admin-tool-card.danger-zone { background: #fff5f5; border-color: #f4b6b6; }
@media (max-width: 900px) { .admin-tools-grid { grid-template-columns: 1fr; } }
