@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap");

/* Tokens */
:root{
  --primary:#2563eb;
  --primary-rgb:37,99,235;
  --primary-contrast:#ffffff;
  --primary-softest:rgba(var(--primary-rgb),.08);
  --primary-soft:rgba(var(--primary-rgb),.12);
  --primary-softer:rgba(var(--primary-rgb),.18);
  --primary-strong:rgba(var(--primary-rgb),.24);
  --primary-glow:rgba(var(--primary-rgb),.34);

  --success:#22c55e;
  --success-rgb:34,197,94;
  --success-soft:rgba(var(--success-rgb),.18);
  --success-strong:rgba(var(--success-rgb),.28);
  --success-glow:rgba(var(--success-rgb),.45);

  --warning:#f59e0b;
  --warning-rgb:245,158,11;
  --warning-soft:rgba(var(--warning-rgb),.2);
  --warning-strong:rgba(var(--warning-rgb),.3);
  --warning-contrast:#b45309;
  --warning-bright:#fbbf24;
  --warning-tint:#ffcb6b;
  --warning-warm:#a86b00;
  --accent-info:#8cc2ff;

  --danger:#ef4444;
  --danger-rgb:239,68,68;
  --danger-soft:rgba(var(--danger-rgb),.18);
  --danger-strong:rgba(var(--danger-rgb),.28);
  --danger-glow:rgba(var(--danger-rgb),.45);

  --base-rgb:15,23,42;
  --slate-rgb:148,163,184;
  --white-rgb:255,255,255;

  --bg:#ffffff;
  --bg-subtle:#f4f8ff;
  --surface:#ffffff;
  --surface-elevated:#f8faff;
  --surface-muted:#eef3ff;
  --surface-tint:rgba(242,247,255,.94);
  --surface-glass:rgba(var(--white-rgb),.82);

  --sidebar-gradient:linear-gradient(180deg,rgba(var(--white-rgb),.97) 0%,rgba(242,247,255,.94) 60%,rgba(233,241,255,.9) 100%);
  --card-gradient:linear-gradient(135deg,rgba(var(--white-rgb),.98),rgba(241,247,255,.92));
  --combo-gradient:linear-gradient(135deg,rgba(var(--white-rgb),.97),rgba(243,248,255,.92));

  --text:#0f172a;
  --text-soft:#273553;
  --muted:#5c6f92;
  --muted-soft:rgba(var(--slate-rgb),.42);

  --border:rgba(var(--base-rgb),.08);
  --border-strong:rgba(var(--base-rgb),.14);
  --border-soft:rgba(var(--base-rgb),.06);
  --divider:rgba(var(--base-rgb),.05);

  --shadow-soft:0 24px 45px rgba(var(--base-rgb),.08);
  --shadow-medium:0 12px 28px rgba(var(--base-rgb),.12);
  --shadow-lifted:0 28px 60px rgba(var(--base-rgb),.1);
  --shadow-strong:0 32px 64px rgba(var(--base-rgb),.14);
  --shadow-ring:0 0 0 1px rgba(var(--primary-rgb),.16),0 14px 30px rgba(var(--primary-rgb),.2);

  --badge-muted:rgba(var(--slate-rgb),.16);
  --chip-bg:rgba(var(--primary-rgb),.12);
  --chip-text:rgba(var(--primary-rgb),.95);

  --radius-lg:18px; --radius-md:12px; --radius-sm:8px;
  --sidebar-width:clamp(240px,24vw,320px);
  --sidebar-collapsed-width:72px;
  --z-panel:770;
  --z-footer:780;
  --z-topbar:800;
  --z-sidebar:850;
  --z-popover:900;
  --z-dropdown:910;
  --z-preview:920;
  --z-toast:930;
  --z-modal:1000;
  --z-modal-content:1010;
}
html[data-theme="dark"]{
  --bg:#040812;
  --bg-subtle:#0b1424;
  --surface:#0f1c33;
  --surface-elevated:#14243d;
  --surface-muted:#192d4f;
  --surface-tint:rgba(20,36,64,.9);
  --surface-glass:rgba(14,26,48,.78);

  --sidebar-gradient:linear-gradient(180deg,rgba(18,27,45,.96) 0%,rgba(12,23,43,.9) 100%);
  --card-gradient:linear-gradient(140deg,rgba(24,40,70,.94),rgba(14,27,49,.92));
  --combo-gradient:linear-gradient(135deg,rgba(22,36,62,.94),rgba(14,25,46,.92));

  --text:#f6f9ff;
  --text-soft:#d5e2ff;
  --muted:#a5bbed;
  --muted-soft:rgba(165,187,237,.42);

  --border:rgba(120,149,232,.24);
  --border-strong:rgba(138,168,245,.32);
  --border-soft:rgba(88,118,210,.18);
  --divider:rgba(36,56,94,.55);

  --shadow-soft:0 30px 60px rgba(4,12,27,.55);
  --shadow-medium:0 16px 34px rgba(2,8,23,.5);
  --shadow-lifted:0 32px 64px rgba(3,10,24,.6);
  --shadow-strong:0 36px 70px rgba(2,8,22,.65);
  --shadow-ring:0 0 0 1px rgba(var(--primary-rgb),.32),0 18px 44px rgba(var(--primary-rgb),.35);

  --primary-softest:rgba(var(--primary-rgb),.16);
  --primary-soft:rgba(var(--primary-rgb),.22);
  --primary-softer:rgba(var(--primary-rgb),.28);
  --primary-strong:rgba(var(--primary-rgb),.34);
  --primary-glow:rgba(var(--primary-rgb),.45);

  --success-soft:rgba(var(--success-rgb),.28);
  --success-strong:rgba(var(--success-rgb),.34);
  --success-glow:rgba(var(--success-rgb),.5);
  --warning-soft:rgba(var(--warning-rgb),.3);
  --warning-strong:rgba(var(--warning-rgb),.4);
  --danger-soft:rgba(var(--danger-rgb),.28);
  --danger-strong:rgba(var(--danger-rgb),.36);
  --danger-glow:rgba(var(--danger-rgb),.5);

  --chip-bg:rgba(var(--primary-rgb),.24);
  --chip-text:rgba(219,234,254,.95);
  --badge-muted:rgba(var(--slate-rgb),.22);
}

/* Base */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,"Helvetica Neue",Arial,"Noto Sans";
  font-size:14px; line-height:1.45; background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
a{color:var(--primary); text-decoration:none} a:hover{text-decoration:underline}
[hidden]{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.muted{color:var(--muted)} .ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.flashes{
  display:grid;
  gap:10px;
  margin:0 0 16px;
}
.flashes__item{
  border:1px solid var(--border);
  background:var(--surface-elevated);
  border-radius:var(--radius-md);
  padding:10px 12px;
  box-shadow:var(--shadow-soft);
}
.flashes__item--success{
  border-color:var(--success-strong);
  background:var(--success-soft);
}
.flashes__item--warning{
  border-color:var(--warning-strong);
  background:var(--warning-soft);
}
.flashes__item--error,
.flashes__item--danger{
  border-color:var(--danger-strong);
  background:var(--danger-soft);
}
.flashes__item--info{
  border-color:var(--primary-strong);
  background:var(--primary-softest);
}
.flashes__message{
  margin:0;
  font-weight:600;
  color:var(--text);
}

/* Layout shell (desktop default: sidebar open) */
#app-shell{
  display:grid;
  grid-template-columns: var(--sidebar-width) minmax(0,1fr);
  min-height:100vh;
}

/* Desktop collapsed/hidden states controlled by body classes */
body.sb-collapsed:not(.sb-closed) #app-shell{ grid-template-columns: var(--sidebar-collapsed-width) minmax(0,1fr); }
body.sb-collapsed:not(.sb-closed) .sidebar{width:var(--sidebar-collapsed-width);}
.brand__logo{
  width: 36px;
  height: 36px;
  border-radius: 8px;
  object-fit: cover;
  display: block;
  box-shadow: var(--shadow-soft);
}

/* Optional: subtle dark-mode lift so it pops on dark backgrounds */
html[data-theme="dark"] .brand__logo{
  box-shadow: 0 0 0 1px rgba(var(--white-rgb),.06), var(--shadow-soft);
}

/* Sidebar (single, no internal burger) */
.sidebar{
  position:sticky;
  top:0;
  height:100vh;
  overflow:visible;
  display:flex;
  flex-direction:column;
  gap:0;
  padding:22px 20px 18px;
  background:var(--sidebar-gradient);
  border-right:1px solid var(--border);
  box-shadow:var(--shadow-lifted);
  backdrop-filter:blur(18px);
  z-index:900;
}
html[data-theme="dark"] .sidebar{
  background:var(--sidebar-gradient);
  border-right:1px solid var(--border);
  box-shadow:var(--shadow-lifted);
}
.sidebar__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:0 0 14px;
  margin:0 0 18px;
  border-bottom:1px solid var(--border-soft);
  background:transparent;
}
html[data-theme="dark"] .sidebar__top{border-bottom:1px solid var(--border-soft);}
.sidebar__brand{display:flex;align-items:center;gap:12px;margin:0;text-decoration:none;color:inherit}
.sidebar__brand:focus,.sidebar__brand:hover{color:inherit;text-decoration:none}
.brand{display:flex;flex-direction:column}
.brand__title{font-weight:600;letter-spacing:.4px;font-size:20px;font-family:"Space Grotesk","Inter",sans-serif}
.brand__tagline{font-size:11px;color:var(--muted);letter-spacing:.2px}
.sidebar__collapse{
  flex-shrink:0;
  width:38px;
  height:38px;
  border-radius:14px;
  display:grid;
  place-items:center;
  border:1px solid var(--border);
  background:var(--surface-glass);
  box-shadow:var(--shadow-soft);
  transition:border-color .24s ease, background .24s ease, transform .18s ease;
}
html[data-theme="dark"] .sidebar__collapse{
  background:var(--surface-glass);
  border-color:var(--border);
}
.sidebar__collapse:hover,
.sidebar__collapse:focus{
  border-color:var(--primary);
  background:var(--primary-soft);
  transform:translateY(-1px);
  outline:none;
}
.sidebar__section{display:block;padding:0;margin-bottom:14px}
.sidebar-nav__label{
  margin:0 0 10px;
  font-size:11px;
  letter-spacing:.18em;
  font-weight:600;
  text-transform:uppercase;
  color:var(--muted);
}
.sidebar__model-card{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:12px;
  margin-bottom:14px;
  border-radius:18px;
  background:var(--card-gradient);
  border:1px solid var(--primary-softest);
  box-shadow:var(--shadow-soft);
}
html[data-theme="dark"] .sidebar__model-card{border-color:var(--primary-soft);box-shadow:var(--shadow-strong);}
.sidebar__model-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.sidebar__model-headings{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
}
.sidebar__model-title{
  font-weight:600;
  font-size:13px;
  letter-spacing:.01em;
  color:var(--text);
}
.sidebar__model-caption{
  margin:0;
  font-size:10px;
  line-height:1.4;
  color:var(--muted);
}
.sidebar__model-current{
  font-size:10px;
  font-weight:600;
  padding:3px 9px;
  border-radius:999px;
  background:var(--chip-bg);
  color:var(--chip-text);
  white-space:nowrap;
}
.sidebar__model-select{
  display:flex;
  flex-direction:column;
  gap:5px;
}
.sidebar__model-select-wrap{
  display:block;
}
.sidebar__model-select-wrap .combo{
  width:100%;
}
.sidebar__model-select-wrap .combo__trigger{
  border-radius:12px;
  padding:8px 36px 8px 14px;
  border:1px solid var(--primary-softest);
  background:var(--combo-gradient);
  box-shadow:var(--shadow-soft);
  gap:2px;
  align-items:flex-start;
}
.sidebar__model-select-wrap .combo__trigger:hover,
.sidebar__model-select-wrap .combo__trigger:focus-visible{
  outline:none;
  border-color:var(--primary-softer);
  box-shadow:0 12px 22px var(--primary-soft);
  background:var(--card-gradient);
}
.sidebar__model-select-wrap .combo__primary{
  font-weight:600;
  color:var(--text);
  font-size:11px;
}
.sidebar__model-select-wrap .combo__secondary{
  font-size:9px;
  color:var(--muted);
}
.sidebar__model-select-wrap[data-model-selected="true"] .combo__trigger{
  border-color:var(--primary-strong);
  box-shadow:0 18px 32px var(--primary-soft);
}
.sidebar__case-card{margin-bottom:12px;position:relative}
.case-card{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:9px 10px;
  border-radius:12px;
  background:var(--card-gradient);
  border:1px solid var(--primary-softest);
  box-shadow:var(--shadow-soft);
}
html[data-theme="dark"] .case-card{border-color:var(--primary-soft);box-shadow:var(--shadow-strong);}
.case-card__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:6px;
}
.case-card__label{
  font-size:12px;
  font-weight:600;
  letter-spacing:.01em;
  color:var(--text);
}
.case-card__chip{
  display:none;
}
.case-card__badge{
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--primary);
}
.case-card__status{
  font-size:9px;
  font-weight:600;
  padding:2px 7px;
  border-radius:999px;
  background:var(--badge-muted);
  color:var(--text-soft);
  transition:background .2s ease,color .2s ease;
}
.case-card__status--active{
  background:var(--primary-soft);
  color:var(--chip-text);
}
.case-card__status--empty{
  background:var(--badge-muted);
  color:var(--muted);
}
.case-card__body{display:flex;flex-direction:column;gap:4px;position:relative;z-index:1}
.case-card__title{margin:0;font-size:12px;font-weight:600;letter-spacing:.01em}
.case-card__description{
  margin:0;
  font-size:10px;
  line-height:1.4;
  color:var(--muted);
  display:block;
}

