:root, [data-theme="light"] {
  --color-bg: #f7f6f2; --color-surface: #f9f8f5; --color-surface-2: #fbfbf9;
  --color-surface-offset: #f3f0ec; --color-surface-offset-2: #edeae5;
  --color-surface-dynamic: #e6e4df; --color-divider: #dcd9d5; --color-border: #d4d1ca;
  --color-text: #28251d; --color-text-muted: #7a7974; --color-text-faint: #bab9b4;
  --color-text-inverse: #f9f8f4;
  --color-primary: #01696f; --color-primary-hover: #0c4e54; --color-primary-active: #0f3638;
  --color-primary-highlight: #cedcd8;
  --color-warning: #964219; --color-warning-highlight: #ddcfc6;
  --color-error: #a12c7b; --color-error-highlight: #e0ced7;
  --color-success: #437a22; --color-success-hover: #2e5c10; --color-success-highlight: #d4dfcc;
  --color-gold: #d19900; --color-gold-highlight: #e9e0c6;
  --color-blue: #006494; --color-blue-highlight: #c6d8e4;
  --color-orange: #da7101; --color-orange-highlight: #e7d7c4;
  --color-notification: #a13544; --color-notification-highlight: #dececb;
  --radius-sm: 0.375rem; --radius-md: 0.5rem; --radius-lg: 0.75rem; --radius-xl: 1rem; --radius-full: 9999px;
  --shadow-sm: 0 1px 2px rgba(40,37,29,0.06);
  --shadow-md: 0 4px 12px rgba(40,37,29,0.08);
  --shadow-lg: 0 12px 32px rgba(40,37,29,0.12);
  --transition-interactive: 180ms cubic-bezier(0.16, 1, 0.3, 1);
  --font-body: 'Inter', system-ui, sans-serif; --font-display: 'EB Garamond', 'Times New Roman', Georgia, serif;
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --space-1: .25rem; --space-2: .5rem; --space-3: .75rem; --space-4: 1rem; --space-5: 1.25rem;
  --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem; --space-12: 3rem; --space-16: 4rem;
}

