
:root {
  --bg: #eef3f9;
  --card: #ffffff;
  --text: #142033;
  --muted: #66758f;
  --line: #d7dfeb;
  --accent: #1558d6;
  --accent-2: #0f3d99;
  --success: #0f9d58;
  --danger: #c62828;
  --warning: #f9a825;
  --sidebar: #0f172a;
  --sidebar-link: #d8e1f2;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: radial-gradient(circle at top left, #f8fbff 0%, var(--bg) 55%);
  color: var(--text);
}

body.login-body {
  background:
    radial-gradient(circle at 12% 18%, rgba(21,88,214,.2) 0%, rgba(21,88,214,0) 35%),
    radial-gradient(circle at 86% 12%, rgba(10,164,255,.16) 0%, rgba(10,164,255,0) 28%),
    linear-gradient(180deg, #08121f 0%, #0f2037 100%);
  min-height: 100vh;
}

a { color: var(--accent); }

.shell-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  padding: 14px 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

body.login-body .shell-header {
  background: transparent;
  border-bottom: none;
  padding: 20px 28px 0;
}

.shell-brand-wrap { display: flex; align-items: center; gap: 14px; }
.shell-brand-logo {
  width: 48px;
  height: 48px;
  object-fit: contain;
  filter: drop-shadow(0 10px 22px rgba(7, 25, 62, .18));
}
.shell-brand { font-size: 18px; font-weight: 800; }
.shell-subtitle { color: var(--muted); font-size: 13px; }
body.login-body .shell-brand,
body.login-body .shell-subtitle,
body.login-body .shell-user { color: #f3f7ff; }
body.login-body .shell-subtitle { color: rgba(243,247,255,.72); }
.shell-user { font-size: 14px; color: var(--muted); }

.shell { display: grid; grid-template-columns: 250px 1fr; min-height: calc(100vh - 81px); }
.sidebar { background: linear-gradient(180deg, #0f172a 0%, #111d35 100%); padding: 22px 16px; }
.sidebar-nav { display: grid; gap: 8px; }
.sidebar-nav a {
  color: var(--sidebar-link); text-decoration: none; padding: 12px 14px; border-radius: 14px;
  border: 1px solid rgba(255,255,255,.05); background: rgba(255,255,255,.02);
}
.sidebar-nav a:hover { background: rgba(255,255,255,.08); }
.content { max-width: 1380px; padding: 22px 24px 34px; }
body.login-body .shell { grid-template-columns: 1fr; min-height: calc(100vh - 86px); }
body.login-body .content { max-width: 1480px; width: 100%; padding: 14px 28px 40px; margin: 0 auto; }

.card {
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(215,223,235,.95);
  border-radius: 24px;
  padding: 18px;
  margin-bottom: 16px;
  box-shadow: 0 18px 42px rgba(17,24,39,.06);
}
.card-narrow { max-width: 460px; margin: 60px auto; }
.grid-two { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.kpi-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-bottom: 16px; }
.kpi-grid-wide { margin-top: 14px; }
.kpi-grid-six { grid-template-columns: repeat(6, 1fr); }
.kpi-card { background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 14px 16px; box-shadow: 0 12px 24px rgba(17,24,39,.05); }
.kpi-card-accent { background: linear-gradient(135deg, #153d8d 0%, #1558d6 52%, #3ea1ff 100%); border-color: transparent; color: #fff; }
.kpi-card-accent .kpi-label { color: rgba(255,255,255,.82); }
.kpi-label { display:block; color: var(--muted); font-size: 13px; margin-bottom: 8px; }
.kpi-value { font-size: 26px; line-height: 1; }
.page-head, .section-head { display:flex; justify-content:space-between; align-items:flex-start; gap: 16px; }
.page-head { margin-bottom: 16px; }
.form-grid { display:grid; gap: 16px; }
.form-grid-two { grid-template-columns: 1fr 1fr; }
label { display:grid; gap:8px; font-size:14px; }
input, select, button, textarea {
  border-radius: 14px; border: 1px solid var(--line); padding: 12px 14px; font-size: 14px;
  background: #fff; color: var(--text);
}
textarea { resize: vertical; min-height: 110px; }
button, .button-link {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%); color:#fff; border:none; text-decoration:none;
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer; min-height: 44px; padding: 0 16px; border-radius: 14px;
  box-shadow: 0 10px 24px rgba(21,88,214,.18);
}
.button-link-secondary { background: #f3f6fb; color: var(--text); border: 1px solid var(--line); box-shadow: none; }

button:disabled, .button-link:disabled, .button-link.is-busy {
  cursor: not-allowed;
  opacity: .65;
  filter: grayscale(.35);
  box-shadow: none;
}
.button-danger { background: linear-gradient(135deg, #d32f2f 0%, #a91f1f 100%); }
.button-stack { display:flex; flex-wrap: wrap; gap: 12px; }
.form-actions { grid-column: 1 / -1; display:flex; justify-content:flex-start; }
.checkbox-label { align-self:end; display:flex; gap:10px; align-items:center; }
.checkbox-label input { width: 18px; height: 18px; margin:0; }
.span-all { grid-column: 1 / -1; }
.filter-row { display:flex; flex-wrap:wrap; gap: 10px; margin-bottom: 16px; }
.chip { border:1px solid var(--line); padding: 10px 14px; border-radius: 999px; text-decoration:none; background:#fff; color: var(--text); }
.chip-active { background: rgba(21,88,214,.1); border-color: rgba(21,88,214,.25); color: var(--accent); }
.table { width:100%; border-collapse:collapse; }
.table th, .table td { border-bottom:1px solid var(--line); text-align:left; padding: 11px 8px; font-size:14px; vertical-align: top; }
.table th { color: var(--muted); font-weight: 700; font-size: 12px; letter-spacing: .03em; text-transform: uppercase; }
.flash-stack { margin-bottom:18px; display:grid; gap:10px; }
.flash { padding: 12px 14px; border-radius: 14px; border:1px solid var(--line); background:#fff; }
.flash-success { border-color: rgba(15,157,88,.25); }
.flash-warning { border-color: rgba(249,168,37,.25); }
.flash-error { border-color: rgba(198,40,40,.25); }
.pill { display:inline-flex; padding: 6px 10px; border-radius:999px; font-size: 13px; font-weight:700; }
.pill-success { background: rgba(15,157,88,.12); color: var(--success); }
.pill-danger { background: rgba(198,40,40,.12); color: var(--danger); }
.pill-warning { background: rgba(249,168,37,.16); color: #8a5a00; }
.code { background:#0f172a; color:#e2e8f0; padding:14px; border-radius:14px; overflow:auto; font-size:12px; }
.detail-grid { display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
.detail-grid dt { color: var(--muted); font-size:13px; }
.detail-grid dd { margin:6px 0 0 0; font-weight:600; }
.details-box summary { cursor:pointer; margin:16px 0 10px; }
.muted { color: var(--muted); }
.error-text { color: var(--danger); }
.top-space { margin-top: 18px; }
.status-line { display:flex; gap: 8px; align-items:center; }

.hero-card {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  align-items: center;
  gap: 18px;
  padding: 20px 22px;
  border-radius: 24px;
  margin-bottom: 16px;
  background: linear-gradient(135deg, #091326 0%, #153d8d 54%, #1b74e4 100%);
  box-shadow: 0 20px 38px rgba(10, 22, 54, .20);
  color: #fff;
}
.hero-eyebrow, .login-eyebrow {
  margin: 0 0 10px;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 12px;
  font-weight: 700;
}
.hero-card h1, .login-panel h1, .login-panel h2 { margin: 0 0 12px; line-height: 1.1; }
.hero-card .muted { color: rgba(255,255,255,.82); }
.hero-mark-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
}
.hero-mark {
  width: min(250px, 100%);
  object-fit: contain;
  filter: drop-shadow(0 20px 38px rgba(0,0,0,.24));
}
.hero-card-compact h1 { font-size: 34px; margin-bottom: 8px; }
.hero-card-compact .muted { font-size: 14px; }
.hero-mark-compact { width: min(210px, 100%); }
.compact-stack { gap: 10px; }
.compact-card { padding: 16px 18px; }
.dashboard-grid-tight { gap: 16px; }
.top-space-sm { margin-top: 12px; }
.mini-summary-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.mini-summary-item { border: 1px solid var(--line); border-radius: 16px; padding: 12px 14px; background: #f8fbff; display: grid; gap: 6px; }
.mini-summary-item span { color: var(--muted); font-size: 12px; }
.mini-summary-item strong { font-size: 22px; }
.tag-row { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-chip { display: inline-flex; align-items: center; padding: 7px 10px; border-radius: 999px; background: #eef4ff; color: #1b4ec7; border: 1px solid #d8e6ff; font-size: 12px; font-weight: 700; }
.split-mini-tables { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.split-mini-tables h3 { margin: 0 0 10px; font-size: 14px; }
.mini-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.mini-list li { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; border-radius: 14px; background: #f8fbff; border: 1px solid var(--line); }
.mini-list li span { color: var(--muted); }
.compact-table th, .compact-table td { padding-top: 9px; padding-bottom: 9px; }

.login-shell {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 24px;
  align-items: stretch;
  min-height: calc(100vh - 140px);
}
.login-panel {
  border-radius: 30px;
  overflow: hidden;
}
.login-panel-brand {
  padding: 34px;
  background: linear-gradient(145deg, rgba(11,26,50,.94) 0%, rgba(17,45,86,.94) 50%, rgba(18,87,188,.88) 100%);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 28px 60px rgba(1,7,20,.28);
  color: #fff;
}
.login-brand-block {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 20px;
  align-items: center;
  margin-bottom: 24px;
}
.login-logo {
  width: 100%;
  max-width: 180px;
  object-fit: contain;
  filter: drop-shadow(0 24px 48px rgba(0,0,0,.26));
}
.login-copy { max-width: 620px; color: rgba(243,247,255,.76); }
.login-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 28px;
}
.login-feature-card {
  display: grid;
  gap: 8px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.08);
}
.login-feature-card strong { font-size: 16px; }
.login-feature-card span { color: rgba(243,247,255,.76); font-size: 14px; }
.login-panel-form {
  padding: 32px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(215,223,235,.92);
  box-shadow: 0 28px 56px rgba(5,18,42,.12);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.login-form-head { margin-bottom: 22px; }
.login-form-head h2 { font-size: 32px; }
.login-form-grid button { margin-top: 8px; }
.login-panel-form input {
  min-height: 50px;
  border-radius: 16px;
}

button:disabled, select:disabled, input:disabled { opacity: .65; cursor: not-allowed; }

@media (max-width: 1320px) {
  .login-feature-grid { grid-template-columns: 1fr; }
}
@media (max-width: 1180px) {
  .kpi-grid, .kpi-grid-six { grid-template-columns: repeat(3, 1fr); }
  .hero-card { grid-template-columns: 1fr; }
  .split-mini-tables { grid-template-columns: 1fr; }
}
@media (max-width: 980px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { padding: 10px 16px; }
  .sidebar-nav { grid-template-columns: repeat(2, 1fr); }
  .grid-two, .form-grid-two, .detail-grid, .kpi-grid, .kpi-grid-six, .login-shell, .mini-summary-grid { grid-template-columns: 1fr; }
  .login-brand-block { grid-template-columns: 1fr; text-align: center; }
  .login-logo { margin: 0 auto; }
}
@media (max-width: 640px) {
  .shell-header { flex-direction: column; gap: 12px; align-items: flex-start; }
  .sidebar-nav { grid-template-columns: 1fr; }
  .content { padding: 20px 16px 32px; }
  body.login-body .shell-header, body.login-body .content { padding-left: 16px; padding-right: 16px; }
  .login-panel-brand, .login-panel-form, .hero-card { padding: 22px; }
}

.toolbar-row {
  display: grid;
  gap: 14px;
}
.toolbar-search-row {
  grid-template-columns: 1fr auto;
  align-items: end;
}
.search-field {
  display: grid;
  gap: 8px;
}
.toolbar-actions-inline {
  display: flex;
  gap: 12px;
  align-items: center;
}
.top-space-sm { margin-top: 12px; }
.detail-grid-three { grid-template-columns: repeat(3, 1fr); }
.button-xs {
  min-height: 36px;
  padding: 0 12px;
  border-radius: 12px;
  font-size: 13px;
}
@media (max-width: 980px) {
  .toolbar-search-row, .detail-grid-three { grid-template-columns: 1fr; }
}

.kpi-grid-three { grid-template-columns: repeat(3, 1fr); }
.inline-actions { display: inline-flex; align-items: center; gap: 10px; }
.link-button {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  color: var(--accent);
  font: inherit;
  cursor: pointer;
}
.danger-link { color: #c62828; }

.table-actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.table-actions-wrap {
  flex-wrap: wrap;
}
.table-actions form {
  margin: 0;
}
.bulk-actions-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin: 10px 0 14px;
  flex-wrap: wrap;
}
.checkbox-inline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.checkbox-inline input {
  width: 18px;
  height: 18px;
}


.client-picker { display: grid; gap: 12px; }
.client-picker-selected {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: #f8fbff;
}
.client-picker-selected strong { font-size: 15px; }
.client-picker-selected span { color: var(--muted); font-size: 13px; }
.client-picker-results {
  max-height: 260px;
  overflow: auto;
  display: grid;
  gap: 8px;
  padding-right: 4px;
}
.client-picker-item {
  width: 100%;
  text-align: left;
  padding: 13px 14px;
  display: grid;
  gap: 6px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  box-shadow: none;
}
.client-picker-item strong { font-size: 14px; }
.client-picker-item span { color: var(--muted); font-size: 12px; }
.client-picker-item.is-selected {
  border-color: rgba(21,88,214,.35);
  background: rgba(21,88,214,.08);
}

.sidebar-section-label {
  color: rgba(216,225,242,.6);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  padding: 12px 12px 2px;
}
.kpi-grid-three { grid-template-columns: repeat(3, 1fr); }
.kpi-value-small { font-size: 15px; line-height: 1.2; word-break: break-all; }
.bulk-bar { display:flex; gap:12px; align-items:center; margin-top: 14px; }
.button-xs { min-height: 32px; padding: 0 10px; font-size: 12px; }
.inline-actions { display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.link-button { background:none; border:none; padding:0; min-height:auto; color: var(--accent); box-shadow:none; }
.danger-link { color: var(--danger); }
@media (max-width: 980px) {
  .kpi-grid-three { grid-template-columns: 1fr; }
}

.kpi-grid-four { grid-template-columns: repeat(4, 1fr); }
.note-box { padding: 14px 16px; border-radius: 16px; background: rgba(21,88,214,.08); border: 1px solid rgba(21,88,214,.14); color: var(--text); }
.json-box { margin: 12px 0 0; padding: 14px; border-radius: 14px; background: #0f172a; color: #d7e3ff; overflow: auto; font-size: 12px; }
.timeline-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.timeline-list li { display: grid; gap: 6px; padding: 12px 14px; border: 1px solid var(--line); border-radius: 16px; background: #fff; }
.timeline-list li span { color: var(--text); font-size: 14px; }
.timeline-list li small { color: var(--muted); font-size: 12px; }
@media (max-width: 980px) {
  .kpi-grid-four { grid-template-columns: 1fr; }
}

.note-box p { margin: 8px 0 0; }
.note-box-warn { background: rgba(249,168,37,.14); border-color: rgba(249,168,37,.28); }
.section-subtitle { margin: 18px 0 0; font-size: 15px; }
.metric-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.metric-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 12px 14px;
  background: #f8fbff;
  display: grid;
  gap: 6px;
}
.metric-card span {
  color: var(--muted);
  font-size: 12px;
}
.metric-card strong {
  font-size: 16px;
  line-height: 1.25;
}
.decision-hero {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  padding: 16px;
  border-radius: 20px;
  background: linear-gradient(135deg, #0f172a 0%, #113267 100%);
  color: #fff;
}
.decision-hero-approve { background: linear-gradient(135deg, #0f3d2e 0%, #0f9d58 100%); }
.decision-hero-reject { background: linear-gradient(135deg, #6b1f1f 0%, #c62828 100%); }
.decision-hero > div { display: grid; gap: 6px; }
.decision-label { color: rgba(255,255,255,.78); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.decision-hero strong { font-size: 20px; line-height: 1.15; }
.doc-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.doc-preview-card {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 16px;
  background: #fff;
  display: grid;
  gap: 12px;
}
.doc-preview-card header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.doc-preview-frame {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 220px;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: #f8fbff;
}
.doc-preview-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.doc-preview-pdf span,
.doc-preview-empty span {
  font-weight: 800;
  letter-spacing: .08em;
  color: var(--muted);
}
.doc-preview-meta {
  display: grid;
  gap: 8px;
}
.doc-preview-meta div {
  display: grid;
  gap: 3px;
}
.doc-preview-meta span {
  font-size: 12px;
  color: var(--muted);
}
.doc-preview-meta strong {
  font-size: 14px;
}
@media (max-width: 1180px) {
  .metric-grid { grid-template-columns: repeat(2, 1fr); }
  .decision-hero { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 980px) {
  .doc-preview-grid,
  .metric-grid,
  .decision-hero { grid-template-columns: 1fr; }
}
.subtle-card {
  background: #f8fbff;
  border: 1px dashed var(--line);
}
.family-forms-wrap {
  display: grid;
  gap: 16px;
}
.inner-grid {
  margin-top: 8px;
}
.inside-checkbox {
  display: inline-flex;
  margin-top: 8px;
}
.compact-inline-form {
  display: inline-flex;
}
.compact-inline-form input[type="hidden"] {
  display: none;
}
.button-xs {
  padding: 6px 10px;
  font-size: 12px;
}

.two-col-layout {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1rem;
}

.definition-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem 1rem;
}
.definition-grid span {
  display: block;
  color: var(--muted, #667085);
  font-size: .85rem;
  margin-bottom: .15rem;
}
.definition-grid strong {
  display: block;
}

.pill-active, .pill-paid { background: rgba(15,157,88,.12); color: #0f9d58; }
.pill-pending, .pill-pending-approval, .pill-approved { background: rgba(33,150,243,.12); color: #1565c0; }
.pill-overdue, .pill-in-arrears, .pill-closed, .pill-cancelled { background: rgba(198,40,40,.12); color: #c62828; }

@media (max-width: 960px) {
  .two-col-layout,
  .definition-grid {
    grid-template-columns: 1fr;
  }
}

.page-actions { display:flex; gap:10px; align-items:center; }
.message-bubble { display:grid; gap:8px; padding:16px 18px; border:1px solid #dde5f0; border-radius:18px; background:#fff; margin-bottom:12px; }
.message-bubble-own { background:#eef5ff; border-color:#c6daf8; }
.message-bubble header { display:flex; justify-content:space-between; gap:12px; align-items:center; }
.message-body { white-space: pre-wrap; word-break: break-word; }
.table-row-unread td { background: rgba(230,241,255,.45); }
.table-actions-inline { display:flex; gap:8px; align-items:center; }
.pill-low { background:#eef3f8; color:#44556b; }
.pill-normal { background:#ecf5ff; color:#0f5ab8; }
.pill-high { background:#fff4de; color:#a66a00; }
.pill-critical { background:#ffe5e5; color:#b42318; }
.pill-open, .pill-pending { background:#fff4de; color:#a66a00; }
.pill-done, .pill-paid { background:#e9f8ee; color:#0f7b38; }
.pill-overdue, .pill-cancelled { background:#ffe5e5; color:#b42318; }


.message-recipient-list { display: grid; gap: 4px; }
.recipient-chip-row { display:flex; flex-wrap:wrap; gap:8px; }
.tag-chip-primary { background:#dce9ff; color:#123f9e; border-color:#bfd4ff; }
.small-text { font-size: 12px; }
.table-row-unread td { background: rgba(27,116,228,.05); }
.calendar-toolbar { display:flex; justify-content:space-between; gap:16px; align-items:flex-start; margin-bottom: 16px; }
.calendar-grid { display:grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 8px; }
.calendar-weekday { text-align:center; font-size:12px; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.04em; padding-bottom: 6px; }
.calendar-cell { min-height: 128px; border:1px solid var(--line); border-radius:18px; background:#fff; padding:10px; display:grid; gap:8px; }
.calendar-cell-muted { background:#f7f9fc; color:#98a2b3; }
.calendar-cell-today { border-color:#1b74e4; box-shadow: inset 0 0 0 1px rgba(27,116,228,.2); }
.calendar-day-number { font-weight:700; font-size:14px; }
.calendar-cell-items { display:grid; gap:6px; align-content:start; }
.calendar-chip { border-radius:12px; padding:6px 8px; font-size:12px; line-height:1.25; }
.calendar-chip-event { background:#eef4ff; color:#16439e; border:1px solid #d9e8ff; }
.calendar-chip-due { background:#fff5e8; color:#8a5400; border:1px solid #ffe0b0; }
.calendar-chip-more { background:#f4f4f5; color:#52525b; border:1px dashed #d4d4d8; }
.calendar-chip-event.priority-high, .calendar-chip-event.priority-critical { background:#ffe6e6; color:#a91f1f; border-color:#ffc7c7; }
.calendar-chip-due.status-overdue { background:#ffe7e7; color:#b42318; border-color:#fecaca; }
@media (max-width: 980px) {
  .calendar-grid { grid-template-columns: 1fr; }
  .calendar-weekday { display:none; }
  .calendar-cell { min-height: auto; }
  .calendar-toolbar { flex-direction:column; }
}


.label-inline { font-weight: 700; }
.recipient-block { display: grid; gap: 10px; }
.recipient-block-head { display:flex; justify-content:space-between; align-items:center; gap:12px; }
.recipient-block-head h3 { margin:0; font-size:15px; }
.empty-inline-state { border:1px dashed var(--line); border-radius:14px; padding:12px 14px; color: var(--muted); background:#f8fbff; }

.calendar-layout { display:grid; grid-template-columns: minmax(0, 1.7fr) minmax(320px, .9fr); gap:16px; align-items:start; }
.calendar-main-card { margin-bottom: 0; }
.calendar-side-stack { display:grid; gap:16px; }
.calendar-side-card { margin-bottom: 0; }
.calendar-grid { display:grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap:6px; }
.calendar-weekday { font-size:12px; text-transform:uppercase; letter-spacing:.04em; color:var(--muted); padding:0 4px 4px; }
.calendar-cell { min-height: 112px; border:1px solid var(--line); border-radius:16px; padding:8px; background:#fff; overflow:hidden; }
.calendar-cell-muted { background:#f8fafc; opacity:.72; }
.calendar-cell-today { border-color: rgba(21,88,214,.35); box-shadow: inset 0 0 0 1px rgba(21,88,214,.12); }
.calendar-day-number { font-size:13px; font-weight:700; margin-bottom:6px; }
.calendar-cell-items { display:grid; gap:4px; }
.calendar-chip { border-radius:10px; padding:4px 6px; font-size:11px; line-height:1.25; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.calendar-chip span { font-weight:700; }
.calendar-chip-event { background:#eef4ff; color:#1549b7; }
.calendar-chip-due { background:#fff5e8; color:#9a4a02; }
.calendar-chip-more { background:#f3f4f6; color:#475569; }
.calendar-toolbar { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; margin-bottom:12px; }
.calendar-toolbar h2 { margin:0 0 4px; }
.toolbar-actions-inline { display:flex; flex-wrap:wrap; gap:8px; }
.table-actions-inline { display:flex; flex-wrap:wrap; gap:8px; }

.message-widget { position:fixed; right:18px; bottom:18px; z-index:60; width:280px; border-radius:18px; background:#fff; border:1px solid var(--line); box-shadow:0 18px 36px rgba(17,24,39,.16); overflow:hidden; }
.message-widget summary { list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; padding:12px 14px; font-weight:700; background:linear-gradient(135deg, #153d8d 0%, #1558d6 52%, #3ea1ff 100%); color:#fff; }
.message-widget summary::-webkit-details-marker { display:none; }
.message-widget summary strong { display:inline-flex; align-items:center; justify-content:center; min-width:24px; height:24px; padding:0 8px; border-radius:999px; background:rgba(255,255,255,.18); }
.message-widget-body { display:grid; gap:12px; padding:14px; }
.message-widget-line { display:grid; gap:4px; }
.message-widget-actions { display:flex; gap:8px; }
.message-widget-actions a { flex:1; }
.message-widget-calendar { font-size:13px; color:var(--accent); text-decoration:none; }

@media (max-width: 1200px) {
  .calendar-layout { grid-template-columns: 1fr; }
}
@media (max-width: 980px) {
  .message-widget { right:12px; left:12px; width:auto; }
  .calendar-cell { min-height: 96px; }
}

.assistant-widget {
  position: fixed;
  right: 18px;
  bottom: 96px;
  width: min(360px, calc(100vw - 28px));
  z-index: 50;
  background: rgba(255,255,255,.96);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 22px 40px rgba(10,22,54,.14);
  overflow: hidden;
}
.assistant-widget summary {
  list-style: none;
  display:flex; justify-content:space-between; align-items:center;
  padding: 12px 14px; cursor:pointer; font-weight:700;
  background: linear-gradient(135deg, #122d56 0%, #1558d6 100%); color:#fff;
}
.assistant-widget-body { padding: 14px; display:grid; gap:12px; }
.assistant-widget-form { display:grid; gap:10px; }
.assistant-widget-form textarea { min-height: 96px; }
.assistant-widget-reply { display:grid; gap:8px; border:1px solid var(--line); border-radius:14px; padding:10px 12px; background:#f8fbff; }
.assistant-widget-reply pre { margin:0; white-space:pre-wrap; font-family: inherit; font-size:13px; }
.assistant-layout { align-items:start; }
.assistant-chat-card { min-height: 60vh; }
.assistant-thread { display:grid; gap:12px; max-height: 64vh; overflow:auto; }
.assistant-bubble { border-radius: 18px; padding: 12px 14px; border:1px solid var(--line); background:#fff; display:grid; gap:8px; }
.assistant-bubble header { display:flex; justify-content:space-between; gap:12px; align-items:center; }
.assistant-bubble-user { margin-left: 40px; background:#eef4ff; }
.assistant-bubble-assistant { margin-right: 40px; background:#f8fbff; }
.assistant-bubble pre { margin:0; white-space:pre-wrap; font-family: inherit; }
.assistant-side-card .mini-list li { align-items:flex-start; gap:12px; }
.assistant-conversations li, .assistant-docs li { display:flex; justify-content:space-between; gap:12px; }
.assistant-meta-list li strong { text-align:right; }


.assistant-clean-layout { display:grid; grid-template-columns: 320px minmax(0,1fr); gap:16px; align-items:start; }
.assistant-clean-sidebar, .assistant-clean-chat { margin-bottom:0; }
.assistant-header-actions { display:flex; gap:10px; align-items:center; }
.assistant-provider-badge { display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; background:#eef4ff; color:#1549b7; font-weight:700; font-size:12px; }
.assistant-clean-conversations, .assistant-clean-docs { list-style:none; margin:0; padding:0; display:grid; gap:8px; }
.assistant-clean-conversations li a { display:grid; gap:4px; text-decoration:none; color:inherit; border:1px solid var(--line); border-radius:14px; padding:10px 12px; background:#fff; }
.assistant-clean-conversations li.is-active a { border-color:#1558d6; background:#f8fbff; }
.assistant-clean-docs li { display:flex; justify-content:space-between; gap:10px; align-items:flex-start; border:1px solid var(--line); border-radius:14px; padding:10px 12px; }
.assistant-doc-status { font-size:11px; font-weight:700; border-radius:999px; padding:4px 8px; background:#f3f4f6; color:#334155; }
.assistant-doc-status-indexed, .assistant-doc-status-ready, .assistant-doc-status-stored { background:#ecfdf3; color:#166534; }
.assistant-upload-form { gap:10px; }
.assistant-clean-chat { display:grid; grid-template-rows:minmax(420px, 62vh) auto; gap:14px; }
.assistant-thread-clean { overflow:auto; display:grid; gap:12px; padding-right:4px; }
.assistant-bubble-body { white-space:pre-wrap; line-height:1.5; }
.assistant-empty-state { min-height: 220px; display:grid; place-items:center; text-align:center; border:1px dashed var(--line); border-radius:18px; background:#f8fbff; padding:18px; }
.assistant-chat-form { display:grid; gap:10px; border-top:1px solid var(--line); padding-top:10px; }
.assistant-chat-form textarea { min-height:96px; resize:vertical; }
.assistant-chat-actions { display:flex; align-items:center; justify-content:space-between; gap:12px; }

.assistant-orb-widget { position:fixed; right:18px; bottom:92px; z-index:70; }
.assistant-orb-widget summary { list-style:none; width:64px; height:64px; border-radius:999px; cursor:pointer; display:flex; align-items:center; justify-content:center; background:radial-gradient(circle at 30% 30%, #4bb3ff 0%, #1558d6 48%, #153d8d 100%); color:#fff; box-shadow:0 16px 32px rgba(21,88,214,.28); font-weight:800; letter-spacing:.04em; }
.assistant-orb-widget summary::-webkit-details-marker { display:none; }
.assistant-orb-panel { position:absolute; right:0; bottom:76px; width:360px; max-width:calc(100vw - 28px); border-radius:22px; background:#fff; border:1px solid var(--line); box-shadow:0 24px 48px rgba(17,24,39,.2); overflow:hidden; }
.assistant-orb-header { display:flex; justify-content:space-between; align-items:flex-start; gap:10px; padding:14px 16px; border-bottom:1px solid var(--line); background:#f8fbff; }
.assistant-orb-header a { color:var(--accent); text-decoration:none; font-weight:700; }
.assistant-orb-thread { display:grid; gap:8px; padding:14px 16px; max-height:240px; overflow:auto; background:#fff; }
.assistant-mini-bubble { border-radius:16px; padding:10px 12px; white-space:pre-wrap; line-height:1.45; font-size:13px; }
.assistant-mini-user { margin-left:40px; background:#eef4ff; }
.assistant-mini-assistant { margin-right:40px; background:#f8fbff; border:1px solid var(--line); }
.assistant-mini-empty { font-size:13px; }
.assistant-orb-form { display:grid; gap:10px; padding:14px 16px; border-top:1px solid var(--line); }
.assistant-orb-form textarea { min-height:80px; resize:vertical; }
.assistant-orb-actions { display:flex; gap:8px; }
.assistant-orb-actions > * { flex:1; }

@media (max-width: 980px) {
  .assistant-clean-layout { grid-template-columns: 1fr; }
  .assistant-clean-chat { grid-template-rows:minmax(320px, 56vh) auto; }
}
@media (max-width: 680px) {
  .assistant-orb-widget { right:14px; bottom:86px; }
  .assistant-orb-panel { width:min(360px, calc(100vw - 20px)); }
}


.assistant-chat-only-layout { grid-template-columns: 280px minmax(0,1fr); }
.assistant-chat-only-card { grid-template-rows:minmax(420px, 64vh) auto; }
.assistant-composer-block { display:grid; gap:10px; }
.assistant-hidden-upload { display:none; }
.assistant-upload-trigger { cursor:pointer; }
.assistant-header-actions { display:flex; gap:8px; flex-wrap:wrap; }
.assistant-orb-button { width:64px; height:64px; border:none; border-radius:999px; cursor:pointer; display:flex; align-items:center; justify-content:center; background:radial-gradient(circle at 30% 30%, #4bb3ff 0%, #1558d6 48%, #153d8d 100%); color:#fff; box-shadow:0 16px 32px rgba(21,88,214,.28); font-weight:800; letter-spacing:.04em; }
.assistant-orb-button:focus-visible { outline:3px solid rgba(62,161,255,.45); outline-offset:2px; }
.assistant-orb-widget { position:fixed; right:18px; bottom:92px; z-index:70; }
.assistant-orb-panel[hidden] { display:none !important; }
@media (max-width: 980px) {
  .assistant-chat-only-layout { grid-template-columns: 1fr; }
}

.table-actions-cell { display:flex; gap:8px; align-items:center; justify-content:flex-end; }
.table-actions-cell form { margin:0; }
.table-actions-cell button { background:none; border:none; color:var(--accent); font:inherit; cursor:pointer; padding:0; }
.assistant-conversation-row { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:10px; align-items:start; }
.assistant-conversation-row a { display:grid; gap:4px; text-decoration:none; color:inherit; border:1px solid var(--line); border-radius:14px; padding:10px 12px; background:#fff; }
.assistant-clean-conversations li.is-active .assistant-conversation-row a { border-color:#1558d6; background:#f8fbff; }
.assistant-conversation-actions { display:flex; gap:8px; align-items:center; }
.assistant-conversation-actions a,
.assistant-conversation-actions button { display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:999px; border:1px solid var(--line); background:#fff; color:var(--accent); text-decoration:none; cursor:pointer; }
.assistant-conversation-actions form { margin:0; }


/* V11.4 assistant compact/performance */
.assistant-clean-layout { grid-template-columns: 248px minmax(0,1fr); gap: 12px; }
.assistant-clean-sidebar { max-height: calc(100vh - 170px); overflow: auto; }
.assistant-clean-conversations { gap: 6px; }
.assistant-conversation-row { gap: 6px; }
.assistant-conversation-row a { padding: 8px 10px; border-radius: 12px; }
.assistant-conversation-link strong { display:block; font-size: 13px; line-height: 1.25; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.assistant-conversation-link .muted { font-size: 11px; }
.assistant-conversation-actions a, .assistant-conversation-actions button { width: 24px; height: 24px; }
.assistant-chat-only-card, .assistant-clean-chat { grid-template-rows: minmax(340px, calc(100vh - 260px)) auto; gap: 10px; }
.assistant-thread-clean { gap: 8px; overflow-y: auto; overflow-x: hidden; padding-right: 0; }
.assistant-bubble { max-width: 78%; padding: 8px 10px; border-radius: 14px; gap: 4px; }
.assistant-bubble header { font-size: 11px; }
.assistant-bubble-body { font-size: 13px; line-height: 1.4; }
.assistant-bubble-user { margin-left: auto; }
.assistant-bubble-assistant { margin-right: auto; }
.assistant-chat-form { gap: 8px; padding-top: 8px; }
.assistant-chat-form textarea { min-height: 64px; max-height: 160px; }
.assistant-composer-block { position: sticky; bottom: 0; background: #fff; }
.assistant-empty-state { min-height: 120px; padding: 12px; border-radius: 14px; }
.assistant-orb-panel { width: 320px; border-radius: 18px; }
.assistant-orb-header { padding: 10px 12px; }
.assistant-orb-thread { gap: 6px; padding: 10px 12px; max-height: 180px; }
.assistant-mini-bubble { padding: 8px 10px; font-size: 12px; border-radius: 12px; }
.assistant-mini-user { margin-left: 26px; }
.assistant-mini-assistant { margin-right: 26px; }
.assistant-orb-form { gap: 8px; padding: 10px 12px; }
.assistant-orb-form textarea { min-height: 56px; max-height: 120px; }
.assistant-orb-actions { gap: 6px; }
.assistant-orb-actions .button-link { white-space: nowrap; }
@media (max-width: 980px) {
  .assistant-clean-layout { grid-template-columns: 1fr; }
  .assistant-clean-sidebar { max-height: none; }
  .assistant-chat-only-card, .assistant-clean-chat { grid-template-rows: minmax(280px, 56vh) auto; }
}


/* V11.5 assistant compact improvements */
.assistant-workbench{grid-template-columns:minmax(0,1fr);}
#assistant-history-drawer[hidden]{display:none !important;}
#assistant-history-drawer{position:fixed; top:84px; right:18px; width:300px; max-width:calc(100vw - 36px); max-height:calc(100vh - 120px); z-index:55; overflow:auto; box-shadow:0 16px 32px rgba(17,24,39,.16);}
.assistant-chat-only-card,.assistant-clean-chat{grid-template-rows:minmax(320px,calc(100vh - 250px)) auto; gap:8px;}
.assistant-thread-clean{padding-right:4px;}
.assistant-bubble{max-width:72%; padding:10px 12px; border-radius:14px;}
.assistant-bubble header{margin-bottom:4px;}
.assistant-bubble strong{font-size:13px;}
.assistant-bubble .muted{font-size:11px;}
.assistant-bubble-body{font-size:14px; line-height:1.4;}
.assistant-conversation-link strong{display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-size:13px;}
.assistant-conversation-link .muted{font-size:11px;}
@media (max-width: 900px){#assistant-history-drawer{left:14px; right:14px; width:auto;}}

.provider-summary-card { border: 1px solid var(--line); border-radius: 20px; padding: 16px; background: #f8fbff; }
.provider-summary-top { display:flex; justify-content:space-between; gap:16px; align-items:flex-start; }
.provider-summary-top h3 { margin: 12px 0 8px; }
.provider-summary-links { display:flex; gap:10px; flex-wrap:wrap; }
.provider-note-list { margin: 12px 0 0; padding-left: 18px; display:grid; gap:8px; color: var(--muted); }
.tag-chip-neutral { background:#f3f6fb; color:#334155; border-color:#d9e2ef; }
.provider-fieldset { border: 1px solid var(--line); border-radius: 20px; padding: 14px 16px; background: #fff; }
.provider-fieldset-head h3 { margin: 0 0 6px; font-size: 16px; }
.provider-fields-grid { margin-top: 6px; }
.is-hidden { display:none !important; }
.provider-custom-code input { max-width: 420px; }

.gateway-card { border:1px solid #d9e7fb; background:linear-gradient(180deg,#fbfdff 0%,#f7fbff 100%); }
.gateway-form-grid { align-items:end; }
.gateway-inline-stats { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.gateway-card .section-head p { margin:4px 0 0; }
.pill-approved, .pill-captured, .pill-posted, .pill-settled, .pill-reconciled { background: rgba(15,157,88,.12); color: #0f7b38; }
.pill-rejected, .pill-refunded, .pill-failed { background: rgba(198,40,40,.12); color: #c62828; }
.pill-cancelled { background: rgba(198,40,40,.12); color: #c62828; }
.pill-authorized { background: rgba(33,150,243,.12); color: #1565c0; }
@media (max-width: 980px) {
  .gateway-inline-stats { justify-content:flex-start; }
}

.code-block{background:#0f172a;color:#e5e7eb;padding:14px;border-radius:12px;overflow:auto;font-size:.9rem;line-height:1.5;}
.small-text{font-size:.9rem;}
.text-success{color:#15803d;}
.text-danger{color:#b91c1c;}


.subcard-muted { background:#fcfdff; border:1px solid #e5edf8; }
.subcard-muted .section-head { margin-bottom:10px; }


.choice-grid { display:grid; gap:10px; }
.mail-compose-layout { display:grid; grid-template-columns: minmax(0, 1.8fr) minmax(280px, .9fr); gap:18px; align-items:start; }
.mail-compose-main, .mail-compose-side { display:grid; gap:16px; }
.mail-compose-side-card { border:1px solid var(--line); border-radius:18px; padding:14px; background:#f8fbff; display:grid; gap:12px; }
.mail-compose-to-field input { background:#fff; }
.recipient-search-panel { border:1px solid var(--line); border-radius:20px; padding:14px; background:#fff; display:grid; gap:12px; }
.recipient-search-results { display:grid; gap:8px; max-height:280px; overflow:auto; padding-right:4px; }
.recipient-row { display:flex; gap:12px; align-items:flex-start; border:1px solid #e6edf8; border-radius:16px; padding:12px 14px; background:#fbfdff; cursor:pointer; }
.recipient-row:hover { border-color:#bfd4ff; background:#f4f8ff; }
.recipient-row input { width:18px; height:18px; margin-top:2px; }
.recipient-row-main { display:grid; gap:4px; }
.recipient-row-main strong { font-size:14px; }
.recipient-row-main small { color:var(--muted); font-size:12px; }
.site-choice-list { display:grid; gap:8px; }
.checkbox-label-card { border:1px solid #e6edf8; border-radius:14px; padding:10px 12px; background:#fff; }
.client-bottom-grid { align-items:start; }
.collapsible-section-card details > summary { list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:14px; font-weight:700; }
.collapsible-section-card details > summary::-webkit-details-marker { display:none; }
.collapsible-section-card details > summary strong { min-width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; border-radius:999px; background:#eef4ff; color:#1549b7; }
.collapsible-section-card details > summary::after { content:'+'; margin-left:auto; font-size:22px; line-height:1; color:#1549b7; }
.collapsible-section-card details[open] > summary::after { content:'−'; }
.collapsible-section-body { display:grid; gap:12px; }
@media (max-width: 980px) {
  .mail-compose-layout { grid-template-columns: 1fr; }
  .mail-compose-side { order: 2; }
}

.autocomplete-field { position: relative; }
.recipient-autocomplete { position: absolute; left: 0; right: 0; top: calc(100% + 8px); z-index: 30; background: #fff; border: 1px solid var(--line); border-radius: 18px; box-shadow: 0 20px 45px rgba(15, 23, 42, 0.12); display: grid; gap: 4px; padding: 8px; max-height: 280px; overflow: auto; }
.recipient-suggestion { display: grid; gap: 4px; text-align: left; width: 100%; border: 0; background: transparent; padding: 10px 12px; border-radius: 14px; cursor: pointer; }
.recipient-suggestion:hover { background: #f4f8ff; }
.recipient-suggestion strong { font-size: 14px; }
.recipient-suggestion small, .recipient-suggestion-empty { color: var(--muted); font-size: 12px; }
.recipient-suggestion-empty { padding: 10px 12px; }
.recipient-chip-panel { min-height: 52px; padding: 12px 14px; border: 1px solid var(--line); border-radius: 18px; background: #fbfdff; }
.removable-chip { gap: 8px; }
.removable-chip button { border: 0; background: transparent; color: inherit; cursor: pointer; font-size: 15px; line-height: 1; padding: 0; }
.side-card-compact { padding: 12px 14px; }
.compact-site-choice-list { display: grid; gap: 8px; max-height: 260px; overflow: auto; }
.compact-site-check { padding: 10px 12px; border-radius: 14px; }
.nested-form-grid { margin-top: 6px; }
.section-subgroup-head { display: grid; gap: 4px; padding-top: 8px; }
.section-subgroup-head h3 { margin: 0; font-size: 16px; }
.table-like-card { border: 1px solid var(--line); border-radius: 18px; padding: 12px; background: #fbfdff; }
.participant-row-grid { display: grid; grid-template-columns: 1.4fr .9fr .95fr .55fr 1.2fr .95fr 1fr auto; gap: 10px; align-items: start; }
.participant-table-head { padding: 0 0 10px; color: var(--muted); font-size: 12px; }
.participant-row { padding: 10px 0; border-top: 1px solid #e8eef7; }
.participant-row:first-child { border-top: 0; }
.participant-flags { display: grid; gap: 6px; padding-top: 4px; }
.compact-check { font-size: 12px; }
.company-profile-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.inline-chip-stack { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.company-doc-card header { align-items: flex-start; }
.company-participant-form { align-items: end; }
.align-end { align-self: end; }
@media (max-width: 1180px) {
  .participant-row-grid { grid-template-columns: 1fr 1fr; }
  .participant-table-head { display: none; }
  .participant-row { border-top: 1px solid #e8eef7; padding-top: 14px; }
  .company-profile-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 780px) {
  .recipient-autocomplete { position: static; margin-top: 8px; }
  .company-profile-grid { grid-template-columns: 1fr; }
  .participant-row-grid { grid-template-columns: 1fr; }
}


.client-intake-layout { align-items: start; }
.client-type-switcher-wrap { display:grid; gap:14px; }
.client-type-switcher { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:14px; }
.client-type-card { width:100%; border:1px solid var(--line); background:#f8fbff; border-radius:18px; padding:16px 18px; text-align:left; display:grid; gap:6px; cursor:pointer; color:var(--text); box-shadow:0 10px 24px rgba(15,23,42,.05); }
.client-type-card strong { font-size:16px; }
.client-type-card span { color:var(--muted); font-size:13px; }
.client-type-card small { color:#1d4ed8; font-weight:700; }
.client-type-card.is-active { border-color:#7cb0ff; background:#eaf4ff; box-shadow:0 14px 28px rgba(44,94,199,.14); }
.client-type-banner { border:1px solid #dbe7f6; border-radius:16px; background:#f7fbff; padding:14px 16px; display:grid; gap:4px; }
.client-type-banner strong { font-size:15px; }
.client-type-banner span { color:var(--muted); }
.client-type-banner.is-company { background:#f4f8ff; border-color:#cfe0ff; }
.intake-panel { display:none; border:1px solid #e4ebf5; border-radius:20px; padding:18px; background:#fcfdff; }
.intake-panel.is-active { display:block; }
.no-margin { margin-top:0; }
@media (max-width: 900px) {
  .client-type-switcher { grid-template-columns: 1fr; }
}

.compact-list {
  margin: 0;
  padding-left: 1.1rem;
}

.compact-form-card {
  background: #f8fafc;
  border: 1px solid #dbe5f1;
  border-radius: 14px;
  padding: 14px;
}

.company-participant-editor {
  display: grid;
  gap: 16px;
}

.participant-editor-card {
  border: 1px solid #dbe5f1;
}

.tag-chip-success {
  background: #e8fff1;
  color: #0f7a3b;
  border-color: #b6e9c8;
}

/* Expedientes - badges de estado */
.badge {
  padding: 4px 8px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  display: inline-block;
  line-height: 1.2;
}

.badge-approved { background: #d1fae5; color: #065f46; }
.badge-rejected { background: #fee2e2; color: #991b1b; }
.badge-under_review { background: #fef3c7; color: #92400e; }
.badge-submitted { background: #e0f2fe; color: #075985; }
.badge-draft { background: #f3f4f6; color: #374151; }
.badge-operational { background: #ede9fe; color: #5b21b6; }
.badge-servicing { background: #cffafe; color: #155e75; }
.badge-cancelled { background: #e5e7eb; color: #4b5563; }

/* Highlight filas por riesgo */
tr.row-risk-rejected { background: #fef2f2; }
tr.row-risk-review   { background: #fffbeb; }
tr.row-risk-approved { background: #f0fdf4; }

tr.row-risk-rejected:hover,
tr.row-risk-review:hover,
tr.row-risk-approved:hover {
  filter: brightness(0.98);
}

body.financial-wide .table .button-link,
  body.financial-wide .table button,
  body.financial-wide .financial-table .button-link,
  body.financial-wide .financial-table button {
    font-size: 10.5px !important;
    padding: 0.15rem 0.30rem !important;
  }
}



/* =========================
   FINANZAS: USAR MÁS ANCHO REAL
   ========================= */
body.financial-wide {
  overflow-x: hidden;
}

body.financial-wide .shell {
  width: 100% !important;
  max-width: none !important;
  grid-template-columns: 230px minmax(0, 1fr) !important;
  column-gap: 18px !important;
}

body.financial-wide .content {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
}

body.financial-wide .card {
  width: 100% !important;
  max-width: none !important;
}

body.financial-wide .card-body {
  width: 100% !important;
  max-width: none !important;
  overflow: visible !important;
}

body.financial-wide .table-wrap,
body.financial-wide .financial-table-wrap {
  width: 100% !important;
  max-width: none !important;
  overflow: visible !important;
}

body.financial-wide .financial-responsive-table,
body.financial-wide .financial-table,
body.financial-wide .table.financial-responsive-table {
  width: 100% !important;
  min-width: 0 !important;
  table-layout: auto !important;
  border-collapse: collapse;
}

body.financial-wide .financial-responsive-table th,
body.financial-wide .financial-responsive-table td,
body.financial-wide .financial-table th,
body.financial-wide .financial-table td {
  white-space: normal !important;
  word-break: break-word;
  overflow-wrap: anywhere;
  font-size: 10.5px !important;
  line-height: 1.1 !important;
  padding: 0.26rem 0.28rem !important;
  vertical-align: middle;
}

body.financial-wide .financial-responsive-table th,
body.financial-wide .financial-table th {
  font-size: 10px !important;
}

body.financial-wide .financial-responsive-table .button-link,
body.financial-wide .financial-responsive-table button,
body.financial-wide .financial-table .button-link,
body.financial-wide .financial-table button {
  font-size: 10px !important;
  line-height: 1.05 !important;
  padding: 0.14rem 0.26rem !important;
  white-space: nowrap !important;
}

body.financial-wide .financial-responsive-table input[type="number"],
body.financial-wide .financial-table input[type="number"] {
  width: 72px !important;
  min-width: 72px !important;
  font-size: 10px !important;
  padding: 0.12rem 0.18rem !important;
}

/* Mantener visible la acción sin scroll */
body.financial-wide .financial-col-action,
body.financial-wide td.financial-col-action {
  position: static !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* KPIs compactos */
body.financial-wide .metric-card {
  min-width: 0;
}
body.financial-wide .metric-card span {
  font-size: 10px !important;
  line-height: 1.05 !important;
}
body.financial-wide .metric-card strong {
  font-size: 15px !important;
  line-height: 1.05 !important;
}

/* En escritorio ancho, usar todavía más aire */
@media (min-width: 1450px) {
  body.financial-wide .shell {
    grid-template-columns: 220px minmax(0, 1fr) !important;
    column-gap: 22px !important;
  }

  body.financial-wide .financial-responsive-table th,
  body.financial-wide .financial-responsive-table td,
  body.financial-wide .financial-table th,
  body.financial-wide .financial-table td {
    font-size: 10.8px !important;
    padding: 0.28rem 0.30rem !important;
  }
}

/* En resoluciones medias, esconder SOLO columnas menos críticas para que entre la acción */
@media (max-width: 1650px) {
  /* cartera: ocultar DNI y código producto implícito si viene largo */
  body.financial-wide #financialPortfolioTable th:nth-child(3),
  body.financial-wide #financialPortfolioTable td:nth-child(3) {
    display: none;
  }
}

@media (max-width: 1500px) {
  /* cartera: ocultar pagadas y pendientes, pero dejar acción visible */
  body.financial-wide #financialPortfolioTable th:nth-child(8),
  body.financial-wide #financialPortfolioTable td:nth-child(8),
  body.financial-wide #financialPortfolioTable th:nth-child(9),
  body.financial-wide #financialPortfolioTable td:nth-child(9) {
    display: none;
  }
}

@media (max-width: 1600px) {
  /* detalle: ocultar capital/interés pagado para priorizar pago/acción */
  body.financial-wide .financial-responsive-table th:nth-child(7),
  body.financial-wide .financial-responsive-table td:nth-child(7),
  body.financial-wide .financial-responsive-table th:nth-child(8),
  body.financial-wide .financial-responsive-table td:nth-child(8) {
    display: none;
  }
}

/* =========================================================
   FINANZAS - CONTENEDOR ANCHO REAL
   ========================================================= */
body.financial-wide .shell {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: 220px minmax(0, 1fr) !important;
  column-gap: 16px !important;
  align-items: start !important;
}

body.financial-wide .content {
  width: calc(100vw - 280px) !important;
  max-width: calc(100vw - 280px) !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding-right: 8px !important;
  box-sizing: border-box !important;
}

body.financial-wide .content > .card,
body.financial-wide .content article.card {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

body.financial-wide .card-body,
body.financial-wide .table-wrap,
body.financial-wide .financial-table-wrap {
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
}

/* La tabla usa todo el marco blanco */
body.financial-wide .financial-responsive-table,
body.financial-wide .financial-table {
  width: 100% !important;
  table-layout: auto !important;
}

/* Un poco más compacto para que acompañe mejor */
body.financial-wide .financial-responsive-table th,
body.financial-wide .financial-responsive-table td,
body.financial-wide .financial-table th,
body.financial-wide .financial-table td {
  font-size: 10.5px !important;
  padding: 0.24rem 0.26rem !important;
  line-height: 1.1 !important;
}

body.financial-wide .financial-responsive-table .button-link,
body.financial-wide .financial-responsive-table button,
body.financial-wide .financial-table .button-link,
body.financial-wide .financial-table button {
  font-size: 10px !important;
  padding: 0.14rem 0.24rem !important;
  white-space: nowrap !important;
}

body.financial-wide .financial-responsive-table input[type="number"],
body.financial-wide .financial-table input[type="number"] {
  width: 72px !important;
  min-width: 72px !important;
  font-size: 10px !important;
  padding: 0.10rem 0.16rem !important;
}

/* En pantallas más grandes, aprovechar todavía más ancho */
@media (min-width: 1500px) {
  body.financial-wide .shell {
    grid-template-columns: 215px minmax(0, 1fr) !important;
    column-gap: 18px !important;
  }

  body.financial-wide .content {
    width: calc(100vw - 255px) !important;
    max-width: calc(100vw - 255px) !important;
  }
}

/* En pantallas medianas, preservar estética sin scroll */
@media (max-width: 1550px) {
  body.financial-wide .content {
    width: calc(100vw - 265px) !important;
    max-width: calc(100vw - 265px) !important;
  }
}

/* =========================
   FINANZAS FULL WIDTH
   ========================= */
body.financial-wide .content {
  max-width: none !important;
  width: 100% !important;
}

body.financial-wide .card {
  width: 100% !important;
  max-width: none !important;
}

body.financial-wide .card-body {
  overflow-x: visible !important;
}

body.financial-wide .table-wrap,
body.financial-wide .financial-table-wrap {
  overflow-x: visible !important;
  width: 100% !important;
  max-width: 100% !important;
}

body.financial-wide .table,
body.financial-wide .financial-table {
  width: 100% !important;
  min-width: 0 !important;
  table-layout: auto !important;
}

body.financial-wide .table th,
body.financial-wide .table td,
body.financial-wide .financial-table th,
body.financial-wide .financial-table td {
  white-space: normal !important;
  word-break: break-word;
  overflow-wrap: anywhere;
  font-size: 11px !important;
  line-height: 1.15;
  padding: 0.38rem 0.42rem !important;
  vertical-align: middle;
}

body.financial-wide .table th,
body.financial-wide .financial-table th {
  font-size: 10.5px !important;
}

body.financial-wide .table .button-link,
body.financial-wide .table button,
body.financial-wide .financial-table .button-link,
body.financial-wide .financial-table button {
  padding: 0.18rem 0.38rem !important;
  font-size: 11px !important;
  line-height: 1.05;
  white-space: nowrap !important;
}

/* KPIs más compactos */
body.financial-wide .metric-card {
  min-width: 0;
}

body.financial-wide .metric-card span {
  font-size: 10.5px !important;
  line-height: 1.05;
}

body.financial-wide .metric-card strong {
  font-size: 16px !important;
  line-height: 1.05;
}

/* Aprovechar mejor el ancho en desktop */
@media (min-width: 1200px) {
  body.financial-wide .shell {
    grid-template-columns: 230px minmax(0, 1fr) !important;
  }
}

/* En resoluciones medias, apretar todavía más la tabla */
@media (max-width: 1500px) {
  body.financial-wide .table th,
  body.financial-wide .table td,
  body.financial-wide .financial-table th,
  body.financial-wide .financial-table td {
    font-size: 10.5px !important;
    padding: 0.32rem 0.34rem !important;
  }

  body.financial-wide .table .button-link,
  body.financial-wide .table button,
  body.financial-wide .financial-table .button-link,
  body.financial-wide .financial-table button {
    font-size: 10.5px !important;
    padding: 0.15rem 0.30rem !important;
  }
}
