
:root {
  --bg: #f4f7fb;
  --bg-soft: #eef3f9;
  --surface: #ffffff;
  --surface-soft: #f8fbff;
  --surface-muted: #f3f6fb;
  --line: #d9e3f0;
  --line-strong: #c8d6e8;
  --text: #10233f;
  --text-soft: #5f7089;
  --heading: #0b1c34;
  --primary: #2d6cdf;
  --primary-strong: #1f59c1;
  --primary-soft: #eaf2ff;
  --success: #198754;
  --success-soft: #e8f7ef;
  --warning: #b7791f;
  --warning-soft: #fff5e6;
  --danger: #c24141;
  --danger-soft: #fff0f0;
  --shadow-sm: 0 10px 24px rgba(15, 35, 62, 0.06);
  --shadow-md: 0 18px 40px rgba(15, 35, 62, 0.08);
  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 24px;
  --sidebar-width: 292px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: 'Cairo', sans-serif;
  background:
    radial-gradient(circle at top right, rgba(45,108,223,0.08), transparent 28%),
    linear-gradient(180deg, #f9fbfe 0%, var(--bg) 100%);
  color: var(--text);
}

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

img { max-width: 100%; }
button, input, select, textarea {
  font: inherit;
}

.admin-shell {
  display: grid;
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
  min-height: 100vh;
}

.mobile-menu-toggle,
.sidebar-close,
.mobile-overlay {
  display: none;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  padding: 22px 18px;
  background: rgba(255,255,255,0.86);
  backdrop-filter: blur(16px);
  border-left: 1px solid rgba(201, 214, 233, 0.85);
  box-shadow: 8px 0 32px rgba(15, 35, 62, 0.04);
}

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

.brand-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
}

.brand-logo {
  width: 50px;
  height: 50px;
  border-radius: 16px;
  object-fit: cover;
  background: var(--surface);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}

.brand {
  font-size: 21px;
  line-height: 1.4;
  font-weight: 900;
  color: var(--heading);
}

.brand-subtitle {
  color: var(--text-soft);
  font-size: 13px;
  margin-bottom: 18px;
  line-height: 1.8;
}

.user-mini-card {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  margin-bottom: 18px;
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}
.user-mini-card strong {
  color: var(--heading);
  font-size: 15px;
}
.user-mini-card span,
.user-mini-card small {
  color: var(--text-soft);
}

.sidebar-nav {
  display: grid;
  gap: 8px;
}

.sidebar-nav a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  color: var(--text);
  font-weight: 700;
  border: 1px solid transparent;
  transition: 0.18s ease;
}

.sidebar-nav a:hover {
  background: var(--surface-soft);
  border-color: var(--line);
  color: var(--heading);
  transform: translateY(-1px);
}

.sidebar-nav a.active {
  background: var(--primary-soft);
  color: var(--primary-strong);
  border-color: rgba(45,108,223,0.18);
  box-shadow: inset 0 0 0 1px rgba(45,108,223,0.08);
}

.sidebar-nav a.logout-link {
  margin-top: 10px;
  color: var(--danger);
  background: #fff8f8;
  border-color: rgba(194,65,65,0.08);
}

.nav-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 7px;
  border-radius: 999px;
  background: var(--danger-soft);
  color: var(--danger);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
}

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

.page-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.page-head h1 {
  margin: 0 0 6px;
  font-size: clamp(26px, 2.4vw, 34px);
  line-height: 1.25;
  color: var(--heading);
}

.page-head p {
  margin: 0;
  color: var(--text-soft);
  max-width: 760px;
  line-height: 1.9;
}

.page-actions,
.inline-actions,
.form-actions,
.settings-submit-row,
.print-toolbar,
.calendar-toolbar,
.table-actions,
.note-meta,
.task-meta,
.badge-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.btn {
  appearance: none;
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 46px;
  padding: 11px 18px;
  border-radius: 14px;
  cursor: pointer;
  font-weight: 800;
  transition: 0.18s ease;
  box-shadow: none;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn-primary {
  background: linear-gradient(180deg, var(--primary) 0%, var(--primary-strong) 100%);
  color: #fff;
  box-shadow: 0 14px 24px rgba(45,108,223,0.18);
}

.btn-secondary {
  background: var(--surface);
  color: var(--heading);
  border-color: var(--line);
}

.btn-secondary:hover {
  background: var(--surface-soft);
}

.btn-danger {
  background: var(--danger-soft);
  color: var(--danger);
  border-color: rgba(194,65,65,0.12);
}

.installment-action-stack {
  display: grid;
  gap: 8px;
  width: 100%;
}

.installment-action-stack form {
  margin: 0;
}

.installment-action-stack .btn,
.installment-action .btn {
  width: 100%;
}

.btn-sm {
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 11px;
  font-size: 13px;
}

.btn-block { width: 100%; }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 20px;
}

.dashboard-stats {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.stat-card,
.panel,
.auth-card,
.calendar-cell,
.note-card,
.task-card,
.mini-item,
.period-card,
.metric-row,
.report-tag,
.empty-box,
.activity-item,
.print-sheet,
.receipt-amount-box,
.signature-box,
.info-list div,
.report-tag {
  background: rgba(255,255,255,0.94);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.panel {
  overflow: hidden;
}

.stat-card {
  padding: 18px;
  position: relative;
}

.stat-card .label {
  display: block;
  margin-bottom: 10px;
  font-size: 13px;
  color: var(--text-soft);
  font-weight: 700;
}

.stat-card strong {
  display: block;
  color: var(--heading);
  font-size: clamp(24px, 2vw, 30px);
  line-height: 1.2;
}

.panel-head,
.panel-body {
  padding: 18px 20px;
}

.panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.panel-head h2 {
  margin: 0;
  color: var(--heading);
  font-size: 19px;
}

.filter-panel .panel-body {
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

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

.data-table,
.print-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.data-table th,
.data-table td,
.print-table th,
.print-table td {
  padding: 13px 14px;
  border-bottom: 1px solid #e7edf6;
  text-align: right;
  vertical-align: top;
}

.data-table thead th,
.print-table thead th {
  position: sticky;
  top: 0;
  background: #f5f8fd;
  color: #5a6b83;
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
  z-index: 1;
}

.data-table tbody tr:hover {
  background: #fbfdff;
}

.table-link {
  color: var(--primary-strong);
  font-weight: 800;
}

.table-link:hover {
  text-decoration: underline;
}

.empty-box {
  padding: 24px;
  color: var(--text-soft);
  text-align: center;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.form-panel { max-width: 980px; }
.wide-panel { max-width: 1240px; }

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

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

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

.form-group label {
  color: var(--heading);
  font-size: 14px;
  font-weight: 800;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  min-height: 46px;
  padding: 11px 14px;
  border-radius: 14px;
  border: 1px solid var(--line-strong);
  background: #fff;
  color: var(--text);
  outline: none;
  transition: 0.18s ease;
}

.form-group textarea {
  min-height: 120px;
  resize: vertical;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: #98a6ba;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: rgba(45,108,223,0.55);
  box-shadow: 0 0 0 4px rgba(45,108,223,0.10);
}

.form-group small.hint {
  color: var(--text-soft);
  font-size: 12px;
  line-height: 1.7;
}

.filters-row {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(180px, 1fr) auto;
  gap: 16px;
  align-items: end;
}

.filters-row-wide {
  grid-template-columns: minmax(0, 2fr) repeat(2, minmax(170px, 1fr)) minmax(170px, 1fr) auto;
}

.search-field { min-width: 220px; }
.status-field { min-width: 160px; }
.full-mobile-actions { justify-content: flex-start; }
.compact-stats { margin-bottom: 16px; }
.compact-table { min-width: 620px; }
.notes-col { min-width: 200px; max-width: 360px; }

.checkbox-group {
  align-self: end;
}

.checkbox-group label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--text);
  font-weight: 700;
}

.checkbox-group input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--primary);
}

.flash {
  padding: 14px 16px;
  border-radius: 14px;
  margin-bottom: 16px;
  font-weight: 800;
  border: 1px solid transparent;
}

.flash-success {
  background: var(--success-soft);
  color: var(--success);
  border-color: rgba(25,135,84,0.12);
}

.flash-error {
  background: var(--danger-soft);
  color: var(--danger);
  border-color: rgba(194,65,65,0.12);
}

.flash-warning,
.period-lock-banner {
  background: var(--warning-soft);
  color: var(--warning);
  border-color: rgba(183,121,31,0.12);
}

.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 6px 11px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  border: 1px solid transparent;
}

.status-active {
  background: var(--primary-soft);
  color: var(--primary-strong);
  border-color: rgba(45,108,223,0.15);
}

.status-completed {
  background: var(--success-soft);
  color: var(--success);
  border-color: rgba(25,135,84,0.15);
}

.status-late {
  background: var(--warning-soft);
  color: var(--warning);
  border-color: rgba(183,121,31,0.15);
}

.status-danger {
  background: var(--danger-soft);
  color: var(--danger);
  border-color: rgba(194,65,65,0.15);
}

.status-suspended,
.status-default {
  background: #f2f5f9;
  color: #617188;
  border-color: rgba(97,113,136,0.14);
}

.content-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

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

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

.customer-profile .panel-body {
  padding-bottom: 8px;
}

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

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

.info-list div {
  padding: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.info-list span,
.report-tag span,
.print-meta span,
.print-summary-grid span,
.print-mini-stats span,
.receipt-amount-box span,
.signature-box span,
.metric-row span {
  display: block;
  margin-bottom: 6px;
  font-size: 13px;
  color: var(--text-soft);
}

.info-list strong,
.report-tag strong,
.print-meta strong,
.print-summary-grid strong,
.print-mini-stats strong,
.receipt-amount-box strong,
.signature-box strong {
  color: var(--heading);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.8;
}

.report-grid-two {
  align-items: start;
}

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

.report-tag {
  padding: 16px;
}

.report-tag strong {
  font-size: 24px;
}

.metric-stack,
.note-card-list,
.task-card-list,
.mini-list,
.activity-list,
.settings-layout,
.alerts-grid {
  display: grid;
  gap: 12px;
}

.metric-row,
.note-card,
.task-card,
.mini-item,
.period-card,
.activity-item {
  padding: 14px 16px;
}

.metric-row {
  justify-content: space-between;
  gap: 12px;
}

.note-card-head,
.task-card-head,
.period-card-head,
.note-footer,
.task-footer,
.period-card-footer,
.alert-hero-body,
.print-header,
.receipt-header,
.calendar-day-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  flex-wrap: wrap;
}

.note-body,
.task-body {
  line-height: 1.95;
  white-space: pre-wrap;
}

.note-footer,
.task-footer,
.period-card-footer,
.activity-item span,
.activity-item small {
  color: var(--text-soft);
  font-size: 13px;
}

.activity-item strong {
  display: block;
  margin-bottom: 6px;
  color: var(--heading);
}

.alert-hero-panel {
  margin-bottom: 18px;
  border-color: rgba(45,108,223,0.14);
  background: linear-gradient(135deg, rgba(45,108,223,0.09), rgba(255,255,255,0.98));
}

.alert-hero-body p {
  margin: 6px 0 0;
  color: var(--text-soft);
}

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

.calendar-weekday {
  text-align: center;
  padding: 10px;
  color: #6a7b93;
  font-weight: 800;
}