[data-theme="dark"] {
  --color-bg: #171614; --color-surface: #1c1b19; --color-surface-2: #201f1d;
  --color-surface-offset: #1d1c1a; --color-surface-offset-2: #22211f;
  --color-surface-dynamic: #2d2c2a; --color-divider: #262523; --color-border: #393836;
  --color-text: #cdccca; --color-text-muted: #797876; --color-text-faint: #5a5957;
  --color-primary: #4f98a3; --color-primary-hover: #227f8b; --color-primary-highlight: #313b3b;
  --color-warning: #bb653b; --color-warning-highlight: #564942;
  --color-error: #d163a7; --color-error-highlight: #4c3d46;
  --color-success: #6daa45; --color-success-highlight: #3a4435;
  --color-gold: #e8af34; --color-gold-highlight: #4d4332;
  --color-blue: #5591c7; --color-blue-highlight: #3a4550;
  --color-orange: #fdab43; --color-orange-highlight: #564b3e;
  --color-notification: #dd6974; --color-notification-highlight: #574848;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; scroll-behavior: smooth; }
body { min-height: 100dvh; font-family: var(--font-body); font-size: var(--text-base);
  color: var(--color-text); background: var(--color-bg); }
img, svg { display: block; max-width: 100%; }
button { cursor: pointer; background: none; border: none; font: inherit; color: inherit; }
a { color: var(--color-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
a, button, [role="button"] {
  transition: color var(--transition-interactive), background var(--transition-interactive),
    border-color var(--transition-interactive), box-shadow var(--transition-interactive);
}
:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 3px; border-radius: var(--radius-sm); }
input, select, textarea { font: inherit; color: inherit; }

/* SIDEBAR layout (admin) */
.app-shell { display: flex; height: 100vh; overflow: hidden; }
.sidebar { width: 260px; min-width: 260px; background: var(--color-surface);
  border-right: 1px solid var(--color-divider); display: flex; flex-direction: column;
  height: 100vh; overflow-y: auto; }
.sidebar-header { padding: var(--space-6) var(--space-6) var(--space-4);
  border-bottom: 1px solid var(--color-divider); }
.logo { display: flex; align-items: center; gap: var(--space-3); }
.logo-icon { width: 34px; height: 34px; flex-shrink: 0; }
.logo-text { font-family: var(--font-display); font-size: var(--text-lg); line-height: 1.1; }
.logo-text span { display: block; font-size: var(--text-xs); font-family: var(--font-body);
  color: var(--color-text-muted); font-weight: 400; letter-spacing: .05em;
  text-transform: uppercase; margin-top: 1px; }
.sidebar-nav { padding: var(--space-4) var(--space-3); flex: 1; }
.nav-section-label { font-size: var(--text-xs); color: var(--color-text-faint);
  text-transform: uppercase; letter-spacing: .08em;
  padding: var(--space-2) var(--space-3) var(--space-1); }
.nav-item { display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-md);
  cursor: pointer; font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: 2px; }
.nav-item:hover { background: var(--color-surface-offset); color: var(--color-text); }
.nav-item.active { background: var(--color-primary-highlight); color: var(--color-primary); font-weight: 500; }
.nav-item .badge { margin-left: auto; background: var(--color-primary); color: white;
  font-size: 10px; padding: 1px 6px; border-radius: var(--radius-full); font-weight: 600; }
.sidebar-footer { padding: var(--space-4) var(--space-6); border-top: 1px solid var(--color-divider); }
.user-card { display: flex; align-items: center; gap: var(--space-3); }
.user-avatar { width: 32px; height: 32px; border-radius: var(--radius-full);
  background: var(--color-primary); color: white; display: flex;
  align-items: center; justify-content: center;
  font-size: var(--text-xs); font-weight: 600; flex-shrink: 0; }
.user-info { flex: 1; min-width: 0; }
.user-name { font-size: var(--text-sm); font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-role { font-size: var(--text-xs); color: var(--color-text-muted); }

/* MAIN */
.main { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
.topbar { height: 56px; background: var(--color-surface);
  border-bottom: 1px solid var(--color-divider); display: flex;
  align-items: center; padding: 0 var(--space-6); gap: var(--space-4); flex-shrink: 0; }
.topbar-title { font-size: var(--text-lg); font-weight: 600; flex: 1; }
.topbar-actions { display: flex; align-items: center; gap: var(--space-2); }
.content { flex: 1; overflow-y: auto; padding: var(--space-6); }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-4); border-radius: var(--radius-md);
  font-size: var(--text-sm); font-weight: 500; cursor: pointer; border: none; font-family: inherit; }
.btn-primary { background: var(--color-primary); color: white; }
.btn-primary:hover { background: var(--color-primary-hover); }
.btn-secondary { background: var(--color-surface-offset); color: var(--color-text); border: 1px solid var(--color-border); }
.btn-secondary:hover { background: var(--color-surface-offset-2); }
.btn-ghost { background: transparent; color: var(--color-text-muted); padding: var(--space-2); }
.btn-ghost:hover { background: var(--color-surface-offset); color: var(--color-text); }
.btn-danger { background: var(--color-notification-highlight); color: var(--color-notification); }
.btn-danger:hover { background: var(--color-notification); color: white; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-block { width: 100%; justify-content: center; }
.btn-sm { padding: var(--space-1) var(--space-3); font-size: var(--text-xs); }

/* INPUTS */
.field { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-4); }
.field label { font-size: var(--text-xs); color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: .04em; font-weight: 500; }
.field input, .field select, .field textarea {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm); color: var(--color-text); outline: none;
  transition: border-color var(--transition-interactive), box-shadow var(--transition-interactive);
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-highlight);
}
.field textarea { min-height: 84px; resize: vertical; font-family: inherit; }
.field-error { color: var(--color-notification); font-size: var(--text-xs); margin-top: 2px; }

/* STATS */
.stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); margin-bottom: var(--space-6); }
.stat-card { background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-4) var(--space-5); }
.stat-label { font-size: var(--text-xs); color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: var(--space-2); }
.stat-value { font-size: var(--text-xl); font-weight: 700; line-height: 1; font-variant-numeric: tabular-nums; }
.stat-sub { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: var(--space-1); }
.stat-card.c-penal .stat-value { color: var(--color-notification); }
.stat-card.c-civil .stat-value { color: var(--color-blue); }
.stat-card.c-familia .stat-value { color: var(--color-primary); }
.stat-card.c-laboral .stat-value { color: var(--color-warning); }

/* CASES TABLE */
.section-header { display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-4); flex-wrap: wrap; gap: var(--space-3); }
.section-title { font-size: var(--text-lg); font-weight: 600; }
.filters { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.filter-btn { padding: var(--space-1) var(--space-3); border-radius: var(--radius-full);
  font-size: var(--text-xs); font-weight: 500; border: 1px solid var(--color-border);
  background: var(--color-surface); color: var(--color-text-muted); cursor: pointer; }
.filter-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
.filter-btn.active { background: var(--color-primary-highlight);
  border-color: var(--color-primary); color: var(--color-primary); }
.cases-table { background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); overflow: hidden; }
.table-head { display: grid; grid-template-columns: 2fr 1fr 1.5fr 1.5fr 1fr auto;
  padding: var(--space-3) var(--space-5); border-bottom: 1px solid var(--color-divider);
  font-size: var(--text-xs); color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: .06em; font-weight: 500; }
