*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  background: var(--bg);
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a {
  color: var(--color-teal);
  font-weight: 700;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

.main {
  max-width: var(--content-max);
  margin: 34px auto 60px;
  padding: 0 24px;
}

body:has(.global-sidebar) .main {
  margin-left: calc(var(--sidebar-width) + max(24px, calc((100vw - var(--sidebar-width) - var(--content-max)) / 2)));
}

h1,
h2,
h3 {
  color: var(--text-strong);
  letter-spacing: -0.035em;
  line-height: 1.15;
}

h1 {
  font-size: clamp(1.7rem, 2.2vw, 2.35rem);
  margin: 0 0 12px;
}

h2 {
  font-size: 1.35rem;
}

h3 {
  font-size: 1.08rem;
}

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

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 24px;
  margin-bottom: 22px;
  box-shadow: var(--shadow-md);
}

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

.kpi {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--surface-soft) 100%);
}

.kpi span {
  display: block;
  margin-bottom: 8px;
  color: var(--text-muted);
  font-size: 0.92rem;
}

.kpi h3 {
  margin: 0;
}

.badge,
.status-badge {
  display: inline-flex;
  align-items: center;
  width: max-content;
  border-radius: var(--radius-pill);
  padding: 6px 12px;
  background: #E8F6F3;
  color: var(--color-teal);
  font-size: 0.84rem;
  font-weight: 900;
}

.ok,
.alert-success {
  background: var(--success-bg);
  color: var(--success);
  border: 1px solid var(--success-border);
  padding: 12px 14px;
  border-radius: var(--radius-md);
  margin: 16px 0;
}

.warn,
.alert-warning {
  background: var(--warning-bg);
  color: var(--warning);
  border: 1px solid var(--warning-border);
  padding: 12px 14px;
  border-radius: var(--radius-md);
  margin: 16px 0;
}

.bad,
.alert-danger,
.error {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid var(--danger-border);
  padding: 12px 14px;
  border-radius: var(--radius-md);
  margin: 16px 0;
}

.btn,
button,
input[type="submit"],
input[type="button"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0;
  border-radius: var(--radius-md);
  background: var(--color-teal);
  color: #fff;
  padding: 11px 15px;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
  text-decoration: none;
}

.btn:hover,
button:hover {
  filter: brightness(0.96);
  text-decoration: none;
}

.btn-primary {
  background: var(--color-teal);
}

.btn-secondary,
button.secondary {
  background: var(--color-navy);
}

.btn-danger,
button.danger {
  background: var(--danger);
}

.btn-sm {
  padding: 8px 11px;
  font-size: 0.86rem;
  border-radius: var(--radius-sm);
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 10px 12px;
  font: inherit;
  color: var(--text);
  background: var(--surface);
}

table {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface);
}

td,
th {
  padding: 12px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  font-size: 0.92rem;
}

th {
  background: var(--surface-soft);
  color: var(--text-strong);
  font-weight: 900;
}

@media (max-width: 980px) {
  .main,
  body:has(.global-sidebar) .main {
    margin: 22px auto 50px;
    padding: 0 16px;
  }

  .card {
    padding: 18px;
  }
}

/* CERTUS SPRINT 2 — Operational dashboard components */
.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.card-header h2{margin:0;font-size:1.05rem}
.card-header p{margin:4px 0 0;color:var(--text-muted);font-size:.92rem}
.card-link{font-weight:800;font-size:.9rem;color:var(--color-teal);text-decoration:none;white-space:nowrap}
.page-eyebrow{margin:0 0 6px;color:var(--color-teal);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.page-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}
.kpi-card{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}
.kpi-label{margin:0;color:var(--text-muted);font-size:.86rem;font-weight:800}
.kpi-value{display:block;margin-top:8px;font-size:2rem;line-height:1;color:var(--text-strong);letter-spacing:-.04em}
.kpi-hint{margin:8px 0 0;color:var(--text-muted);font-size:.9rem}
.empty-state{border:1px dashed var(--border);background:var(--surface-soft);border-radius:var(--radius-lg);padding:32px;text-align:center}
.empty-state-compact{padding:22px;text-align:left}
.dashboard-list{display:grid;gap:10px}
.dashboard-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface)}
.dashboard-row strong{display:block;color:var(--text-strong)}
.dashboard-row span,.dashboard-row small{color:var(--text-muted)}
.dashboard-row-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:5px;color:var(--text-muted);font-size:.88rem}
.quick-actions-grid{display:grid;gap:10px}
.quick-actions-grid .btn{width:100%;justify-content:flex-start}
.status-label{display:inline-flex;align-items:center;width:max-content;border-radius:var(--radius-pill);padding:5px 10px;background:var(--surface-soft);color:var(--text-muted);font-size:.78rem;font-weight:900}
@media(max-width:720px){.card-header,.dashboard-row{grid-template-columns:1fr}.dashboard-row{align-items:stretch}.page-actions{width:100%;justify-content:flex-start}}

/* CERTUS COMPONENT SYSTEM V1 — START */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:24px}
.page-eyebrow{margin:0 0 6px;color:var(--color-teal);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.page-title{margin:0;color:var(--text-strong);font-size:clamp(1.7rem,2.2vw,2.35rem);line-height:1.12;letter-spacing:-.04em}
.page-subtitle{margin:6px 0 0;max-width:780px;color:var(--text-muted)}
.page-actions,.card-actions,.form-actions,.table-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}

.btn,button.btn,a.btn,input[type="submit"].btn,input[type="button"].btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 16px;border-radius:var(--radius-md);border:1px solid transparent;background:var(--surface);color:var(--text);font:inherit;font-weight:800;line-height:1;text-decoration:none;cursor:pointer;white-space:nowrap}
.btn:hover{text-decoration:none;filter:brightness(.98)}
.btn-primary{background:var(--color-teal);color:#fff}
.btn-secondary,.btn-muted{background:var(--surface);color:var(--text);border-color:var(--border)}
.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent}
.btn-danger{background:var(--danger);color:#fff}
.btn-success{background:var(--success);color:#fff}
.btn-sm{min-height:34px;padding:0 12px;font-size:.88rem;border-radius:var(--radius-sm)}
.btn-lg{min-height:48px;padding:0 20px}
.btn-icon{width:40px;min-width:40px;padding:0}
.btn-block{width:100%}

.card,.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-sm)}
.panel-muted{background:var(--surface-soft)}
.card-header,.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.card-title,.section-title{margin:0;color:var(--text-strong);font-size:1.08rem;line-height:1.2;letter-spacing:-.025em}
.card-subtitle,.section-subtitle{margin:4px 0 0;color:var(--text-muted);font-size:.92rem}
.card-body{min-width:0}
.card-footer{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px;margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}
.card-link{color:var(--color-teal);font-size:.9rem;font-weight:800;text-decoration:none;white-space:nowrap}

.kpi-card{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}
.kpi-label{margin:0;color:var(--text-muted);font-size:.86rem;font-weight:800}
.kpi-value{display:block;margin-top:8px;color:var(--text-strong);font-size:2rem;line-height:1;letter-spacing:-.04em}
.kpi-hint{margin:8px 0 0;color:var(--text-muted);font-size:.9rem}