.calendar-cell {
  min-height: 160px;
  padding: 12px;
  display: grid;
  gap: 10px;
  align-content: start;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.calendar-cell.is-today {
  border-color: rgba(45,108,223,0.35);
  box-shadow: inset 0 0 0 1px rgba(45,108,223,0.18), var(--shadow-sm);
}

.calendar-cell.is-outside {
  opacity: 0.55;
}

.calendar-day-head strong {
  font-size: 18px;
  color: var(--heading);
}

.calendar-items {
  display: grid;
  gap: 8px;
}

.calendar-item {
  padding: 8px 10px;
  border-radius: 12px;
  background: #f5f8fd;
  border: 1px solid #e3ebf6;
  font-size: 12px;
  line-height: 1.75;
}

.auth-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}

.auth-card {
  width: min(560px, 100%);
  padding: 28px;
  background: rgba(255,255,255,0.95);
  border-radius: 28px;
  box-shadow: var(--shadow-md);
}

.auth-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--primary-soft);
  color: var(--primary-strong);
  font-weight: 800;
  margin-bottom: 12px;
}

.auth-brand h1 {
  margin: 0 0 8px;
  color: var(--heading);
  font-size: clamp(28px, 4vw, 36px);
}

.auth-brand p,
.auth-help span,
.auth-help small {
  color: var(--text-soft);
}

.auth-form {
  display: grid;
  gap: 16px;
  margin-top: 18px;
}

.auth-help {
  margin-top: 18px;
  display: grid;
  gap: 6px;
  padding: 16px;
  border-radius: 16px;
  background: #f8fbff;
  border: 1px solid var(--line);
}

.print-page {
  background: #eef3f8;
  color: #0f172a;
}

.print-toolbar {
  width: min(1120px, calc(100% - 32px));
  margin: 16px auto 0;
  justify-content: flex-end;
}

.print-sheet {
  width: min(1120px, calc(100% - 32px));
  margin: 16px auto 40px;
  padding: 28px;
  border-radius: 24px;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.10);
  background: #fff;
}

.print-header {
  align-items: flex-start;
  border-bottom: 2px solid #e6edf6;
  padding-bottom: 18px;
  margin-bottom: 18px;
}

.print-header h1 {
  margin: 0 0 6px;
  font-size: 30px;
  color: var(--heading);
}

.print-header p {
  margin: 0;
  color: #53657d;
}

.print-meta {
  display: grid;
  gap: 10px;
  text-align: left;
}

.print-summary-grid,
.print-mini-stats,
.receipt-signatures {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.print-summary-grid > div,
.print-mini-stats > div {
  border: 1px solid #e5ecf6;
  border-radius: 16px;
  padding: 14px;
  background: #f8fbff;
}

.receipt-sheet {
  max-width: 900px;
}

.receipt-amount-box {
  padding: 18px;
  margin-bottom: 18px;
  text-align: center;
  border-style: dashed;
}

.receipt-amount-box strong {
  font-size: 34px;
  font-weight: 900;
}

.receipt-table th {
  width: 180px;
  background: #f8fbff;
}

.signature-box {
  padding: 18px;
  min-height: 110px;
}

.sticky-actions-panel {
  position: sticky;
  bottom: 12px;
  z-index: 4;
  backdrop-filter: blur(10px);
}

.no-print { }

@media (max-width: 1200px) {
  .stats-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .content-grid.two-cols,
  .info-list.three-cols,
  .calendar-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  body:not(.auth-page):not(.print-page) {
    padding-top: 72px;
  }

  .admin-shell {
    grid-template-columns: 1fr;
  }

  .mobile-menu-toggle {
    position: fixed;
    top: 14px;
    right: 14px;
    z-index: 80;
    width: 48px;
    height: 48px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255,255,255,0.96);
    color: var(--heading);
    box-shadow: var(--shadow-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    cursor: pointer;
  }

  .mobile-overlay {
    position: fixed;
    inset: 0;
    background: rgba(12, 24, 44, 0.32);
    z-index: 60;
  }

  .sidebar {
    position: fixed;
    top: 0;
    right: 0;
    width: min(86vw, 330px);
    max-width: 330px;
    transform: translateX(100%);
    transition: transform 0.22s ease;
    z-index: 70;
    height: 100vh;
    border-left: 1px solid var(--line);
    box-shadow: -16px 0 40px rgba(12, 24, 44, 0.14);
  }

  .sidebar-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: #fff;
    color: var(--heading);
    cursor: pointer;
  }

  body.sidebar-open .sidebar {
    transform: translateX(0);
  }

  body.sidebar-open .mobile-overlay {
    display: block;
  }

  .main-content {
    padding: 18px;
  }

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

  .filters-row,
  .filters-row-wide,
  .form-grid,
  .info-list,
  .content-grid.two-cols,
  .print-summary-grid,
  .print-mini-stats,
  .receipt-signatures {
    grid-template-columns: 1fr;
  }

  .page-actions,
  .full-mobile-actions {
    width: 100%;
  }
}

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

  .calendar-weekday {
    display: none;
  }

  .data-table,
  .print-table,
  .compact-table {
    min-width: 640px;
  }
}

@media (max-width: 640px) {
  .main-content {
    padding: 16px;
  }

  .panel-head,
  .panel-body,
  .auth-card,
  .print-sheet,
  .stat-card {
    padding: 16px;
  }

  .stats-grid {
    grid-template-columns: 1fr;
  }

  .btn,
  .page-actions .btn,
  .inline-actions .btn,
  .form-actions .btn,
  .full-mobile-actions .btn {
    width: 100%;
  }

  .page-head {
    align-items: stretch;
  }

  .print-toolbar {
    width: calc(100% - 20px);
  }

  .print-sheet {
    width: calc(100% - 20px);
    margin: 12px auto 24px;
    padding: 18px;
  }
}

@media print {
  body.print-page {
    background: #fff;
    padding-top: 0 !important;
  }

  .no-print,
  .mobile-menu-toggle,
  .mobile-overlay {
    display: none !important;
  }

  .print-sheet {
    width: 100%;
    margin: 0;
    border-radius: 0;
    box-shadow: none;
    padding: 0;
    border: 0;
  }
}


.main-content > .panel,
.content-grid > .panel,
.content-grid > section,
.content-grid > article {
  min-width: 0;
}

.page-head {
  position: relative;
  padding: 24px;
  border: 1px solid rgba(201, 214, 233, 0.9);
  border-radius: 24px;
  background:
    radial-gradient(circle at top left, rgba(45,108,223,0.08), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
  box-shadow: var(--shadow-sm);
}

.page-head::after {
  content: "";
  position: absolute;
  inset-inline-start: 24px;
  inset-block-end: 0;
  width: 84px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--primary), rgba(45,108,223,0));
}

.page-head > div:first-child {
  min-width: min(100%, 520px);
}

.page-actions {
  justify-content: flex-end;
}

.panel + .panel,
.panel + .content-grid,
.stats-grid + .panel,
.page-head + .panel,
.page-head + .stats-grid {
  margin-top: 0;
}

.table-wrap.responsive-cards {
  overflow: auto;
  background: transparent;
}

.table-wrap.responsive-cards .data-table td {
  white-space: normal;
}

.data-table td,
.data-table th {
  overflow-wrap: anywhere;
}

.data-table tbody tr:nth-child(even) {
  background: rgba(248, 251, 255, 0.74);
}

.data-table tbody tr:last-child td {
  border-bottom: 0;
}

.table-actions.full-mobile-actions {
  align-items: stretch;
}

.info-list div {
  min-width: 0;
}

@media (max-width: 980px) {
  .page-head {
    padding: 18px;
    border-radius: 20px;
  }

  .page-head::after {
    inset-inline-start: 18px;
  }
}

@media (max-width: 720px) {
  .page-head {
    padding: 16px;
  }

  .page-head::after {
    inset-inline-start: 16px;
    width: 64px;
  }

  .table-wrap.responsive-cards {
    overflow: visible;
    border: 0;
    border-radius: 0;
  }

  .table-wrap.responsive-cards .data-table {
    min-width: 100%;
    display: block;
  }

  .table-wrap.responsive-cards .data-table thead {
    display: none;
  }

  .table-wrap.responsive-cards .data-table tbody {
    display: grid;
    gap: 12px;
  }

  .table-wrap.responsive-cards .data-table tbody tr {
    display: block;
    padding: 12px;
    background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
    border: 1px solid var(--line);
    border-radius: 18px;
    box-shadow: var(--shadow-sm);
  }

  .table-wrap.responsive-cards .data-table tbody tr:hover {
    background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  }

  .table-wrap.responsive-cards .data-table tbody td {
    display: grid;
    grid-template-columns: minmax(92px, 112px) minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    width: 100%;
    padding: 8px 0;
    border-bottom: 1px dashed #e4ecf7;
    text-align: right;
  }

  .table-wrap.responsive-cards .data-table tbody td:last-child {
    border-bottom: 0;
    padding-bottom: 0;
  }

  .table-wrap.responsive-cards .data-table tbody td::before {
    content: attr(data-label);
    color: var(--text-soft);
    font-size: 12px;
    font-weight: 800;
    line-height: 1.8;
  }

  .table-wrap.responsive-cards .data-table tbody td[data-label="الإجراءات"] {
    display: block;
  }

  .table-wrap.responsive-cards .data-table tbody td[data-label="الإجراءات"]::before {
    display: block;
    margin-bottom: 8px;
  }

  .table-wrap.responsive-cards .data-table tbody td[data-label="الإجراءات"] .table-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .table-wrap.responsive-cards .data-table tbody td[data-label="الإجراءات"] .table-actions form {
    display: contents;
  }

  .table-wrap.responsive-cards .data-table tbody td[data-label="الإجراءات"] .btn {
    width: 100%;
    min-height: 40px;
  }

  .table-wrap.responsive-cards .notes-col {
    max-width: none;
  }
}

@media (max-width: 520px) {
  .table-wrap.responsive-cards .data-table tbody td {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .table-wrap.responsive-cards .data-table tbody td[data-label="الإجراءات"] .table-actions {
    grid-template-columns: 1fr;
  }
}


/* Stage 10 | refined forms and mobile-first entry screens */
body {
  line-height: 1.7;
}

.form-page-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(280px, 0.85fr);
  gap: 18px;
  align-items: start;
}

.form-main-panel,
.settings-panel,
.side-note-panel,
.summary-panel {
  min-width: 0;
}

.form-panel {
  width: 100%;
  max-width: none;
}

.form-side-stack,
.form-main-stack {
  display: grid;
  gap: 18px;
}

.form-meta-grid,
.quick-meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin: 18px 0;
}

.meta-card,
.helper-card,
.preview-card,
.form-section-title,
.field-addon,
.template-chip,
.settings-preview-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
}

.meta-card,
.helper-card,
.preview-card,
.settings-preview-card {
  padding: 16px;
}

.meta-card span,
.helper-card span,
.preview-card span,
.settings-preview-card span,
.helper-list li,
.panel-subtitle,
.form-section-title small,
.template-chip,
.side-note-panel p,
.side-note-panel li,
.form-stat small,
.mobile-page-kicker {
  color: var(--text-soft);
}

.meta-card strong,
.helper-card strong,
.preview-card strong,
.settings-preview-card strong,
.form-stat strong {
  display: block;
  color: var(--heading);
  font-size: 18px;
  font-weight: 900;
  line-height: 1.5;
  margin-top: 4px;
}

.meta-card small,
.helper-card small,
.preview-card small,
.settings-preview-card small {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.8;
}

.form-section-title {
  grid-column: 1 / -1;
  padding: 14px 16px;
  border-style: dashed;
  background: linear-gradient(180deg, rgba(45,108,223,0.06), rgba(255,255,255,0.98));
}