.case-card__form{position:relative;z-index:1;margin-top:0}
.case-card__select-wrap{display:block}
.case-card__select-wrap .combo{width:100%}
.case-card__select-wrap .combo__trigger{
  border-radius:12px;
  padding:7px 32px 7px 12px;
  border:1px solid var(--primary-softest);
  background:var(--combo-gradient);
  box-shadow:var(--shadow-soft);
  gap:2px;
  align-items:flex-start;
}
.case-card__select-wrap .combo__trigger:hover,
.case-card__select-wrap .combo__trigger:focus-visible{
  outline:none;
  border-color:var(--primary-softer);
  box-shadow:0 12px 22px var(--primary-soft);
  background:var(--card-gradient);
}
.case-card__select-wrap .combo__primary{
  font-size:11px;
  font-weight:600;
  letter-spacing:.02em;
}
.case-card__select-wrap .combo__secondary--trigger{
  display:none;
}
.case-card__select-wrap[data-case-selected="true"] .combo__trigger{
  border-color:var(--primary-strong);
  box-shadow:0 12px 26px var(--primary-softer);
}
html[data-theme="dark"] .case-card__select-wrap .combo__trigger{
  border-color:var(--primary-strong);
  background:linear-gradient(135deg,rgba(30,41,59,.92),rgba(17,24,39,.88));
  box-shadow:0 16px 30px rgba(0,0,0,.5);
}
html[data-theme="dark"] .case-card__select-wrap .combo__trigger:hover,
html[data-theme="dark"] .case-card__select-wrap .combo__trigger:focus-visible{
  border-color:var(--primary-glow);
  background:linear-gradient(135deg,rgba(30,41,59,.98),rgba(var(--base-rgb),.94));
  box-shadow:0 20px 40px rgba(6,40,82,.5);
}
html[data-theme="dark"] .case-card__select-wrap[data-case-selected="true"] .combo__trigger{
  border-color:var(--primary-glow);
  box-shadow:0 22px 46px var(--primary-glow);
}
.case-card:hover .case-card__description,
.case-card:focus-within .case-card__description{
  display:block;
}
.sidebar__profile-stat{
  padding:10px 12px;
  border-radius:14px;
  background:rgba(var(--white-rgb),.72);
  border:1px solid rgba(var(--base-rgb),.05);
  display:flex;
  flex-direction:column;
  gap:4px;
}
html[data-theme="dark"] .sidebar__profile-stat{
  background:rgba(30,34,46,.8);
  border-color:rgba(var(--slate-rgb),.14);
}
.sidebar__profile-stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.sidebar__profile-stat-value{font-size:14px;font-weight:600;color:var(--text)}
.sidebar__quick{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:16px;
}
.sidebar__quick-entry{
  position:relative;
  width:100%;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.sidebar__quick-shell{display:flex;align-items:center;gap:6px;width:100%;position:relative}
.sidebar__quick-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  width:100%;
  padding:12px 38px 12px 12px;
  border-radius:14px;
  border:1px solid transparent;
  background:linear-gradient(135deg,rgba(var(--white-rgb),.95),rgba(243,246,255,.85));
  color:var(--muted);
  cursor:pointer;
  transition:transform .18s ease, box-shadow .22s ease, border-color .22s ease;
  text-align:left;
  text-decoration:none;
  position:relative;
}
.sidebar__quick-item:hover,
.sidebar__quick-item:focus{
  outline:none;
  border-color:var(--primary-strong);
  box-shadow:0 12px 24px rgba(var(--base-rgb),.1);
  transform:translateY(-0.5px);
  color:var(--text);
  text-decoration:none;
}
.sidebar__quick-item--menu{
  align-items:center;
}
.sidebar__quick-item svg{width:20px;height:20px}
.sidebar__quick-icon{
  width:28px;
  height:28px;
  border-radius:10px;
  background:var(--primary-soft);
  display:grid;
  place-items:center;
  flex-shrink:0;
  color:var(--primary);
}
.sidebar__quick-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.sidebar__quick-title{font-weight:600;font-size:12px;color:var(--text);letter-spacing:.01em}
.sidebar__quick-caption{font-size:10px;color:var(--muted);line-height:1.2}
.sidebar__quick-badge{
  margin-left:auto;
  align-self:center;
  font-size:9px;
  font-weight:500;
  font-style:italic;
  padding:2px 5px;
  border-radius:999px;
  background:var(--danger-soft);
  color:var(--danger);
  letter-spacing:.02em;
}
.sidebar__quick-badge--complete{
  background:var(--success-soft);
  color:var(--success);
}
.sidebar__quick-item--complete{
  border-color:var(--success-strong);
}
.sidebar__quick-item--complete:hover,
.sidebar__quick-item--complete:focus{
  border-color:var(--success-glow);
  box-shadow:0 14px 24px var(--success-soft);
}
.sidebar__quick-info-btn{
  position:absolute;
  top:8px;
  right:12px;
  z-index:2;
  flex-shrink:0;
  border:none;
  background:transparent;
  color:var(--muted);
  font-size:11px;
  font-style:italic;
  font-weight:600;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:18px;
  min-height:18px;
  padding:0;
  cursor:pointer;
  transition:color .18s ease, transform .18s ease;
}
.sidebar__quick-info-btn:hover,
.sidebar__quick-info-btn:focus-visible{
  outline:none;
  color:var(--text);
  transform:translateY(-1px);
}
.sidebar__quick-info{
  margin:0;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(var(--base-rgb),.08);
  background:rgba(244,247,255,.95);
  font-size:11px;
  line-height:1.45;
  color:var(--muted);
  box-shadow:0 10px 20px rgba(var(--base-rgb),.08);
}
.sidebar__quick-info p{margin:0 0 6px}
.sidebar__quick-info p:last-child{margin-bottom:0}
.sidebar__quick-entry[data-info-open="true"] .sidebar__quick-info-btn{color:var(--primary)}
html[data-theme="dark"] .sidebar__quick-item{
  background:linear-gradient(135deg,rgba(30,34,46,.94),rgba(18,23,35,.9));
  border-color:rgba(var(--slate-rgb),.1);
  color:rgba(226,232,240,.88);
}
html[data-theme="dark"] .sidebar__quick-item:hover,
html[data-theme="dark"] .sidebar__quick-item:focus{
  border-color:var(--primary-glow);
  box-shadow:0 18px 38px rgba(0,0,0,.5);
}
html[data-theme="dark"] .sidebar__quick-icon{
  background:var(--primary-softer);
  color:rgba(191,219,254,.96);
}
html[data-theme="dark"] .sidebar__quick-badge{
  background:var(--danger-soft);
  color:rgba(254,202,202,.92);
}
html[data-theme="dark"] .sidebar__quick-badge--complete{
  background:var(--success-strong);
  color:rgba(187,247,208,.95);
}
html[data-theme="dark"] .sidebar__quick-item--complete{
  border-color:var(--success-strong);
}
html[data-theme="dark"] .sidebar__quick-item--complete:hover,
html[data-theme="dark"] .sidebar__quick-item--complete:focus{
  border-color:var(--success-glow);
  box-shadow:0 16px 28px var(--success-glow);
}
html[data-theme="dark"] .sidebar__quick-info-btn{
  color:rgba(var(--slate-rgb),.9);
}
html[data-theme="dark"] .sidebar__quick-info-btn:hover,
html[data-theme="dark"] .sidebar__quick-info-btn:focus-visible{
  color:rgba(226,232,240,.95);
}
html[data-theme="dark"] .sidebar__quick-info{
  border-color:rgba(var(--slate-rgb),.18);
  background:rgba(30,34,46,.92);
  color:rgba(203,213,225,.88);
  box-shadow:0 16px 28px rgba(0,0,0,.4);
}
.sidebar__quick-item--required::after{display:none}
.sidebar__quick-menu-indicator{
  margin-left:auto;
  display:flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  color:var(--muted);
}
.sidebar__quick-entry--menu .sidebar__quick-item:hover .sidebar__quick-menu-indicator,
.sidebar__quick-entry--menu .sidebar__quick-item:focus .sidebar__quick-menu-indicator{
  color:var(--text);
}
.sidebar__quick-popover{
  position:absolute;
  top:0;
  left:calc(100% + 16px);
  min-width:200px;
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:8px;
  border-radius:18px;
  border:1px solid rgba(var(--base-rgb),.08);
  background:linear-gradient(135deg,rgba(var(--white-rgb),.98),rgba(244,247,255,.9));
  box-shadow:0 18px 38px rgba(var(--base-rgb),.18);
  z-index:calc(var(--z-modal) - 10);
  transition:opacity .18s ease, transform .18s ease;
  opacity:0;
  transform:translateX(-6px);
  pointer-events:none;
}
.sidebar__quick-popover[data-open="true"]{
  opacity:1;
  transform:translateX(0);
  pointer-events:auto;
}
html[data-theme="dark"] .sidebar__quick-popover{
  border-color:var(--primary-soft);
  background:linear-gradient(135deg,rgba(30,34,46,.95),rgba(18,23,35,.9));
  box-shadow:0 18px 42px rgba(2,8,23,.58);
}
.sidebar__quick-popover::before{
  content:"";
  position:absolute;
  top:14px;
  left:-10px;
  width:16px;
  height:16px;
  transform:rotate(45deg);
  border-radius:4px;
  background:inherit;
  border-left:1px solid rgba(var(--base-rgb),.08);
  border-bottom:1px solid rgba(var(--base-rgb),.08);
}
html[data-theme="dark"] .sidebar__quick-popover::before{
  border-color:var(--primary-soft);
}
.sidebar__quick-popover-item{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  padding:10px;
  border-radius:14px;
  border:none;
  background:transparent;
  color:var(--text);
  font:inherit;
  text-align:left;
  cursor:pointer;
  transition:background .16s ease, transform .14s ease;
}
.sidebar__quick-popover-item:hover,
.sidebar__quick-popover-item:focus{
  background:var(--primary-soft);
  outline:none;
  transform:translateX(2px);
}
html[data-theme="dark"] .sidebar__quick-popover-item:hover,
html[data-theme="dark"] .sidebar__quick-popover-item:focus{
  background:var(--primary-softer);
}
.sidebar__quick-popover-icon{
  width:30px;
  height:30px;
  border-radius:12px;
  background:var(--primary-soft);
  display:grid;
  place-items:center;
  flex-shrink:0;
  color:var(--primary);
}
html[data-theme="dark"] .sidebar__quick-popover-icon{
  background:var(--primary-softer);
  color:rgba(191,219,254,.96);
}
.sidebar__quick-popover-icon svg{
  width:18px;
  height:18px;
}
.sidebar__quick-popover-label{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.sidebar__quick-popover-title{
  font-size:13px;
  font-weight:600;
  letter-spacing:.01em;
}
.sidebar__quick-popover-desc{
  font-size:11px;
  color:var(--muted);
}
.sidebar__scroll{
  flex:1;
  overflow-y:auto;
  padding-right:2px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.sidebar__footer{
  margin-top:auto;
  text-align:center;
  font-size:11px;
  padding:14px 0 0;
  color:var(--muted);
}

/* Mobile off-canvas (overrides desktop) */
@media (max-width:1080px){
  .topbar__center{display:none}
  .sidebar__quick-popover{
    position:relative;
    left:0;
    top:12px;
    width:100%;
    transform:translateY(-6px);
  }
  .sidebar__quick-popover::before{
    top:-8px;
    left:24px;
    border-left-width:0;
    border-bottom-width:0;
    border-top:1px solid rgba(var(--base-rgb),.08);
    border-right:1px solid rgba(var(--base-rgb),.08);
  }
  html[data-theme="dark"] .sidebar__quick-popover::before{
    border-top-color:var(--primary-soft);
    border-right-color:var(--primary-soft);
  }
}

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:var(--z-topbar);
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:4px 12px; background:var(--surface); border-bottom:1px solid var(--border);
  flex-wrap:nowrap;
  min-height:48px;
}
.topbar__left{display:flex;align-items:center;gap:10px}
.topbar__center{
  flex:1;
  display:flex;
  justify-content:center;
  align-items:center;
  min-width:0;
}
.consultant-session{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.consultant-session__selector{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0;
}
.consultant-session__label{
  font-size:12px;
  font-weight:600;
  color:var(--muted);
  letter-spacing:.02em;
}
.consultant-session__select{
  min-width:170px;
  max-width:240px;
  padding:6px 10px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:var(--surface);
  font-size:13px;
  color:var(--text);
}
.consultant-session__select:focus{
  outline:2px solid rgba(var(--primary-rgb),.28);
  outline-offset:1px;
}
.consultant-session__reset{
  margin:0;
}
.consultant-session__reset-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  font-weight:600;
  padding:6px 12px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  transition:background .2s ease,border-color .2s ease;
}
.consultant-session__reset-btn svg{
  width:14px;
  height:14px;
}
.consultant-session__reset-btn:hover,
.consultant-session__reset-btn:focus-visible{
  border-color:rgba(var(--primary-rgb),.32);
  background:var(--primary-softest);
  outline:none;
}
.consultant-session__badge{
  display:inline-flex;
  align-items:center;
  padding:4px 12px;
  border-radius:999px;
  background:var(--primary-softest);
  font-size:12px;
  font-weight:600;
  color:var(--text);
}
.consultant-session__empty{
  font-size:12px;
  color:var(--muted);
}
.consultant-session__note{
  font-size:12px;
  margin:0;
  flex-basis:100%;
}
html[data-theme="dark"] .consultant-session__select{
  background:rgba(var(--base-rgb),.96);
  border-color:rgba(var(--primary-rgb),.28);
  color:var(--text);
}
html[data-theme="dark"] .consultant-session__reset-btn{
  background:rgba(var(--white-rgb),.06);
  border-color:rgba(var(--white-rgb),.12);
  color:rgba(226,232,240,.94);
}
html[data-theme="dark"] .consultant-session__reset-btn:hover,
html[data-theme="dark"] .consultant-session__reset-btn:focus-visible{
  background:rgba(var(--primary-rgb),.16);
  border-color:rgba(var(--primary-rgb),.28);
}
@media (max-width:960px){
  .consultant-session{
    flex-wrap:wrap;
    gap:8px;
  }
  .consultant-session__selector{
    width:100%;
    justify-content:flex-start;
  }
}
.topbar__news{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 10px;
  border-radius:999px;
  background:var(--primary-softest);
  color:var(--text);
  font-size:11px;
  letter-spacing:.01em;
  max-width:100%;
  overflow:hidden;
  white-space:nowrap;
}
.topbar__news[hidden]{display:none}
.topbar__news-label{
  font-weight:700;
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--primary);
}
.topbar__news-link{
  color:inherit;
  text-decoration:none;
  max-width:420px;
  overflow:hidden;
  text-overflow:ellipsis;
}
.topbar__news-link:hover,
.topbar__news-link:focus{
  text-decoration:underline;
  outline:none;
}
.topbar__news-date{
  font-size:10px;
  color:var(--muted);
  letter-spacing:.1em;
  text-transform:uppercase;
}
html[data-theme="dark"] .topbar__news{
  background:var(--primary-soft);
  color:rgba(226,232,240,.92);
}
html[data-theme="dark"] .topbar__news-label{
  color:rgba(191,219,254,.96);
}
html[data-theme="dark"] .topbar__news-date{
  color:rgba(var(--slate-rgb),.8);
}
.consultant-dashboard{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.consultant-dashboard__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.consultant-dashboard__headline h1{
  margin:0;
  font-size:24px;
  font-weight:700;
  letter-spacing:.01em;
}
.consultant-dashboard__headline p{
  margin:6px 0 0;
  font-size:14px;
  color:var(--muted);
  max-width:520px;
}
.consultant-dashboard__headline-meta{
  display:flex;
  align-items:center;
  gap:8px;
}
.consultant-dashboard__toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  padding:14px 18px;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  background:var(--surface);
  box-shadow:0 12px 24px rgba(var(--base-rgb),.08);
}
.consultant-dashboard__stats{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.consultant-stat{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:96px;
}
.consultant-stat strong{
  font-size:18px;
  font-weight:700;
  color:var(--text);
}
.consultant-stat span{
  font-size:11px;
  color:var(--muted);
  letter-spacing:.08em;
  text-transform:uppercase;
}
.consultant-dashboard__actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.btn--slim{
  padding:6px 14px;
  font-size:13px;
}
.consultant-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  background:var(--surface-muted);
  border:1px solid var(--border);
  color:var(--text);
}
.consultant-chip--accent{
  background:var(--primary-soft);
  border-color:rgba(var(--primary-rgb),.3);
}
.consultant-chip--case{
  background:var(--primary-softest);
  border-color:rgba(var(--primary-rgb),.28);
}
.consultant-chip--success{
  background:var(--success-soft);
  border-color:rgba(var(--success-rgb),.28);
  color:rgba(var(--success-rgb),.85);
}
.consultant-chip--warning{
  background:var(--warning-soft);
  border-color:rgba(var(--warning-rgb),.24);
  color:var(--warning-warm);
}
.consultant-dashboard__section{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.consultant-dashboard__section-header h2{
  margin:0;
  font-size:18px;
  font-weight:700;
}
.consultant-dashboard__section-meta{
  font-size:12px;
  color:var(--muted);
}
.consultant-dashboard__empty{
  margin:0;
  padding:16px;
  border-radius:var(--radius-md);
  border:1px dashed var(--border);
  color:var(--muted);
  background:var(--surface);
}
.consultant-client-grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
.consultant-client-card{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:16px;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  background:var(--surface);
  box-shadow:0 10px 24px rgba(var(--base-rgb),.06);
}
.consultant-client-card__top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}
.consultant-client-card__identity h3{
  margin:0;
  font-size:16px;
  font-weight:600;
}
.consultant-client-card__email{
  display:block;
  font-size:12px;
  color:var(--muted);
  margin-top:4px;
}
.consultant-client-card__chips{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
}
.consultant-client-card__metrics{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
  padding:12px;
  border-radius:var(--radius-md);
  border:1px solid var(--border-soft);
  background:var(--surface-muted);
}
.consultant-client-card__metrics span{
  display:flex;
  flex-direction:column;
  gap:2px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--muted);
  text-align:center;
}
.consultant-client-card__metrics strong{
  font-size:13px;
  font-weight:600;
  color:var(--text);
  letter-spacing:0;
}
.consultant-client-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
  font-size:11px;
  color:var(--muted);
}
.consultant-client-card__flags{
  margin:0;
  padding-left:18px;
  font-size:12px;
  color:var(--warning-warm);
}
.consultant-client-card__footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.consultant-client-card__active{
  font-size:12px;
  font-weight:600;
  color:var(--primary);
}
.btn--icon{
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.btn--icon svg{
  width:15px;
  height:15px;
}
.consultant-dashboard__layout{
  display:grid;
  grid-template-columns:2fr minmax(280px, 0.9fr);
  gap:18px;
}
.consultant-dashboard__column{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.consultant-dashboard__card{
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:16px;
  background:var(--surface);
  display:flex;
  flex-direction:column;
  gap:12px;
  box-shadow:0 8px 22px rgba(var(--base-rgb),.06);
}
.consultant-activity{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.consultant-activity li{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:var(--radius-md);
  border:1px solid var(--border);
  background:var(--surface);
}
.consultant-activity__kind{
  font-size:11px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
}
.consultant-activity__title{
  font-size:13px;
  font-weight:600;
  color:var(--text);
}
.consultant-activity__timestamp{
  font-size:12px;
  color:var(--muted);
  text-align:right;
}
.consultant-notifications{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.consultant-notifications li{
  padding:10px 12px;
  border-radius:var(--radius-md);
  background:var(--warning-soft);
  border:1px solid rgba(var(--warning-rgb),.28);
  color:var(--warning-warm);
  display:flex;
  flex-direction:column;
  gap:4px;
}
.consultant-notifications strong{
  font-size:13px;
}
.consultant-resources{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.consultant-resources li{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid var(--border-soft);
}
.consultant-resources li:last-child{
  border-bottom:none;
}
.consultant-resources strong{
  font-size:13px;
  font-weight:600;
}
.consultant-resources p{
  margin:4px 0 0;
  font-size:12px;
  color:var(--muted);
}
.consultant-resources__link{
  font-size:12px;
  font-weight:600;
  color:var(--primary);
  white-space:nowrap;
}
.consultant-modal-body{
  display:flex;
  flex-direction:column;
  gap:22px;
}
.consultant-modal-subtitle{
  margin:4px 0 0;
  font-size:12px;
  color:var(--muted);
}
.consultant-modal-form{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.consultant-modal-form--stacked{
  gap:12px;
}
.consultant-modal-inline{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0;
}
.consultant-modal-inline--danger .btn{
  color:var(--danger);
}
.consultant-modal-inline--active{
  font-size:12px;
  color:var(--primary);
}
.consultant-modal-hint{
  font-size:11px;
  color:var(--muted);
}
.field-note{
  font-size:12px;
  color:var(--muted);
  margin:0;
}
.consultant-toggle{
  display:flex;
  align-items:center;
  gap:8px;
}
.consultant-toggle__label{
  font-size:13px;
  font-weight:600;
  color:var(--text);
}
.consultant-modal-inline--danger .btn--ghost{
  border-color:rgba(var(--danger-rgb),.24);
  background:rgba(var(--danger-rgb),.08);
}
.consultant-modal-inline--danger .btn--ghost:hover{
  border-color:rgba(var(--danger-rgb),.32);
}
html[data-theme="dark"] .consultant-dashboard__toolbar{
  background:rgba(var(--base-rgb),.85);
  border-color:rgba(var(--primary-rgb),.28);
  box-shadow:0 14px 32px rgba(4,12,27,.55);
}
html[data-theme="dark"] .consultant-client-card__metrics{
  background:rgba(var(--white-rgb),.04);
  border-color:rgba(var(--white-rgb),.08);
}
html[data-theme="dark"] .consultant-resources li{
  border-color:rgba(var(--white-rgb),.08);
}
@media (max-width:1080px){
  .consultant-dashboard__layout{
    grid-template-columns:1fr;
  }
}
.topbar__title{margin:0;font-size:18px;font-weight:600;letter-spacing:.3px}
.topbar__model{
  display:flex;
  align-items:center;
  gap:8px;
  margin-left:18px;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(var(--base-rgb),.04);
  border:1px solid rgba(var(--base-rgb),.08);
  box-shadow:inset 0 1px 0 rgba(var(--white-rgb),.4);
}
html[data-theme="dark"] .topbar__model{
  background:rgba(var(--white-rgb),.06);
  border-color:rgba(var(--white-rgb),.08);
  box-shadow:none;
}
.topbar__model-label{
  font-size:12px;
  font-weight:600;
  letter-spacing:.02em;
  color:var(--muted-strong, var(--muted));
}
.topbar__model-select{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid var(--primary-strong);
  background:linear-gradient(135deg,rgba(var(--white-rgb),.96),rgba(248,250,252,.86));
  color:var(--text);
  font-weight:600;
  font-size:12px;
  letter-spacing:.03em;
  padding:6px 34px 6px 12px;
  border-radius:999px;
  position:relative;
  line-height:1.3;
  min-width:150px;
  cursor:pointer;
  white-space:pre-line;
  box-shadow:0 8px 20px rgba(var(--base-rgb),.12);
  transition:border-color .2s ease, box-shadow .2s ease, transform .12s ease;
  width:100%;
}
.topbar__model-select:focus-visible,
.topbar__model-select:hover{
  outline:none;
  border-color:var(--primary-glow);
  box-shadow:0 12px 26px var(--primary-softer);
  background:linear-gradient(135deg,rgba(var(--white-rgb),1),rgba(237,245,255,.95));
}
.topbar__model-select::-ms-expand{display:none}
.topbar__model-select option{
  white-space:pre-line;
  font-size:12px;
  font-weight:500;
  padding:8px 10px;
  color:var(--text);
}html[data-theme="dark"] .topbar__model-select{
  border-color:var(--primary-strong);
  background:linear-gradient(135deg,rgba(30,41,59,.92),rgba(var(--base-rgb),.9));
  color:rgba(226,232,240,.9);
  box-shadow:0 10px 22px rgba(0,0,0,.4);
}
html[data-theme="dark"] .topbar__model-select:focus-visible,html[data-theme="dark"] .topbar__model-select:hover{
  border-color:var(--primary-glow);
  background:linear-gradient(135deg,rgba(30,41,59,.98),rgba(var(--base-rgb),.96));
  box-shadow:0 14px 28px rgba(6,40,82,.45);
}
.topbar__model-select-wrap{
  position:relative;
  display:inline-flex;
}
.topbar__model-select-wrap[data-combo-ready="true"]::after{display:none}
.topbar__model-select-wrap::after{
  content:"";
  position:absolute;
  top:50%;
  right:12px;
  width:10px;
  height:10px;
  border-left:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:translateY(-50%) rotate(-45deg);
  pointer-events:none;
  opacity:.65;
}
html[data-theme="dark"] .topbar__model-select-wrap::after{
  color:rgba(var(--slate-rgb),.85);
}
@media (max-width: 860px){
  .topbar__model{display:none}
}
.topbar__controls{
  display:flex;align-items:center;gap:12px;
  margin-left:auto;
  justify-content:flex-end;
  flex-wrap:nowrap;
}
.topbar__controls > *{flex-shrink:0}
.case-selector,
.assess-btn,
.topbar-btn,
.metric,
#themeToggle,
.avatar-menu{flex-shrink:0}
.topbar-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;border:1px solid var(--border);
  background:var(--surface-muted);color:inherit;font:inherit;
  cursor:pointer;transition:border-color .2s ease, background .2s ease, transform .12s ease;
}
.topbar-btn:hover{border-color:var(--primary);background:var(--surface)}
.topbar-btn:active{transform:translateY(1px)}
.topbar-btn__icon{font-size:15px;line-height:1}
.topbar-btn__label{font-size:13px;font-weight:600;letter-spacing:.2px}
.assess-btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;position:relative}
#btnFilesQuick{
  width:34px;
  height:34px;
  padding:0;
  gap:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
}
#btnFilesQuick svg{
  width:16px;
  height:16px;
  display:block;
}
.assess-btn__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
}
.assess-btn__icon svg{
  width:16px;
  height:16px;
  display:block;
}
.assess-btn__spinner{display:inline-block;width:0;height:0;margin-right:0;opacity:0;border-radius:999px;border:2px solid transparent;transition:width .2s ease,height .2s ease,margin-right .2s ease,opacity .2s ease}
.assess-btn.is-loading,.assess-btn:disabled{pointer-events:none}
.is-loading .assess-btn__spinner{width:14px;height:14px;margin-right:6px;opacity:1;border-color:currentColor;border-right-color:transparent;animation:spin .8s linear infinite}
.assess-btn.is-disabled,
.assess-btn:disabled{
  opacity:.5;
}
.metric__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  margin-right:6px;
}
.metric__icon svg{
  width:16px;
  height:16px;
  display:block;
}
.metric__text{
  font-weight:600;
}