.case-row { display: grid; grid-template-columns: 2fr 1fr 1.5fr 1.5fr 1fr auto;
  padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--color-divider);
  align-items: center; cursor: pointer; transition: background var(--transition-interactive); }
.case-row:last-child { border-bottom: none; }
.case-row:hover { background: var(--color-surface-offset); }
.case-name { font-weight: 500; font-size: var(--text-sm); margin-bottom: 2px; }
.case-id { font-size: var(--text-xs); color: var(--color-text-muted); font-family: monospace; }

.tag { display: inline-flex; align-items: center; padding: 2px var(--space-2);
  border-radius: var(--radius-full); font-size: var(--text-xs); font-weight: 500; }
.tag-penal { background: var(--color-notification-highlight); color: var(--color-notification); }
.tag-civil { background: var(--color-blue-highlight); color: var(--color-blue); }
.tag-familia { background: var(--color-primary-highlight); color: var(--color-primary); }
.tag-laboral { background: var(--color-warning-highlight); color: var(--color-warning); }
.tag-comercial { background: var(--color-gold-highlight); color: var(--color-gold); }

.etapa-badge { font-size: var(--text-xs); font-weight: 500; padding: 3px var(--space-3);
  border-radius: var(--radius-full); display: inline-block; }
.etapa-1 { background: var(--color-blue-highlight); color: var(--color-blue); }
.etapa-2 { background: var(--color-gold-highlight); color: var(--color-gold); }
.etapa-3 { background: var(--color-warning-highlight); color: var(--color-warning); }
.etapa-4 { background: var(--color-primary-highlight); color: var(--color-primary); }
.etapa-5 { background: var(--color-success-highlight); color: var(--color-success); }
.etapa-6 { background: #e8d5ff; color: #6b21a8; }

.status-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; margin-right: var(--space-2); }
.dot-active { background: var(--color-success); }
.dot-pending { background: var(--color-gold); }
.dot-urgent { background: var(--color-notification); }
.dot-closed { background: var(--color-text-faint); }

/* MODAL */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.35); z-index: 100;
  display: none; align-items: center; justify-content: center; backdrop-filter: blur(2px);
  padding: var(--space-4); }
.overlay.open { display: flex; }
.panel { background: var(--color-surface); border-radius: var(--radius-xl);
  width: min(760px, 95vw); max-height: 90vh; overflow-y: auto;
  box-shadow: var(--shadow-lg); animation: panelIn .22s cubic-bezier(0.16, 1, 0.3, 1); }
.panel.sm { width: min(480px, 95vw); }
@keyframes panelIn { from { opacity: 0; transform: translateY(12px) scale(0.97); } to { opacity: 1; transform: none; } }
.panel-header { padding: var(--space-6) var(--space-6) var(--space-4);
  border-bottom: 1px solid var(--color-divider); display: flex;
  align-items: flex-start; justify-content: space-between; gap: var(--space-4); }
.panel-title { font-family: var(--font-display); font-size: var(--text-xl); line-height: 1.2; }
.panel-body { padding: var(--space-6); }
.panel-section { margin-bottom: var(--space-6); }
.panel-section:last-child { margin-bottom: 0; }
.panel-section-title { font-size: var(--text-sm); font-weight: 600; color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: var(--space-3); }
.panel-footer { padding: var(--space-4) var(--space-6); border-top: 1px solid var(--color-divider);
  display: flex; justify-content: flex-end; gap: var(--space-3); }

/* ETAPA TRACKER */
.etapa-tracker { display: flex; flex-direction: column; gap: var(--space-2); }
.etapa-item { display: flex; align-items: flex-start; gap: var(--space-4);
  padding: var(--space-3) var(--space-4); border-radius: var(--radius-md);
  border: 1px solid transparent; }
.etapa-item.completed { border-color: var(--color-success-highlight); background: var(--color-success-highlight); }
.etapa-item.active { border-color: var(--color-primary); background: var(--color-primary-highlight); }
.etapa-item.pending { border-color: var(--color-border); }
.etapa-num { width: 28px; height: 28px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: var(--text-xs); font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.etapa-item.completed .etapa-num { background: var(--color-success); color: white; }
.etapa-item.active .etapa-num { background: var(--color-primary); color: white; }
.etapa-item.pending .etapa-num { background: var(--color-surface-dynamic); color: var(--color-text-muted); }
.etapa-content { flex: 1; }
.etapa-name { font-weight: 600; font-size: var(--text-sm); margin-bottom: 2px; }
.etapa-desc { font-size: var(--text-xs); color: var(--color-text-muted); line-height: 1.5; }
.etapa-date { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--space-1); }