.form-section-title strong {
  display: block;
  color: var(--heading);
  font-size: 15px;
  margin-bottom: 2px;
}

.form-grid.form-grid-relaxed {
  gap: 18px;
}

.form-grid.form-grid-relaxed .form-group input,
.form-grid.form-grid-relaxed .form-group select,
.form-grid.form-grid-relaxed .form-group textarea,
.settings-panel .form-group input,
.settings-panel .form-group select,
.settings-panel .form-group textarea {
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.form-group {
  min-width: 0;
}

.form-group label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 22px;
}

.form-group input,
.form-group select,
.form-group textarea {
  font-size: 15px;
}

.form-group input[type="date"],
.form-group input[type="datetime-local"],
.form-group input[type="number"],
.form-group input[type="url"],
.form-group input[type="email"],
.form-group input[type="password"] {
  direction: rtl;
}

.form-group.is-readonly input,
.form-group.is-readonly textarea {
  background: #f3f7fd;
}

.form-help-list,
.helper-list,
.template-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.helper-list li,
.template-list li {
  position: relative;
  padding-inline-start: 18px;
  line-height: 1.9;
}

.helper-list li::before,
.template-list li::before {
  content: "•";
  position: absolute;
  inset-inline-start: 0;
  top: 0;
  color: var(--primary);
  font-weight: 900;
}

.side-note-panel .panel-head,
.summary-panel .panel-head {
  align-items: center;
}

.side-note-panel .panel-head h2,
.summary-panel .panel-head h2,
.settings-panel .panel-head h2 {
  font-size: 17px;
}

.inline-value {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  background: #f4f8fe;
  border: 1px solid #e2ebf7;
  font-size: 13px;
  font-weight: 700;
  color: var(--heading);
}

.template-chip-row,
.form-stat-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.template-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 800;
}

.settings-preview-card {
  position: sticky;
  top: 24px;
}

.settings-preview-swatch {
  width: 100%;
  height: 54px;
  border-radius: 16px;
  border: 1px solid rgba(16,35,63,0.08);
  margin-bottom: 14px;
}

.settings-preview-sheet {
  padding: 16px;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid #e6edf6;
  box-shadow: inset 0 0 0 1px rgba(45,108,223,0.03);
}

.settings-preview-sheet strong {
  font-size: 16px;
}

.settings-preview-sheet p {
  margin: 8px 0 0;
  color: var(--text-soft);
  line-height: 1.9;
}

.form-actions.sticky-form-actions {
  position: sticky;
  bottom: 12px;
  padding: 12px;
  border: 1px solid rgba(201,214,233,0.9);
  border-radius: 18px;
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(14px);
  box-shadow: 0 18px 32px rgba(15,35,62,0.08);
  z-index: 4;
}

.form-actions.sticky-form-actions .btn {
  min-width: 150px;
}

.helper-card + .helper-card,
.side-note-panel + .side-note-panel,
.summary-panel + .summary-panel {
  margin-top: 0;
}

.mobile-page-kicker {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(45,108,223,0.08);
  color: var(--primary-strong);
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 8px;
}

.settings-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.7fr);
  gap: 18px;
  align-items: start;
}

.settings-main-stack,
.settings-side-stack {
  display: grid;
  gap: 18px;
}

.settings-panel .panel-head {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.settings-panel .panel-body.form-grid {
  gap: 18px;
}

.inline-actions {
  align-items: center;
}

.inline-actions .hint {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 8px 12px;
  border-radius: 12px;
  background: #f7faff;
  border: 1px solid #e4ecf7;
}

.preview-box {
  white-space: pre-wrap;
  line-height: 1.95;
  min-height: 180px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

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

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

  .settings-preview-card {
    position: static;
  }
}

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

  .form-actions.sticky-form-actions {
    bottom: 8px;
    padding: 10px;
  }

  .form-actions.sticky-form-actions .btn {
    min-width: 0;
  }

  .inline-actions {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .inline-actions .hint,
  .inline-actions .btn {
    width: 100%;
  }
}

/* Stage 11 | final polish for navigation, dashboard, and secondary tables */
.main-content {
  max-width: 1680px;
}

.page-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(45,108,223,0.10);
  color: var(--primary-strong);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.2px;
}

.page-kicker::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.75;
}

.sidebar {
  background: linear-gradient(180deg, rgba(255,255,255,0.95) 0%, rgba(247,250,255,0.98) 100%);
}

.sidebar-nav {
  gap: 9px;
}

.sidebar-nav a {
  min-height: 52px;
  padding: 11px 13px;
}

.nav-side {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.nav-icon {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: linear-gradient(180deg, #ffffff 0%, #eef4ff 100%);
  border: 1px solid rgba(45,108,223,0.10);
  color: var(--primary-strong);
  font-size: 16px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8);
}

.nav-text {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-nav a.active .nav-icon {
  background: linear-gradient(180deg, var(--primary) 0%, var(--primary-strong) 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 10px 20px rgba(45,108,223,0.18);
}

.sidebar-nav a.logout-link .nav-icon {
  color: var(--danger);
  background: linear-gradient(180deg, #fffdfd 0%, #fff1f1 100%);
  border-color: rgba(194,65,65,0.10);
}

.user-mini-card {
  position: relative;
  overflow: hidden;
}

.user-mini-card::after {
  content: "";
  position: absolute;
  inset-inline-end: -28px;
  inset-block-start: -28px;
  width: 92px;
  height: 92px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(45,108,223,0.12) 0%, rgba(45,108,223,0) 72%);
}

.dashboard-hero {
  align-items: center;
}

.dashboard-hero-copy {
  display: grid;
  gap: 0;
}

.hero-summary-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.hero-chip {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.94);
  border: 1px solid rgba(45,108,223,0.12);
  color: var(--heading);
  font-weight: 800;
  font-size: 13px;
  box-shadow: var(--shadow-sm);
}

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

.quick-link-card {
  display: grid;
  gap: 8px;
  padding: 18px;
  min-height: 118px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,250,255,0.98) 100%);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
  transition: 0.18s ease;
}

.quick-link-card strong {
  color: var(--heading);
  font-size: 16px;
}

.quick-link-card span {
  color: var(--text-soft);
  line-height: 1.8;
  font-size: 13px;
}

.quick-link-card:hover {
  transform: translateY(-2px);
  border-color: rgba(45,108,223,0.20);
  box-shadow: var(--shadow-md);
}

.stat-card {
  overflow: hidden;
}

.stat-card::after {
  content: "";
  position: absolute;
  inset-inline-end: -18px;
  inset-block-end: -18px;
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(45,108,223,0.10) 0%, rgba(45,108,223,0) 72%);
  pointer-events: none;
}

.stat-card strong {
  position: relative;
  z-index: 1;
}

.panel-head h2 {
  position: relative;
  padding-inline-start: 14px;
}

.panel-head h2::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--primary), rgba(45,108,223,0.30));
}

.table-wrap {
  background: linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(250,252,255,0.96) 100%);
}

.data-table tbody tr {
  transition: background 0.15s ease, transform 0.15s ease;
}

.data-table tbody tr:hover {
  transform: translateY(-1px);
}

.data-table tbody td:first-child {
  font-weight: 800;
  color: var(--heading);
}

.data-table tbody td .status-badge,
.data-table tbody td .btn-sm {
  vertical-align: middle;
}

.data-table tbody td[data-label="الإجراءات"] .table-actions {
  gap: 8px;
}

.table-wrap.compact-elevated,
.panel .table-wrap {
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.70);
}

.flash {
  box-shadow: var(--shadow-sm);
}

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

@media (max-width: 980px) {
  .main-content {
    max-width: none;
  }

  .dashboard-hero {
    gap: 14px;
  }

  .hero-summary-chips {
    margin-top: 12px;
  }

  .sidebar-nav a {
    min-height: 50px;
  }
}

@media (max-width: 720px) {
  .quick-links-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .quick-link-card {
    min-height: auto;
    padding: 16px;
  }

  .nav-icon {
    width: 32px;
    height: 32px;
    flex-basis: 32px;
    border-radius: 11px;
  }

  .hero-summary-chips {
    display: grid;
    grid-template-columns: 1fr;
  }

  .data-table tbody td:first-child {
    padding-top: 0;
  }

  .data-table tbody td .status-badge {
    width: fit-content;
  }
}

@media (max-width: 520px) {
  .page-kicker {
    width: fit-content;
  }

  .sidebar-nav a {
    padding: 10px 12px;
  }
}


/* Stage 12 | polish secondary utility pages */
.page-head.page-head-soft {
  padding: 22px 24px;
  margin-bottom: 18px;
  background: linear-gradient(135deg, rgba(45,108,223,0.08) 0%, rgba(255,255,255,0.98) 55%, rgba(255,255,255,0.94) 100%);
  border: 1px solid rgba(45,108,223,0.10);
  border-radius: 24px;
  box-shadow: var(--shadow-sm);
}

.page-head.page-head-soft p {
  max-width: 860px;
}

.hero-inline-note {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(45,108,223,0.10);
  color: var(--heading);
  font-size: 13px;
  font-weight: 800;
  box-shadow: var(--shadow-sm);
}

.secondary-mini-stats {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  margin-bottom: 18px;
}

.stat-card.stat-card-soft {
  padding: 16px 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
}

.stat-card.stat-card-soft strong {
  font-size: clamp(20px, 1.8vw, 26px);
}

.utility-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 18px;
  align-items: start;
  margin-bottom: 18px;
}

.utility-stack {
  display: grid;
  gap: 18px;
}

.side-card {
  padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
}

.side-card h3,
.feature-card h3,
.dataset-card h3 {
  margin: 0 0 8px;
  color: var(--heading);
  font-size: 18px;
}

.side-card p,
.feature-card p,
.dataset-card p,
.muted-note {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.9;
}

.feature-grid,
.dataset-grid,
.info-pill-grid {
  display: grid;
  gap: 14px;
}

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

.feature-card,
.dataset-card {
  padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
  transition: 0.18s ease;
}

.feature-card:hover,
.dataset-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: rgba(45,108,223,0.16);
}

.card-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(45,108,223,0.08);
  color: var(--primary-strong);
  font-size: 12px;
  font-weight: 900;
}

.card-kicker::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.8;
}

.card-action-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.info-pill-grid {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.info-pill {
  display: grid;
  gap: 5px;
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}

.info-pill span {
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 700;
}

.info-pill strong {
  color: var(--heading);
  font-size: 15px;
  font-weight: 900;
}

.dataset-card .card-action-row .btn,
.feature-card .card-action-row .btn {
  min-width: 128px;
}

.list-checks,
.info-list-plain {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.list-checks li,
.info-list-plain li {
  position: relative;
  padding-inline-start: 18px;
  color: var(--text-soft);
  line-height: 1.9;
}

.list-checks li::before,
.info-list-plain li::before {
  content: "•";
  position: absolute;
  inset-inline-start: 0;
  top: 0;
  color: var(--primary);
  font-weight: 900;
}

.timeline-list {
  display: grid;
  gap: 12px;
}

.timeline-item {
  position: relative;
  padding: 14px 16px 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  box-shadow: var(--shadow-sm);
}

.timeline-item::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  top: 14px;
  bottom: 14px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--primary), rgba(45,108,223,0.22));
}

.timeline-item strong {
  display: block;
  margin-bottom: 6px;
  padding-inline-start: 10px;
  color: var(--heading);
}