/* Controls */
.input,.select,.btn,.icon-btn{
  font:inherit;color:inherit;border-radius:var(--radius-sm);
  border:1px solid var(--border); background:var(--surface);
  transition:border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.input,.select{padding:8px 10px;width:100%}
.input:focus,.select:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-strong)}
.input--textarea{width:100%;resize:vertical;min-height:120px}
.select--pill{border-radius:999px;padding:8px 14px;background:var(--surface)}

.case-form__select{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid var(--primary-softer);
  background:linear-gradient(135deg,rgba(var(--white-rgb),.96),rgba(248,250,252,.9));
  color:var(--text);
  font-weight:600;
  font-size:12px;
  letter-spacing:.02em;
  padding:8px 34px 8px 14px;
  border-radius:999px;
  line-height:1.35;
  width:100%;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(var(--base-rgb),.12);
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease, transform .12s ease;
}
.case-form__select:focus-visible,
.case-form__select:hover{
  outline:none;
  border-color:var(--primary-glow);
  background:linear-gradient(135deg,rgba(var(--white-rgb),1),rgba(235,244,255,.95));
  box-shadow:0 14px 30px var(--primary-soft);
}
.case-form__select::-ms-expand{display:none}
.case-form__select option{
  font-size:12px;
  font-weight:600;
  padding:8px 12px;
  color:var(--text);
}
.case-form__select optgroup{
  font-size:11px;
  font-style:italic;
  font-weight:400;
  color:var(--muted);
  padding:6px 12px;
}
.case-form__select optgroup option{
  font-style:normal;
  font-weight:600;
}
html[data-theme="dark"] .case-form__select{
  border-color:var(--primary-strong);
  background:linear-gradient(135deg,rgba(30,41,59,.92),rgba(var(--base-rgb),.9));
  color:rgba(226,232,240,.9);
  box-shadow:0 12px 26px rgba(0,0,0,.44);
}
html[data-theme="dark"] .case-form__select:focus-visible,
html[data-theme="dark"] .case-form__select:hover{
  border-color:var(--primary-glow);
  background:linear-gradient(135deg,rgba(30,41,59,.98),rgba(var(--base-rgb),.96));
  box-shadow:0 16px 32px rgba(6,40,82,.48);
}
html[data-theme="dark"] .case-form__select option{color:var(--text)}
html[data-theme="dark"] .case-form__select optgroup{
  color:rgba(var(--slate-rgb),.82);
}
.case-form__select-wrap{
  position:relative;
  display:block;
}
.case-form__select-wrap[data-combo-ready="true"]::after{display:none}
.case-form__select-wrap::after{
  content:"";
  position:absolute;
  top:50%;
  right:14px;
  width:10px;
  height:10px;
  border-left:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:translateY(-50%) rotate(-45deg);
  pointer-events:none;
  opacity:.7;
}
html[data-theme="dark"] .case-form__select-wrap::after{
  color:rgba(var(--slate-rgb),.88);
}