/* DOCS */
.docs-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: var(--space-3); }
.doc-card { background: var(--color-surface-offset); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-4); cursor: pointer; }
.doc-card:hover { border-color: var(--color-primary); background: var(--color-primary-highlight); }
.doc-icon { width: 32px; height: 32px; margin-bottom: var(--space-2); color: var(--color-text-muted); }
.doc-card:hover .doc-icon { color: var(--color-primary); }
.doc-name { font-size: var(--text-sm); font-weight: 500; margin-bottom: 3px; }
.doc-meta { font-size: var(--text-xs); color: var(--color-text-muted); }
.doc-status { font-size: var(--text-xs); padding: 2px var(--space-2);
  border-radius: var(--radius-full); margin-top: var(--space-2); display: inline-block; }
.doc-ok { background: var(--color-success-highlight); color: var(--color-success); }
.doc-pend { background: var(--color-gold-highlight); color: var(--color-gold); }
.doc-missing { background: var(--color-notification-highlight); color: var(--color-notification); }

/* INFO GRID */
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.info-item { background: var(--color-surface-offset); padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); }
.info-label { font-size: var(--text-xs); color: var(--color-text-muted);
  margin-bottom: 3px; text-transform: uppercase; letter-spacing: .04em; }
.info-value { font-size: var(--text-sm); font-weight: 500; }

/* SEARCH */
.search-box { display: flex; align-items: center; gap: var(--space-2);
  background: var(--color-surface-offset); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); padding: var(--space-2) var(--space-3); width: 240px; }
.search-box input { background: none; border: none; outline: none; font: inherit;
  font-size: var(--text-sm); color: var(--color-text); width: 100%; }
.search-box input::placeholder { color: var(--color-text-faint); }

/* AUTH / LANDING */
.auth-shell { min-height: 100vh; display: grid; place-items: center;
  padding: var(--space-6); background: var(--color-bg); }
.auth-card { width: min(440px, 100%); background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius-xl);
  padding: var(--space-8); box-shadow: var(--shadow-md); }
.auth-card .logo { justify-content: center; margin-bottom: var(--space-6); }
.auth-title { font-family: var(--font-display); font-size: var(--text-xl);
  text-align: center; margin-bottom: var(--space-2); }
.auth-sub { font-size: var(--text-sm); color: var(--color-text-muted);
  text-align: center; margin-bottom: var(--space-6); }
.auth-tabs { display: flex; gap: var(--space-2); margin-bottom: var(--space-6);
  background: var(--color-surface-offset); padding: 4px; border-radius: var(--radius-md); }
.auth-tab { flex: 1; padding: var(--space-2); font-size: var(--text-sm);
  border-radius: var(--radius-sm); cursor: pointer; text-align: center; color: var(--color-text-muted); }
.auth-tab.active { background: var(--color-surface); color: var(--color-text);
  box-shadow: var(--shadow-sm); font-weight: 500; }
.auth-foot { font-size: var(--text-xs); color: var(--color-text-muted);
  text-align: center; margin-top: var(--space-4); }

/* LANDING */
.landing { min-height: 100vh; background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-surface) 100%); }
.landing-nav { padding: var(--space-4) var(--space-6); display: flex;
  align-items: center; justify-content: space-between; max-width: 1200px; margin: 0 auto; }
.landing-hero { max-width: 1200px; margin: 0 auto;
  padding: var(--space-16) var(--space-6); text-align: center; }
.landing-hero h1 { font-family: var(--font-display); font-size: clamp(2.4rem, 5vw, 4rem);
  line-height: 1.05; margin-bottom: var(--space-4); }
.landing-hero p { font-size: var(--text-lg); color: var(--color-text-muted);
  max-width: 620px; margin: 0 auto var(--space-8); }
.landing-ctas { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }
.landing-features { max-width: 1100px; margin: 0 auto;
  padding: var(--space-12) var(--space-6); display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-6); }
.feature-card { background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-6); }
.feature-icon { width: 40px; height: 40px; border-radius: var(--radius-md);
  background: var(--color-primary-highlight); color: var(--color-primary);
  display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-4); }