.timeline-item p,
.timeline-item small {
  display: block;
  margin: 0;
  padding-inline-start: 10px;
  color: var(--text-soft);
  line-height: 1.8;
}

.panel-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
  margin-bottom: 14px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(45,108,223,0.06) 0%, rgba(255,255,255,0.96) 100%);
  border: 1px solid rgba(45,108,223,0.10);
  color: var(--text-soft);
}

.panel-note strong {
  color: var(--heading);
}

.table-wrap.responsive-cards.utility-table .data-table tbody td:first-child {
  color: var(--primary-strong);
}

.status-badge.is-plain {
  background: #f4f7fb;
  color: var(--heading);
  border-color: rgba(16,35,63,0.08);
}

.export-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.export-chip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  background: #f4f8fe;
  border: 1px solid #e2ebf7;
  color: var(--heading);
  font-size: 12px;
  font-weight: 800;
}

.panel-subactions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

@media (max-width: 1100px) {
  .utility-grid,
  .feature-grid.two-col,
  .dataset-grid.two-col {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .page-head.page-head-soft {
    padding: 16px;
    border-radius: 20px;
  }

  .hero-inline-note {
    width: 100%;
    justify-content: center;
  }

  .card-action-row {
    flex-direction: column;
  }

  .dataset-card .card-action-row .btn,
  .feature-card .card-action-row .btn {
    min-width: 0;
    width: 100%;
  }
}

/* Stage 13 | reports, statements, receipts, and print polish */
.page-head-rich {
  align-items: stretch;
}

.page-head-aside,
.page-actions-stack-mobile {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: flex-end;
}

.hero-chip {
  min-width: 180px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(201, 214, 233, 0.95);
  box-shadow: var(--shadow-sm);
}

.hero-chip span,
.document-kicker,
.document-section-title,
.table-strong + small {
  color: var(--text-soft);
}

.hero-chip span,
.document-kicker {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 800;
}

.hero-chip strong {
  display: block;
  color: var(--heading);
  font-size: 15px;
  line-height: 1.8;
}

.report-filter-panel .panel-body,
.statement-filter-panel .panel-body {
  display: grid;
  gap: 18px;
}

.report-quick-meta,
.statement-meta-grid {
  margin: 0;
}

.meta-card.accent-primary,
.stat-primary {
  background: linear-gradient(180deg, rgba(234,242,255,0.9) 0%, rgba(255,255,255,0.98) 100%);
}

.meta-card.accent-success,
.stat-success {
  background: linear-gradient(180deg, rgba(232,247,239,0.95) 0%, rgba(255,255,255,0.98) 100%);
}

.meta-card.accent-warning,
.stat-warning {
  background: linear-gradient(180deg, rgba(255,245,230,0.96) 0%, rgba(255,255,255,0.98) 100%);
}

.stat-danger {
  background: linear-gradient(180deg, rgba(255,240,240,0.96) 0%, rgba(255,255,255,0.98) 100%);
}

.stat-card-accent {
  border-color: rgba(201, 214, 233, 0.95);
}

.panel-soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
}

.report-bucket-list {
  display: grid;
  gap: 12px;
}

.report-bucket-item {
  border-radius: 16px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.report-bucket-item strong,
.table-strong {
  color: var(--heading);
  font-weight: 900;
}

.report-bucket-item.tone-success {
  background: linear-gradient(180deg, rgba(232,247,239,0.96) 0%, rgba(255,255,255,0.98) 100%);
}

.report-bucket-item.tone-warning {
  background: linear-gradient(180deg, rgba(255,245,230,0.96) 0%, rgba(255,255,255,0.98) 100%);
}

.report-bucket-item.tone-danger {
  background: linear-gradient(180deg, rgba(255,240,240,0.96) 0%, rgba(255,255,255,0.98) 100%);
}

.report-tags-elevated {
  gap: 14px;
}

.report-outcome-tag {
  min-height: 118px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.statement-info-grid strong,
.statement-table td strong {
  line-height: 1.9;
}

.statement-opening-row {
  background: linear-gradient(180deg, rgba(234,242,255,0.55) 0%, rgba(255,255,255,0.98) 100%);
}

.statement-table-wrap .data-table tbody tr td:last-child {
  font-weight: 900;
}

.document-sheet {
  background:
    radial-gradient(circle at top left, rgba(45,108,223,0.05), transparent 24%),
    linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.document-brand {
  position: relative;
}

.document-header {
  align-items: flex-end;
}

.document-header h1 {
  margin-bottom: 8px;
}

.document-meta {
  min-width: 240px;
}

.document-summary-grid > div,
.document-mini-stats > div,
.document-section-card {
  background: linear-gradient(180deg, rgba(248,251,255,0.98) 0%, rgba(255,255,255,0.98) 100%);
  border: 1px solid #e5ecf6;
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
}

.document-section-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 18px;
}

.document-section-card {
  padding: 16px;
}

.document-section-title {
  display: block;
  margin-bottom: 12px;
  font-size: 13px;
  font-weight: 800;
}

.document-table-tight {
  min-width: 100%;
}

.document-table-tight th,
.document-table-tight td {
  padding: 12px 14px;
}

.receipt-amount-elevated {
  background: linear-gradient(180deg, rgba(234,242,255,0.95) 0%, rgba(255,255,255,0.98) 100%);
  border-color: rgba(45,108,223,0.22);
}

.receipt-amount-elevated small {
  display: block;
  margin-top: 8px;
  color: var(--text-soft);
}

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

.statement-table-card {
  padding: 16px;
}

.statement-print-table {
  min-width: 100%;
}

.statement-print-table tbody tr:nth-child(even) {
  background: rgba(248, 251, 255, 0.7);
}

@media (max-width: 980px) {
  .page-head-aside,
  .page-actions-stack-mobile {
    width: 100%;
    justify-content: flex-start;
  }

  .document-section-grid,
  .document-signatures {
    grid-template-columns: 1fr;
  }

  .hero-chip {
    min-width: 0;
    flex: 1 1 220px;
  }
}

@media (max-width: 720px) {
  .hero-chip,
  .page-actions-stack-mobile .btn,
  .page-head-aside {
    width: 100%;
  }

  .statement-page .table-wrap.responsive-cards .data-table tbody td,
  .reports-page .table-wrap.responsive-cards .data-table tbody td {
    grid-template-columns: minmax(90px, 108px) minmax(0, 1fr);
  }

  .document-meta {
    min-width: 0;
    width: 100%;
  }
}

@media (max-width: 640px) {
  .hero-chip,
  .document-section-card,
  .statement-table-card {
    padding: 14px;
  }

  .document-header,
  .document-brand,
  .document-signatures {
    gap: 14px;
  }

  .document-header h1,
  .print-header h1 {
    font-size: 25px;
  }

  .receipt-amount-box strong {
    font-size: 28px;
  }
}

@media print {
  .document-sheet,
  .statement-document-sheet,
  .receipt-sheet {
    background: #fff;
  }

  .document-section-card,
  .document-summary-grid > div,
  .document-mini-stats > div,
  .hero-chip {
    box-shadow: none;
  }
}

/* === Stage 14: detail pages polish === */
.customer-view-page,
.collector-workspace-page,
.collection-calendar-page,
.installments-page {
  --hero-gap: 18px;
}

.eyebrow-label {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--primary-strong);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.02em;
}

.dot-separator {
  padding: 0 8px;
  color: #9aaac0;
}

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

.remaining-amount {
  color: var(--heading);
}

.progress-line {
  width: 100%;
  height: 10px;
  background: #e8eef8;
  border-radius: 999px;
  overflow: hidden;
}

.progress-line.compact {
  height: 8px;
}

.progress-line span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--primary), var(--primary-strong));
}

.customer-hero {
  margin-bottom: 18px;
  border-color: rgba(45,108,223,0.14);
  background: linear-gradient(135deg, rgba(45,108,223,0.08), rgba(255,255,255,0.98));
}

.customer-hero-body,
.workspace-hero-body,
.calendar-summary-body,
.installments-overview-body {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: var(--hero-gap);
  align-items: stretch;
}

.customer-identity-card,
.workspace-context-card,
.calendar-insight-card,
.installments-progress-card {
  padding: 20px;
  border-radius: 20px;
  background: rgba(255,255,255,0.86);
  border: 1px solid rgba(201,214,233,0.95);
  box-shadow: var(--shadow-sm);
}

.customer-identity-card {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 16px;
}

.customer-avatar {
  width: 76px;
  height: 76px;
  border-radius: 22px;
  display: grid;
  place-items: center;
  font-size: 30px;
  font-weight: 900;
  color: var(--primary-strong);
  background: linear-gradient(180deg, #ffffff 0%, var(--primary-soft) 100%);
  border: 1px solid rgba(45,108,223,0.16);
}

.customer-identity-copy h2,
.workspace-context-card h2,
.calendar-insight-card strong,
.installments-progress-card strong {
  margin: 6px 0 8px;
  color: var(--heading);
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.3;
}

.customer-identity-copy p,
.workspace-context-card p,
.calendar-insight-card p,
.installments-progress-card p {
  margin: 0 0 14px;
  color: var(--text-soft);
  line-height: 1.85;
}

.customer-identity-meta,
.task-footer-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.customer-identity-meta div,
.task-footer-grid div {
  padding: 13px 14px;
  border-radius: 14px;
  background: #f8fbff;
  border: 1px solid var(--line);
}

.customer-identity-meta span,
.task-footer-grid span,
.installment-progress-cell small {
  display: block;
  margin-bottom: 5px;
  color: var(--text-soft);
  font-size: 12px;
}

.customer-identity-meta strong,
.task-footer-grid strong {
  color: var(--heading);
  font-size: 14px;
}

.customer-progress-card,
.installments-progress-card,
.calendar-insight-card,
.workspace-context-card {
  display: grid;
  gap: 12px;
  align-content: start;
}

.customer-summary-grid {
  margin-bottom: 18px;
}

.customer-details-grid {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.8fr);
  align-items: start;
}

.customer-info-list strong {
  word-break: break-word;
}

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

.quick-action-card {
  padding: 16px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  transition: .18s ease;
  display: grid;
  gap: 6px;
}

.quick-action-card:hover {
  transform: translateY(-2px);
  border-color: rgba(45,108,223,0.22);
  box-shadow: var(--shadow-sm);
}

.quick-action-card strong {
  color: var(--heading);
  font-size: 15px;
}

.quick-action-card span {
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.8;
}

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

.workspace-hero,
.installments-overview,
.calendar-summary-strip {
  margin-bottom: 18px;
}

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

.workspace-chip-row,
.calendar-legend-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.collector-layout {
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.75fr);
  align-items: start;
}

.collector-side-grid {
  display: grid;
  gap: 18px;
}

.task-card-enhanced {
  display: grid;
  gap: 14px;
}

.task-footer.task-footer-grid {
  display: grid;
}

.compact-empty {
  padding: 16px;
}

.compact-list .mini-item {
  padding: 13px 14px;
}

.calendar-legend-panel {
  margin-bottom: 18px;
}

.calendar-legend-row {
  justify-content: flex-start;
}