.combo{
  position:relative;
  display:flex;
  flex-direction:column;
  width:100%;
}
.combo__select--hidden{
  position:absolute !important;
  opacity:0 !important;
  pointer-events:none !important;
  width:0 !important;
  height:0 !important;
  margin:0 !important;
}
.combo__trigger{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  width:100%;
  border-radius:999px;
  padding:8px 38px 8px 14px;
  font:inherit;
  color:var(--text);
  cursor:pointer;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease, transform .12s ease;
}
.combo__trigger::after{
  content:"";
  position:absolute;
  top:50%;
  right:18px;
  width:11px;
  height:11px;
  border-left:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:translateY(-50%) rotate(-45deg);
  opacity:.7;
  transition:transform .2s ease, opacity .2s ease;
  pointer-events:none;
}
.combo[data-open="true"] .combo__trigger::after{
  transform:translateY(-50%) rotate(135deg);
  opacity:1;
}
.combo__primary{
  font-size:13px;
  font-weight:600;
  letter-spacing:.02em;
  line-height:1.35;
}
.combo__secondary{
  font-size:11px;
  font-style:italic;
  color:var(--muted);
  line-height:1.2;
}
.combo__badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  align-self:flex-start;
  font-size:11px;
  font-style:italic;
  font-weight:500;
  letter-spacing:0.01em;
  color:var(--success);
  line-height:1.2;
}
.combo__badge--trigger{margin-top:2px;}
.combo__badge--option{margin-top:4px;}
.combo__secondary--trigger{display:none;}
.combo[data-has-secondary="false"] .combo__secondary{display:none}
.combo__list{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  width:100%;
  min-width:220px;
  max-height:none;
  overflow:visible;
  padding:8px;
  border-radius:16px;
  border:1px solid var(--primary-soft);
  box-shadow:0 16px 38px rgba(var(--base-rgb),.15);
  background:linear-gradient(135deg,rgba(var(--white-rgb),.95),rgba(248,250,252,.9));
  display:none;
  z-index:var(--z-popover);
  backdrop-filter:saturate(160%) blur(14px);
}
.combo[data-open="true"] .combo__list{display:block}
.combo__option{
  list-style:none;
  padding:8px 12px;
  border-radius:12px;
  display:flex;
  flex-direction:column;
  gap:2px;
  cursor:pointer;
  transition:background .15s ease, transform .12s ease;
}
.combo__option:hover,
.combo__option:focus-visible{
  background:var(--primary-softest);
  outline:none;
}
.combo__option[data-selected="true"]{
  background:var(--primary-soft);
  color:var(--text);
}
.combo__option[aria-disabled="true"]{
  opacity:.55;
  cursor:default;
}
.combo__option[aria-disabled="true"]:hover{background:transparent}
.combo__secondary--option{color:var(--muted)}
.combo--topbar .combo__trigger{
  border:1px solid var(--primary-strong);
  background:linear-gradient(135deg,rgba(var(--white-rgb),.96),rgba(248,250,252,.86));
  box-shadow:0 9px 22px rgba(var(--base-rgb),.12);
}
.combo--topbar .combo__trigger:hover,
.combo--topbar .combo__trigger:focus-visible{
  outline:none;
  border-color:var(--primary-glow);
  box-shadow:0 12px 26px var(--primary-softer);
  background:linear-gradient(135deg,rgba(var(--white-rgb),1),rgba(237,245,255,.95));
}
.combo--topbar .combo__list{
  min-width:230px;
}
.combo--case .combo__trigger{
  border:1px solid var(--primary-strong);
  background:linear-gradient(135deg,rgba(var(--white-rgb),.97),rgba(241,245,255,.92));
  box-shadow:0 11px 24px rgba(var(--base-rgb),.12);
}
.combo--case .combo__trigger:hover,
.combo--case .combo__trigger:focus-visible{
  outline:none;
  border-color:var(--primary-glow);
  background:linear-gradient(135deg,rgba(var(--white-rgb),1),rgba(235,244,255,.95));
  box-shadow:0 15px 30px var(--primary-soft);
}
.combo--case .combo__list{
  min-width:230px;
  padding:10px;
}
.combo--case .combo__option{
  padding:9px 12px;
}
.combo--version .combo__trigger{
  border:1px solid var(--primary-softer);
  background:linear-gradient(135deg,rgba(var(--white-rgb),.95),rgba(243,246,255,.9));
  box-shadow:0 9px 22px rgba(var(--base-rgb),.12);
  min-width:140px;
}
.combo--version .combo__trigger:hover,
.combo--version .combo__trigger:focus-visible{
  outline:none;
  border-color:var(--primary-glow);
  background:linear-gradient(135deg,rgba(var(--white-rgb),1),rgba(235,244,255,.95));
  box-shadow:0 12px 26px var(--primary-soft);
}
.combo--version .combo__list{
  top:auto;
  bottom:calc(100% + 10px);
  min-width:220px;
  padding:10px;
  max-height:260px;
  overflow:auto;
}
.combo--version .combo__option{
  padding:9px 12px;
  flex-direction:column;
  align-items:flex-start;
  gap:3px;
  white-space:normal;
}
.combo--version .combo__option .combo__primary{
  font-size:12.5px;
  display:block;
  width:100%;
}
.combo--version .combo__secondary--option{
  display:block;
  font-style:normal;
  color:var(--muted);
  font-size:11.5px;
  opacity:.85;
  width:100%;
  line-height:1.3;
}
html[data-theme="dark"] .combo__trigger{
  color:rgba(226,232,240,.94);
}
html[data-theme="dark"] .combo__secondary{
  color:rgba(var(--slate-rgb),.85);
}
html[data-theme="dark"] .combo--topbar .combo__trigger,
html[data-theme="dark"] .combo--case .combo__trigger{
  border-color:var(--primary-strong);
  background:linear-gradient(135deg,rgba(30,41,59,.92),rgba(var(--base-rgb),.9));
  box-shadow:0 14px 32px rgba(0,0,0,.45);
}
html[data-theme="dark"] .combo--topbar .combo__trigger:hover,
html[data-theme="dark"] .combo--topbar .combo__trigger:focus-visible,
html[data-theme="dark"] .combo--case .combo__trigger:hover,
html[data-theme="dark"] .combo--case .combo__trigger:focus-visible,
html[data-theme="dark"] .combo--version .combo__trigger:hover,
html[data-theme="dark"] .combo--version .combo__trigger:focus-visible{
  border-color:var(--primary-glow);
  background:linear-gradient(135deg,rgba(30,41,59,.98),rgba(var(--base-rgb),.96));
  box-shadow:0 18px 38px rgba(6,40,82,.5);
}
html[data-theme="dark"] .combo__list{
  border-color:var(--primary-strong);
  background:linear-gradient(135deg,rgba(30,41,59,.94),rgba(var(--base-rgb),.92));
  box-shadow:0 22px 44px rgba(0,0,0,.55);
}
html[data-theme="dark"] .combo__option{
  color:rgba(226,232,240,.9);
}
html[data-theme="dark"] .combo__option:hover,
html[data-theme="dark"] .combo__option:focus-visible{
  background:var(--primary-softer);
}
html[data-theme="dark"] .combo__option[data-selected="true"]{
  background:var(--primary-strong);
  color:rgba(226,232,240,.98);
}
html[data-theme="dark"] .combo__option .combo__secondary{
  color:rgba(var(--slate-rgb),.85);
}
html[data-theme="dark"] .combo--version .combo__trigger{
  border-color:var(--primary-strong);
  background:linear-gradient(135deg,rgba(30,41,59,.94),rgba(var(--base-rgb),.9));
  box-shadow:0 12px 28px rgba(0,0,0,.48);
}