.badge,.badge-status,.badge-count,.badge-plan{display:inline-flex;align-items:center;justify-content:center;width:max-content;border-radius:var(--radius-pill);padding:5px 10px;background:var(--surface-soft);color:var(--text-muted);font-size:.78rem;font-weight:900;line-height:1}
.badge-count:empty,.badge-count[data-count="0"]{display:none}
.badge-soft,.badge-neutral{background:var(--surface-soft);color:var(--text-muted)}
.badge-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}
.badge-warning{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}
.badge-danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}
.badge-plan{background:#E8F6F3;color:var(--color-teal)}
.status-label{display:inline-flex;align-items:center;width:max-content;border-radius:var(--radius-pill);padding:5px 10px;background:var(--surface-soft);color:var(--text-muted);font-size:.78rem;font-weight:900}

.alert,.alert-info,.alert-success,.alert-warning,.alert-danger,.ok,.warn,.bad{border-radius:var(--radius-lg);padding:14px 16px;margin:16px 0;border:1px solid var(--border);background:var(--surface);color:var(--text)}
.alert strong{display:block;margin-bottom:4px;color:var(--text-strong)}
.alert p{margin:0;color:var(--text-muted)}
.alert-success,.ok{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}
.alert-warning,.warn{background:var(--warning-bg);color:var(--warning);border-color:var(--warning-border)}
.alert-danger,.bad{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}
.alert-info{background:var(--info-bg);color:var(--info);border-color:var(--info-border)}

.table-wrap{width:100%;overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface)}
.data-table{width:100%;min-width:720px;border-collapse:collapse;background:var(--surface)}
.data-table th{text-align:left;padding:14px 16px;color:var(--text-muted);background:var(--surface-soft);border-bottom:1px solid var(--border);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em}
.data-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
.data-table tr:last-child td{border-bottom:0}
.table-meta{color:var(--text-muted);font-size:.88rem}
.table-empty-row{padding:24px;text-align:center;color:var(--text-muted)}

.form{display:grid;gap:18px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.form-group{display:grid;gap:7px}
.form-label{color:var(--text-strong);font-size:.88rem;font-weight:900}
.form-control,.form-select,.form-textarea,input.form-control,select.form-select,textarea.form-textarea{width:100%;min-height:42px;border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;background:var(--surface);color:var(--text);font:inherit}
.form-textarea,textarea.form-textarea{min-height:120px;resize:vertical}
.form-control:focus,.form-select:focus,.form-textarea:focus{outline:3px solid rgba(47,126,121,.16);border-color:var(--color-teal)}
.form-help{margin:0;color:var(--text-muted);font-size:.86rem}
.form-error{margin:0;color:var(--danger);font-size:.86rem;font-weight:800}
.checkbox-row,.radio-row{display:flex;align-items:flex-start;gap:10px}

.empty-state{border:1px dashed var(--border);background:var(--surface-soft);border-radius:var(--radius-lg);padding:32px;text-align:center}
.empty-state-compact{padding:22px;text-align:left}
.empty-state-inline{padding:14px;text-align:left;border-radius:var(--radius-md)}
.empty-state h2,.empty-state h3{margin:0 0 8px;color:var(--text-strong)}
.empty-state p{margin:0;color:var(--text-muted)}

.dashboard-list,.activity-list,.record-list{display:grid;gap:10px}
.dashboard-row,.activity-item,.record-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface)}
.dashboard-row strong,.activity-item strong,.record-item strong{display:block;color:var(--text-strong)}
.dashboard-row span,.dashboard-row small,.activity-item span,.activity-item small,.record-item span,.record-item small{color:var(--text-muted)}
.dashboard-row-meta,.activity-meta,.record-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:5px;color:var(--text-muted);font-size:.88rem}

.tabs{display:flex;align-items:center;gap:8px;overflow-x:auto;border-bottom:1px solid var(--border);margin-bottom:18px}
.tab-link{display:inline-flex;align-items:center;min-height:40px;padding:0 12px;color:var(--text-muted);border-bottom:2px solid transparent;font-weight:900;text-decoration:none;white-space:nowrap}
.tab-link.is-active,.tab-link.active{color:var(--color-teal);border-bottom-color:var(--color-teal)}

.profile-card,.user-card,.integration-card,.billing-plan-card,.security-log-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}

.quick-actions-grid{display:grid;gap:10px}
.quick-actions-grid .btn{width:100%;justify-content:flex-start}

.text-muted{color:var(--text-muted)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:12px}.hidden{display:none}

@media(max-width:720px){.page-header,.card-header,.section-header{flex-direction:column}.dashboard-row,.activity-item,.record-item{grid-template-columns:1fr}.page-actions,.card-actions,.form-actions,.table-actions{width:100%;justify-content:flex-start}.form-grid{grid-template-columns:1fr}.card,.panel{padding:18px}}
/* CERTUS COMPONENT SYSTEM V1 — END */

/* CERTUS SPRINT 3 BATCH 2A — Profile and team components */
.profile-hero{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(260px,.7fr);gap:16px;margin-bottom:16px}
.profile-layout,.page-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.82fr);gap:16px;align-items:start}
.profile-stack,.user-list,.role-list,.retention-grid{display:grid;gap:16px}
.profile-identity{display:flex;align-items:center;gap:14px}
.profile-avatar{width:58px;height:58px;border-radius:var(--radius-pill);background:#eef6f5;color:var(--color-teal);display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:1.35rem;flex:0 0 auto}
.profile-card,.profile-panel,.summary-card,.user-item,.role-item,.retention-grid>div,.helper-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}
.profile-panel h2,.profile-panel h3,.panel h2,.summary-card strong,.user-item strong,.role-item strong,.retention-grid strong,.helper-box strong{margin-top:0;color:var(--text-strong)}
.profile-panel p,.panel-intro,.role-item span,.retention-grid span,.helper-box p,.user-meta span{color:var(--text-muted)}
.profile-actions,.hero-actions,.user-actions{display:flex;align-items:center;justify-content:flex-start;gap:10px;flex-wrap:wrap}
.check-row{display:flex;align-items:center;gap:8px;min-height:44px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-soft);font-weight:800;color:var(--text-strong)}
.check-row input{width:auto;min-height:auto}
.field{display:grid;gap:7px}
.field.full{grid-column:1/-1}
.field label,.form-grid label{color:var(--text-strong);font-size:.88rem;font-weight:900}
.form-grid input:not([type="hidden"]),.form-grid select{width:100%;min-height:42px;border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;background:var(--surface);color:var(--text);font:inherit}
.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}
.summary-card small{display:block;color:var(--text-muted);font-weight:900;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em;font-size:.72rem}
.summary-card strong{display:block;font-size:1.85rem}
.summary-card span{display:block;margin-top:6px;color:var(--text-muted);font-size:.88rem;font-weight:700}
.users-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.user-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center}
.user-item-head,.user-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.user-meta{gap:8px 12px}
.mini-pill{display:inline-flex;align-items:center;gap:6px;min-height:28px;padding:6px 10px;border-radius:var(--radius-pill);background:var(--surface-soft);color:var(--text-muted);font-size:.78rem;font-weight:900}
@media(max-width:1180px){.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.page-grid,.profile-layout{grid-template-columns:1fr}}
@media(max-width:760px){.profile-hero,.summary-grid{grid-template-columns:1fr}.user-item{grid-template-columns:1fr}.user-actions,.hero-actions{justify-content:flex-start}.hero-actions .btn{width:100%}}

/* CERTUS SPRINT 3 BATCH 2B — Billing and integrations */
.billing-provider-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:14px 0}
.billing-provider-card,.integration-provider-card{border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;background:var(--surface)}
.billing-provider-card p,.integration-provider-card p{margin:.45rem 0 0;color:var(--text-muted)}
.inline-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.inline-form .form-control{max-width:160px}
.table-wrap table{margin:0}
.table-wrap table th,.table-wrap table td{white-space:normal}
.btn-warning{background:var(--warning-bg);color:var(--warning);border-color:var(--warning-border)}
.mt-2{margin-top:16px}
.mb-2{margin-bottom:16px}