.calendar-cell.is-busy {
  border-color: rgba(45,108,223,0.2);
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.installment-progress-cell {
  display: grid;
  gap: 8px;
  min-width: 180px;
}

.installment-progress-cell strong {
  color: var(--heading);
  font-size: 14px;
  line-height: 1.7;
}

@media (max-width: 1200px) {
  .customer-hero-body,
  .workspace-hero-body,
  .calendar-summary-body,
  .installments-overview-body,
  .collector-layout,
  .customer-details-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .customer-identity-card {
    grid-template-columns: 1fr;
  }

  .customer-avatar {
    width: 62px;
    height: 62px;
    font-size: 24px;
  }

  .customer-identity-meta,
  .task-footer-grid,
  .quick-actions-grid,
  .two-cols-cards,
  .workspace-kpi-grid,
  .calendar-summary-grid {
    grid-template-columns: 1fr;
  }

  .calendar-toolbar {
    width: 100%;
    justify-content: space-between;
  }
}

@media (max-width: 640px) {
  .customer-hero-body,
  .workspace-hero-body,
  .calendar-summary-body,
  .installments-overview-body {
    gap: 14px;
  }

  .customer-identity-card,
  .workspace-context-card,
  .calendar-insight-card,
  .installments-progress-card {
    padding: 16px;
  }

  .page-actions {
    width: 100%;
  }

  .page-actions .btn,
  .calendar-toolbar .btn {
    flex: 1 1 calc(50% - 8px);
  }

  .calendar-toolbar strong {
    width: 100%;
    text-align: center;
    order: -1;
  }
}


/* === Stage 15: final cleanup for notes, periods, reminders, plan === */
.notes-page,
.financial-periods-page,
.reminder-page {
  --hero-gap: 18px;
}

.notes-hero-panel,
.periods-hero-panel,
.reminder-hero-panel,
.plan-overview-panel {
  margin-bottom: 18px;
  border-color: rgba(45,108,223,0.14);
  background: linear-gradient(135deg, rgba(45,108,223,0.08), rgba(255,255,255,0.98));
}

.notes-hero-body,
.periods-hero-body,
.reminder-hero-body {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  gap: var(--hero-gap);
  align-items: stretch;
}

.notes-hero-stats,
.periods-hero-stats,
.reminder-hero-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.notes-feed-list,
.periods-feed-list {
  gap: 14px;
}

.note-card-enhanced,
.period-card-enhanced {
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(201,214,233,0.95);
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
  box-shadow: var(--shadow-sm);
  display: grid;
  gap: 14px;
}

.note-created-meta,
.period-duration-badge {
  min-width: 120px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #f8fbff;
}

.note-created-meta span,
.period-duration-badge span,
.note-detail-grid span,
.period-detail-grid span {
  display: block;
  margin-bottom: 5px;
  color: var(--text-soft);
  font-size: 12px;
}

.note-created-meta strong,
.period-duration-badge strong,
.note-detail-grid strong,
.period-detail-grid strong {
  color: var(--heading);
  font-size: 14px;
  line-height: 1.8;
}

.note-detail-grid,
.period-detail-grid,
.plan-progress-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.note-detail-grid > div,
.period-detail-grid > div {
  padding: 13px 14px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #f8fbff;
}

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

.stacked-actions-mobile {
  align-items: stretch;
}

.plan-overview-copy,
.plan-progress-card {
  min-height: 100%;
}

.reminder-page-grid {
  align-items: start;
}

.reminder-preview-box {
  min-height: 220px;
  line-height: 2;
  white-space: pre-wrap;
}

.reminder-channel-form {
  gap: 12px;
}

.reminder-channel-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.reminder-channel-card strong {
  display: block;
  color: var(--heading);
  margin-bottom: 6px;
}

.reminder-channel-card p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.8;
}

.reminder-channel-card.is-disabled {
  opacity: .7;
  background: linear-gradient(180deg, #fafbfd 0%, #f4f6fa 100%);
}

@media (max-width: 1200px) {
  .notes-hero-body,
  .periods-hero-body,
  .reminder-hero-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .notes-hero-stats,
  .periods-hero-stats,
  .reminder-hero-stats,
  .note-detail-grid,
  .period-detail-grid,
  .plan-progress-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .note-card-enhanced,
  .period-card-enhanced,
  .reminder-channel-card {
    padding: 15px;
  }

  .reminder-channel-card {
    flex-direction: column;
    align-items: stretch;
  }

  .stacked-actions-mobile {
    grid-template-columns: 1fr;
  }
}


/* === Stage 16: final global polish and mobile consistency === */
body.admin-page {
  color-scheme: light;
}

.mobile-menu-toggle {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  border: 1px solid rgba(201,214,233,0.88);
  background: rgba(255,255,255,0.96);
  box-shadow: 0 14px 28px rgba(15,35,62,0.10);
  color: var(--heading);
}

.sidebar-section {
  display: grid;
  gap: 8px;
}

.sidebar-section + .sidebar-section {
  margin-top: 10px;
}

.sidebar-section-title {
  padding-inline: 4px;
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.2px;
}

.sidebar-section-links {
  display: grid;
  gap: 8px;
}

.sidebar-nav .logout-link {
  margin-top: 14px;
}

.section-block {
  display: grid;
  gap: 16px;
  margin-bottom: 22px;
}

.section-head-inline {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.section-head-inline h2 {
  margin: 6px 0 0;
  color: var(--heading);
  font-size: 22px;
}

.section-head-inline p {
  margin: 0;
  max-width: 620px;
  color: var(--text-soft);
  line-height: 1.9;
}

.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(45,108,223,0.08);
  color: var(--primary-strong);
  font-size: 12px;
  font-weight: 900;
}

.section-eyebrow::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
}

.auth-page.login-page {
  padding: 24px;
  background:
    radial-gradient(circle at top left, rgba(45,108,223,0.12), transparent 28%),
    linear-gradient(180deg, #f9fbff 0%, #eef3f9 100%);
}

.auth-shell {
  width: min(1120px, 100%);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: 22px;
  align-items: stretch;
}

.auth-showcase {
  padding: 30px;
  border-radius: 30px;
  background: linear-gradient(145deg, rgba(45,108,223,0.10) 0%, rgba(255,255,255,0.98) 58%, rgba(255,255,255,0.94) 100%);
  border: 1px solid rgba(45,108,223,0.10);
  box-shadow: var(--shadow-md);
  display: grid;
  align-content: center;
  gap: 18px;
}

.auth-showcase h1 {
  margin: 0;
  color: var(--heading);
  font-size: clamp(32px, 4vw, 46px);
  line-height: 1.2;
}

.auth-showcase p {
  margin: 0;
  color: var(--text-soft);
  line-height: 2;
  max-width: 720px;
}

.auth-showcase-badge {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(45,108,223,0.14);
  color: var(--primary-strong);
  font-size: 12px;
  font-weight: 900;
}

.auth-showcase-badge::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

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

.auth-glance-card {
  display: grid;
  gap: 6px;
  padding: 18px;
  border-radius: 20px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(201,214,233,0.88);
}

.auth-glance-card strong {
  color: var(--heading);
  font-size: 16px;
}

.auth-glance-card span {
  color: var(--text-soft);
  line-height: 1.8;
  font-size: 14px;
}

.auth-card.auth-card-enhanced {
  width: 100%;
  min-height: 100%;
  padding: 32px;
  border: 1px solid rgba(201,214,233,0.92);
  background: rgba(255,255,255,0.97);
}

.auth-card-enhanced .auth-brand h2 {
  margin: 0 0 8px;
  color: var(--heading);
  font-size: clamp(26px, 3vw, 34px);
}

.auth-card-enhanced .auth-brand p {
  margin: 0;
  line-height: 1.9;
}

.auth-card-enhanced .auth-form {
  margin-top: 22px;
}

.auth-card-enhanced .form-group input {
  min-height: 54px;
}

.auth-card-enhanced .auth-help {
  margin-top: 20px;
}

.page-login .mobile-menu-toggle,
.login-page .mobile-menu-toggle,
.login-page .mobile-overlay {
  display: none !important;
}

@media (max-width: 1100px) {
  .auth-shell {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .section-head-inline {
    align-items: stretch;
  }

  .auth-page.login-page {
    padding: 14px;
  }

  .auth-showcase,
  .auth-card.auth-card-enhanced {
    padding: 22px 18px;
    border-radius: 24px;
  }

  .auth-glance-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  .mobile-menu-toggle {
    inset-inline-start: 12px;
    inset-block-start: 12px;
  }

  .sidebar-section-title {
    font-size: 11px;
  }
}


.section-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 6px 0 2px;
  color: var(--heading);
  font-weight: 900;
}
.section-divider::before,
.section-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, rgba(45,108,223,0), rgba(45,108,223,0.22), rgba(45,108,223,0));
}
.section-divider span {
  padding: 0 10px;
  border-radius: 999px;
  background: var(--primary-soft);
  color: var(--primary-strong);
  min-height: 34px;
  display: inline-flex;
  align-items: center;
}
.form-page-grid-wide {
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
}
.installment-preview-card {
  padding: 18px 18px 16px;
  border-radius: 18px;
  border: 1px solid rgba(45,108,223,0.16);
  background: linear-gradient(180deg, #f8fbff 0%, #eef5ff 100%);
}
.preview-title {
  font-weight: 900;
  color: var(--heading);
  margin-bottom: 12px;
}
.preview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.preview-grid div {
  border-radius: 16px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(45,108,223,0.12);
}
.preview-grid span {
  display: block;
  font-size: 12px;
  color: var(--text-soft);
  margin-bottom: 6px;
}
.preview-grid strong {
  color: var(--heading);
  font-size: 18px;
}
.stacked-date {
  display: grid;
  gap: 3px;
}
.stacked-date small {
  color: var(--text-soft);
}
.unified-form-panel .panel-head h2 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.unified-form-panel .panel-head h2::before {
  content: "◎";
  color: var(--primary);
  font-size: 16px;
}
@media (max-width: 980px) {
  .form-page-grid-wide {
    grid-template-columns: 1fr;
  }
  .preview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .preview-grid {
    grid-template-columns: 1fr;
  }
  .section-divider span {
    font-size: 13px;
  }
}


.installment-debt-stack {
  display: grid;
  gap: 16px;
}
.debt-installment-card {
  border: 1px solid rgba(37,99,235,0.12);
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  padding: 16px;
}
.debt-installment-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.debt-installment-head h3 {
  margin: 0 0 6px;
  font-size: 18px;
  color: var(--heading);
}
.debt-installment-head p {
  margin: 0;
  color: var(--text-soft);
}
.debt-installment-head-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.installment-list {
  display: grid;
  gap: 12px;
}
.installment-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: 18px;
  background: #fff;
  padding: 14px 16px;
}
.installment-item.installment-paid {
  border-color: rgba(22,163,74,0.16);
  background: #f3fcf6;
}
.installment-item.installment-overdue {
  border-color: rgba(220,38,38,0.16);
  background: #fff7f7;
}
.installment-main,
.installment-meta {
  display: grid;
  gap: 4px;
}
.installment-main strong {
  color: var(--heading);
  font-size: 16px;
}
.installment-main span,
.installment-meta span {
  color: var(--text-soft);
}
.installment-action {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.is-readonly input[readonly] {
  background: #f8fafc;
  color: var(--text-soft);
}
@media (max-width: 820px) {
  .debt-installment-head {
    flex-direction: column;
  }
  .installment-item {
    grid-template-columns: 1fr;
  }
  .installment-action {
    justify-content: stretch;
  }
  .installment-action form,
  .installment-action .btn {
    width: 100%;
  }
}


/* Quick payments */
.panel-link,
.panel-meta {
  color: var(--text-soft);
  font-size: 13px;
}
.panel-link:hover {
  color: var(--primary);
}
.dashboard-focus-panel,
.dashboard-queue-panel,
.quick-pay-strip,
.quick-pay-list-panel,
.quick-pay-filters-panel {
  margin-bottom: 18px;
}
.dashboard-focus-body {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) auto auto;
  gap: 18px;
  align-items: center;
}
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 800;
  color: var(--primary);
  background: rgba(37,99,235,0.08);
  border: 1px solid rgba(37,99,235,0.12);
  border-radius: 999px;
  padding: 6px 10px;
  margin-bottom: 10px;
}
.focus-copy h2 {
  margin: 0 0 8px;
  color: var(--heading);
  font-size: 24px;
}
.focus-copy p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.9;
}
.focus-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(130px, 1fr));
  gap: 12px;
}
.focus-metric {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,0.08);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  display: grid;
  gap: 6px;
}
.focus-metric span {
  color: var(--text-soft);
  font-size: 13px;
}
.focus-metric strong {
  color: var(--heading);
  font-size: 18px;
}
.queue-card-list {
  display: grid;
  gap: 12px;
}
.queue-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: 18px;
  padding: 14px 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}