.btn{
  cursor:pointer;
  padding:8px 12px;
  border-radius:999px;
  background:var(--surface-muted);
  text-decoration:none;
}
.btn:hover,
.btn:focus{
  text-decoration:none;
}
.btn:hover{border-color:var(--primary)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn--primary{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary)}
.btn--ghost{background:transparent}
.btn--danger{color:var(--danger);border-color:var(--danger-strong)}

.icon-btn{width:32px;height:32px;padding:0;display:grid;place-items:center;border-radius:50%;cursor:pointer;background:transparent}
.icon-btn:hover{border-color:var(--primary)}
.icon-btn--ghost{background:transparent}

/* Simple icons */
.icon--collapse{width:16px;height:16px;transition:transform .2s ease;transform-origin:center}

/* Modules & lists */
.module{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:14px;box-shadow:var(--shadow-soft);scroll-margin-top:16px;transition:border-color .2s ease, box-shadow .2s ease}
.module--highlight{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-strong);transition:border-color .3s ease, box-shadow .3s ease}
.module__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.module__heading{display:flex;align-items:center;gap:6px}
.module__title{margin:0;font-size:14px;letter-spacing:.3px;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:6px}
.module__title-text{line-height:1;display:inline-flex;align-items:center;gap:4px}
.module__title--required .module__title-text::before{
  content:"*";
  color:var(--danger);
  font-weight:700;
  font-size:12px;
  line-height:1;
  position:relative;
  top:-1px;
}
.module__link{font-size:13px}
.module__footer{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.module__hint{margin:16px 0 0;font-size:13px}
.module__summary{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px;background:var(--surface-muted);border-radius:var(--radius-sm);font-size:12px}
.module__heading .info-btn{flex-shrink:0;margin-top:0}
.module__info{margin-top:8px;padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-muted);font-size:13px;line-height:1.5;color:var(--text)}
.module__info p{margin:0 0 6px}
.module__info p:last-child{margin-bottom:0}
.module__info:focus{outline:2px solid var(--primary);outline-offset:2px}

.module__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

.info-btn{width:22px;height:22px;border-radius:50%;border:1px solid var(--border);background:var(--surface-muted);color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1;padding:0;cursor:pointer;transition:color .2s ease,border-color .2s ease,background .2s ease}
.info-btn:hover,
.info-btn:focus{color:var(--primary);border-color:var(--primary);background:var(--surface);outline:none}
.info-btn__icon{font-weight:600;font-size:11px;transform:translateY(-.5px)}

.stack{display:flex;flex-direction:column;gap:14px}.stack--compact{gap:12px}
.file-drop{display:flex;align-items:center;justify-content:center;padding:12px;border:1px dashed var(--border);border-radius:var(--radius-md);color:var(--muted);cursor:pointer;background:var(--surface-muted)}
.file-drop input[type=file]{display:none}
.file-drop--compact{padding:8px 10px;border-radius:var(--radius-sm);font-size:12px}
.file-drop__spinner{display:none;align-items:center;gap:8px;font-size:12px;color:var(--muted)}
.file-drop__spinner-circle{width:16px;height:16px;border-radius:50%;border:2px solid var(--primary);border-top-color:transparent;animation:resume-spin .75s linear infinite}
.resume-upload.is-uploading .file-drop__label{display:none}
.resume-upload.is-uploading .file-drop__spinner{display:flex}
.resume-upload.is-uploading .file-drop{cursor:progress}
.resume-upload__status{
  font-size:12px;
  color:var(--muted);
  min-height:1em;
  transition:color .2s ease;
}
.resume-upload__status.is-success{color:var(--primary)}
.resume-upload__status.is-error{color:var(--danger)}
.resume-upload__status[hidden]{display:none}

.resume-modal__body{padding:24px;flex:1 1 auto;overflow-y:auto;}
.resume-modal__grid{
  display:grid;
  grid-template-columns:minmax(260px,320px) minmax(0,1fr);
  gap:24px;
  align-items:flex-start;
}
.resume-modal__column{display:flex;flex-direction:column;gap:18px;}
.resume-modal__column--summary{max-width:360px;}
.resume-modal__column--sections{min-height:0;gap:12px;}

.resume-sections__header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:4px;}
.resume-sections__header h4{margin:0;font-size:14px;letter-spacing:.01em;}
.resume-sections__form{display:flex;flex-direction:column;gap:14px;}
.resume-sections{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.resume-sections__tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.resume-tab{
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  gap:1px;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid rgba(var(--base-rgb),.08);
  background:var(--surface-muted);
  font-size:11px;
  font-weight:600;
  color:var(--muted);
  cursor:pointer;
  transition:border-color .2s ease, background .2s ease, color .2s ease, transform .18s ease;
}
.resume-tab:hover,
.resume-tab:focus-visible{
  outline:none;
  border-color:var(--primary-glow);
  color:var(--text);
  transform:translateY(-1px);
}
.resume-tab.is-active{
  background:var(--surface);
  border-color:var(--primary-glow);
  color:var(--text);
  box-shadow:0 12px 28px rgba(var(--base-rgb),.12);
}
.resume-tab__title{font-size:12px;letter-spacing:.01em;}
.resume-tab__status{font-size:11px;color:var(--muted);font-weight:500;}
.resume-tab__status.is-empty{color:var(--warning-contrast);}
.resume-tab__dirty{display:none;font-size:10px;color:var(--primary);letter-spacing:.08em;text-transform:uppercase;}
.resume-tab.is-dirty .resume-tab__dirty{display:inline;}

.resume-sections__panels{background:var(--surface);border:1px solid rgba(var(--base-rgb),.08);border-radius:14px;box-shadow:0 12px 26px rgba(var(--base-rgb),.08);overflow:hidden;}
.resume-panel{display:none;padding:16px 18px;min-height:220px;gap:12px;flex-direction:column;}
.resume-panel.is-active{display:flex;}
.resume-panel__meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;}
.resume-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:999px;font-size:10px;font-weight:600;background:var(--primary-softest);color:var(--primary);}
.resume-chip--warning{background:rgba(234,179,8,.14);color:var(--warning-contrast);}
.resume-panel__textarea{min-height:150px;resize:vertical;font-size:12px;line-height:1.5;}
.resume-panel__controls{display:flex;flex-direction:column;gap:6px;margin-top:8px;}
.resume-panel__select{max-width:200px;font-size:12px;padding:8px 10px;}
.resume-panel__hint{margin-top:4px;display:block;}

.resume-sections__status{font-size:12px;min-height:1em;}
.resume-sections__status.is-success{color:var(--primary);}
.resume-sections__status.is-error{color:var(--danger);}
.resume-sections__status[hidden]{display:none;}
.resume-sections__actions{display:flex;align-items:center;gap:10px;}
.resume-sections__empty{padding:24px;border-radius:16px;border:1px dashed var(--border);background:var(--surface-muted);text-align:center;}

html[data-theme="dark"] .resume-modal__grid{gap:20px;}
html[data-theme="dark"] .resume-tab{background:rgba(30,34,46,.92);border-color:rgba(var(--slate-rgb),.18);color:rgba(226,232,240,.86);}
html[data-theme="dark"] .resume-tab.is-active{background:rgba(var(--base-rgb),.95);border-color:var(--primary-glow);color:rgba(241,245,249,.95);box-shadow:0 20px 42px rgba(0,0,0,.55);}
html[data-theme="dark"] .resume-tab__status.is-empty{color:var(--warning-bright);}
html[data-theme="dark"] .resume-sections__panels{background:rgba(var(--base-rgb),.92);border-color:var(--primary-softer);box-shadow:0 24px 48px rgba(2,6,23,.65);}
html[data-theme="dark"] .resume-panel__textarea{background:rgba(var(--base-rgb),.96);color:rgba(226,232,240,.95);border-color:var(--primary-strong);}
html[data-theme="dark"] .resume-chip{background:var(--primary-softer);color:rgba(191,219,254,.95);}
html[data-theme="dark"] .resume-chip--warning{background:rgba(250,204,21,.18);color:rgba(253,230,138,.95);}

@media (max-width: 1100px){
  .resume-modal__grid{grid-template-columns:1fr;}
  .resume-modal__column--summary{order:2;}
  .resume-modal__column--sections{order:1;}
  .resume-modal__column--summary{max-width:none;}
}

@keyframes resume-spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