/* CERTUS SPRINT 3 BATCH 3 — Trust, reporting and retention pages */
.hero{background:var(--color-navy);color:#fff;border-radius:var(--radius-xl);padding:24px;margin-bottom:18px}
.hero h1,.hero h2{margin:0;color:#fff}
.hero p{margin:8px 0 0;color:rgba(255,255,255,.78)}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.item{display:flex;gap:14px;align-items:flex-start;border-bottom:1px solid var(--border);padding:14px 0}
.item:last-child{border-bottom:0}
.dot{width:26px;height:26px;border-radius:var(--radius-pill);display:grid;place-items:center;font-weight:800;flex:0 0 auto}
.progress{width:100%;height:12px;appearance:none;border:0;border-radius:var(--radius-pill);overflow:hidden;background:var(--surface-soft)}
.progress::-webkit-progress-bar{background:var(--surface-soft);border-radius:var(--radius-pill)}
.progress::-webkit-progress-value{background:var(--color-teal);border-radius:var(--radius-pill)}
.progress::-moz-progress-bar{background:var(--color-teal);border-radius:var(--radius-pill)}
.progress-inline{min-width:160px}
.metric{font-size:1.85rem;font-weight:900;color:var(--text-strong)}
.bar{width:100%}
.flash{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}
.full{grid-column:1/-1}
.card.flash{border-color:var(--success-border)}

/* CE
/* CE
/* CE

/* CERTUS SPRINT 3 BATCH 4 — Matter/case workspace */
.case-layout,.case-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.35fr);gap:18px;align-items:start}
.case-main,.case-stack,.case-side{display:grid;gap:16px;min-width:0}
.case-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.case-head-spaced{margin-bottom:10px}
.case-tabs{display:flex;align-items:center;gap:8px;overflow-x:auto;margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.case-tabs a{display:inline-flex;align-items:center;min-height:38px;padding:0 12px;border-radius:var(--radius-pill);color:var(--text-muted);font-weight:900;text-decoration:none;white-space:nowrap}
.case-tabs a.active,.case-tabs a.is-active{background:#E8F6F3;color:var(--color-teal)}
.case-actions,.actions-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.actions-row-bottom{margin-top:12px;align-items:flex-end}
.case-action-stack{display:grid;gap:8px}
.case-action-stack .btn{width:100%;justify-content:center}
.card-flat{box-shadow:none}
.doc-form{box-shadow:none}
.version-history{margin-top:12px}
.progress-value{width:100%;height:12px;appearance:none;border:0;border-radius:var(--radius-pill);overflow:hidden;background:var(--surface-soft)}
.progress-value::-webkit-progress-bar{background:var(--surface-soft);border-radius:var(--radius-pill)}
.progress-value::-webkit-progress-value{background:var(--color-teal);border-radius:var(--radius-pill)}
.progress-value::-moz-progress-bar{background:var(--color-teal);border-radius:var(--radius-pill)}
.min-w-160{min-width:160px}.min-w-190{min-width:190px}.min-w-200{min-width:200px}.min-w-220{min-width:220px}.flex-1{flex:1}
@media(max-width:980px){.case-layout,.case-grid{grid-template-columns:1fr}.case-tabs{padding-bottom:10px}.min-w-160,.min-w-190,.min-w-200,.min-w-220{min-width:0;width:100%}}

/* CERTUS SPRINT 4 BATCH 1 — Stability guardrails */
html,body{max-width:100%;overflow-x:hidden}
*,*::before,*::after{box-sizing:border-box}
.app-main,.app-content,.app-shell,.workspace-frame,.workspace-body,.page-header,.card,.panel,.profile-card,.profile-panel,.summary-card,.user-item,.table-wrap,.card-header,.section-header,.case-layout,.case-grid,.dashboard-grid,.dashboard-main-grid{min-width:0}
.table-wrap{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-wrap table,.data-table{width:100%;min-width:640px}
.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.break-anywhere,.user-meta span,.dashboard-row-meta,.card-subtitle,.section-subtitle,.page-subtitle,.table-meta{overflow-wrap:anywhere;word-break:break-word}
.page-header,.card-header,.section-header,.page-actions,.card-actions,.profile-actions,.hero-actions,.actions-row,.quick-actions-grid{min-width:0;max-width:100%}
.page-actions,.card-actions,.profile-actions,.hero-actions,.actions-row{flex-wrap:wrap}
:where(a,button,input,select,textarea,[tabindex]):focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px}
button:disabled,.btn:disabled,.btn[aria-disabled="true"],.is-disabled{opacity:.58;cursor:not-allowed;pointer-events:none}
.state-message,.state-empty,.state-error,.state-loading,.state-permission{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);padding:var(--space-5);color:var(--text)}
.state-message h3,.state-empty h3,.state-error h3,.state-loading h3,.state-permission h3{margin:0 0 var(--space-2);color:var(--text-strong);font-size:var(--text-lg)}
.state-message p,.state-empty p,.state-error p,.state-loading p,.state-permission p{margin:0;color:var(--text-muted);line-height:1.55}
.state-error{border-color:var(--danger-border);background:var(--danger-bg);color:var(--danger)}
.state-permission{border-color:var(--warning-border);background:var(--warning-bg);color:var(--warning)}
.skeleton{display:block;min-height:1rem;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--surface-soft),rgba(148,163,184,.22),var(--surface-soft));background-size:200% 100%;animation:certus-skeleton 1.2s ease-in-out infinite}
@keyframes certus-skeleton{0%{background-position:200% 0}100%{background-position:-200% 0}}
.floating-action{right:var(--safe-right);bottom:var(--safe-bottom)}
@media(max-width:980px){.page-header,.card-header,.section-header{align-items:flex-start}.page-actions,.card-actions,.profile-actions,.hero-actions,.actions-row{width:100%}.page-actions .btn,.hero-actions .btn{max-width:100%}.table-wrap table,.data-table{min-width:720px}}
@media(max-width:640px){.workspace-frame,.card,.panel,.profile-card,.profile-panel,.summary-card{border-radius:var(--radius-lg)}.page-title,h1{font-size:var(--text-2xl);line-height:1.15;overflow-wrap:anywhere}.btn{min-width:0;max-width:100%}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}