.queue-card-title {
  display: grid;
  gap: 4px;
}
.queue-card-title strong {
  color: var(--heading);
}
.queue-card-title span,
.queue-card-meta span {
  color: var(--text-soft);
  font-size: 13px;
}
.queue-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 6px;
}
.queue-card-side {
  display: grid;
  gap: 10px;
  justify-items: end;
}

.segmented-block {
  display: grid;
  gap: 10px;
}
.segmented-block-label {
  color: var(--text-soft);
  font-size: 13px;
  font-weight: 800;
}
.panel-head-rich {
  align-items: start;
  gap: 12px;
}
.panel-subtitle {
  margin: 4px 0 0;
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.8;
}
.quick-inline-note {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  border: 1px solid rgba(15,23,42,0.08);
  background: #fff;
  color: var(--text-soft);
}
.quick-inline-note.is-primary,
.quick-group-pill.is-primary {
  color: var(--primary);
  background: rgba(37,99,235,0.08);
  border-color: rgba(37,99,235,0.18);
}
.quick-inline-note.is-danger,
.quick-group-pill.is-danger {
  color: #b91c1c;
  background: rgba(239,68,68,0.08);
  border-color: rgba(239,68,68,0.18);
}
.quick-inline-note.is-soft,
.quick-group-pill.is-soft {
  color: var(--text-soft);
  background: #fff;
  border-color: rgba(15,23,42,0.08);
}
.quick-pay-groups {
  display: grid;
  gap: 16px;
}
.quick-pay-group {
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: 24px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  overflow: hidden;
}
.quick-pay-group.is-danger {
  border-color: rgba(220,38,38,0.18);
  background: linear-gradient(180deg, #fff8f8 0%, #ffffff 100%);
}
.quick-pay-group.is-primary {
  border-color: rgba(37,99,235,0.16);
  background: linear-gradient(180deg, #f4f9ff 0%, #ffffff 100%);
}
.quick-pay-group-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 18px 18px 14px;
  border-bottom: 1px solid rgba(15,23,42,0.06);
}
.quick-pay-group-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}
.quick-pay-group-title-row h3 {
  margin: 0;
  color: var(--heading);
  font-size: 20px;
}
.quick-pay-group-head p {
  margin: 0;
  color: var(--text-soft);
}
.quick-pay-group-stats {
  display: grid;
  gap: 8px;
  justify-items: end;
}
.quick-pay-group-stats strong {
  color: var(--heading);
  font-size: 22px;
}
.quick-pay-group-stats span {
  color: var(--text-soft);
  font-size: 12px;
}
.quick-group-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,0.08);
  font-size: 12px;
  font-weight: 800;
}
.quick-pay-mini-list {
  display: grid;
  gap: 12px;
  padding: 16px 18px 18px;
}
.quick-pay-mini-card {
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: 18px;
  background: #fff;
  padding: 14px 16px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}
.quick-pay-mini-card.is-overdue {
  border-color: rgba(220,38,38,0.16);
  background: linear-gradient(180deg, #fffafa 0%, #ffffff 100%);
}
.quick-pay-mini-card.is-due {
  border-color: rgba(37,99,235,0.12);
}
.quick-pay-mini-main {
  display: grid;
  gap: 8px;
}
.quick-pay-mini-top {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.quick-pay-mini-top strong {
  color: var(--heading);
  font-size: 16px;
}
.quick-pay-mini-main p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.8;
}
.quick-pay-mini-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
}
.quick-pay-mini-meta span {
  color: var(--text-soft);
  font-size: 13px;
}
.quick-pay-mini-meta strong {
  color: var(--heading);
}
.quick-pay-mini-actions {
  display: grid;
  gap: 8px;
  justify-items: end;
}
.quick-pay-mini-actions form,
.quick-pay-mini-actions .btn {
  width: 100%;
}
.quick-pay-head {
  align-items: center;
}
.quick-pay-strip-body {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.quick-pay-focus-card {
  border-radius: 20px;
  border: 1px solid rgba(15,23,42,0.08);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  padding: 16px;
  display: grid;
  gap: 8px;
}
.quick-pay-focus-card span {
  color: var(--text-soft);
  font-size: 13px;
}
.quick-pay-focus-card strong {
  color: var(--heading);
  font-size: 21px;
}
.quick-pay-focus-card small {
  color: var(--text-soft);
  font-size: 13px;
}
.quick-pay-focus-card.is-primary {
  border-color: rgba(37,99,235,0.18);
  background: linear-gradient(180deg, #eff6ff 0%, #ffffff 100%);
}
.quick-pay-focus-card.is-danger {
  border-color: rgba(220,38,38,0.18);
  background: linear-gradient(180deg, #fff3f3 0%, #ffffff 100%);
}
.quick-pay-filters-body {
  display: grid;
  gap: 14px;
}
.segmented-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.segmented-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text-soft);
  font-weight: 700;
  font-size: 13px;
  transition: .18s ease;
}
.segmented-tab.active,
.segmented-tab:hover {
  color: var(--primary);
  border-color: rgba(37,99,235,0.24);
  background: rgba(37,99,235,0.07);
}
.quick-pay-search-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}
.compact-search-field {
  margin-bottom: 0;
}
.quick-pay-list {
  display: grid;
  gap: 14px;
}
.quick-pay-card {
  border: 1px solid rgba(15,23,42,0.08);
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  padding: 18px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
}
.quick-pay-card.is-overdue {
  border-color: rgba(220,38,38,0.18);
  background: linear-gradient(180deg, #fff7f7 0%, #ffffff 100%);
}
.quick-pay-card.is-due {
  border-color: rgba(37,99,235,0.14);
}
.quick-pay-card-main {
  display: grid;
  gap: 12px;
}
.quick-pay-card-topline {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}
.quick-pay-title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.quick-pay-title-row strong {
  color: var(--heading);
  font-size: 18px;
}
.quick-pay-card-topline p {
  margin: 0;
  color: var(--text-soft);
}
.quick-pay-amount {
  color: var(--heading);
  font-size: 22px;
  font-weight: 900;
  white-space: nowrap;
}
.quick-pay-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.quick-pay-meta-grid div {
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,0.06);
  background: #fff;
  padding: 12px 14px;
  display: grid;
  gap: 6px;
}
.quick-pay-meta-grid span {
  color: var(--text-soft);
  font-size: 12px;
}
.quick-pay-meta-grid strong {
  color: var(--heading);
  font-size: 14px;
}
.quick-pay-card-actions {
  display: grid;
  gap: 10px;
  justify-items: end;
}
.quick-pay-card-actions form,
.quick-pay-card-actions .btn {
  width: 100%;
}
@media (max-width: 1080px) {
  .dashboard-focus-body,
  .quick-pay-card,
  .quick-pay-card-topline,
  .queue-card,
  .quick-pay-group-head,
  .quick-pay-mini-card {
    grid-template-columns: 1fr;
  }
  .focus-actions,
  .queue-card-side,
  .quick-pay-card-actions,
  .quick-pay-group-stats,
  .quick-pay-mini-actions {
    justify-items: stretch;
  }
  .quick-pay-strip-body,
  .quick-pay-meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 780px) {
  .quick-pay-search-form {
    grid-template-columns: 1fr;
  }
  .focus-metrics,
  .quick-pay-strip-body,
  .quick-pay-meta-grid {
    grid-template-columns: 1fr;
  }
  .segmented-tabs {
    overflow: auto;
    flex-wrap: nowrap;
    padding-bottom: 4px;
  }
  .segmented-tab {
    white-space: nowrap;
  }
  .quick-pay-group-head,
  .quick-pay-mini-card {
    grid-template-columns: 1fr;
  }
  .quick-pay-group-stats,
  .quick-pay-mini-actions {
    justify-items: stretch;
  }
  .quick-pay-group-title-row {
    align-items: start;
  }
  .quick-pay-mini-meta {
    display: grid;
    gap: 6px;
  }
}


.customer-status-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.status-chip-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,250,255,0.98) 100%);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px 18px;
  box-shadow: var(--shadow-sm);
  display: grid;
  gap: 8px;
}

.status-chip-card.is-danger {
  border-color: rgba(194,65,65,0.18);
  background: linear-gradient(180deg, #fffefe 0%, #fff5f5 100%);
}

.status-chip-card.is-success {
  border-color: rgba(25,135,84,0.18);
  background: linear-gradient(180deg, #ffffff 0%, #effaf4 100%);
}

.status-chip-card.is-primary {
  border-color: rgba(37,99,235,0.18);
  background: linear-gradient(180deg, #ffffff 0%, #eff6ff 100%);
}

.status-chip-card.is-neutral {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.status-chip-label {
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 800;
}

.status-chip-card strong {
  color: var(--heading);
  font-size: 18px;
  line-height: 1.5;
}

.status-chip-card p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.8;
}

.customer-focus-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.focus-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(247,250,255,0.96) 100%);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 18px;
  box-shadow: var(--shadow-sm);
  display: grid;
  gap: 10px;
}

.focus-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.focus-card-kicker {
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 800;
}

.focus-card strong {
  font-size: 20px;
  color: var(--heading);
  line-height: 1.5;
}

.focus-card p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.9;
}

.focus-card-alert.focus-alert {
  border-color: rgba(194,65,65,0.16);
  background: linear-gradient(180deg, #fffefe 0%, #fff4f4 100%);
}

.focus-card-alert.focus-calm {
  border-color: rgba(25,135,84,0.16);
  background: linear-gradient(180deg, #ffffff 0%, #effaf4 100%);
}

.focus-card-progress {
  background: linear-gradient(180deg, #ffffff 0%, #f1f7ff 100%);
}

.focus-card-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.mini-progress {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  background: #e7eef8;
}

.mini-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--primary) 0%, var(--primary-strong) 100%);
}

.urgent-work-panel .panel-body {
  padding-top: 6px;
}

.urgent-list {
  display: grid;
  gap: 12px;
}

.urgent-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.urgent-item strong {
  color: var(--heading);
  display: block;
  margin-bottom: 4px;
}

.urgent-item p {
  margin: 0;
  color: var(--text-soft);
}