/* Sidebar compact overrides */
#sidebar .module{
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(var(--base-rgb),.07);
  background:linear-gradient(145deg,rgba(var(--white-rgb),.98),rgba(243,246,255,.9));
  box-shadow:0 14px 32px rgba(var(--base-rgb),.08);
  transition:border-color .22s ease, box-shadow .22s ease, transform .18s ease;
}
#sidebar .module:hover{
  border-color:var(--primary-strong);
  box-shadow:0 18px 36px rgba(var(--base-rgb),.12);
  transform:translateY(-1px);
}
html[data-theme="dark"] #sidebar .module{
  background:linear-gradient(145deg,rgba(30,34,46,.94),rgba(18,23,35,.92));
  border-color:rgba(var(--slate-rgb),.14);
  box-shadow:0 18px 40px rgba(0,0,0,.48);
}
#sidebar .module__header{margin-bottom:8px}
#sidebar .module__title{
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:600;
}
#sidebar .module__title-text{font-size:inherit}
#sidebar .module__footer{margin-top:10px;font-size:11px;gap:8px}
#sidebar .stack{gap:10px}
#sidebar .module__info{
  font-size:11px;
  background:rgba(var(--white-rgb),.7);
  border-radius:14px;
  border:1px solid rgba(var(--base-rgb),.06);
}
html[data-theme="dark"] #sidebar .module__info{
  background:rgba(30,34,46,.8);
  border-color:rgba(var(--slate-rgb),.16);
}
#sidebar .file-drop{padding:8px 10px;border-radius:14px}
#sidebar .link-form{gap:6px;margin-bottom:6px}
#sidebar .exhibits-grid{gap:8px}
#sidebar .exhibit-tile{padding:12px 10px;border-radius:14px}
#sidebar .info-btn{width:20px;height:20px}
#sidebar .info-btn__icon{font-size:9px}
#sidebar .module__actions{gap:6px}

body.sb-collapsed:not(.sb-closed) .sidebar{
  width:var(--sidebar-collapsed-width);
  padding:18px 10px;
  overflow:visible;
}
body.sb-collapsed:not(.sb-closed) .sidebar__case-card{display:none}
body.sb-collapsed:not(.sb-closed) .case-card{
  padding:6px;
  border-radius:16px;
  align-items:center;
  box-shadow:0 10px 24px rgba(var(--base-rgb),.12);
}
body.sb-collapsed:not(.sb-closed) .case-card__badge,
body.sb-collapsed:not(.sb-closed) .case-card__label,
body.sb-collapsed:not(.sb-closed) .case-card__status,
body.sb-collapsed:not(.sb-closed) .case-card__body,
body.sb-collapsed:not(.sb-closed) .case-card__form{
  display:none;
}
body.sb-collapsed:not(.sb-closed) .case-card__chip{display:none}
html[data-theme="dark"] body.sb-collapsed:not(.sb-closed) .case-card{
  box-shadow:0 16px 36px rgba(0,0,0,.45);
}
body.sb-collapsed:not(.sb-closed) .sidebar__brand .brand{display:none}
body.sb-collapsed:not(.sb-closed) .sidebar__top{
  flex-direction:column;
  align-items:center;
  gap:10px;
  border-bottom:none;
  margin-bottom:14px;
  padding-bottom:0;
}
body.sb-collapsed:not(.sb-closed) .sidebar__model-card,
body.sb-collapsed:not(.sb-closed) .sidebar__profile-stats,
body.sb-collapsed:not(.sb-closed) .sidebar-nav__label{display:none}
body.sb-collapsed:not(.sb-closed) .sidebar__quick{
  gap:10px;
  margin-bottom:0;
}
body.sb-collapsed:not(.sb-closed) .sidebar__quick-item{
  padding:10px 12px;
  justify-content:center;
  border-radius:16px;
  flex-direction:column;
  align-items:center;
  gap:6px;
  text-align:center;
  min-height:64px;
}
body.sb-collapsed:not(.sb-closed) .sidebar__quick-shell{justify-content:center}
body.sb-collapsed:not(.sb-closed) .sidebar__quick-menu-indicator{display:none}
body.sb-collapsed:not(.sb-closed) .sidebar__quick-icon{
  width:30px;
  height:30px;
}
body.sb-collapsed:not(.sb-closed) .sidebar__quick-body,
body.sb-collapsed:not(.sb-closed) .sidebar__quick-badge{display:none}
body.sb-collapsed:not(.sb-closed) .sidebar__quick-item[data-collapsed-label]::after{
  content:attr(data-collapsed-label);
  display:block;
  font-size:8px;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--muted);
  line-height:1;
  margin-top:1px;
  white-space:nowrap;
}
body.sb-collapsed:not(.sb-closed) .sidebar__quick-info-btn{display:none}
body.sb-collapsed:not(.sb-closed) .sidebar__quick-info{display:none!important}
body.sb-collapsed:not(.sb-closed) .sidebar__scroll{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-right:0;
  align-items:stretch;
}
body.sb-collapsed:not(.sb-closed) .sidebar__footer{display:none}
body.sb-collapsed:not(.sb-closed) .sidebar__collapse{
  width:40px;
  height:40px;
  border-radius:14px;
  border:1px solid rgba(var(--base-rgb),.12);
}
body.sb-collapsed:not(.sb-closed) .sidebar__collapse .icon--collapse{transform:rotate(180deg)}
.resume-upload{display:flex;flex-direction:column;gap:8px}

.resume-card{display:flex;align-items:flex-start;gap:16px;padding:16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-muted)}
.resume-card__thumb{width:56px;height:56px;border-radius:14px;background:var(--surface);display:grid;place-items:center;border:1px solid var(--border);color:var(--primary)}
.resume-card__thumb svg{width:30px;height:30px}
.resume-card__details{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.resume-card__details h4{margin:0;font-size:14px;text-transform:uppercase;letter-spacing:.28px;color:var(--muted)}
.resume-card__filename{margin:0;font-weight:600;font-size:15px;line-height:1.35;word-break:break-word}
.resume-card__meta{margin:0;font-size:12px;color:var(--muted)}
.resume-card__actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.resume-card__actions .btn{padding:6px 12px;font-size:12px}
.resume-card__hint{margin:14px 0 0;font-size:12px;text-align:left}
.resume-card--empty{align-items:center;justify-content:flex-start}
.resume-card--empty .resume-card__thumb{color:var(--muted);border-style:dashed}
.resume-upload__note{margin:0;font-size:11px}

.btn--ghost.btn--danger{color:var(--danger);border-color:var(--danger-glow)}
.btn--ghost.btn--danger:hover,
.btn--ghost.btn--danger:focus{border-color:var(--danger-glow);color:var(--danger)}

@media (max-width:540px){
  .resume-card{flex-direction:column;align-items:flex-start}
  .resume-card__thumb{width:46px;height:46px}
  .resume-card__actions{width:100%;justify-content:flex-start}
}

.btn--slim{padding:6px 10px;border-radius:999px}

.proposed-actions{display:flex;justify-content:flex-end;margin-top:8px}
.proposed-upload{display:flex;flex-direction:column;gap:10px}
.proposed-upload .file-drop{justify-content:flex-start;padding:10px}
.proposed-context{font-size:13px}
.form-divider{border:none;border-top:1px solid var(--border);margin:16px 0}
.form-divider-label{font-size:13px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);margin:0;text-align:left}
.context-toggle-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}

.modal__body--tight{padding:18px;flex:1 1 auto;overflow-y:auto}
.modal__body--tight .stack{gap:12px}
.modal__actions--split{display:flex;align-items:center;justify-content:space-between;gap:10px}
.field{display:flex;flex-direction:column;gap:6px}

.link-form{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.link-form .icon-btn{align-self:flex-start}

.links-modal__body{display:flex;gap:24px;align-items:flex-start;flex:1 1 auto;overflow-y:auto}
.links-modal__nav{display:flex;flex-direction:column;gap:10px;min-width:190px}
.links-modal__tab{display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--surface-muted);border:1px solid var(--border);cursor:pointer;font-size:13px;color:var(--muted);transition:border-color .2s ease,background .2s ease,color .2s ease}
.links-modal__tab.is-active{background:var(--surface);color:var(--text);border-color:var(--primary)}
.links-modal__tab:focus{outline:none;box-shadow:0 0 0 3px var(--primary-softer)}
.links-modal__panels{flex:1;min-width:0;display:flex;flex-direction:column;gap:24px}
.links-modal__panel{display:none;flex-direction:column;gap:18px}
.links-modal__panel.is-active{display:flex}
.links-modal__panel-header{display:flex;flex-direction:column;gap:6px}
.links-modal__requirement{margin:0;font-size:12px;color:var(--danger);font-weight:600}
.links-modal__list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.links-modal__item{display:flex;gap:16px;align-items:flex-start;justify-content:space-between;padding:12px 14px;background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-sm)}
.links-modal__item > div{flex:1;min-width:0}
.links-modal__url{display:block;font-size:12px;color:var(--muted);margin-top:4px;word-break:break-word}
.links-modal__empty{margin:0;font-size:13px}
.links-modal__form{margin-top:4px}
.links-modal__actions{display:flex;justify-content:flex-end}

.links-modal .btn--danger{white-space:nowrap}

@media (max-width:900px){
  .links-modal__body{flex-direction:column}
  .links-modal__nav{flex-direction:row;flex-wrap:wrap;gap:8px}
  .links-modal__tab{flex:1;justify-content:center}
  .links-modal__panels{width:100%}
}

/* Exhibits grid */
.exhibits-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.exhibit-tile{border-radius:var(--radius-md);background:var(--surface-muted);border:1px solid var(--border);padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:border-color .2s ease, transform .2s ease}
.exhibit-tile:hover{border-color:var(--primary);transform:translateY(-2px)}
.exhibit-icon{width:26px;height:26px;color:var(--text)}
.exhibit-label{font-size:13px;color:var(--muted)}

/* Case popover */
.case-selector{position:relative}
.case-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--primary);background:var(--primary);color:var(--primary-contrast);cursor:pointer;font:inherit}
.case-badge:hover{filter:saturate(1.1)}
.case-badge:focus{outline:none;box-shadow:0 0 0 3px var(--primary-strong)}
.case-badge__icon{color:currentColor;opacity:.9}
.case-badge--empty{background:var(--surface-muted);color:var(--muted);border-color:var(--border)}
.case-badge--empty .case-badge__icon{color:var(--muted);opacity:1}
.popover{
  position:absolute;top:calc(100% + 8px);left:0;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-md);box-shadow:var(--shadow-soft);padding:8px;z-index:var(--z-popover);min-width:220px;display:none
}
.popover[aria-hidden="false"]{display:block}

/* Metric & avatar */
.metric{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:var(--surface-muted);border:1px solid var(--border);font-size:12px;color:var(--text)}
.metric__label{color:var(--muted)} .metric__value{font-weight:600;font-size:12px}
.metric--action{cursor:pointer;align-items:center;flex-direction:row;gap:6px;min-width:80px;padding:6px 12px}
.metric--action:focus-visible,.metric--action:hover{border-color:var(--accent);box-shadow:0 0 0 2px var(--primary-soft)}
.metric--action.metric--empty{border-color:var(--danger-border,var(--danger));box-shadow:none}
.metric--action.metric--empty .metric__value{color:var(--danger)}
.metric--ghost{background:transparent;border-style:dashed;color:var(--accent);cursor:pointer;padding:6px 16px;font-weight:600}
.metric--ghost:hover,.metric--ghost:focus-visible{border-color:var(--accent);color:var(--accent)}
.metric-group{display:flex;align-items:center;gap:10px}
.metric__hint{font-size:11px;color:var(--muted);line-height:1}
.avatar-menu{position:relative}
.avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;border:1px solid var(--border);padding:0;background:transparent;cursor:pointer;transition:box-shadow .2s ease,border-color .2s ease}
.avatar:hover{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-softer)}
.avatar img{width:100%;height:100%;object-fit:cover}