.feature-card h3 { font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-2); }
.feature-card p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.6; }
.landing-foot { padding: var(--space-6); text-align: center;
  font-size: var(--text-xs); color: var(--color-text-faint); }

/* PORTAL CLIENTE */
.portal-shell { min-height: 100vh; background: var(--color-bg); }
.portal-nav { background: var(--color-surface); border-bottom: 1px solid var(--color-divider);
  padding: var(--space-4) var(--space-6); display: flex;
  align-items: center; justify-content: space-between; }
.portal-content { max-width: 900px; margin: 0 auto; padding: var(--space-8) var(--space-6); }
.portal-card { background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-6); margin-bottom: var(--space-6); }
.portal-case-head { display: flex; justify-content: space-between;
  align-items: flex-start; gap: var(--space-4); margin-bottom: var(--space-4); flex-wrap: wrap; }

/* TOAST */
.toast { position: fixed; bottom: var(--space-6); right: var(--space-6);
  background: var(--color-text); color: var(--color-text-inverse, white);
  padding: var(--space-3) var(--space-5); border-radius: var(--radius-md);
  font-size: var(--text-sm); box-shadow: var(--shadow-lg);
  z-index: 1000; animation: toastIn .22s; max-width: 360px; }
.toast.toast-error { background: var(--color-notification); color: white; }
.toast.toast-success { background: var(--color-success); color: white; }
.toast.out { animation: toastOut .22s forwards; }
@keyframes toastIn { from { transform: translateY(20px); opacity: 0; } to { transform: none; opacity: 1; } }
@keyframes toastOut { to { transform: translateY(20px); opacity: 0; } }

/* NOTIFICATIONS BELL */
.notif-bell { position: relative; padding: var(--space-2);
  border-radius: var(--radius-md); color: var(--color-text-muted); }
.notif-bell:hover { background: var(--color-surface-offset); color: var(--color-text); }
.notif-dot { position: absolute; top: 6px; right: 6px;
  background: var(--color-notification); color: white;
  font-size: 9px; font-weight: 700; border-radius: var(--radius-full);
  min-width: 16px; height: 16px; display: flex;
  align-items: center; justify-content: center; padding: 0 4px; }
.notif-list { position: absolute; top: 100%; right: 0;
  margin-top: var(--space-2); background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  width: 360px; max-height: 480px; overflow-y: auto;
  box-shadow: var(--shadow-lg); z-index: 50; display: none; }
.notif-list.open { display: block; }
.notif-item { padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-divider); cursor: pointer; }
.notif-item:hover { background: var(--color-surface-offset); }
.notif-item.unread { background: var(--color-primary-highlight); }
.notif-title { font-size: var(--text-sm); font-weight: 500; margin-bottom: 2px; }
.notif-body { font-size: var(--text-xs); color: var(--color-text-muted); }
.notif-time { font-size: 10px; color: var(--color-text-faint); margin-top: 4px; }

/* INVITE LINK */
.invite-link-box { background: var(--color-success-highlight);
  border: 1px solid var(--color-success); border-radius: var(--radius-md);
  padding: var(--space-4); margin-top: var(--space-4); }
.invite-link-box code { background: var(--color-surface); padding: var(--space-2);
  border-radius: var(--radius-sm); display: block; word-break: break-all;
  font-size: var(--text-xs); margin-top: var(--space-2); }

/* MISC */
.muted { color: var(--color-text-muted); }
.center { text-align: center; }
.row { display: flex; gap: var(--space-3); align-items: center; }
.row.between { justify-content: space-between; }
.empty-state { padding: var(--space-12); text-align: center; color: var(--color-text-muted); }
.empty-state svg { width: 48px; height: 48px; margin: 0 auto var(--space-4); color: var(--color-text-faint); }
.empty-title { font-weight: 500; color: var(--color-text); margin-bottom: var(--space-2); }
hr.divider { border: none; border-top: 1px solid var(--color-divider); margin: var(--space-4) 0; }

/* MOBILE */
@media (max-width: 768px) {
  .sidebar { width: 220px; min-width: 220px; }
  .stats-row { grid-template-columns: 1fr 1fr; }
  .table-head, .case-row { grid-template-columns: 2fr 1fr 1fr auto; }
  .col-etapa-inline, .col-fecha { display: none; }
  .search-box { width: 180px; }
}
@media (max-width: 540px) {
  .sidebar { position: fixed; left: -260px; z-index: 200; transition: left var(--transition-interactive); }
  .sidebar.open { left: 0; }
  .main { width: 100%; }
  .stats-row { grid-template-columns: 1fr; }
  .info-grid { grid-template-columns: 1fr; }
}