@media (max-width: 1100px) {
  .customer-status-strip {
    grid-template-columns: 1fr;
  }

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

@media (max-width: 720px) {
  .customer-status-strip {
    grid-template-columns: 1fr;
  }

  .customer-focus-strip {
    grid-template-columns: 1fr;
  }

  .focus-card {
    padding: 16px;
  }

  .focus-card strong {
    font-size: 18px;
  }

  .urgent-item {
    flex-direction: column;
    align-items: stretch;
  }

  .urgent-item .btn,
  .focus-card-actions .btn {
    width: 100%;
  }
}


/* Stage | dashboard direct entries and customer overdue focus */
.dashboard-priority-panel,
.dashboard-list-panel,
.quick-pay-context-panel {
  margin-bottom: 18px;
}
.dashboard-priority-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.priority-entry-card {
  border-radius: 24px;
  border: 1px solid rgba(15,23,42,0.08);
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
  padding: 20px;
  display: grid;
  gap: 16px;
}
.priority-entry-card.is-primary {
  border-color: rgba(37,99,235,0.18);
  background: linear-gradient(180deg, #eef5ff 0%, #ffffff 100%);
}
.priority-entry-card.is-danger {
  border-color: rgba(220,38,38,0.18);
  background: linear-gradient(180deg, #fff5f5 0%, #ffffff 100%);
}
.section-kicker.is-danger {
  color: #b91c1c;
  background: rgba(239,68,68,0.08);
  border-color: rgba(239,68,68,0.16);
}
.priority-entry-copy h2 {
  margin: 0 0 8px;
  color: var(--heading);
  font-size: 26px;
}
.priority-entry-copy p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.9;
}
.priority-entry-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.priority-entry-stats div {
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,0.06);
  background: rgba(255,255,255,0.8);
  padding: 14px 16px;
  display: grid;
  gap: 6px;
}
.priority-entry-stats span {
  color: var(--text-soft);
  font-size: 13px;
}
.priority-entry-stats strong {
  color: var(--heading);
  font-size: 19px;
}
.priority-entry-actions {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 10px;
}
.dashboard-alert-grid {
  margin-bottom: 18px;
}
.dashboard-customer-card.is-primary {
  border-color: rgba(37,99,235,0.14);
  background: linear-gradient(180deg, #f6faff 0%, #ffffff 100%);
}
.dashboard-customer-card.is-danger {
  border-color: rgba(220,38,38,0.16);
  background: linear-gradient(180deg, #fff8f8 0%, #ffffff 100%);
}
.dashboard-customer-card .queue-card-meta strong {
  color: var(--heading);
}
.quick-pay-context-body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.quick-pay-context-body p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.8;
  flex: 1 1 280px;
}
@media (max-width: 1080px) {
  .dashboard-priority-grid,
  .priority-entry-stats {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 780px) {
  .priority-entry-card {
    padding: 16px;
  }
  .priority-entry-copy h2 {
    font-size: 22px;
  }
  .quick-pay-context-body,
  .priority-entry-actions {
    align-items: stretch;
  }
  .quick-pay-context-body .btn,
  .priority-entry-actions .btn {
    width: 100%;
  }
}


/* Stage | dashboard live strip for latest paid and overdue snapshot */
.dashboard-live-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.live-strip-card {
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,0.08);
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.live-strip-card.is-success {
  border-color: rgba(22,163,74,0.18);
  background: linear-gradient(180deg, #f3fff8 0%, #ffffff 100%);
}
.live-strip-card.is-warning {
  border-color: rgba(245,158,11,0.2);
  background: linear-gradient(180deg, #fff9ed 0%, #ffffff 100%);
}
.live-strip-copy {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.live-strip-copy h2 {
  margin: 0;
  font-size: 22px;
  color: var(--heading);
}
.live-strip-copy p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.9;
}
.live-strip-side {
  display: grid;
  gap: 10px;
  justify-items: flex-end;
  text-align: left;
  min-width: 200px;
}
.live-strip-meta {
  color: var(--text-soft);
  font-size: 13px;
}
.live-strip-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}
.section-kicker.is-success {
  color: #15803d;
  background: rgba(34,197,94,0.1);
  border-color: rgba(34,197,94,0.16);
}
.section-kicker.is-warning {
  color: #b45309;
  background: rgba(245,158,11,0.12);
  border-color: rgba(245,158,11,0.18);
}
@media (max-width: 1080px) {
  .dashboard-live-strip {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 780px) {
  .live-strip-card {
    padding: 16px;
    flex-direction: column;
    align-items: stretch;
  }
  .live-strip-copy h2 {
    font-size: 20px;
  }
  .live-strip-side,
  .live-strip-actions {
    justify-items: stretch;
    justify-content: stretch;
    text-align: right;
    min-width: 0;
  }
  .live-strip-actions .btn {
    width: 100%;
  }
}


.color-field-wrap {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.color-input {
  width: 64px;
  min-width: 64px;
  height: 52px;
  padding: 4px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #ffffff;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
}

.color-input::-webkit-color-swatch-wrapper {
  padding: 0;
}

.color-input::-webkit-color-swatch,
.color-input::-moz-color-swatch {
  border: none;
  border-radius: 10px;
}

.color-presets-block {
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px dashed rgba(45,108,223,0.16);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,249,255,0.98));
}

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

.color-presets-head strong {
  font-size: 14px;
  color: var(--heading);
}

.color-current-value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 96px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(45,108,223,0.14);
  background: #ffffff;
  color: var(--primary-strong);
  font-weight: 800;
  font-size: 13px;
  direction: ltr;
}

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

.color-preset-chip {
  width: 46px;
  height: 46px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  border: 2px solid rgba(16,35,63,0.10);
  background: #ffffff;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.color-preset-dot {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: var(--swatch);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.65);
}

.color-preset-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(45,108,223,0.35);
}

.color-preset-chip.is-active {
  border-color: var(--primary-strong);
  background: rgba(45,108,223,0.06);
  box-shadow: 0 0 0 3px rgba(45,108,223,0.10), var(--shadow-sm);
}

.field-hint {
  display: block;
  margin-top: 10px;
  color: var(--text-soft);
  font-size: 12px;
  line-height: 1.8;
}

.settings-actions-stack {
  gap: 10px;
}

.btn-outline-danger {
  background: #fff8f8;
  color: var(--danger);
  border: 1px solid rgba(194,65,65,0.16);
}

.btn-outline-danger:hover {
  background: #fff1f1;
  border-color: rgba(194,65,65,0.28);
}

@media (max-width: 720px) {
  .color-field-wrap {
    grid-template-columns: 1fr;
  }

  .color-input {
    width: 100%;
    min-width: 0;
  }

  .color-presets-block {
    padding: 12px;
  }

  .color-presets-head {
    flex-direction: column;
    align-items: stretch;
  }

  .color-current-value {
    width: 100%;
    min-width: 0;
  }

  .settings-actions-stack .btn {
    width: 100%;
  }
}

/* Mobile dashboard hardening | 2026-03-30 */
html, body {
  overflow-x: clip;
}

.admin-shell,
.main-content,
.dashboard-main,
.dashboard-live-strip,
.dashboard-priority-grid,
.dashboard-alert-grid,
.queue-card-list,
.page-head,
.panel,
.priority-entry-card,
.live-strip-card {
  min-width: 0;
}

.dashboard-page-head,
.priority-entry-card,
.live-strip-card,
.stat-card,
.panel {
  overflow: hidden;
}

.live-strip-card.is-empty {
  padding-block: 14px;
}

.live-strip-card.is-empty .live-strip-copy {
  gap: 6px;
}

.live-strip-card.is-empty .live-strip-copy h2 {
  font-size: 18px;
}

.live-strip-card.is-empty .live-strip-copy p,
.live-strip-card.is-empty .live-strip-meta {
  font-size: 13px;
  line-height: 1.7;
}

.priority-entry-card.is-empty {
  gap: 12px;
}

.priority-entry-stats.is-single {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.priority-entry-card.is-empty .priority-entry-copy h2 {
  font-size: 22px;
}

.priority-entry-card.is-empty .priority-entry-copy p {
  max-width: 52ch;
}

@media (max-width: 980px) {
  body:not(.auth-page):not(.print-page) {
    padding-top: calc(86px + env(safe-area-inset-top, 0px));
  }

  .mobile-menu-toggle {
    top: calc(12px + env(safe-area-inset-top, 0px));
    right: 12px;
    width: 46px;
    height: 46px;
    border-radius: 15px;
  }

  .dashboard-main {
    padding-top: 14px;
  }

  .dashboard-page-head {
    padding-top: 20px;
  }
}

@media (max-width: 720px) {
  .dashboard-main {
    padding-inline: 14px;
    padding-bottom: 20px;
  }

  .dashboard-page-head {
    gap: 14px;
    padding: 16px;
    border-radius: 20px;
  }

  .dashboard-page-head h1 {
    font-size: 28px;
    line-height: 1.15;
    margin-bottom: 8px;
  }

  .dashboard-page-head p {
    font-size: 15px;
    line-height: 1.8;
    max-width: none;
  }

  .page-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
    gap: 10px;
  }

  .dashboard-live-strip {
    gap: 10px;
  }

  .live-strip-card,
  .priority-entry-card,
  .panel {
    border-radius: 18px;
  }

  .live-strip-card {
    padding: 14px;
    gap: 10px;
  }

  .live-strip-copy h2,
  .priority-entry-copy h2 {
    font-size: 18px;
    line-height: 1.35;
  }

  .live-strip-copy p,
  .priority-entry-copy p,
  .panel-subtitle {
    font-size: 14px;
    line-height: 1.8;
  }

  .live-strip-side {
    gap: 6px;
  }

  .live-strip-card.is-empty .live-strip-side {
    display: none;
  }

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

  .stats-grid.dashboard-stats .stat-card {
    padding: 14px;
    border-radius: 18px;
    min-height: auto;
  }

  .stats-grid.dashboard-stats .stat-card .label {
    font-size: 13px;
  }

  .stats-grid.dashboard-stats .stat-card strong {
    font-size: 18px;
    line-height: 1.35;
  }

  .priority-entry-card {
    padding: 14px;
    gap: 12px;
  }

  .priority-entry-stats,
  .priority-entry-stats.is-single {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .priority-entry-stats div {
    padding: 12px 14px;
    border-radius: 14px;
  }

  .priority-entry-stats strong {
    font-size: 17px;
  }

  .priority-entry-card.is-empty .priority-entry-copy p {
    max-width: none;
  }

  .panel-head.panel-head-rich {
    gap: 10px;
  }

  .queue-card,
  .dashboard-customer-card {
    padding: 12px;
    border-radius: 16px;
  }

  .queue-card-title strong {
    font-size: 16px;
  }

  .queue-card-title span,
  .queue-card-meta {
    font-size: 13px;
    line-height: 1.7;
  }
}

@media (max-width: 520px) {
  body:not(.auth-page):not(.print-page) {
    padding-top: calc(92px + env(safe-area-inset-top, 0px));
  }

  .dashboard-main {
    padding-inline: 12px;
  }

  .dashboard-page-head {
    margin-top: 2px;
    padding: 14px;
  }

  .dashboard-page-head h1 {
    font-size: 25px;
  }

  .dashboard-page-head p {
    font-size: 14px;
  }

  .stats-grid.dashboard-stats,
  .priority-entry-stats,
  .priority-entry-stats.is-single {
    grid-template-columns: 1fr;
  }

  .live-strip-card,
  .priority-entry-card,
  .panel,
  .stats-grid.dashboard-stats .stat-card {
    border-radius: 16px;
  }

  .live-strip-copy h2,
  .priority-entry-copy h2 {
    font-size: 17px;
  }

  .live-strip-copy p,
  .priority-entry-copy p,
  .panel-subtitle,
  .queue-card-meta,
  .queue-card-title span {
    font-size: 13px;
    line-height: 1.7;
  }

  .panel-head,
  .panel-body {
    padding: 14px;
  }

  .page-actions .btn,
  .priority-entry-actions .btn,
  .queue-card-side .btn,
  .live-strip-actions .btn {
    width: 100%;
  }
}


.status-warning {
  background: var(--warning-soft);
  color: var(--warning);
  border-color: rgba(183,121,31,0.15);
}

.status-muted {
  background: #f2f5f9;
  color: #617188;
  border-color: rgba(97,113,136,0.14);
}

.installment-item.installment-partial,
.installment-item.installment-partial_overdue {
  border-color: rgba(183,121,31,0.16);
  background: linear-gradient(180deg, #fffaf0 0%, #fffdf7 100%);
}

.payment-preview-card {
  border: 1px dashed rgba(37, 99, 235, 0.18);
  border-radius: 22px;
  padding: 18px;
  background: linear-gradient(180deg, #f7fbff 0%, #ffffff 100%);
}

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

.payment-preview-grid > div {
  border: 1px solid rgba(15, 23, 42, 0.06);
  border-radius: 16px;
  padding: 14px;
  background: #fff;
}

.payment-preview-grid span {
  display: block;
  font-size: 13px;
  color: #6b7a90;
  margin-bottom: 8px;
}

.payment-preview-grid strong {
  display: block;
  font-size: 24px;
  font-weight: 800;
  color: var(--ink-900);
}

.payment-preview-note {
  margin: 12px 0 0;
  color: #6b7a90;
  line-height: 1.8;
  font-size: 14px;
}

.payment-meta-grid .meta-card strong {
  font-size: 22px;
}

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

@media (max-width: 520px) {
  .payment-preview-grid {
    grid-template-columns: 1fr;
  }
}


/* Dashboard direct flexible payment */
.priority-entry-actions .btn-secondary {
  border-color: rgba(37,99,235,0.14);
  background: #ffffff;
}

.payment-picker-grid .helper-list {
  margin: 0;
}

@media (max-width: 720px) {
  .payment-picker-grid .form-actions .btn {
    width: 100%;
  }
}


.inline-payment-box {
  display: block;
  width: 100%;
}
.inline-payment-box summary {
  list-style: none;
}
.inline-payment-box summary::-webkit-details-marker {
  display: none;
}
.inline-payment-box[open] summary {
  margin-bottom: .55rem;
}
.inline-payment-form {
  display: flex;
  flex-direction: column;
  gap: .6rem;
  padding: .75rem;
  border: 1px solid rgba(37, 99, 235, .14);
  border-radius: 14px;
  background: #f8fbff;
}
.inline-payment-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: .65rem;
  align-items: end;
}
.inline-payment-grid label {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  margin: 0;
}
.inline-payment-grid label span {
  font-size: .8rem;
  color: #64748b;
  font-weight: 700;
}
.inline-payment-grid input {
  width: 100%;
}
.inline-payment-preview {
  display: grid;
  gap: .6rem;
  padding-top: .15rem;
}
.inline-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .55rem;
}
.inline-preview-grid > div {
  padding: .72rem .78rem;
  border: 1px solid rgba(15, 23, 42, .06);
  border-radius: 12px;
  background: #ffffff;
}
.inline-preview-grid span {
  display: block;
  font-size: .76rem;
  color: #64748b;
  margin-bottom: .28rem;
  font-weight: 700;
}
.inline-preview-grid strong {
  display: block;
  font-size: .95rem;
  color: #0f172a;
  line-height: 1.5;
}
.inline-preview-state {
  color: #0f172a;
}
.inline-preview-state.is-success {
  color: #15803d;
}
.inline-payment-help {
  margin: 0;
  font-size: .8rem;
  color: #64748b;
  line-height: 1.7;
}
.quick-pay-card-actions .inline-payment-box,
.quick-pay-mini-actions .inline-payment-box,
.queue-card-side .inline-payment-box,
.installment-action-stack .inline-payment-box {
  width: 100%;
}
.quick-pay-card-actions,
.quick-pay-mini-actions,
.queue-card-side,
.installment-action-stack {
  align-items: stretch;
}
@media (max-width: 767px) {
  .inline-payment-grid {
    grid-template-columns: 1fr;
  }
  .inline-preview-grid {
    grid-template-columns: 1fr;
  }
  .inline-payment-box {
    width: 100%;
  }
}


/* Compact installment actions */
.installment-action-stack,
.quick-pay-card-actions,
.quick-pay-mini-actions,
.queue-card-side {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.installment-action-stack form,
.quick-pay-card-actions form,
.quick-pay-mini-actions form,
.queue-card-side form {
  margin: 0;
  width: auto;
}

.installment-action-stack .btn,
.quick-pay-card-actions .btn,
.quick-pay-mini-actions .btn,
.queue-card-side .btn {
  width: auto;
}

.installment-action-stack .btn-secondary,
.quick-pay-card-actions .btn-secondary,
.quick-pay-mini-actions .btn-secondary,
.queue-card-side .btn-secondary {
  background: #fff;
}

.installment-action-stack > .inline-payment-box,
.quick-pay-card-actions > .inline-payment-box,
.quick-pay-mini-actions > .inline-payment-box,
.queue-card-side > .inline-payment-box {
  width: auto;
  flex: 0 0 auto;
}

.installment-action-stack > .inline-payment-box[open],
.quick-pay-card-actions > .inline-payment-box[open],
.quick-pay-mini-actions > .inline-payment-box[open],
.queue-card-side > .inline-payment-box[open] {
  width: 100%;
  flex-basis: 100%;
}

.inline-payment-box summary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: #fff;
  color: var(--heading);
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  white-space: nowrap;
}

.inline-payment-box summary:hover {
  background: var(--surface-soft);
}

.inline-payment-box[open] summary {
  margin-bottom: .7rem;
}

.inline-payment-form {
  width: 100%;
}

.installment-action-stack .btn-success[disabled] {
  width: auto;
  min-width: 130px;
  opacity: .8;
}

.inline-payment-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
}

.inline-payment-grid button {
  min-width: 120px;
}

.partial-followup-note {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

@media (max-width: 767px) {
  .installment-action-stack,
  .quick-pay-card-actions,
  .quick-pay-mini-actions,
  .queue-card-side {
    justify-content: stretch;
  }

  .installment-action-stack form,
  .quick-pay-card-actions form,
  .quick-pay-mini-actions form,
  .queue-card-side form,
  .installment-action-stack > .inline-payment-box,
  .quick-pay-card-actions > .inline-payment-box,
  .quick-pay-mini-actions > .inline-payment-box,
  .queue-card-side > .inline-payment-box {
    width: 100%;
    flex-basis: 100%;
  }

  .installment-action-stack .btn,
  .quick-pay-card-actions .btn,
  .quick-pay-mini-actions .btn,
  .queue-card-side .btn,
  .inline-payment-box summary {
    width: 100%;
  }
}


/* backups */
.inline-head-form{display:inline-flex;margin:0}
.backup-hero-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:18px}
.backup-hero-card,.backup-file-card{background:#fff;border:1px solid rgba(37,99,235,.14);border-radius:28px;padding:24px;box-shadow:0 18px 45px rgba(15,23,42,.06)}
.backup-hero-card h2{margin:10px 0 10px;font-size:1.6rem}
.backup-hero-card p{margin:0 0 14px;color:#64748b;line-height:1.9}
.backup-hero-card.is-create{background:linear-gradient(180deg,rgba(239,246,255,.86),#fff)}
.backup-hero-card.is-restore{background:linear-gradient(180deg,rgba(255,247,237,.75),#fff)}
.backup-meta-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:16px 0}
.backup-meta-list>div,.backup-file-meta>div{border:1px solid rgba(148,163,184,.2);border-radius:18px;padding:14px 16px;background:#fff}
.backup-meta-list span,.backup-file-meta span{display:block;color:#64748b;font-size:.92rem;margin-bottom:6px}
.backup-note-box{border:1px dashed rgba(245,158,11,.36);background:#fff7ed;border-radius:18px;padding:14px 16px;color:#92400e;margin:14px 0}
.restore-upload-form{margin-top:12px}
.panel-subtle{border:1px solid rgba(148,163,184,.18);background:rgba(255,255,255,.7);border-radius:22px;padding:16px}
.backup-cards-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.backup-file-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}
.backup-file-head strong{display:block;font-size:1rem;line-height:1.8;word-break:break-word}
.backup-file-head span{display:block;color:#64748b;margin-top:4px;font-size:.92rem}
.backup-pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:#eff6ff;color:var(--primary);font-weight:800;white-space:nowrap}
.backup-file-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px}
.backup-card-actions{display:flex;flex-wrap:wrap;gap:10px}
.mini-inline-form{display:inline-flex;margin:0}
.stat-small{font-size:1rem;line-height:1.7;word-break:break-word}
@media (max-width: 980px){
  .backup-hero-grid,.backup-cards-grid,.backup-meta-list,.backup-file-meta{grid-template-columns:1fr}
}

.export-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(280px, .95fr);
  gap: 18px;
}

.export-side-panel .panel-body {
  display: grid;
  gap: 14px;
}

.side-note-list {
  margin: 0;
  padding-inline-start: 18px;
  color: var(--text-soft);
  line-height: 1.9;
}

.side-note-list li + li {
  margin-top: 8px;
}

.export-main .export-card-meta {
  margin-bottom: 14px;
}

.export-main .export-chip {
  background: linear-gradient(180deg, #ffffff 0%, #f4f8fe 100%);
  border-color: rgba(45,108,223,0.10);
  min-height: 32px;
  padding: 7px 12px;
}

@media (max-width: 1100px) {
  .export-grid {
    grid-template-columns: 1fr;
  }
}


/* customer notes layout fix */
.customer-notes-panel .panel-body {
  display: grid;
  gap: 16px;
}

.customer-note-entry-form {
  margin: 0;
  padding: 16px 18px;
  border: 1px solid rgba(45,108,223,0.12);
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.customer-note-entry-grid {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
}

.customer-note-entry-grid label {
  display: grid;
  gap: 8px;
  margin: 0;
}

.customer-note-entry-grid label > span {
  display: block;
  font-size: .92rem;
  font-weight: 700;
  color: var(--heading);
}

.customer-note-entry-grid input[type="date"],
.customer-note-entry-grid textarea {
  width: 100%;
  font: inherit;
}

.customer-note-entry-grid input[type="date"] {
  min-height: 46px;
}

.customer-note-entry-grid textarea {
  min-height: 110px;
  padding: 12px 14px;
  border: 1px solid #cfd9ea;
  border-radius: 14px;
  resize: vertical;
  color: var(--text);
  background: #fff;
}

.customer-note-entry-grid textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 4px rgba(37,99,235,.10);
}

.customer-note-entry-grid > .btn,
.customer-note-entry-grid > button {
  align-self: end;
  min-width: 168px;
  min-height: 46px;
  white-space: nowrap;
}

.customer-note-timeline .timeline-item {
  display: grid;
  gap: 8px;
}

.customer-note-timeline .timeline-item strong,
.customer-note-timeline .timeline-item p,
.customer-note-timeline .timeline-item small {
  padding-inline-start: 12px;
}

.timeline-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-start;
  padding-inline-start: 12px;
  margin-top: 2px;
}

.timeline-actions form {
  margin: 0;
}

@media (max-width: 900px) {
  .customer-note-entry-grid {
    grid-template-columns: 1fr;
  }

  .customer-note-entry-grid > .btn,
  .customer-note-entry-grid > button,
  .timeline-actions,
  .timeline-actions form,
  .timeline-actions .btn {
    width: 100%;
  }
}