/* Refined dropdown (glass-like) */
.dropdown{
  position:absolute;right:0;top:calc(100% + 10px);min-width:240px;padding:10px;
  background:rgba(var(--white-rgb),.72);backdrop-filter:saturate(180%) blur(12px);
  border:1px solid rgba(0,0,0,.06);border-radius:14px;box-shadow:0 12px 36px rgba(0,0,0,.12);
  display:none;z-index:var(--z-dropdown)
}
html[data-theme="dark"] .dropdown{
  background:rgba(21,24,33,.64);border-color:rgba(var(--white-rgb),.08);box-shadow:0 18px 44px rgba(0,0,0,.45)
}
.dropdown::before{
  content:"";position:absolute;top:-8px;right:18px;width:12px;height:12px;transform:rotate(45deg);
  background:inherit;border-left:inherit;border-top:inherit
}
.dropdown[aria-hidden="false"]{display:block}
.dropdown__header{padding:8px 8px 12px;margin:0 2px 8px;border-bottom:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;gap:4px}
html[data-theme="dark"] .dropdown__header{border-bottom-color:rgba(var(--white-rgb),.08)}
.role-chip{
  align-self:flex-start;
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:2px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.05em;
  background:var(--primary-soft);
  color:var(--primary);
}
html[data-theme="dark"] .role-chip{
  background:var(--primary-strong);
  color:var(--accent-info);
}
.role-chip[data-role="super_admin"],
.role-chip[data-role="admin"],
.role-chip[data-role="admin_finance"]{
  background:rgba(255,193,7,.16);
  color:var(--warning-warm);
}
html[data-theme="dark"] .role-chip[data-role="super_admin"],
html[data-theme="dark"] .role-chip[data-role="admin"],
html[data-theme="dark"] .role-chip[data-role="admin_finance"]{
  background:rgba(255,193,7,.22);
  color:var(--warning-tint);
}
.dropdown__item{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  background:transparent;
  border:none;
  text-align:left;
  padding:10px 12px;
  margin:2px;
  border-radius:10px;
  cursor:pointer;
  font:inherit;
  color:var(--text);
  transition:background .15s ease, transform .06s ease;
  text-decoration:none;
}
.dropdown .dropdown__item,
.dropdown .dropdown__item:hover,
.dropdown .dropdown__item:focus,
.dropdown .dropdown__item:active{ text-decoration: none; }
.dropdown__item:hover{background:var(--primary-soft)}
html[data-theme="dark"] .dropdown__item:hover{background:var(--primary-softer)}
.dropdown__item:active{transform:scale(.99)}
.dropdown__item:focus-visible{outline:none;box-shadow:0 0 0 3px var(--primary-strong)}
.dropdown__item--danger{color:var(--danger)}
.dropdown__item--danger:hover{background:var(--danger-soft)}

/* Workspace */
.workspace{padding:32px 36px 48px}

.editor__actions{display:flex;align-items:center;gap:16px;padding:0 0 12px}
.case-stream{
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  background:var(--surface-muted);
  padding:16px;
  max-height:340px;
  overflow-y:auto;
  font-family:'SFMono-Regular',Consolas,'Liberation Mono',Menlo,Courier,monospace;
  margin-bottom:16px;
  white-space:pre-wrap;
}
.case-stream strong{color:var(--text)}

/* Modals & preview */
.label{font-weight:600;font-size:13px}
.modal{position:fixed;inset:0;display:none;z-index:var(--z-modal)}
.modal[aria-hidden="false"]{display:block}
.modal__backdrop{position:absolute;inset:0;background:rgba(8,12,22,.45);z-index:0}
.modal__dialog{position:relative;z-index:var(--z-modal-content);width:min(520px,92vw);margin:4vh auto;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-soft);overflow:hidden;display:flex;flex-direction:column;max-height:92vh}
.modal__dialog--wide{width:min(720px,94vw)}
.modal__dialog--xl{width:min(80vw,1440px)}
.modal__dialog--sm{width:min(360px,88vw)}
.modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border)}
.modal__body{padding:22px;background:var(--surface);flex:1 1 auto;overflow-y:auto}
.modal__body > * + *{margin-top:16px}
.modal__body--compact{padding:18px 20px;display:flex;flex-direction:column;gap:16px;background:var(--surface);flex:1 1 auto;overflow-y:auto}
.modal__body--scroll{max-height:60vh;overflow-y:auto;padding:22px}
.modal__actions{display:flex;justify-content:flex-end;gap:10px}
@media (max-width: 640px){
  .modal__dialog{
    width:min(96vw, 520px);
    margin:2vh auto;
    max-height:88vh;
    border-radius:14px;
  }
  .modal__dialog--wide,
  .modal__dialog--xl{
    width:96vw;
  }
  .modal__header{
    padding:12px 16px;
  }
  .modal__body{
    padding:16px;
  }
  .modal__body--compact{
    padding:14px 16px;
  }
  .modal__body--scroll{
    max-height:58vh;
    padding:16px;
  }
  .modal__actions{
    flex-wrap:wrap;
  }
}
@media (max-width: 480px){
  .modal__dialog{
    margin:1.5vh auto;
    max-height:86vh;
  }
  .modal__actions{
    flex-direction:column;
    align-items:stretch;
  }
  .modal__actions .btn{
    width:100%;
    justify-content:center;
  }
}
.evidence-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px}
.evidence-grid__item{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-muted);color:inherit;text-decoration:none;min-height:120px;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}
.evidence-grid__item{position:relative}
.evidence-grid__item:visited,.evidence-grid__item:hover,.evidence-grid__item:focus{text-decoration:none}
.evidence-grid__item:hover{border-color:var(--primary);box-shadow:var(--shadow-soft);transform:translateY(-2px)}
.evidence-grid__item:focus{outline:none;box-shadow:0 0 0 3px var(--primary-softer)}
.evidence-grid__icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:var(--surface);border:1px solid var(--border)}
.evidence-grid__icon svg{width:22px;height:22px}
.evidence-grid__label{font-size:13px;font-weight:600;line-height:1.3}
.evidence-grid__tag{position:absolute;top:10px;right:10px;padding:4px 8px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:11px;font-weight:600;color:var(--muted)}

#eb1aEvidenceModal .modal__dialog{width:min(980px,94vw);background:linear-gradient(160deg,#f8fbff 0%,#eef3ff 45%,#f7f1ff 100%);border:1px solid rgba(99,102,241,.2);box-shadow:0 24px 70px rgba(15,23,42,.25)}
#eb1aEvidenceModal .modal__header{border-bottom:1px solid rgba(99,102,241,.12)}
#eb1aEvidenceModal .modal__body{background:transparent;padding:20px 20px 22px}
#eb1aEvidenceModal .modal__header h3{font-family:"Space Grotesk","Inter",system-ui,sans-serif;font-size:20px;letter-spacing:.2px}
#eb1aEvidenceModal .evidence-modal__actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
#eb1aEvidenceModal .evidence-path-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid rgba(14,116,144,.25);background:linear-gradient(120deg,rgba(59,130,246,.15),rgba(14,165,233,.2));color:#0f172a;font-size:11px;font-weight:600}
#eb1aEvidenceModal .evidence-path-badge--empty{background:var(--surface-muted);color:var(--muted);border-color:var(--border)}
#eb1aEvidenceModal .evidence-modal__intro{background:rgba(255,255,255,.75);border:1px solid rgba(99,102,241,.15);border-radius:14px;padding:14px 16px;box-shadow:0 12px 24px rgba(79,70,229,.1);font-family:"Space Grotesk","Inter",system-ui,sans-serif}
html[data-theme="dark"] #eb1aEvidenceModal .modal__dialog{background:linear-gradient(160deg,#0f172a 0%,#111827 45%,#1f1b3a 100%);border:1px solid rgba(129,140,248,.25);box-shadow:0 24px 70px rgba(2,6,23,.7)}
html[data-theme="dark"] #eb1aEvidenceModal .modal__header{border-bottom:1px solid rgba(129,140,248,.2)}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-modal__intro{background:rgba(15,23,42,.75);border:1px solid rgba(129,140,248,.2);box-shadow:0 12px 24px rgba(2,6,23,.45)}
html[data-theme="dark"] #eb1aEvidenceModal .modal__header h3{color:#f8fafc}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-path-badge{background:linear-gradient(120deg,rgba(59,130,246,.25),rgba(14,165,233,.25));border:1px solid rgba(148,163,184,.3);color:#e2e8f0}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-path-badge--empty{background:rgba(30,41,59,.65);color:rgba(226,232,240,.7);border-color:rgba(148,163,184,.25)}
html[data-theme="dark"] #eb1aEvidenceModal .modal__body{color:#f8fafc}
html[data-theme="dark"] #eb1aEvidenceModal .muted{color:rgba(248,250,252,.78)}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__label{color:#f8fafc}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__item{background:linear-gradient(135deg,rgba(15,23,42,.95) 0%,rgba(30,41,59,.9) 60%,rgba(15,23,42,.8) 100%);border:1px solid rgba(148,163,184,.25);box-shadow:0 14px 28px rgba(2,6,23,.45)}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__item::after{box-shadow:0 0 0 1px rgba(255,255,255,.06) inset}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__item:hover{border-color:rgba(129,140,248,.6);box-shadow:0 20px 36px rgba(15,23,42,.6);transform:translateY(-3px)}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__item:focus{box-shadow:0 0 0 3px rgba(129,140,248,.35),0 18px 34px rgba(2,6,23,.55)}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__icon{border:1px solid rgba(148,163,184,.3);background:radial-gradient(circle at 30% 20%,rgba(30,41,59,.9),rgba(15,23,42,.95));color:#e2e8f0}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__tag{background:linear-gradient(120deg,rgba(59,130,246,.18),rgba(14,165,233,.2));border:1px solid rgba(148,163,184,.3);color:#e2e8f0}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__item:nth-child(3n+1) .evidence-grid__icon{background:radial-gradient(circle at 30% 20%,rgba(30,41,59,.9),rgba(124,45,18,.35));border-color:rgba(251,146,60,.45);color:#fdba74}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__item:nth-child(3n+2) .evidence-grid__icon{background:radial-gradient(circle at 30% 20%,rgba(30,41,59,.9),rgba(76,29,149,.35));border-color:rgba(167,139,250,.5);color:#c4b5fd}
html[data-theme="dark"] #eb1aEvidenceModal .evidence-grid__item:nth-child(3n) .evidence-grid__icon{background:radial-gradient(circle at 30% 20%,rgba(30,41,59,.9),rgba(6,78,59,.35));border-color:rgba(52,211,153,.5);color:#6ee7b7}
#eb1aEvidenceModal .evidence-grid{gap:14px;grid-template-columns:repeat(4,minmax(150px,1fr))}
@media (max-width: 1024px){
  #eb1aEvidenceModal .evidence-grid{grid-template-columns:repeat(2,minmax(150px,1fr))}
}
@media (max-width: 640px){
  #eb1aEvidenceModal .evidence-grid{grid-template-columns:repeat(1,minmax(150px,1fr))}
}
#eb1aEvidenceModal .evidence-grid__item{--accent:#38bdf8;background:linear-gradient(135deg,rgba(255,255,255,.95) 0%,rgba(248,250,255,.9) 60%,rgba(255,255,255,.75) 100%);border:1px solid rgba(148,163,184,.35);box-shadow:0 10px 20px rgba(15,23,42,.08);min-height:110px;padding:12px;gap:8px}
#eb1aEvidenceModal .evidence-grid__item::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;box-shadow:0 0 0 1px rgba(255,255,255,.55) inset}
#eb1aEvidenceModal .evidence-grid__item:hover{border-color:rgba(59,130,246,.65);box-shadow:0 18px 32px rgba(59,130,246,.18);transform:translateY(-3px)}
#eb1aEvidenceModal .evidence-grid__icon{width:40px;height:40px;border-radius:14px;border:1px solid rgba(59,130,246,.25);background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.85),rgba(219,234,254,.7),rgba(191,219,254,.4));color:#2563eb}
#eb1aEvidenceModal .evidence-grid__label{font-family:"Space Grotesk","Inter",system-ui,sans-serif;font-size:14px}
#eb1aEvidenceModal .evidence-grid__tag{background:linear-gradient(120deg,rgba(59,130,246,.15),rgba(14,165,233,.2));border:1px solid rgba(14,116,144,.25);color:#0f172a}
#eb1aEvidenceModal .evidence-grid__item:nth-child(3n+1){--accent:#f97316}
#eb1aEvidenceModal .evidence-grid__item:nth-child(3n+1) .evidence-grid__icon{background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.9),rgba(254,215,170,.75),rgba(253,186,116,.5));border-color:rgba(251,146,60,.4);color:#c2410c}
#eb1aEvidenceModal .evidence-grid__item:nth-child(3n+2){--accent:#8b5cf6}
#eb1aEvidenceModal .evidence-grid__item:nth-child(3n+2) .evidence-grid__icon{background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.9),rgba(221,214,254,.75),rgba(196,181,253,.5));border-color:rgba(167,139,250,.45);color:#6d28d9}
#eb1aEvidenceModal .evidence-grid__item:nth-child(3n){--accent:#10b981}
#eb1aEvidenceModal .evidence-grid__item:nth-child(3n) .evidence-grid__icon{background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.9),rgba(167,243,208,.75),rgba(110,231,183,.5));border-color:rgba(52,211,153,.45);color:#047857}
#eb1aEvidenceModal .evidence-grid__item:focus{box-shadow:0 0 0 3px rgba(59,130,246,.35),0 14px 30px rgba(59,130,246,.2)}
#eb1aEvidenceModal .evidence-grid__item--disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
#eb1aEvidenceModal .evidence-grid__item--disabled:hover{border-color:rgba(148,163,184,.35);box-shadow:none;transform:none}
#eb1aEvidenceModal .evidence-modal__footer{display:flex;justify-content:flex-end;margin-top:16px}
#eb1aEvidenceModal .muted{color:rgba(51,65,85,.78)}

