:root{
  --navy:#0b2a3a;
  --navy-strong:#061826;
  --teal:#18b6ad;
  --teal-dark:#0f766e;
  --white:#ffffff;
  --bg:#f4f7fb;
  --panel:#ffffff;
  --soft:#f8fafc;
  --line:#dbe3ee;
  --muted:#64748b;
  --text:#071a33;
  --danger:#dc2626;
  --warning:#f97316;
  --shadow:0 14px 38px rgba(15,23,42,.08);
  --shadow-hover:0 18px 46px rgba(15,23,42,.12);
  --ring:0 0 0 4px rgba(24,182,173,.16);
}
html[data-theme="dark"]{
  --navy:#05131f;
  --navy-strong:#020812;
  --teal:#2dd4bf;
  --teal-dark:#5eead4;
  --white:#0b1220;
  --bg:#07111f;
  --panel:#0d1726;
  --soft:#111c2d;
  --line:#243247;
  --muted:#93a4bb;
  --text:#e6eef8;
  --danger:#fb7185;
  --warning:#fb923c;
  --shadow:0 18px 42px rgba(0,0,0,.32);
  --shadow-hover:0 22px 54px rgba(0,0,0,.44);
  --ring:0 0 0 4px rgba(45,212,191,.18);
}
*{box-sizing:border-box}
html{max-width:100%;overflow-x:hidden;scroll-behavior:smooth}
body{margin:0;max-width:100%;overflow-x:hidden;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;background:var(--bg);color:var(--text);font-weight:500}
.layout{display:flex;min-height:100vh;max-width:100%}
.sidebar{width:280px;background:linear-gradient(180deg,var(--navy),#092231);color:white;padding:24px 20px;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;border-right:1px solid rgba(255,255,255,.08)}
.logo-wrap{width:220px;height:120px;margin:0 auto 30px;background:white;border-radius:18px;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 16px 34px rgba(0,0,0,.18)}
.logo{width:230px;height:auto;object-fit:contain}
.side-link{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.9);text-decoration:none;padding:13px 16px;border-radius:12px;margin-bottom:10px;font-size:16px;font-weight:800;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}
.side-link.active,.side-link:hover{background:rgba(24,182,173,.18);color:white;box-shadow:inset 3px 0 0 var(--teal)}
.side-link:hover{transform:translateX(2px)}
.alert-card{background:#143f45;border:1px solid var(--teal);border-radius:16px;padding:18px;margin-top:30px}
.alert-card h3{margin:0 0 12px}
.alert-card p{font-size:14px;color:#d9fffb;margin:8px 0}
.main{margin-left:280px;width:calc(100% - 280px);min-width:0;max-width:calc(100% - 280px)}
.topbar{min-height:74px;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);display:flex;justify-content:flex-end;align-items:center;gap:16px;padding:12px 34px;backdrop-filter:blur(16px);position:sticky;top:0;z-index:5}
.topbar input{width:430px;height:44px;border:1px solid var(--line);border-radius:12px;padding:0 16px;font-size:14px}
.brand{font-size:16px;font-weight:900;line-height:1.15;color:var(--text)}
.container{padding:30px 36px;width:100%;max-width:100%;overflow:hidden}
.tabs{display:flex;gap:12px;margin-bottom:22px;flex-wrap:wrap}
.tab{padding:13px 20px;border-radius:14px;text-decoration:none;font-weight:900;background:white;color:var(--text);border:1px solid var(--line);box-shadow:0 6px 18px rgba(15,23,42,.04);transition:all .18s ease}
.tab:hover{border-color:rgba(24,182,173,.45);box-shadow:var(--shadow);transform:translateY(-1px)}
.tab.active{background:var(--teal);color:white;border-color:var(--teal);box-shadow:0 14px 32px rgba(24,182,173,.24)}
.stats{
  display:grid;
  grid-template-columns:repeat(5,minmax(140px,1fr));
  gap:18px;
  margin:0 0 24px 0;
  align-items:start;
  align-self:start;
  width:100%;
  grid-column:1 / -1;
}

.stat{
  background:var(--panel);
  border-radius:18px;
  padding:22px;
  box-shadow:var(--shadow);
  min-height:120px;
  height:auto;
  align-self:start;
  border:1px solid rgba(219,227,238,.8);
}
.stat p{margin:0;color:var(--muted);font-size:14px}
.stat h2{font-size:32px;margin:8px 0 0}
.card{background:var(--panel);border-radius:18px;padding:28px;box-shadow:var(--shadow);margin-bottom:24px;max-width:100%;overflow-x:auto;border:1px solid rgba(219,227,238,.72)}
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin:20px 0}
.toolbar input,.toolbar select{width:170px;height:46px;border:1px solid var(--line);border-radius:12px;padding:0 13px;font-size:14px;margin:0;background:white}
.toolbar button,.toolbar .btn{height:44px}
.pagination-controls{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin:14px 0}
.pagination-summary{color:var(--muted);font-size:13px;font-weight:850}
.pagination-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pagination-page{display:inline-flex;align-items:center;height:36px;border-radius:10px;border:1px solid var(--line);background:var(--soft);padding:0 10px;color:var(--muted);font-size:12px;font-weight:900}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px 13px;font-size:14px;margin:6px 0 16px;background:white;color:var(--text);transition:border-color .18s ease,box-shadow .18s ease}
input:focus,select:focus,textarea:focus,button:focus-visible,.btn:focus-visible,.side-link:focus-visible,.tab:focus-visible,.doc-tab:focus-visible{outline:none;border-color:var(--teal);box-shadow:var(--ring)}
label{font-weight:800;font-size:14px;color:#17243a}
button,.btn{height:40px;background:var(--teal);color:white;border:1px solid transparent;border-radius:11px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-weight:850;font-size:13px;cursor:pointer;white-space:nowrap;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease,color .18s ease}
button:hover,.btn:hover{background:#13a59d;box-shadow:0 12px 28px rgba(24,182,173,.22);transform:translateY(-1px)}
button:active,.btn:active{transform:translateY(0);box-shadow:0 6px 16px rgba(15,23,42,.12)}
.btn-dark{background:var(--navy);border-color:var(--navy);color:white}
.btn-dark:hover{background:var(--navy-strong);box-shadow:0 12px 28px rgba(11,42,58,.24)}
.btn-light{background:#f5f7fa;color:#17243a;border:1px solid var(--line)}
.btn-light:hover{background:white;border-color:rgba(24,182,173,.5);color:var(--teal-dark);box-shadow:0 10px 24px rgba(15,23,42,.08)}
.btn-orange{background:var(--warning);color:white}
.btn-orange:hover{background:#ea580c;box-shadow:0 12px 28px rgba(249,115,22,.24)}
.btn-red{background:var(--danger);color:white}
.btn-red:hover{background:#b91c1c;box-shadow:0 12px 28px rgba(220,38,38,.22)}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;min-width:1500px}
th{background:var(--soft);color:#25344d;text-align:left;padding:15px 18px;border-bottom:1px solid var(--line);white-space:nowrap;font-weight:900}
td{padding:18px;border-bottom:1px solid var(--line);vertical-align:middle;transition:background .18s ease}
tr.candidate-row:hover td,table tr:hover td{background:#fbfdff}
tr.candidate-row:hover td{box-shadow:inset 0 1px 0 rgba(24,182,173,.08),inset 0 -1px 0 rgba(24,182,173,.08)}
.name{font-weight:950;font-size:16px;color:#061826;line-height:1.25}
.small{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.35}
.progress{width:120px;height:9px;background:#e3e7ed;border-radius:99px;margin-top:7px;overflow:hidden}
.bar{height:9px;background:linear-gradient(90deg,var(--teal),#4fd1c5);border-radius:99px}
.num-red{color:var(--danger);font-weight:900}
.num-orange{color:#ea580c;font-weight:900}
.folder-icon{font-size:22px;text-decoration:none}
.doc-link{font-weight:900;color:var(--teal-dark);text-decoration:none}
.doc-link:hover{text-decoration:underline}
.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;max-width:520px}
.compact-status{display:flex;gap:8px;align-items:center;flex-wrap:nowrap}
.compact-status select{width:160px;height:38px;margin:0;padding:0 10px}
.inline-form{display:inline-flex;margin:0}
.badge{padding:6px 11px;border-radius:999px;font-size:12px;display:inline-block;margin:3px 0;font-weight:900;letter-spacing:.01em}
.uploaded{background:#dcfce7;color:#166534}
.missing{background:#fee2e2;color:#991b1b}
.expiring{background:#ffedd5;color:#9a3412}
.expired{background:#fecaca;color:#991b1b}
.review{background:#e0f2fe;color:#075985}
.rejected{background:#fee2e2;color:#991b1b}
.approved{background:#dcfce7;color:#166534}
.status-onboarding{background:#dbeafe;color:#1d4ed8}
.status-active{background:#dcfce7;color:#166534}
.status-hold{background:#ffedd5;color:#9a3412}
.status-lapse{background:#fecaca;color:#991b1b}
.form-card{max-width:720px;margin:30px auto}
.upload-row{border:1px solid #e5e7eb;background:#fafafa;border-radius:14px;padding:16px;margin-bottom:14px}
.doc-title{font-weight:800;font-size:16px}
.doc-meta{font-size:12px;color:#64748b;margin:5px 0}
.doc-description{font-size:13px;color:#374151;line-height:1.45;margin-bottom:12px}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#eef4f6}
.login-card{width:390px;background:white;border-radius:18px;padding:32px;box-shadow:var(--shadow)}
.public-wrap{max-width:1000px;margin:40px auto;padding:0 20px}
.public-header{background:#0f2a3d;color:white;border-radius:18px;padding:24px;margin-bottom:20px}
.timeline{border-left:3px solid #18b6ad;padding-left:20px;margin-top:20px}
.timeline-item{position:relative;margin-bottom:20px}
.timeline-dot{width:12px;height:12px;background:#18b6ad;border-radius:50%;position:absolute;left:-27px;top:5px}
.timeline-content{background:#f8fafc;padding:14px;border-radius:12px;border:1px solid #e5e7eb}
.timeline-header{display:flex;justify-content:space-between;gap:12px;font-weight:800}
.timeline-action{color:#0f172a}
.timeline-time{font-size:12px;color:#64748b}
.timeline-body{margin:8px 0;font-size:14px;color:#334155}
.timeline-user{font-size:12px;color:#475569}
.doc-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}
.doc-tab{padding:10px 14px;border-radius:10px;background:#f8fafc;border:1px solid var(--line);color:#0f172a;text-decoration:none;font-weight:900;font-size:13px;transition:all .18s ease}
.doc-tab:hover{background:white;border-color:rgba(24,182,173,.5);color:var(--teal-dark)}
.doc-tab.active{background:var(--teal);color:white;border-color:var(--teal)}
.internal-box{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:12px;margin-top:10px}
.actions-grid{display:grid;grid-template-columns:repeat(3, max-content);gap:10px;align-items:center}
.actions-grid form{margin:0}
.actions-grid .compact-status{grid-column:1 / -1}

.sidebar-info-card{
  background:#143f45;
  border:1px solid var(--teal);
  border-radius:16px;
  padding:18px;
  margin-top:30px;
}

.sidebar-info-card h3{
  margin:0 0 8px;
  color:white;
}

.sidebar-info-card p{
  margin:0 0 12px;
  color:#d9fffb;
  font-size:14px;
  line-height:1.5;
}

.sidebar-info-card span{
  display:inline-block;
  font-size:12px;
  color:#a7fff7;
  font-weight:700;
}

/* GLOBAL LOADING STATES */
.loading-btn {
  opacity: 0.75;
  pointer-events: none;
  position: relative;
  padding-right: 38px !important;
}

.loading-btn::after {
  content: "";
  width: 15px;
  height: 15px;
  border: 2px solid rgba(255,255,255,0.7);
  border-top: 2px solid transparent;
  border-radius: 50%;
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
  animation: spin 0.7s linear infinite;
}

@keyframes spin {
  to {
    transform: translateY(-50%) rotate(360deg);
  }
}


/* EMPTY STATES */
.empty-state{
  padding:40px 24px;
  border-radius:24px;
  background:#0F172A;
  border:1px solid rgba(255,255,255,0.06);
  text-align:center;
  margin-top:20px;
}

.empty-state h3{
  margin:0 0 10px;
  font-size:22px;
  color:white;
}

.empty-state p{
  margin:0;
  color:#A8B3CF;
  line-height:1.6;
  margin-bottom:20px;
}

.empty-state .btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
}

.top-user{
  display:flex;
  align-items:center;
  gap:14px;
  padding:8px 10px 8px 14px;
  border:1px solid var(--line);
  border-radius:16px;
  background:white;
  box-shadow:0 10px 26px rgba(15,23,42,.05);
}

.top-profile-copy{
  text-align:right;
  display:flex;
  flex-direction:column;
  gap:3px;
}

.top-meta{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}

.top-meta span{
  display:inline-flex;
  align-items:center;
  min-height:20px;
}

.top-role{
  color:var(--teal-dark);
  background:#e6fffb;
  border:1px solid rgba(24,182,173,.22);
  border-radius:999px;
  padding:2px 8px;
}

.user-circle{
  width:42px;
  height:42px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--teal),#12a29a);
  color:white;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:15px;
  box-shadow:0 8px 20px rgba(24,182,173,.25);
}
.password-help{margin:-8px 0 16px;color:var(--muted);font-size:12px;line-height:1.45}
.password-error{margin:8px 0 12px;color:var(--danger);font-weight:800;background:#fff1f2;border:1px solid #fecdd3;border-radius:12px;padding:12px}
.risk-filter.active{background:#e6fffb;color:var(--teal-dark);border-color:var(--teal);box-shadow:0 10px 24px rgba(24,182,173,.16)}
.risk-count{display:inline-flex;align-items:center;justify-content:center;margin-left:8px;min-width:22px;height:22px;border-radius:999px;background:rgba(15,42,61,.08);font-size:12px;font-weight:950;padding:0 7px}
.risk-filter.active .risk-count{background:var(--teal);color:white}
.toolbar-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;grid-column:1 / -1;}

.intelligence-grid{
  display:grid;
  grid-template-columns:1.4fr .9fr;
  gap:24px;
  align-items:stretch;
}

.risk-chart{
  background:#ffffff;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:22px;
  color:#0f172a;
  box-shadow:0 8px 24px rgba(15,23,42,.04);
}

.risk-chart h3{
  margin:0 0 18px;
}

.risk-donut-wrap{
  display:flex;
  align-items:center;
  gap:22px;
}

.risk-donut{
  width:150px;
  height:150px;
  border-radius:50%;
  background:
    conic-gradient(#18b6ad var(--score), #e5e7eb 0);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  flex:0 0 auto;
}

.risk-donut::after{
  content:"";
  width:104px;
  height:104px;
  background:white;
  border-radius:50%;
  position:absolute;
}

.risk-donut span{
  position:relative;
  z-index:1;
  font-size:28px;
  font-weight:900;
}

.risk-metrics{
  flex:1;
}

.risk-metric{
  display:flex;
  justify-content:space-between;
  padding:10px 0;
  border-bottom:1px solid #edf2f7;
  font-size:14px;
}

.risk-metric b{
  font-size:16px;
}

.risk-note{
  margin-top:18px;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:14px;
  color:#475569;
  font-size:13px;
  line-height:1.6;
}
.ai-command-center{
  grid-column:1 / -1;
  margin-top:30px;
  background:linear-gradient(135deg,#061826 0%,#092536 42%,#0f766e 100%);
  border:1px solid rgba(24,182,173,.45);
  border-radius:32px;
  padding:34px;
  color:white;
  box-shadow:0 28px 80px rgba(15,23,42,.25);
  display:grid;
  grid-template-columns:1.25fr .95fr;
  gap:28px;
  align-items:stretch;
  overflow:hidden;
  position:relative;
}
.ai-command-center:before{
  content:"";
  position:absolute;
  right:-120px;
  top:-120px;
  width:300px;
  height:300px;
  background:radial-gradient(circle,rgba(24,182,173,.32),transparent 65%);
}
.ai-command-kicker{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#a7fff7;
  font-weight:900;
}
.ai-command-title{
  margin:12px 0 14px;
  font-size:38px;
  line-height:1.05;
  color:white;
  font-weight:950;
}
.ai-command-text{
  color:#d9fffb;
  line-height:1.75;
  font-size:17px;
  max-width:720px;
}
.ai-command-panel{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.16);
  border-radius:26px;
  padding:24px;
  backdrop-filter:blur(16px);
  position:relative;
  z-index:2;
}
.ai-signal-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.ai-signal{
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  padding:16px;
}
.ai-signal span{
  display:block;
  color:#bffdfa;
  font-size:13px;
}
.ai-signal b{
  display:block;
  margin-top:4px;
  color:white;
  font-size:30px;
}

.ai-chat-shell{
  max-width:1040px;
  margin:auto;
  border-radius:30px;
  overflow:hidden;
  padding:0;
  box-shadow:0 24px 70px rgba(15,23,42,.12);
}
.ai-chat-head{
  background:linear-gradient(135deg,#061826,#0d3f45);
  color:white;
  padding:28px 32px;
}
.ai-chat-body{
  background:#f8fafc;
  padding:30px;
  min-height:560px;
}
.ai-msg-row{
  display:flex;
  gap:12px;
  margin-bottom:18px;
}
.ai-msg-row.user{
  justify-content:flex-end;
}
.ai-bubble{
  max-width:76%;
  padding:16px 18px;
  border-radius:22px;
  line-height:1.7;
  white-space:pre-wrap;
}
.ai-bubble.bot{
  background:white;
  border:1px solid #e2e8f0;
  color:#334155;
  border-bottom-left-radius:6px;
}
.ai-bubble.user{
  background:#18b6ad;
  color:white;
  border-bottom-right-radius:6px;
}
.ai-avatar{
  width:44px;
  height:44px;
  border-radius:50%;
  background:#18b6ad;
  color:white;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.ai-chip-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:22px 0;
}
.ai-input-row{
  display:flex;
  gap:12px;
  align-items:flex-end;
  margin-top:22px;
}
.ai-typing::after{
  content:"";
  display:inline-block;
  width:24px;
  height:10px;
  margin-left:8px;
  background:radial-gradient(circle,#fff 35%,transparent 40%) 0 50%/8px 8px repeat-x;
  animation:typingDots 1s infinite linear;
}
@keyframes typingDots{
  0%{opacity:.25}
  50%{opacity:1}
  100%{opacity:.25}
}

/* PHASE 2 ENTERPRISE SAAS SYSTEM */
.topbar-brand{
  font-size:18px;
  font-weight:950;
  letter-spacing:.01em;
  color:var(--text);
}

.top-profile-menu{
  position:relative;
  display:flex;
  align-items:center;
}

.avatar-trigger{
  width:42px;
  height:42px;
  border-radius:50%;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--teal),#11a39b);
  color:white;
  box-shadow:0 12px 30px rgba(24,182,173,.28);
  font-size:14px;
  font-weight:950;
}

.avatar-trigger:hover{box-shadow:0 16px 36px rgba(24,182,173,.36)}

.profile-popover{
  position:absolute;
  right:0;
  top:54px;
  width:320px;
  min-width:280px;
  max-width:calc(100vw - 32px);
  max-height:min(70vh,620px);
  overflow-y:auto;
  box-sizing:border-box;
  padding:14px;
  border:1px solid rgba(219,227,238,.76);
  border-radius:18px;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(18px);
  box-shadow:0 24px 62px rgba(15,23,42,.16);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .18s ease,visibility .18s ease;
  z-index:90;
}

.top-profile-menu.open .profile-popover{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.profile-popover-head{
  display:flex;
  gap:10px;
  align-items:center;
  padding:9px;
  border-radius:13px;
  background:linear-gradient(135deg,rgba(15,42,58,.06),rgba(24,182,173,.08));
}

.profile-avatar{width:36px;height:36px;box-shadow:none}
.profile-name{font-size:14px;font-weight:950;color:var(--text)}
.profile-email{font-size:11px;color:var(--muted);margin-top:2px;word-break:break-word}
.profile-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0}
.profile-meta-grid div{min-width:0;background:rgba(248,250,252,.9);border:1px solid var(--line);border-radius:12px;padding:8px}
.profile-meta-grid span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:900;margin-bottom:5px}
.profile-meta-grid b{display:block;min-width:0;font-size:12px;color:var(--text);overflow:hidden;text-overflow:ellipsis}
.top-role{display:inline-flex!important;width:max-content;max-width:100%;border-radius:999px;background:#e6fffb;color:var(--teal-dark);padding:3px 7px}
.profile-hint{margin:0 0 8px;border:1px solid rgba(219,227,238,.72);border-radius:12px;background:rgba(248,250,252,.78);padding:8px 9px;color:var(--muted);font-size:11px;font-weight:850}
.profile-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.profile-action{height:34px;border-radius:11px;background:white;border:1px solid var(--line);color:var(--text);text-decoration:none;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:12px}
.profile-action:hover{border-color:rgba(24,182,173,.45);color:var(--teal-dark);box-shadow:0 10px 22px rgba(15,23,42,.08)}
.profile-action.disabled{color:var(--muted);cursor:default}
.profile-action.logout{background:var(--navy);color:white;border-color:var(--navy)}

.kpi-card{
  position:relative;
  overflow:hidden;
  min-height:104px;
  padding:18px;
  border-radius:16px;
  background:linear-gradient(180deg,#fff,#fbfdff);
}

.kpi-card:before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:3px;
  background:linear-gradient(90deg,var(--teal),rgba(24,182,173,.08));
}

.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.kpi-card h2{font-size:30px;letter-spacing:0;margin:6px 0 7px}
.kpi-trend{display:inline-flex;align-items:center;border-radius:999px;background:#edfdfb;color:var(--teal-dark);padding:4px 8px;font-size:11px;font-weight:950}
.kpi-trend.danger{background:#fff1f2;color:#be123c}
.kpi-trend.warning{background:#fff7ed;color:#c2410c}

.intelligence-card{
  background:linear-gradient(180deg,#ffffff,#f9fbff);
  overflow:hidden;
}

.intelligence-card > h2{display:none}
.section-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px}
.section-header h2{margin:4px 0 0;font-size:24px;line-height:1.15}
.section-eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:950;color:var(--teal-dark)}
.section-badge{display:inline-flex;align-items:center;height:30px;border-radius:999px;border:1px solid rgba(24,182,173,.24);background:#e6fffb;color:var(--teal-dark);padding:0 11px;font-size:12px;font-weight:950;white-space:nowrap}
.intelligence-grid{grid-template-columns:minmax(0,1.18fr) minmax(340px,.82fr);gap:18px}
.intelligence-grid > div[style]{display:none}
.insight-panel,.risk-chart{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(219,227,238,.9);
  border-radius:18px;
  box-shadow:0 14px 34px rgba(15,23,42,.06);
}
.insight-panel{padding:20px}
.insight-panel h3{font-size:20px;margin:6px 0 16px}
.insight-matrix{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.insight-matrix div{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:12px}
.insight-matrix span{display:block;font-size:12px;color:var(--muted);font-weight:850}
.insight-matrix b{display:block;font-size:24px;margin-top:4px;color:var(--text)}
.action-recommendation{margin-top:12px;border-radius:16px;border:1px solid rgba(24,182,173,.22);background:linear-gradient(135deg,#eefdfa,#ffffff);padding:14px}
.action-recommendation span,.risk-note b{display:block;color:var(--teal-dark);font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:950;margin-bottom:5px}
.action-recommendation p{margin:0;color:#334155;line-height:1.5}
.risk-chart{padding:20px}
.risk-donut{width:136px;height:136px;background:conic-gradient(var(--teal) var(--score), #e7ecf3 0);box-shadow:inset 0 0 0 1px rgba(15,23,42,.04)}
.risk-donut::after{width:92px;height:92px}
.risk-donut span{font-size:26px}
.risk-metric{padding:9px 0}
.risk-note{display:block;background:#fbfdff;border-color:var(--line)}
.risk-note span{display:block;color:#475569;line-height:1.5}

.ai-command-center{
  margin-top:20px;
  grid-template-columns:minmax(0,1fr) minmax(300px,.68fr);
  border-radius:24px;
  padding:26px;
  background:
    radial-gradient(circle at 20% 0%,rgba(24,182,173,.28),transparent 30%),
    linear-gradient(135deg,#061826 0%,#092536 58%,#0b4f51 100%);
}
.ai-command-center:before{opacity:.55}
.ai-command-copy{position:relative;z-index:2}
.ai-command-title{font-size:30px;max-width:620px}
.ai-command-text{font-size:15px;line-height:1.65;max-width:680px}
.ai-command-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:20px}
.ai-command-actions span{display:inline-flex;align-items:center;color:#a7fff7;font-weight:900;font-size:13px}
.ai-primary-cta{height:46px;min-width:190px;background:white;color:var(--navy)}
.ai-primary-cta:hover{background:#e6fffb;color:var(--teal-dark)}
.ai-command-panel h3{margin:0 0 14px;color:white;font-size:18px}
.ai-signal{border-radius:16px;padding:14px;background:rgba(255,255,255,.11)}
.ai-signal b{font-size:26px}

.candidate-profile-panel{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#ffffff,#f9fbff);
}
.candidate-profile-panel:before{content:"";position:absolute;right:-80px;top:-90px;width:220px;height:220px;background:radial-gradient(circle,rgba(24,182,173,.18),transparent 68%)}
.candidate-profile-head{position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:18px}
.candidate-profile-head h2{margin:4px 0;font-size:28px}
.candidate-profile-head p{margin:0;color:var(--muted);font-weight:800}
.candidate-score{min-width:132px;border-radius:18px;border:1px solid rgba(24,182,173,.22);background:#e6fffb;padding:14px;text-align:right}
.candidate-score span{display:block;font-size:12px;color:var(--teal-dark);font-weight:950;text-transform:uppercase;letter-spacing:.08em}
.candidate-score b{display:block;font-size:30px;color:var(--navy);margin-top:2px}
.candidate-info-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.info-tile{border:1px solid var(--line);background:white;border-radius:14px;padding:12px;min-width:0}
.info-tile span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:950;margin-bottom:6px}
.info-tile b{display:block;font-size:13px;color:var(--text);line-height:1.35;word-break:break-word}
.candidate-action-bar{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;border-top:1px solid var(--line);margin-top:18px;padding-top:16px}
.action-group{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.action-group .btn,.action-group button{height:40px}

.documents-workspace{width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}
.doc-table{width:100%;max-width:100%;min-width:0;font-size:13px;border-collapse:separate;border-spacing:0 12px;table-layout:fixed}
.doc-table-head th{background:transparent;border:0;padding:0 0 4px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.doc-table td{border:0;padding:0;vertical-align:top;max-width:100%;min-width:0}
.doc-workflow-row:hover td{background:transparent}
.doc-workflow-card{width:100%;max-width:100%;box-sizing:border-box;border:1px solid rgba(219,227,238,.92);border-radius:16px;background:white;box-shadow:0 12px 30px rgba(15,23,42,.05);overflow:visible}
.doc-workflow-card:hover{border-color:rgba(24,182,173,.32);box-shadow:0 16px 36px rgba(15,23,42,.08)}
.doc-workflow-top{display:grid;grid-template-columns:minmax(220px,1.5fr) minmax(160px,.8fr) minmax(130px,.6fr) auto auto;gap:16px;align-items:center;width:100%;max-width:100%;box-sizing:border-box;padding:14px 16px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fff,#fbfdff)}
.doc-workflow-top > *{min-width:0;max-width:100%}
.doc-title{font-size:14px;font-weight:950;color:var(--text);line-height:1.25}
.doc-top-item span,.field-group label,.workflow-block-head span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:950;margin-bottom:5px}
.doc-top-item b,.doc-expiry{font-size:13px;font-weight:900;color:#334155}
.doc-status-expiry,.doc-top-actions{display:contents}
.doc-workflow-top > .btn,.doc-workflow-top > .btn-disabled{height:36px;white-space:nowrap;justify-self:end}
.btn-disabled{background:#eef2f7;color:#94a3b8;border:1px solid var(--line);border-radius:11px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;font-weight:850;font-size:13px;cursor:not-allowed}
.doc-workflow-bottom{display:grid;grid-template-columns:minmax(360px,1fr) minmax(480px,1.2fr);gap:16px;width:100%;max-width:100%;box-sizing:border-box;padding:14px;background:#f8fafc}
.workflow-block{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.92);padding:12px;min-width:0;max-width:100%;box-sizing:border-box}
.workflow-block-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:10px}
.workflow-block-head b{font-size:13px;color:var(--text)}
.workflow-block.unavailable{display:flex;flex-direction:column;justify-content:center;color:var(--muted);line-height:1.45}
.inline-upload-form,.review-form-grid{display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin:0;min-width:0;max-width:100%}
.inline-upload-form .field-group{flex:1 1 150px}
.inline-upload-form .field-group:nth-of-type(2){flex:1.2 1 180px}
.review-form-grid .field-group{flex:1 1 150px}
.review-form-grid .field-group:nth-of-type(2){flex:1 1 170px}
.review-form-grid .field-group:nth-of-type(3){flex:1.3 1 220px}
.review-form-grid > *{min-width:0;max-width:100%}
.field-group{display:flex;flex-direction:column;gap:6px;min-width:0}
.field-group label{margin:0}
.field-group input,.field-group select,.field-group textarea{margin:0;font-size:12px;width:100%;min-width:0}
.inline-upload-form button,.review-form-grid button{margin:0;font-size:12px;white-space:nowrap;min-width:max-content;max-width:100%;flex:0 0 auto}
.field-group input,.field-group select{height:38px}
.field-group input[type="file"]{height:38px;padding:7px;background:#f8fafc}
.field-group textarea{min-height:38px;max-height:96px;resize:vertical;padding:9px;line-height:1.35}
.inline-upload-form button,.review-form-grid button{height:38px;align-self:end}
.timeline-content{box-shadow:0 10px 24px rgba(15,23,42,.05)}

@media(max-width:1200px){
  .doc-workflow-bottom{grid-template-columns:1fr}
  .inline-upload-form button,.review-form-grid button{margin-left:auto}
}

@media(max-width:900px){
  .doc-workflow-top{grid-template-columns:1fr}
  .doc-status-expiry,.doc-top-actions{display:flex;flex-wrap:wrap;gap:10px}
  .doc-workflow-top > .btn,.doc-workflow-top > .btn-disabled{justify-self:start}
}

.ai-chat-shell{max-width:1180px;border-radius:24px;box-shadow:0 28px 80px rgba(15,23,42,.14)}
.ai-chat-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;padding:26px 30px;background:radial-gradient(circle at 20% 0%,rgba(24,182,173,.24),transparent 28%),linear-gradient(135deg,#061826,#0b3b46)}
.ai-chat-head h2{margin:4px 0 0;color:white;font-size:28px}
.ai-chat-head p{line-height:1.5}
.ai-workspace-meta{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;max-width:420px}
.ai-workspace-meta span,.ai-workspace-meta b{display:inline-flex;align-items:center;height:30px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);padding:0 10px;color:#d9fffb;font-size:12px;font-weight:900}
.ai-workspace-meta b{background:#e6fffb;color:var(--teal-dark)}
.ai-chat-body{background:linear-gradient(180deg,#f8fafc,#ffffff);padding:0}
.ai-conversation{padding:26px 30px 12px;min-height:380px}
.ai-msg-row{margin-bottom:14px}
.ai-bubble{border-radius:18px;box-shadow:0 12px 28px rgba(15,23,42,.06)}
.ai-bubble.bot{background:white;border-color:var(--line)}
.ai-bubble.user{background:linear-gradient(135deg,var(--teal),#12a29a)}
.ai-prompt-panel{position:sticky;bottom:92px;background:rgba(248,250,252,.92);backdrop-filter:blur(14px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 30px}
.ai-chip-row{margin:8px 0 0}
.ai-prompt-chip{height:36px;border-radius:999px;background:white;color:var(--navy);border:1px solid var(--line);box-shadow:none;padding:0 14px}
.ai-prompt-chip:hover{background:#e6fffb;color:var(--teal-dark);border-color:rgba(24,182,173,.35)}
.ai-composer{position:sticky;bottom:0;background:rgba(255,255,255,.95);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:16px 30px;margin:0}
.ai-composer textarea{flex:1;resize:none;border-radius:16px;border:1px solid #cbd5e1;padding:13px 15px;font-size:14px;margin:0;min-height:52px}
.ai-composer button{height:52px;min-width:96px}
.ai-chat-footer{padding:14px 24px;background:white;display:flex;gap:10px;flex-wrap:wrap;border-top:1px solid var(--line)}

/* PHASE 3 PRODUCT FEATURES */
html[data-theme="dark"] body{background:var(--bg);color:var(--text)}
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .card,
html[data-theme="dark"] .stat,
html[data-theme="dark"] .tab,
html[data-theme="dark"] .login-card,
html[data-theme="dark"] .risk-chart,
html[data-theme="dark"] .insight-panel,
html[data-theme="dark"] .workflow-block,
html[data-theme="dark"] .doc-workflow-card,
html[data-theme="dark"] .profile-popover,
html[data-theme="dark"] .notification-popover,
html[data-theme="dark"] .command-panel,
html[data-theme="dark"] .modal-panel,
html[data-theme="dark"] .drawer-panel{background:var(--panel);color:var(--text);border-color:var(--line)}
html[data-theme="dark"] th,
html[data-theme="dark"] .doc-workflow-bottom,
html[data-theme="dark"] .ai-chat-body,
html[data-theme="dark"] .timeline-content,
html[data-theme="dark"] .info-tile,
html[data-theme="dark"] .insight-matrix div,
html[data-theme="dark"] .risk-note,
html[data-theme="dark"] .action-recommendation,
html[data-theme="dark"] input,
html[data-theme="dark"] select,
html[data-theme="dark"] textarea{background:var(--soft);color:var(--text);border-color:var(--line)}
html[data-theme="dark"] .small,
html[data-theme="dark"] .profile-email,
html[data-theme="dark"] .event-meta,
html[data-theme="dark"] .event-body{color:var(--muted)}
html[data-theme="dark"] .analytics-card,
html[data-theme="dark"] .chart-card,
html[data-theme="dark"] .activity-card,
html[data-theme="dark"] .notification-item,
html[data-theme="dark"] .profile-meta-grid div,
html[data-theme="dark"] .profile-hint,
html[data-theme="dark"] .risk-chip,
html[data-theme="dark"] .expiry-item{background:var(--soft);border-color:var(--line)}
html[data-theme="dark"] .activity-card .section-header{background:linear-gradient(180deg,var(--panel),rgba(13,23,38,.94));border-color:var(--line)}
html[data-theme="dark"] .trend-empty{background:linear-gradient(180deg,rgba(17,28,45,.92),rgba(13,23,38,.94))}
html[data-theme="dark"] .segmented-bar,
html[data-theme="dark"] .mini-track{background:#1d2a3c}

html[data-sidebar="collapsed"] .sidebar{width:92px;padding:18px 12px}
html[data-sidebar="collapsed"] .main{margin-left:92px;width:calc(100% - 92px);max-width:calc(100% - 92px)}
html[data-sidebar="collapsed"] .logo-wrap{width:56px;height:56px;border-radius:16px;margin-bottom:20px}
html[data-sidebar="collapsed"] .logo{width:106px}
html[data-sidebar="collapsed"] .sidebar-info-card{display:none}
html[data-sidebar="collapsed"] .side-link{justify-content:center;padding:12px;font-size:0}
html[data-sidebar="collapsed"] .side-link:before{font-size:14px;font-weight:950}
html[data-sidebar="collapsed"] .side-link[href="/dashboard"]:before{content:"D"}
html[data-sidebar="collapsed"] .side-link[href="/add"]:before{content:"+"}
html[data-sidebar="collapsed"] .side-link[href="/performance"]:before{content:"P"}
html[data-sidebar="collapsed"] .side-link[href="/users"]:before{content:"U"}
html[data-sidebar="collapsed"] .side-link[href="/admin-rules"]:before{content:"R"}
html[data-sidebar="collapsed"] .side-link[href="/run-auto-alerts"]:before{content:"A"}
html[data-sidebar="collapsed"] .side-link[href="/logout"]:before{content:"L"}
.sidebar,.main{transition:width .22s ease,margin-left .22s ease}
.sidebar-toggle{width:100%;height:36px;margin:0 0 14px;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:white}
.side-icon{width:22px;display:inline-flex;justify-content:center;font-weight:950}

.topbar-actions{display:flex;align-items:center;gap:10px;overflow:visible}
.icon-trigger{width:40px;height:40px;border-radius:50%;padding:0;background:white;color:var(--navy);border:1px solid var(--line);box-shadow:0 10px 24px rgba(15,23,42,.08);font-weight:950}
.icon-trigger:hover{border-color:rgba(24,182,173,.45);color:var(--teal-dark);background:#f7fffe}
.notification-menu{position:relative}
.notification-trigger svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.notification-trigger.has-unread:after{content:"";position:absolute;right:7px;top:7px;width:9px;height:9px;border-radius:50%;background:var(--danger);box-shadow:0 0 0 3px var(--panel)}
.notification-popover{position:absolute;right:0;top:52px;width:380px;min-width:280px;max-width:calc(100vw - 32px);max-height:min(70vh,620px);overflow-y:auto;box-sizing:border-box;padding:14px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.9);backdrop-filter:blur(18px);box-shadow:0 24px 62px rgba(15,23,42,.16);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,visibility .18s ease;z-index:90}
.notification-menu.open .notification-popover{opacity:1;visibility:visible;pointer-events:auto}
.popover-head{display:flex;justify-content:space-between;gap:10px;margin-bottom:10px}
.popover-head span{font-size:12px;color:var(--muted);font-weight:850}
.notification-list{display:grid;gap:8px;overflow:visible}
.notification-item{min-width:0;border:1px solid var(--line);border-radius:13px;padding:10px;background:var(--soft);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}
.notification-item:hover{border-color:rgba(24,182,173,.34);box-shadow:0 10px 24px rgba(15,23,42,.08);transform:translateY(-1px)}
.notification-item b{display:block;font-size:13px}
.notification-item span{display:block;margin-top:3px;font-size:12px;color:var(--muted);line-height:1.4}
.notification-item.danger{border-color:rgba(220,38,38,.25)}
.notification-item.warning{border-color:rgba(249,115,22,.28)}
.theme-toggle{grid-column:1/-1;width:100%;height:34px;border-radius:11px;background:#e6fffb;color:var(--teal-dark);border:1px solid rgba(24,182,173,.24);font-size:12px}

.empty-panel{padding:18px;border-radius:14px;background:var(--soft);border:1px solid var(--line);color:var(--muted);font-weight:800;text-align:center}
.event-list{display:grid;gap:10px;max-width:100%}
.event-item{display:grid;grid-template-columns:12px minmax(0,1fr) auto;gap:10px;align-items:start;min-width:0;padding:11px;border:1px solid var(--line);border-radius:14px;background:var(--panel);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}
.event-item:hover{border-color:rgba(24,182,173,.3);box-shadow:0 10px 24px rgba(15,23,42,.07);transform:translateY(-1px)}
.event-dot{width:9px;height:9px;border-radius:50%;background:var(--teal);margin-top:5px;box-shadow:0 0 0 4px rgba(24,182,173,.12)}
.event-title{font-weight:950;font-size:13px;color:var(--text)}
.event-meta,.event-body{font-size:12px;color:var(--muted);line-height:1.4}
.event-item time{font-size:11px;color:var(--muted);white-space:nowrap}
.dashboard-lower-grid{width:100%;max-width:100%;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(340px,.8fr);gap:24px;box-sizing:border-box;align-items:start}
.dashboard-lower-grid > *{min-width:0;max-width:100%}
.analytics-card,.activity-card{min-width:0;overflow:hidden}
.analytics-card{padding:22px;background:linear-gradient(180deg,#ffffff,#fbfdff)}
.analytics-card .section-header{margin-bottom:14px}
.chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;min-width:0;max-width:100%}
.chart-card{min-width:0;overflow:hidden;border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,var(--panel),#fbfdff);padding:14px;box-shadow:0 10px 24px rgba(15,23,42,.04)}
.chart-card h3{margin:0;font-size:15px;line-height:1.2}
.chart-card-head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:12px}
.chart-card-head span{color:var(--muted);font-size:11px;font-weight:900;white-space:nowrap}
.trend-empty{height:120px;border:1px dashed rgba(100,116,139,.38);border-radius:14px;background:linear-gradient(180deg,rgba(248,250,252,.88),rgba(255,255,255,.92));padding:12px;display:grid;align-content:end;gap:10px;position:relative;overflow:hidden}
.trend-empty:before{content:"";position:absolute;inset:14px;background:repeating-linear-gradient(to right,rgba(100,116,139,.08) 0 1px,transparent 1px 34px),repeating-linear-gradient(to bottom,rgba(100,116,139,.08) 0 1px,transparent 1px 28px)}
.trend-line{height:42px;border-bottom:3px solid rgba(24,182,173,.42);border-radius:60% 18% 0 0;transform:skewY(-8deg);position:relative;z-index:1}
.trend-caption{position:relative;z-index:1;color:var(--muted);font-size:12px;font-weight:800;line-height:1.35}
.segmented-bar{display:flex;width:100%;height:12px;overflow:hidden;border-radius:999px;background:#e7ecf3;margin-bottom:12px}
.segment{display:block;height:100%}
.segment-danger{background:#f97316}.segment-warning{background:#fbbf24}.segment-teal{background:var(--teal)}.segment-critical{background:var(--danger)}
.risk-chip-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.risk-chip{min-width:0;border:1px solid var(--line);border-radius:13px;padding:9px;background:var(--soft)}
.risk-chip span{display:block;color:var(--muted);font-size:11px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.risk-chip b{font-size:19px;color:var(--text);margin-right:6px}
.risk-chip em{font-style:normal;color:var(--muted);font-size:11px;font-weight:900}
.risk-chip.danger{border-color:rgba(249,115,22,.26)}.risk-chip.warning{border-color:rgba(251,191,36,.34)}.risk-chip.teal{border-color:rgba(24,182,173,.3)}.risk-chip.critical{border-color:rgba(220,38,38,.26)}
.compact-progress-list{display:grid;gap:9px}
.progress-item{display:grid;grid-template-columns:minmax(0,1fr) minmax(84px,.8fr);gap:10px;align-items:center}
.progress-item b{display:block;font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.progress-item span{display:block;color:var(--muted);font-size:11px;font-weight:800}
.mini-track{height:8px;border-radius:999px;background:#e7ecf3;overflow:hidden}
.mini-track span{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--teal),#67e8f9)}
.compact-empty{padding:14px;border:1px dashed var(--line);border-radius:13px;color:var(--muted);font-size:12px;font-weight:850;text-align:center}
.expiry-timeline{display:grid;gap:9px;position:relative}
.expiry-item{display:grid;grid-template-columns:16px minmax(0,1fr) auto;gap:9px;align-items:center;padding:9px;border:1px solid var(--line);border-radius:13px;background:var(--soft)}
.expiry-marker{width:10px;height:10px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(24,182,173,.12)}
.expiry-item b{display:block;font-size:12px;color:var(--text)}
.expiry-item span{display:block;color:var(--muted);font-size:11px;font-weight:800}
.expiry-item strong{font-size:18px}
.expiry-item.danger .expiry-marker{background:#f97316;box-shadow:0 0 0 4px rgba(249,115,22,.12)}
.expiry-item.warning .expiry-marker{background:#fbbf24;box-shadow:0 0 0 4px rgba(251,191,36,.14)}
.expiry-item.critical .expiry-marker{background:var(--danger);box-shadow:0 0 0 4px rgba(220,38,38,.12)}
.activity-card{display:flex;flex-direction:column;padding:18px}
.activity-card .section-header{position:sticky;top:0;z-index:1;margin:-2px -2px 12px;padding:2px 2px 12px;background:linear-gradient(180deg,var(--panel),rgba(255,255,255,.94));border-bottom:1px solid rgba(219,227,238,.55)}
.activity-link{height:32px;border-radius:10px;padding:0 11px;background:#f5f7fa;border:1px solid var(--line);color:var(--text);display:inline-flex;align-items:center;text-decoration:none;font-size:12px;font-weight:900;white-space:nowrap}
.activity-link:hover{border-color:rgba(24,182,173,.42);color:var(--teal-dark);background:#f7fffe}
.activity-card .event-list{position:relative;max-height:720px;overflow-y:auto;overflow-x:hidden;padding:2px 4px 2px 24px}
.activity-card .event-list:before{content:"";position:absolute;left:8px;top:12px;bottom:12px;width:2px;background:linear-gradient(180deg,rgba(24,182,173,.45),rgba(24,182,173,.05))}
.activity-card .event-item{position:relative;grid-template-columns:minmax(0,1fr) auto;padding:10px 12px;margin:0;border-radius:13px}
.activity-card .event-dot{position:absolute;left:-21px;top:16px;margin:0}
.activity-card .event-meta{margin-top:2px}
.activity-card .event-body{margin-top:4px}
.sparkline{width:100%;height:92px}
.sparkline polyline{fill:none;stroke:var(--teal);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.sparkline .area{fill:rgba(24,182,173,.1);stroke:none}

@media(max-width:1180px){
  .dashboard-lower-grid{grid-template-columns:1fr}
  .activity-card .event-list{max-height:520px}
}

@media(max-width:760px){
  .chart-grid{grid-template-columns:1fr}
  .activity-card .event-item{grid-template-columns:1fr}
  .activity-card .event-item time{margin-top:4px}
  .risk-chip-row{grid-template-columns:1fr}
  .progress-item{grid-template-columns:1fr}
}

.command-palette{position:fixed;inset:0;background:rgba(4,12,22,.42);backdrop-filter:blur(8px);display:none;align-items:flex-start;justify-content:center;padding:10vh 18px;z-index:80}
.command-palette.open{display:flex}
.command-panel{width:min(720px,100%);border:1px solid var(--line);border-radius:20px;background:white;box-shadow:0 34px 90px rgba(15,23,42,.28);overflow:hidden}
.command-search-row{display:flex;gap:12px;align-items:center;padding:14px;border-bottom:1px solid var(--line)}
.command-search-row span{font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:8px;padding:4px 7px;font-weight:900}
.command-search{margin:0;border:0;box-shadow:none;font-size:16px}
.command-results{max-height:420px;overflow:auto;padding:8px}
.command-item{display:flex;justify-content:space-between;gap:12px;align-items:center;border-radius:12px;padding:12px;text-decoration:none;color:var(--text)}
.command-item:hover,.command-item.active{background:#e6fffb;color:var(--teal-dark)}
.command-item b{font-size:12px;color:var(--muted)}

.modal-overlay,.drawer-overlay{position:fixed;inset:0;background:rgba(4,12,22,.48);backdrop-filter:blur(6px);display:none;z-index:70}
.modal-overlay.open,.drawer-overlay.open{display:block}
.modal-panel{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(920px,calc(100vw - 28px));max-height:86vh;overflow:auto;border:1px solid var(--line);border-radius:20px;background:white;box-shadow:0 34px 90px rgba(15,23,42,.3);display:none;z-index:75}
.modal-panel.open{display:block}
.modal-head,.drawer-head{display:flex;justify-content:space-between;gap:16px;align-items:center;border-bottom:1px solid var(--line);padding:14px 18px}
.modal-body{padding:18px}
.preview-frame{width:100%;height:62vh;border:1px solid var(--line);border-radius:14px;background:var(--soft)}
.drawer-panel{position:fixed;right:0;top:0;bottom:0;width:min(440px,calc(100vw - 24px));background:white;border-left:1px solid var(--line);box-shadow:-24px 0 70px rgba(15,23,42,.2);transform:translateX(105%);transition:transform .22s ease;z-index:76;display:flex;flex-direction:column}
.drawer-panel.open{transform:translateX(0)}
.drawer-body{padding:16px;overflow:auto}
.close-button{width:36px;height:36px;border-radius:10px;background:var(--soft);color:var(--text);border:1px solid var(--line)}

.summary-card{background:linear-gradient(135deg,rgba(24,182,173,.08),rgba(255,255,255,.9));border:1px solid rgba(24,182,173,.2)}
.summary-text{white-space:pre-wrap;line-height:1.6;color:#334155}
html[data-theme="dark"] .summary-text{color:var(--text)}
.skeleton{position:relative;overflow:hidden;background:var(--soft);border-radius:12px;min-height:18px}
.skeleton:after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:shimmer 1.4s infinite}
.loading-skeleton{position:relative}
.loading-skeleton:before{content:"";position:absolute;inset:10px;border-radius:16px;background:linear-gradient(90deg,rgba(248,250,252,.72),rgba(230,255,251,.9),rgba(248,250,252,.72));background-size:220% 100%;animation:shimmer 1.2s infinite;z-index:4;pointer-events:none}
@keyframes shimmer{100%{transform:translateX(100%)}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation:none!important;transition:none!important}}

@media(max-width:900px){
  .ai-command-center{grid-template-columns:1fr;padding:24px}
  .ai-command-title{font-size:30px}
  .ai-bubble{max-width:88%}
  .ai-input-row{flex-direction:column}
  .ai-input-row button{width:100%}
}

/* MOBILE RESPONSIVE FIX */
@media (max-width: 768px) {
  body {
    overflow-x: hidden;
  }

  .layout {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
  }

  .sidebar {
    position: relative;
    width: 100%;
    height: auto;
    padding: 10px;
    display: flex;
    flex-direction: row;
    gap: 8px;
    overflow-x: auto;
    white-space: nowrap;
  }

  .logo-wrap,
  .alert-card {
    display: none !important;
  }

  .side-link {
    margin: 0;
    padding: 9px 12px;
    font-size: 12px;
    border-radius: 999px;
    flex: 0 0 auto;
  }

  .main {
    margin-left: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .topbar {
    height: auto;
    padding: 10px;
    display: flex;
    flex-direction: row;
    gap: 8px;
    align-items: center;
    justify-content: space-between;
  }

  .topbar input {
    width: 100%;
    height: 38px;
  }

  .brand {
    font-size: 15px;
  }

  .topbar-brand {
    font-size: 15px;
  }

  .profile-popover {
    width: min(320px, calc(100vw - 32px));
    min-width: 280px;
    right: 0;
  }

  .notification-popover {
    width: min(380px, calc(100vw - 32px));
    min-width: 280px;
    right: 0;
  }

  .top-user {
    width: 100%;
    justify-content:space-between;
  }

  .top-profile-copy {
    text-align:left;
  }

  .top-meta {
    justify-content:flex-start;
    flex-wrap:wrap;
  }

  .container {
    padding: 10px;
  }

  .tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
  }

  .tab {
    white-space: nowrap;
    font-size: 12px;
    padding: 9px 12px;
  }

  .stats {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    align-items:start;
  }

  .stat {
    padding: 14px;
  }

  .stat h2 {
    font-size: 24px;
  }

  .card {
    padding: 14px;
    overflow-x: auto;
    border-radius: 16px;
  }

  .toolbar {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .toolbar input,
  .toolbar select,
  .toolbar button,
  .toolbar .btn {
    width: 100%;
  }

  table {
    display: block;
    width: 100%;
    min-width: unset !important;
    overflow-x: auto;
    white-space: nowrap;
  }

  .doc-table {
    display: table;
    overflow: visible;
    white-space: normal;
    table-layout: fixed;
  }

  th,
  td {
    padding: 10px 12px;
    font-size: 12px;
  }

  .name {
    font-size: 13px;
  }

  .small {
    font-size: 11px;
  }

  .actions-grid {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: stretch;
  }

  .actions-grid .btn,
  .actions-grid button,
  .actions-grid select {
    width: 100%;
  }

  .compact-status {
    flex-direction: column;
    width: 100%;
  }

  .compact-status select,
  .compact-status button {
    width: 100%;
  }

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

  .section-header,
  .candidate-profile-head,
  .candidate-action-bar,
  .ai-chat-head {
    flex-direction:column;
  }

  .insight-matrix,
  .candidate-info-grid {
    grid-template-columns:1fr;
  }

  .candidate-score {
    width:100%;
    text-align:left;
  }

  .inline-upload-form,
  .review-form-grid {
    grid-template-columns:1fr;
    min-width:0;
  }

  .doc-workflow-top {
    grid-template-columns:1fr;
  }

  .ai-workspace-meta {
    justify-content:flex-start;
  }

  .ai-prompt-panel,
  .ai-composer,
  .ai-conversation {
    padding-left:14px;
    padding-right:14px;
  }

  .login-card {
    width: 92%;
    max-width: 380px;
  }

  .form-card {
    margin: 10px auto;
  }

  input,
  select,
  textarea {
    font-size: 14px;
  }
}