/* CERTUS SPRINT 4 BATCH 2A — Extracted dashboard legacy CSS */
* { box-sizing: border-box; }

        :root {
            --bg: #f4f7fb;
            --card: rgba(255,255,255,.90);
            --solid: #ffffff;
            --text: #172033;
            --muted: #667085;
            --primary: #15324B;
            --accent: #2F7E79;
            --accent-dark: #246661;
            --border: #d8e2ec;
            --soft: #eef6f5;
            --danger: #b42318;
            --warning: #b54708;
            --success: #067647;
            --blue: #175cd3;
            --shadow: 0 18px 45px rgba(21, 50, 75, .10);
            --shadow-soft: 0 10px 28px rgba(21, 50, 75, .08);
        }

        body {
            margin: 0;
            font-family: Arial, sans-serif;
            color: var(--text);
            background:
                radial-gradient(circle at 12% 8%, rgba(47,126,121,.16), transparent 30%),
                radial-gradient(circle at 88% 0%, rgba(21,50,75,.12), transparent 28%),
                linear-gradient(180deg, #fbfdff 0%, #edf3f8 100%);
        }

        a { color: inherit; }

        header {
            background:
                radial-gradient(circle at 18% 25%, rgba(47,126,121,.48), transparent 28%),
                radial-gradient(circle at 85% 0%, rgba(255,255,255,.12), transparent 32%),
                linear-gradient(135deg, #15324B, #0e2438);
            color: white;
            padding: 30px 0;
        }

        .wrap {
            width: min(1480px, calc(100% - 34px));
            margin: 0 auto;
        }

        .topbar {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 18px;
            flex-wrap: wrap;
        }

        .brand h1 {
            margin: 0;
            font-size: clamp(1.7rem, 3vw, 2.55rem);
            letter-spacing: -.05em;
        }

        .brand p {
            margin: 8px 0 0;
            color: rgba(255,255,255,.78);
            line-height: 1.45;
        }

        .top-actions {
            display: flex;
            align-items: center;
            gap: 10px;
            flex-wrap: wrap;
        }

        .plan-badge,
        .logout {
            text-decoration: none;
            color: white;
            font-weight: 900;
            padding: 10px 14px;
            border-radius: 999px;
            background: rgba(255,255,255,.12);
            border: 1px solid rgba(255,255,255,.22);
        }

        .premium-badge {
            background: linear-gradient(135deg, #fef3c7, #fde68a);
            color: #78350f;
            border: 1px solid rgba(255,255,255,.30);
        }

        .section { padding: 24px 0 46px; }

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

        .alert.ok {
            background: #dcfae6;
            border-color: #abefc6;
            color: #067647;
        }

        .alert.bad {
            background: #fee4e2;
            border-color: #fecdca;
            color: #b42318;
        }

        .alert.warn {
            background: #fef0c7;
            border-color: #fedf89;
            color: #b54708;
        }

        .premium-hero {
            background: linear-gradient(135deg, rgba(255,255,255,.97), rgba(239,248,255,.92));
            border: 1px solid #b2ddff;
            border-radius: 28px;
            padding: 20px;
            box-shadow: var(--shadow);
            margin-bottom: 18px;
            display: grid;
            grid-template-columns: 1.5fr .9fr;
            gap: 16px;
            align-items: center;
        }

        .premium-hero h2 {
            margin: 0 0 8px;
            color: var(--primary);
            letter-spacing: -.04em;
        }

        .premium-hero p {
            margin: 0;
            color: var(--muted);
            line-height: 1.55;
        }

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

        .btn {
            border: 0;
            border-radius: 15px;
            padding: 12px 15px;
            font-weight: 900;
            cursor: pointer;
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            font-family: inherit;
        }

        .btn-primary { background: var(--accent); color: white; }
        .btn-primary:hover { background: var(--accent-dark); }
        .btn-muted { background: #eef2f7; color: var(--primary); }
        .btn-blue { background: #eff8ff; color: var(--blue); }
        .btn-warning { background: #fff7ed; color: var(--warning); }
        .btn-danger { background: #fee4e2; color: var(--danger); }
        .btn-danger:hover { background: #fecdca; }
        .btn-disabled { background: #f2f4f7; color: #98a2b3; cursor: not-allowed; }

        .premium-cta {
            width: 100%;
            margin-top: 8px;
            border: 0;
            border-radius: 18px;
            padding: 14px;
            background: linear-gradient(135deg, #15324B, #2F7E79);
            color: white;
            font-weight: 900;
            cursor: pointer;
            box-shadow: 0 12px 24px rgba(21,50,75,.18);
        }

        .premium-cta.disabled {
            background: #e4e7ec;
            color: #667085;
            cursor: not-allowed;
            box-shadow: none;
        }


        .public-link-card {
            background: linear-gradient(135deg, rgba(255,255,255,.97), rgba(238,246,245,.95));
            border: 1px solid #b7dcd8;
            border-radius: 26px;
            padding: 20px;
            box-shadow: var(--shadow);
            margin-bottom: 18px;
            display: grid;
            grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
            gap: 18px;
            align-items: center;
        }

        .public-link-copy small {
            display: inline-block;
            color: var(--accent);
            font-weight: 900;
            text-transform: uppercase;
            letter-spacing: .05em;
            font-size: .78rem;
            margin-bottom: 7px;
        }

        .public-link-copy h2 {
            margin: 0 0 8px;
            color: var(--primary);
            letter-spacing: -.04em;
        }

        .public-link-copy p {
            margin: 0;
            color: var(--muted);
            line-height: 1.55;
        }

        .public-link-box {
            background: rgba(255,255,255,.78);
            border: 1px solid #d7e8e6;
            border-radius: 20px;
            padding: 14px;
        }

        .public-link-input {
            width: 100%;
            border: 1px solid #cfd8e3;
            background: #ffffff;
            border-radius: 14px;
            padding: 13px 14px;
            color: var(--primary);
            font-weight: 800;
            margin-bottom: 10px;
        }

        .public-link-actions {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 10px;
        }

        .public-link-empty {
            background: #fff7ed;
            border: 1px solid #fed7aa;
            color: #9a3412;
            border-radius: 16px;
            padding: 14px;
            font-weight: 800;
            line-height: 1.45;
        }

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

        .stat {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 22px;
            padding: 18px;
            box-shadow: var(--shadow-soft);
            backdrop-filter: blur(14px);
        }

        .stat small {
            display: block;
            color: var(--muted);
            margin-bottom: 9px;
            font-weight: 800;
            font-size: .82rem;
        }

        .stat strong {
            display: block;
            color: var(--primary);
            font-size: 2rem;
            letter-spacing: -.05em;
        }

        .stat span {
            display: block;
            color: var(--muted);
            margin-top: 6px;
            font-size: .82rem;
            line-height: 1.35;
        }

        .layout {
            display: grid;
            grid-template-columns: minmax(0, 1fr) 380px;
            gap: 22px;
            align-items: start;
        }

        .panel,
        .side-panel,
        .lead-card,
        .kanban-col {
            background: var(--card);
            border: 1px solid var(--border);
            box-shadow: var(--shadow);
            backdrop-filter: blur(14px);
        }

        .panel {
            border-radius: 26px;
            overflow: hidden;
            margin-bottom: 18px;
        }

        .panel-head {
            padding: 20px;
            border-bottom: 1px solid #e7edf4;
            display: flex;
            justify-content: space-between;
            gap: 16px;
            align-items: center;
            flex-wrap: wrap;
        }

        .panel-head h2 {
            margin: 0;
            color: var(--primary);
            letter-spacing: -.04em;
        }

        .panel-head p {
            margin: 6px 0 0;
            color: var(--muted);
            line-height: 1.45;
        }

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

        .tab {
            text-decoration: none;
            padding: 10px 13px;
            border-radius: 999px;
            background: #eef2f7;
            color: var(--primary);
            font-weight: 900;
            font-size: .87rem;
        }

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

        .panel-note {
            display:inline-flex;
            align-items:center;
            min-height:38px;
            padding:9px 12px;
            border-radius:999px;
            background:#eef6f5;
            color:var(--primary);
            font-weight:900;
            font-size:.84rem;
        }

        .case-progress {
            height: 9px;
            border-radius: 999px;
            background: #eef2f7;
            overflow: hidden;
            margin-top: 12px;
        }

        .case-progress > div {
            height: 100%;
            background: var(--accent);
            border-radius: 999px;
        }

        .filters {
            padding: 16px 20px;
            border-bottom: 1px solid #e7edf4;
            background: rgba(255,255,255,.55);
        }

        .filters form {
            display: grid;
            grid-template-columns: minmax(220px, 1fr) auto auto;
            gap: 10px;
        }

        .filters input {
            width: 100%;
            padding: 13px 14px;
            border-radius: 14px;
            border: 1px solid #ccd6e2;
            outline: none;
            background: white;
            font-size: .95rem;
        }

        .quick-filters {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin-top: 12px;
        }

        .quick-filters a,
        .locked-chip {
            text-decoration: none;
            border-radius: 999px;
            padding: 8px 12px;
            font-weight: 800;
            font-size: .86rem;
            background: #eef6f5;
            color: var(--primary);
        }

        .quick-filters a.active {
            background: var(--primary);
            color: white;
        }

        .locked-chip {
            opacity: .62;
            cursor: not-allowed;
            border: 1px dashed #b9c8d7;
        }

        .content-area { padding: 18px; }

        .leads-grid {
            display: grid;
            gap: 14px;
        }

        .lead-card {
            border-radius: 22px;
            padding: 18px;
            background: rgba(255,255,255,.90);
        }

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

        .lead-title h3 {
            margin: 0 0 6px;
            color: var(--primary);
            font-size: 1.15rem;
        }

        .lead-title p {
            margin: 0;
            color: var(--muted);
            line-height: 1.45;
        }

        .lead-meta {
            margin-top: 14px;
            display: grid;
            grid-template-columns: repeat(4, minmax(0, 1fr));
            gap: 10px;
        }

        .meta-item {
            background: #f8fafc;
            border: 1px solid #e6edf5;
            border-radius: 14px;
            padding: 11px;
        }

        .meta-item small {
            display: block;
            color: var(--muted);
            margin-bottom: 4px;
            font-size: .75rem;
            font-weight: 900;
            text-transform: uppercase;
            letter-spacing: .04em;
        }

        .meta-item strong {
            color: var(--text);
            font-size: .9rem;
            word-break: break-word;
        }

        .lead-objective {
            margin-top: 12px;
            background: #f7fbfa;
            border-color: rgba(47, 126, 121, 0.18);
        }

        .lead-objective strong {
            display: block;
            line-height: 1.55;
            white-space: pre-wrap;
        }

        .lead-internal-preview {
            background: #f8fafc;
            border-color: #e6edf5;
        }

        .lead-actions {
            display: flex;
            gap: 9px;
            flex-wrap: wrap;
            margin-top: 14px;
        }
        .inline-delete-form {
            display: inline-flex;
            margin: 0;
        }

        .pill {
            display: inline-flex;
            padding: 7px 11px;
            border-radius: 999px;
            font-weight: 900;
            font-size: .78rem;
            white-space: nowrap;
        }

        .pill.nuevo { background: #dbeafe; color: #1d4ed8; }
        .pill.contactado { background: #fef3c7; color: #92400e; }
        .pill.agendado { background: #d1fae5; color: #065f46; }
        .pill.cerrado { background: #dcfce7; color: #166534; }
        .pill.descartado { background: #fee2e2; color: #991b1b; }
        .pill.pendiente { background:#eff8ff; color:#175cd3; }
        .pill.procesando { background:#eef6f5; color:#2F7E79; }
        .pill.requiere_revision { background:#fff7ed; color:#b54708; }
        .pill.completada { background:#dcfae6; color:#067647; }
        .pill.fallida { background:#fee4e2; color:#b42318; }
        .pill.cancelada { background:#f2f4f7; color:#667085; }

        .urgencia {
            display: inline-flex;
            padding: 6px 10px;
            border-radius: 999px;
            font-size: .78rem;
            font-weight: 900;
        }

        .urgencia.alta { background: #fee4e2; color: #b42318; }
        .urgencia.media { background: #fef0c7; color: #b54708; }
        .urgencia.baja { background: #dcfae6; color: #067647; }

        .edit-form {
            margin-top: 16px;
            padding-top: 16px;
            border-top: 1px solid #e7edf4;
        }

        .edit-grid {
            display: grid;
            grid-template-columns: 1fr 1fr 1fr;
            gap: 12px;
        }

        .edit-form label {
            display: block;
            font-weight: 900;
            font-size: .86rem;
            margin-bottom: 6px;
            color: var(--primary);
        }

        .edit-form input,
        .edit-form select,
        .edit-form textarea {
            width: 100%;
            padding: 12px;
            border-radius: 13px;
            border: 1px solid #cfd8e3;
            background: white;
        }

        .edit-form textarea {
            min-height: 110px;
            resize: vertical;
        }

        .kanban {
            display: grid;
            grid-template-columns: repeat(5, minmax(220px, 1fr));
            gap: 12px;
            overflow-x: auto;
            padding-bottom: 8px;
        }

        .kanban-col {
            border-radius: 22px;
            padding: 14px;
            min-height: 240px;
            background: rgba(255,255,255,.9);
        }

        .kanban-col h3 {
            margin: 0 0 12px;
            color: var(--primary);
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-size: .98rem;
        }

        .kanban-card {
            background: #f8fafc;
            border: 1px solid #e6edf5;
            border-radius: 16px;
            padding: 12px;
            margin-bottom: 10px;
        }

        .kanban-card strong {
            display: block;
            color: var(--primary);
            margin-bottom: 5px;
        }

        .kanban-card span {
            display: block;
            color: var(--muted);
            font-size: .84rem;
            line-height: 1.4;
        }
        
        button.kanban-card {
    width: 100%;
    text-align: left;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

button.kanban-card:hover {
    transform: translateY(-2px);
    border-color: #b8c9da;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .08);
}

.lead-drawer-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, .46);
    z-index: 1200;
    display: none;
}

.lead-drawer-backdrop.show {
    display: block;
}

.lead-drawer {
    position: absolute;
    top: 0;
    right: 0;
    width: min(580px, 100%);
    height: 100%;
    background: #ffffff;
    overflow-y: auto;
    box-shadow: -10px 0 30px rgba(15, 23, 42, .15);
    padding: 22px;
}

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

.lead-drawer-head h2 {
    margin: 0;
    color: var(--primary);
    letter-spacing: -.03em;
}

.lead-drawer-head p {
    margin: 6px 0 0;
    color: var(--muted);
}

.drawer-close {
    border: 0;
    background: #eef2f7;
    color: var(--primary);
    min-width: 70px;
    height: 42px;
    padding: 0 14px;
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 900;
    cursor: pointer;
}

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

.drawer-block {
    background: #f8fafc;
    border: 1px solid #e6edf5;
    border-radius: 14px;
    padding: 12px;
}

.drawer-block small {
    display: block;
    color: var(--muted);
    margin-bottom: 5px;
    font-size: .75rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.drawer-block strong,
.drawer-block span {
    color: var(--text);
    word-break: break-word;
}

.drawer-section {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #e7edf4;
}

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

.hidden {
    display: none !important;
}

.helper-text {
    margin-top: 6px;
    color: var(--muted);
    font-size: .84rem;
    line-height: 1.4;
}

.conflict-panel {
    background: #fff7ed;
    border: 1px solid #fed7aa;
    border-radius: 18px;
    padding: 14px;
}

.conflict-panel h3 { color: #9a3412; }
.conflict-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.conflict-actions button { width: auto; }
.drawer-facts { display: grid; grid-template-columns: 1fr; gap: 8px; }

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

        .agenda-item {
            background: #f8fafc;
            border: 1px solid #e6edf5;
            border-radius: 18px;
            padding: 15px;
            display: grid;
            grid-template-columns: 160px 1fr auto;
            gap: 14px;
            align-items: center;
        }

        .agenda-time {
            color: var(--primary);
            font-weight: 900;
        }

        .agenda-detail strong {
            color: var(--primary);
            display: block;
            margin-bottom: 4px;
        }

        .agenda-detail span {
            color: var(--muted);
            font-size: .9rem;
        }

        .side-panel {
            border-radius: 28px;
            padding: 18px;
            position: sticky;
            top: 20px;
            background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.80));
        }

        .side-section {
            border-bottom: 1px solid #e7edf4;
            padding-bottom: 16px;
            margin-bottom: 16px;
        }

        .side-section:last-child {
            border-bottom: 0;
            margin-bottom: 0;
            padding-bottom: 0;
        }

        .side-section h2,
        .side-section h3 {
            margin: 0 0 10px;
            color: var(--primary);
            letter-spacing: -.03em;
        }

        .side-section p {
            color: var(--muted);
            margin: 0;
            line-height: 1.45;
            font-size: .92rem;
        }

        .insight,
        .feature {
            background: #f8fafc;
            border: 1px solid #e6edf5;
            border-radius: 16px;
            padding: 12px;
            margin-bottom: 10px;
        }

        .insight strong,
        .feature strong {
            display: block;
            color: var(--primary);
            margin-bottom: 4px;
        }

        .insight span,
        .feature span {
            color: var(--muted);
            font-size: .86rem;
            line-height: 1.4;
        }

        .feature.locked {
            cursor: pointer;
            opacity: .78;
        }

        .feature.locked:hover {
            background: #fff7ed;
            border-color: #fed7aa;
        }

        .progress {
            height: 9px;
            border-radius: 999px;
            background: #e5e7eb;
            overflow: hidden;
            margin-top: 8px;
        }

        .progress div {
            height: 100%;
            background: linear-gradient(90deg, var(--accent), var(--primary));
            border-radius: 999px;
        }

        .empty {
            border: 1px dashed #cbd5e1;
            border-radius: 20px;
            padding: 34px;
            text-align: center;
            color: var(--muted);
            background: white;
        }

        .toast {
            position: fixed;
            right: 24px;
            bottom: 24px;
            max-width: 400px;
            background: #15324B;
            color: white;
            padding: 16px 18px;
            border-radius: 18px;
            box-shadow: 0 18px 42px rgba(21, 50, 75, .28);
            transform: translateY(120px);
            opacity: 0;
            transition: .25s ease;
            z-index: 60;
            line-height: 1.45;
        }

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

        .modal-backdrop {
            position: fixed;
            inset: 0;
            background: rgba(15, 23, 42, .58);
            backdrop-filter: blur(8px);
            z-index: 80;
            display: none;
            align-items: center;
            justify-content: center;
            padding: 22px;
        }

        .modal-backdrop.show {
            display: flex;
        }

        .upgrade-modal {
            width: min(520px, 100%);
            background: #ffffff;
            border: 1px solid #d8e2ec;
            border-radius: 28px;
            box-shadow: 0 28px 80px rgba(21, 50, 75, .34);
            overflow: hidden;
        }

        .upgrade-modal-head {
            background:
                radial-gradient(circle at 15% 25%, rgba(47,126,121,.35), transparent 28%),
                linear-gradient(135deg, #15324B, #0e2438);
            color: white;
            padding: 22px;
        }

        .upgrade-modal-head h2 {
            margin: 0;
            font-size: 1.35rem;
            letter-spacing: -.03em;
        }

        .upgrade-modal-head p {
            margin: 8px 0 0;
            color: rgba(255,255,255,.78);
            line-height: 1.45;
        }

        .upgrade-modal-body {
            padding: 22px;
        }

        .upgrade-price {
            background: #f8fafc;
            border: 1px solid #e6edf5;
            border-radius: 18px;
            padding: 14px;
            margin-bottom: 14px;
        }

        .upgrade-price small {
            display: block;
            color: var(--muted);
            margin-bottom: 4px;
            font-weight: 800;
        }

        .upgrade-price strong {
            display: block;
            color: var(--primary);
            font-size: 1.6rem;
        }

        .upgrade-list {
            margin: 0;
            padding-left: 18px;
            color: var(--muted);
            line-height: 1.7;
        }

        .upgrade-modal-actions {
            padding: 0 22px 22px;
            display: flex;
            gap: 10px;
            justify-content: flex-end;
            flex-wrap: wrap;
        }

        @media (max-width: 1280px) {
            .stats { grid-template-columns: repeat(3, 1fr); }
            .layout { grid-template-columns: 1fr; }
            .side-panel {
                position: relative;
                top: auto;
            }
            .lead-meta { grid-template-columns: repeat(2, 1fr); }
        }

        @media (max-width: 760px) {
            .stats,
            .filters form,
            .public-link-card,
            .public-link-actions,
            .edit-grid,
            .lead-meta,
            .premium-hero,
            .agenda-item {
                grid-template-columns: 1fr;
            }

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

            .top-actions {
                width: 100%;
            }

            .plan-badge,
            .logout {
                width: 100%;
                text-align: center;
            }

            .toast {
                left: 16px;
                right: 16px;
                bottom: 16px;
                max-width: none;
            }

            .upgrade-modal-actions {
                flex-direction: column-reverse;
            }

            .upgrade-modal-actions .btn {
                width: 100%;
            }
        }

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

        .automation-summary-card,
        .automation-explainer,
        .automation-card {
            border: 1px solid var(--border);
            background: #ffffff;
            border-radius: 22px;
            box-shadow: 0 14px 34px rgba(15, 23, 42, .06);
        }

        .automation-summary-card {
            padding: 16px;
        }

        .automation-summary-card small {
            display: block;
            color: var(--muted);
            font-weight: 900;
            text-transform: uppercase;
            letter-spacing: .04em;
            font-size: .72rem;
        }

        .automation-summary-card strong {
            display: block;
            margin-top: 6px;
            color: var(--primary);
            font-size: 2rem;
            letter-spacing: -.05em;
        }

        .automation-summary-card span {
            display: block;
            margin-top: 4px;
            color: var(--muted);
            font-size: .86rem;
            line-height: 1.35;
        }

        .automation-summary-card.danger-soft {
            background: #fffafa;
            border-color: #fee4e2;
        }

        .automation-explainer {
            padding: 18px;
            margin-bottom: 16px;
            background: linear-gradient(135deg, #f8fafc, #ffffff);
        }

        .automation-explainer h3 {
            margin: 0 0 8px;
            color: var(--primary);
        }

        .automation-explainer p {
            margin: 0;
            color: var(--muted);
            line-height: 1.55;
            max-width: 920px;
        }

        .automation-list {
            display: grid;
            gap: 14px;
        }

        .automation-card {
            padding: 16px;
            display: grid;
            grid-template-columns: minmax(0, 1fr) 170px;
            gap: 14px;
            align-items: center;
        }

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

        .automation-card-head h3 {
            margin: 0;
            color: var(--primary);
            letter-spacing: -.03em;
        }

        .automation-card-head p,
        .automation-timing {
            margin: 4px 0 0;
            color: var(--muted);
            line-height: 1.4;
        }

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

        .automation-error {
            margin: 10px 0 0;
            color: #b42318;
            font-weight: 800;
        }

        .automation-actions {
            display: grid;
            gap: 8px;
        }

        @media (max-width: 1120px) {
            .automation-summary-grid,
            .automation-meta-grid {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }

            .automation-card {
                grid-template-columns: 1fr;
            }
        }

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


        /* Organización nueva del dashboard */
        header {
            padding: 18px 0;
        }

        .brand h1 {
            font-size: clamp(1.35rem, 2vw, 1.9rem);
        }

        .brand p {
            max-width: 760px;
            font-size: .94rem;
        }

        .workspace-hero {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 18px;
            align-items: center;
            background: rgba(255,255,255,.92);
            border: 1px solid var(--border);
            border-radius: 28px;
            padding: 20px;
            box-shadow: var(--shadow-soft);
            margin-bottom: 16px;
        }

        .workspace-hero .eyebrow,
        .public-link-mini small {
            display: inline-block;
            margin-bottom: 7px;
            color: var(--accent);
            text-transform: uppercase;
            letter-spacing: .08em;
            font-weight: 900;
            font-size: .72rem;
        }

        .workspace-hero h2 {
            margin: 0;
            color: var(--primary);
            letter-spacing: -.045em;
            font-size: clamp(1.55rem, 2.5vw, 2.2rem);
        }

        .workspace-hero p {
            margin: 7px 0 0;
            color: var(--muted);
            line-height: 1.5;
            max-width: 780px;
        }

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

        .btn-sm {
            min-height: 38px;
            padding: 9px 12px;
            border-radius: 13px;
            font-size: .84rem;
        }

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

        .kpi-card {
            position: relative;
            overflow: hidden;
            background: rgba(255,255,255,.93);
            border: 1px solid var(--border);
            border-radius: 24px;
            padding: 16px;
            box-shadow: var(--shadow-soft);
        }

        .kpi-card::before {
            content: "";
            position: absolute;
            inset: 0 0 auto 0;
            height: 4px;
            background: #d8e2ec;
        }

        .kpi-card.priority::before {
            background: linear-gradient(90deg, var(--accent), var(--primary));
        }

        .kpi-card small {
            display: block;
            color: var(--muted);
            font-weight: 900;
            text-transform: uppercase;
            letter-spacing: .045em;
            font-size: .72rem;
            margin-bottom: 8px;
        }

        .kpi-card strong {
            display: block;
            color: var(--primary);
            font-size: 2rem;
            letter-spacing: -.055em;
            line-height: 1;
        }

        .kpi-card span {
            display: block;
            color: var(--muted);
            margin-top: 8px;
            line-height: 1.35;
            font-size: .86rem;
        }

        .overview-grid {
            display: grid;
            gap: 14px;
        }

        .overview-section,
        .plan-card {
            background: #ffffff;
            border: 1px solid #e1e8f0;
            border-radius: 24px;
            padding: 18px;
            box-shadow: 0 12px 28px rgba(15,23,42,.05);
        }

        .section-title-row {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            gap: 14px;
            margin-bottom: 12px;
        }

        .section-title-row h3,
        .plan-card h3,
        .public-link-mini h3 {
            margin: 0;
            color: var(--primary);
            letter-spacing: -.03em;
        }

        .section-title-row p,
        .plan-card p {
            margin: 5px 0 0;
            color: var(--muted);
            line-height: 1.45;
        }

        .compact-list {
            display: grid;
            gap: 9px;
        }

        .compact-row {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 12px;
            align-items: center;
            padding: 12px;
            border: 1px solid #e6edf5;
            border-radius: 16px;
            background: #f8fafc;
        }

        .compact-row strong {
            display: block;
            color: var(--primary);
            margin-bottom: 3px;
        }

        .compact-row span {
            color: var(--muted);
            font-size: .86rem;
            line-height: 1.4;
        }

        .compact-actions {
            display: flex;
            gap: 8px;
            align-items: center;
            flex-wrap: wrap;
            justify-content: flex-end;
        }

        .empty.slim {
            padding: 18px;
            border-radius: 16px;
        }

        .work-queue-head {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 16px;
            align-items: center;
            padding: 18px;
            border-radius: 24px;
            border: 1px solid #dce8f2;
            background: linear-gradient(135deg, #ffffff, #f4fbfa);
            margin-bottom: 14px;
        }

        .work-queue-head h3 {
            margin: 0;
            color: var(--primary);
            letter-spacing: -.03em;
        }

        .work-queue-head p {
            margin: 6px 0 0;
            color: var(--muted);
            line-height: 1.45;
            max-width: 760px;
        }

        .work-queue-actions {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
            justify-content: flex-end;
        }

        .work-lanes {
            display: grid;
            grid-template-columns: repeat(4, minmax(0, 1fr));
            gap: 10px;
            margin-bottom: 14px;
        }

        .work-lanes article {
            border: 1px solid #e5edf5;
            border-radius: 18px;
            padding: 14px;
            background: #ffffff;
        }

        .work-lanes small {
            display: block;
            color: var(--muted);
            font-size: .72rem;
            font-weight: 900;
            text-transform: uppercase;
            letter-spacing: .04em;
        }

        .work-lanes strong {
            display: block;
            margin-top: 6px;
            color: var(--primary);
            font-size: 1.6rem;
            line-height: 1;
        }

        .work-lanes span {
            display: block;
            margin-top: 6px;
            color: var(--muted);
            font-size: .84rem;
            line-height: 1.35;
        }

        .work-run-card {
            margin-bottom: 14px;
        }

        .work-queue-list {
            display: grid;
            gap: 10px;
        }

        .work-item {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 14px;
            align-items: center;
            padding: 15px;
            border: 1px solid #e3ebf4;
            border-radius: 20px;
            background: #ffffff;
            box-shadow: 0 10px 24px rgba(15,23,42,.045);
        }

        .work-item-main h3 {
            margin: 4px 0;
            color: var(--primary);
            letter-spacing: -.02em;
            font-size: 1rem;
        }

        .work-item-main p,
        .work-item-main small {
            display: block;
            color: var(--muted);
            line-height: 1.42;
        }

        .work-type {
            display: inline-flex;
            width: fit-content;
            padding: 5px 9px;
            border-radius: 999px;
            background: #eef6f5;
            color: var(--accent);
            font-weight: 900;
            font-size: .72rem;
            text-transform: uppercase;
            letter-spacing: .045em;
        }

        .work-item-side {
            display: flex;
            align-items: center;
            justify-content: flex-end;
            gap: 9px;
            flex-wrap: wrap;
        }

        .context-panel .side-section h3 {
            font-size: 1rem;
        }

        .public-link-mini {
            background: linear-gradient(135deg, #ffffff, #eef6f5);
            border-radius: 22px;
            padding: 16px;
            border: 1px solid #cde6e2;
        }

        .public-link-input.compact {
            margin: 9px 0;
            padding: 11px 12px;
            font-size: .86rem;
            border-radius: 13px;
        }

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

        .public-link-actions.compact .btn {
            flex: 1 1 110px;
        }

        .side-full {
            width: 100%;
            margin-top: 12px;
        }

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

        .primary-plan-card {
            background: linear-gradient(135deg, var(--primary), var(--accent));
            color: white;
        }

        .primary-plan-card small,
        .primary-plan-card h3,
        .primary-plan-card p,
        .primary-plan-card .plan-price {
            color: white;
        }

        .primary-plan-card p {
            opacity: .84;
        }

        .plan-price {
            display: block;
            margin-top: 18px;
            font-size: 1.55rem;
            letter-spacing: -.04em;
        }

        .clean-list {
            margin: 12px 0 0;
            padding: 0;
            list-style: none;
            display: grid;
            gap: 9px;
        }

        .clean-list li {
            padding: 10px 11px;
            border: 1px solid #e6edf5;
            border-radius: 14px;
            background: #f8fafc;
            color: var(--primary);
            font-weight: 800;
        }

        .muted-list li {
            color: var(--muted);
            background: #f9fafb;
        }

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

        .feature-list.compact {
            margin-top: 12px;
        }

        .plan-upgrade-card {
            border-color: #b7dcd8;
            background: #f4fbfa;
        }

        @media (max-width: 1120px) {
            .workspace-hero,
            .compact-row,
            .work-queue-head,
            .work-item {
                grid-template-columns: 1fr;
            }

            .workspace-actions,
            .compact-actions,
            .work-queue-actions,
            .work-item-side {
                justify-content: flex-start;
            }

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

        @media (max-width: 720px) {
            .kpi-grid,
            .plan-grid,
            .work-lanes {
                grid-template-columns: 1fr;
            }

            .work-item-side .btn {
                width: 100%;
            }
        }


        /* Shell visual tipo CRM: un solo contenedor flotante para toda la operación */
        body {
            background:
                radial-gradient(circle at 8% 0%, rgba(47,126,121,.10), transparent 28%),
                linear-gradient(180deg, #eef4f8 0%, #e8eef4 100%);
        }

        .section {
            padding: 16px 0 34px;
        }

        .workspace-frame {
            position: relative;
            overflow: hidden;
            background: rgba(255,255,255,.96);
            border: 1px solid rgba(210, 223, 234, .92);
            border-radius: 34px;
            box-shadow: 0 28px 80px rgba(21, 50, 75, .14);
            padding: 14px;
        }

        .workspace-frame::before {
            content: "";
            position: absolute;
            inset: 0;
            pointer-events: none;
            background:
                linear-gradient(90deg, rgba(47,126,121,.08), transparent 28%),
                radial-gradient(circle at 96% 0%, rgba(21,50,75,.08), transparent 25%);
        }

        .workspace-frame > * {
            position: relative;
            z-index: 1;
        }

        .workspace-frame-header {
            background: transparent;
            color: var(--text);
            padding: 6px 8px 14px;
            border-bottom: 1px solid #edf2f7;
        }

        .workspace-frame-header .topbar {
            min-height: 46px;
        }

        .workspace-frame-header .brand h1 {
            color: var(--primary);
            font-size: clamp(1.05rem, 1.6vw, 1.42rem);
            letter-spacing: -.04em;
        }

        .workspace-frame-header .brand p {
            color: var(--muted);
            font-size: .86rem;
            margin-top: 3px;
        }

        .workspace-frame-header .plan-badge,
        .workspace-frame-header .logout {
            color: var(--primary);
            background: #f8fafc;
            border: 1px solid #edf2f7;
            padding: 8px 11px;
            box-shadow: none;
        }

        .workspace-frame-header .logout:hover {
            background: #eef6f5;
            color: var(--accent);
        }

        .workspace-body {
            padding-top: 14px;
        }

        .workspace-hero {
            background: #f8fafc;
            border-color: #edf2f7;
            border-radius: 24px;
            box-shadow: none;
            padding: 16px;
        }

        .workspace-hero h2 {
            font-size: clamp(1.35rem, 2vw, 1.9rem);
        }

        .kpi-grid {
            gap: 10px;
            margin-bottom: 14px;
        }

        .kpi-card,
        .panel,
        .side-panel,
        .overview-section,
        .plan-card,
        .automation-summary-card,
        .automation-explainer,
        .automation-card,
        .lead-card,
        .kanban-col {
            box-shadow: none;
        }

        .kpi-card {
            border-color: #edf2f7;
            border-radius: 20px;
            padding: 14px;
        }

        .kpi-card strong {
            font-size: 1.7rem;
        }

        .layout {
            grid-template-columns: minmax(0, 1fr) 330px;
            gap: 14px;
        }

        .panel,
        .side-panel {
            border-color: #edf2f7;
            border-radius: 24px;
            background: #ffffff;
        }

        .panel-head {
            padding: 16px;
        }

        .content-area {
            padding: 16px;
        }

        .side-panel {
            top: 18px;
            padding: 14px;
        }

        .public-link-mini {
            border-radius: 18px;
            padding: 14px;
        }

        .btn {
            box-shadow: none;
        }

        .btn-sm {
            min-height: 34px;
            padding: 8px 11px;
            border-radius: 12px;
        }

        @media (max-width: 980px) {
            .workspace-frame {
                border-radius: 24px;
                padding: 10px;
            }

            .workspace-frame-header {
                padding: 4px 4px 12px;
            }

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

/* CERTUS SPRINT 4 BATCH 2A — Dashboard cleanup utilities */
.mt-1{margin-top:10px}

/* CERTUS SPRINT 4 BATCH 2B — Token-based dark mode coverage */
html.certus-dark-mode body,
html.certus-dark-mode .certus-app,
html.certus-dark-mode .app-main,
html.certus-dark-mode .app-content,
html.certus-dark-mode .workspace-frame,
html.certus-dark-mode .workspace-body{
  background:var(--bg);
  color:var(--text);
}

html.certus-dark-mode .card,
html.certus-dark-mode .panel,
html.certus-dark-mode .profile-card,
html.certus-dark-mode .profile-panel,
html.certus-dark-mode .summary-card,
html.certus-dark-mode .user-item,
html.certus-dark-mode .billing-provider-card,
html.certus-dark-mode .integration-provider-card,
html.certus-dark-mode .state-message,
html.certus-dark-mode .table-wrap,
html.certus-dark-mode .modal,
html.certus-dark-mode .dropdown-menu,
html.certus-dark-mode .lead-drawer,
html.certus-dark-mode .drawer-card{
  background:var(--surface);
  border-color:var(--border);
  color:var(--text);
  box-shadow:var(--shadow-sm);
}

html.certus-dark-mode h1,
html.certus-dark-mode h2,
html.certus-dark-mode h3,
html.certus-dark-mode h4,
html.certus-dark-mode strong,
html.certus-dark-mode label,
html.certus-dark-mode .page-title,
html.certus-dark-mode .card-title,
html.certus-dark-mode .section-title,
html.certus-dark-mode .kpi-value{
  color:var(--text-strong);
}

html.certus-dark-mode p,
html.certus-dark-mode .muted,
html.certus-dark-mode .text-muted,
html.certus-dark-mode .page-subtitle,
html.certus-dark-mode .card-subtitle,
html.certus-dark-mode .section-subtitle,
html.certus-dark-mode .kpi-hint,
html.certus-dark-mode .table-meta,
html.certus-dark-mode small{
  color:var(--text-muted);
}

html.certus-dark-mode input,
html.certus-dark-mode select,
html.certus-dark-mode textarea,
html.certus-dark-mode .form-control,
html.certus-dark-mode .form-select,
html.certus-dark-mode .form-textarea{
  background:var(--surface-soft);
  border-color:var(--border);
  color:var(--text);
}

html.certus-dark-mode input::placeholder,
html.certus-dark-mode textarea::placeholder{
  color:var(--text-muted);
}

html.certus-dark-mode .data-table th{
  background:var(--surface-soft);
  color:var(--text-strong);
  border-color:var(--border);
}

html.certus-dark-mode .data-table td{
  color:var(--text);
  border-color:var(--border);
}

html.certus-dark-mode .btn-muted,
html.certus-dark-mode .btn-secondary,
html.certus-dark-mode .btn-ghost{
  background:var(--surface-soft);
  border-color:var(--border);
  color:var(--text-strong);
}

html.certus-dark-mode .badge,
html.certus-dark-mode .mini-pill,
html.certus-dark-mode .status-label,
html.certus-dark-mode .check-row,
html.certus-dark-mode .checkbox-row,
html.certus-dark-mode .radio-row{
  background:var(--surface-soft);
  border-color:var(--border);
  color:var(--text);
}

html.certus-dark-mode .progress,
html.certus-dark-mode .progress-value{
  background:var(--surface-soft);
}

html.certus-dark-mode .alert,
html.certus-dark-mode .state-empty,
html.certus-dark-mode .empty-state,
html.certus-dark-mode .empty-state-compact{
  background:var(--surface);
  border-color:var(--border);
  color:var(--text);
}