.manager-group{margin-bottom:28px}
.manager-group__header h4{margin:0 0 12px;font-size:14px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted)}
.manager-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.manager-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-muted)}
.manager-row + .manager-row{margin-top:12px}
.manager-row__actions{display:flex;align-items:center;gap:8px}
.manager-row__meta{margin-left:8px;font-size:12px}

/* STYLES FOR TEXT PREVIEW MODAL */
.preview-text{
  --preview-page-width: 794px;
  padding:clamp(28px,4vw,60px) clamp(32px,5vw,68px);
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  border-radius:12px;
  border:1px solid rgba(15,23,42,.08);
  line-height:1.65;
  font-size:15px;
  font-family:"Source Serif Pro","Georgia","Times New Roman",serif;
  color:var(--text);
  width:min(var(--preview-page-width),calc(100% - 32px));
  min-height:min(1120px,82vh);
  margin:0 auto;
  box-shadow:0 18px 45px rgba(15,23,42,.18);
  letter-spacing:.01em;
  text-rendering:optimizeLegibility;
  font-feature-settings:"liga","kern","onum";
  background-image:linear-gradient(transparent 88%,rgba(15,23,42,.04) 88%);
  background-size:100% 32px;
  position:relative;
}
.preview-text::before,
.preview-text::after{
  content:"";
  position:absolute;
  inset:14px;
  border-radius:8px;
  pointer-events:none;
  z-index:-1;
}
.preview-text::before{
  border:1px solid rgba(15,23,42,.04);
}
.preview-text::after{
  inset:auto 0 0 0;
  height:32px;
  background:linear-gradient(180deg,rgba(255,255,255,0) 0,rgba(0,0,0,.05) 90%);
  opacity:.35;
  border-bottom-left-radius:12px;
  border-bottom-right-radius:12px;
}
.preview-text h1,
.preview-text h2,
.preview-text h3,
.preview-text h4 {
  margin: 1.2em 0 0.6em;
  font-weight: 600;
  line-height: 1.3;
}
.preview-text p {
  margin: 0 0 1em;
}
.preview-text ul,
.preview-text ol {
  margin: 0 0 1em 1.5em;
  padding: 0;
}
.preview-text li {
  margin-bottom: 0.4em;
}
.preview-text blockquote{
  margin:1.2em 0;
  padding:0.2em 1.2em;
  border-left:3px solid rgba(15,23,42,.3);
  font-style:italic;
  color:rgba(15,23,42,.8);
}
.preview-text strong{font-weight:650}
.preview-text em{font-style:italic}
.preview-text hr{
  border:0;
  border-top:1px solid rgba(15,23,42,.18);
  margin:1.6em 0;
}
.preview-text pre{
  font-family:"JetBrains Mono","SFMono-Regular",Consolas,monospace;
  background:rgba(15,23,42,.03);
  border:1px solid rgba(15,23,42,.08);
  border-radius:8px;
  padding:14px;
  overflow:auto;
  font-size:13px;
}
.preview-text table{
  width:100%;
  border-collapse:collapse;
  margin:1.2em 0;
  font-size:0.95em;
}
.preview-text th,
.preview-text td{
  border:1px solid rgba(15,23,42,.15);
  padding:10px 12px;
  text-align:left;
}
.preview-text th{
  background:rgba(15,23,42,.05);
  font-weight:600;
}
html[data-theme="dark"] .preview-text{
  background:linear-gradient(180deg,#161b27 0%,#0d111b 100%);
  color:rgba(236,240,250,.92);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 28px 60px rgba(0,0,0,.65);
  background-image:linear-gradient(transparent 85%,rgba(255,255,255,.05) 85%);
}
html[data-theme="dark"] .preview-text::before{
  border:1px solid rgba(255,255,255,.05);
}
html[data-theme="dark"] .preview-text::after{
  background:linear-gradient(180deg,rgba(13,17,27,0) 0,rgba(0,0,0,.5) 90%);
}
html[data-theme="dark"] .preview-text blockquote{
  border-left-color:rgba(255,255,255,.3);
  color:rgba(236,240,250,.8);
}
html[data-theme="dark"] .preview-text pre{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.1);
}
html[data-theme="dark"] .preview-text th,
html[data-theme="dark"] .preview-text td{
  border-color:rgba(255,255,255,.12);
}
html[data-theme="dark"] .preview-text th{
  background:rgba(255,255,255,.04);
}
@media (max-width:768px){
  .preview-text{
    font-size:14px;
    line-height:1.55;
    min-height:60vh;
    background-size:100% 28px;
  }
}

.preview{position:fixed;right:0;top:0;bottom:0;width:min(640px,90vw);background:var(--surface);border-left:1px solid var(--border);transform:translateX(100%);transition:transform .24s ease;z-index:var(--z-preview);display:flex;flex-direction:column}
.preview[aria-hidden="false"]{transform:translateX(0)}
.preview__header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border)}
.preview__content{padding:24px;overflow-y:auto}
.gap{flex:1}

/* Payments */
.payment-form{display:flex;flex-direction:column;gap:10px}
.payment-mode-group{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;border:1px solid var(--border);border-radius:var(--radius-lg);padding:6px}
.payment-mode-group legend{font-size:10px;font-weight:600;color:var(--muted);padding:0 2px;grid-column:1/-1}
.payment-mode-option{display:flex;align-items:center;gap:6px;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-muted);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,opacity .2s ease}
.payment-mode-option input{accent-color:var(--accent);margin-top:0}
.payment-mode-option__content{display:flex;align-items:center;gap:4px;min-width:0}
.payment-mode-option__name{font-size:12px;font-weight:600;line-height:1.1;color:var(--text);white-space:nowrap}
.payment-mode-option__meta{font-size:10px;line-height:1.1;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.payment-mode-option.is-active{border-color:var(--accent);box-shadow:0 0 0 2px var(--primary-soft);background:var(--surface)}
.payment-mode-option.is-disabled{opacity:.72;border-style:dashed}
.payment-plan-group{display:grid;gap:8px;border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px}
.payment-plan-group legend{font-size:12px;font-weight:600;color:var(--muted);padding:0 4px}
.payment-plan-option{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-muted);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}
.payment-plan-option input{accent-color:var(--accent)}
.payment-plan-option__content{display:flex;flex-direction:column;gap:2px}
.payment-plan-option__name{font-weight:600;color:var(--text)}
.payment-plan-option__meta{font-size:12px;color:var(--muted)}
.payment-plan-option.is-active{border-color:var(--accent);box-shadow:0 0 0 2px var(--primary-soft);background:var(--surface)}
.payment-field span{display:block;margin-bottom:6px;font-size:12px;font-weight:600;color:var(--muted)}
.payment-promo-field{display:flex;flex-direction:column;gap:6px}
.payment-promo-field__label{font-size:12px;font-weight:600;color:var(--muted)}
.payment-promo-field__controls{display:flex;gap:8px;align-items:center}
.payment-promo-field__controls .input{flex:1}
#paymentTopUpNotice{margin:0}
#paymentPromoMessage{min-height:16px}
#paymentPromoMessage.is-error{color:var(--danger)}
#paymentPromoMessage.is-success{color:var(--primary)}
.payment-summary{display:flex;flex-direction:column;gap:8px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-muted)}
.payment-summary__row{display:flex;justify-content:space-between;align-items:center;gap:12px}
.payment-summary__label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.payment-summary__value{font-size:14px;font-weight:600;color:var(--text)}
.payment-summary__value--discount{color:var(--primary)}
.payment-summary__value--emphasis{font-size:16px;font-weight:700}
.payment-summary__row--total{padding-top:8px;margin-top:4px;border-top:1px dashed var(--border)}
.payment-error{color:var(--danger);font-size:13px;margin:0}
.payment-actions{display:flex;justify-content:flex-end;gap:10px}

#paymentModal .modal__dialog--sm{width:min(400px,92vw)}
#paymentModal .modal__header{padding:8px 12px}
#paymentModal .modal__header h3{margin:0;font-size:15px;line-height:1.2}
#paymentModal .modal__body{padding:12px}
#paymentModal .modal__body > * + *{margin-top:10px}
#paymentModal .icon-btn{width:30px;height:30px}
#paymentModal #paymentReason{margin:0;font-size:12px;line-height:1.35}

@media (max-width:640px){
  .payment-mode-group{grid-template-columns:1fr}
  #paymentModal .modal__header{padding:7px 10px}
  #paymentModal .modal__header h3{font-size:14px}
  #paymentModal .modal__body{padding:10px}
  #paymentModal .modal__body > * + *{margin-top:8px}
}

@keyframes spin{to{transform:rotate(360deg)}}

/* Responsive tighten */
@media (max-width:1180px){
  .topbar{padding:12px 16px}
  .workspace{padding:24px}
}

@media (max-width:1080px){
  .topbar__center{display:none}
  .topbar__news {
    display: none;
  }
  .sidebar__quick-popover{
    position:relative;
    left:0;
    top:12px;
    width:100%;
    transform:translateY(-6px);
  }
  .sidebar__quick-popover::before{
    top:-8px;
    left:24px;
    border-left-width:0;
    border-bottom-width:0;
    border-top:1px solid rgba(var(--base-rgb),.08);
    border-right:1px solid rgba(var(--base-rgb),.08);
  }
  html[data-theme="dark"] .sidebar__quick-popover::before{
    border-top-color:var(--primary-soft);
    border-right-color:var(--primary-soft);
  }
}

@media (max-width:960px){
  .consultant-session{
    flex-wrap:wrap;
    gap:8px;
  }
  .consultant-session__selector{
    width:100%;
    justify-content:flex-start;
  }
}

@media (max-width:1080px){
  .consultant-dashboard__layout{
    grid-template-columns:1fr;
  }
}

@media (max-width: 860px){
  .topbar__model{display:none}
}

@media (max-width:640px){
  #btnFilesQuick{
    display:none;
  }
  #btnHowto,
  #btnAssessProfile,
  #generationRefill{
    padding:6px;
    min-width:40px;
    justify-content:center;
  }
  #btnHowto span,
  #btnAssessProfile .assess-btn__label,
  #generationRefill .metric__text{
    display:none;
  }
  #btnAssessProfile{
    gap:6px;
  }
  #generationRefill{
    gap:0;
  }
  #generationRefill .metric__icon{
    margin-right:0;
  }
}

@media (max-width: 1100px){
  .resume-modal__grid{grid-template-columns:1fr;}
  .resume-modal__column--summary{order:2;}
  .resume-modal__column--sections{order:1;}
  .resume-modal__column--summary{max-width:none;}
}

@media (max-width:540px){
  .resume-card{flex-direction:column;align-items:flex-start}
  .resume-card__thumb{width:46px;height:46px}
  .resume-card__actions{width:100%;justify-content:flex-start}
}

@media (max-width:900px){
  .links-modal__body{flex-direction:column}
  .links-modal__nav{flex-direction:row;flex-wrap:wrap;gap:8px}
  .links-modal__tab{flex:1;justify-content:center}
  .links-modal__panels{width:100%}
}

@media (max-width:1180px){
  .topbar{padding:12px 16px}
  .workspace{padding:24px}
}
