/* DocMind Admin — dark navy + teal theme matching the marketing site */

:root {
  --bg-primary:#0b1120;
  --bg-secondary:#0e1525;
  --bg-card:rgba(17,26,46,0.6);
  --bg-card-hover:#152035;
  --accent:#4f7ef7;
  --accent-teal:#14d6b4;
  --text-primary:#e8eaf0;
  --text-secondary:#8494b2;
  --text-muted:#4a5672;
  --border:rgba(255,255,255,0.06);
  --border-hover:rgba(20,214,180,0.3);
  --danger:#ef4444;
  --success:#22c55e;
  --warning:#f59e0b;
  --radius:12px;
  --radius-sm:8px;
  --radius-pill:100px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg-primary);
  color:var(--text-primary);
  font-family:'Inter',-apple-system,sans-serif;
  font-weight:400;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
body::before{
  content:'';position:fixed;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse 60% 40% at 20% 0%, rgba(20,65,115,0.25) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 80% 100%, rgba(20,214,180,0.08) 0%, transparent 60%),
    linear-gradient(180deg,#0c1a2a 0%,#0a1520 50%,#081018 100%);
}
h1,h2,h3,h4,h5,h6{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;line-height:1.2}
a{color:var(--accent-teal);text-decoration:none}
a:hover{color:#20f0cc}
button{font-family:inherit;cursor:pointer}

/* ===== LOGIN ===== */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}
.login-card{
  background:var(--bg-card);backdrop-filter:blur(14px);
  border:1px solid var(--border);border-radius:16px;
  padding:40px 36px;width:100%;max-width:420px;
  box-shadow:0 20px 80px rgba(0,0,0,0.4);
}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:22px}
.login-logo svg{width:32px;height:32px}
.login-card h1{font-size:22px;margin-bottom:6px}
.login-card .subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:28px}
.login-card label{display:block;font-size:13px;color:var(--text-secondary);margin:14px 0 6px}
.login-card input{
  width:100%;padding:12px 14px;font-size:14px;
  background:rgba(0,0,0,0.25);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-primary);outline:none;transition:border-color .2s;
}
.login-card input:focus{border-color:var(--accent-teal)}
.login-card .error{color:var(--danger);font-size:13px;margin-top:10px;min-height:18px}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:var(--radius-sm);
  padding:10px 20px;font-size:14px;font-weight:500;
  cursor:pointer;transition:all .2s;text-decoration:none;
}
.btn-teal{background:var(--accent-teal);color:#062029}
.btn-teal:hover{background:#20f0cc;color:#062029}
.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--accent-teal);color:var(--accent-teal)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#ff5555}
.btn-block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ===== LAYOUT (sidebar + main) ===== */
.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{
  background:rgba(11,17,32,0.7);backdrop-filter:blur(14px);
  border-right:1px solid var(--border);
  padding:24px 18px;display:flex;flex-direction:column;gap:4px;
}
.sidebar .brand{display:flex;align-items:center;gap:10px;padding:6px 10px;margin-bottom:20px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:18px;flex-wrap:wrap}
.sidebar .brand svg{width:24px;height:24px;flex-shrink:0}
.brand-version{
  font-family:'JetBrains Mono',monospace;font-weight:500;font-size:10px;
  color:var(--accent-teal);background:rgba(20,214,180,0.1);
  padding:2px 7px;border-radius:var(--radius-pill);letter-spacing:.5px;
  border:1px solid rgba(20,214,180,0.25);
}
.nav-section{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:1.5px;color:var(--text-muted);padding:16px 10px 8px;text-transform:uppercase}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:var(--radius-sm);
  font-size:14px;color:var(--text-secondary);cursor:pointer;transition:all .15s;
}
.nav-item:hover{background:rgba(20,214,180,0.06);color:var(--text-primary)}
.nav-item.active{background:rgba(20,214,180,0.12);color:var(--accent-teal)}
.nav-item .nav-icon{width:16px;height:16px;flex-shrink:0}
.sidebar-footer{margin-top:auto;padding:14px 10px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted)}
.sidebar-footer .user-name{color:var(--text-primary);font-weight:600;margin-bottom:4px}
.sidebar-footer .logout-link{color:var(--text-muted);cursor:pointer;display:inline-block;margin-top:8px}
.sidebar-footer .logout-link:hover{color:var(--danger)}

.main{overflow-y:auto;display:flex;flex-direction:column;min-width:0}
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 40px;
  background:linear-gradient(180deg, rgba(11,17,32,0.9), rgba(11,17,32,0.6));
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.topbar-right{display:flex;align-items:center;gap:12px}
.sidebar-toggle{
  background:transparent;border:none;color:var(--text-secondary);
  cursor:pointer;padding:8px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.sidebar-toggle:hover{background:rgba(20,214,180,0.08);color:var(--accent-teal)}
.main-content{padding:24px 40px 40px;flex:1}

/* Collapsed sidebar state (toggled by the hamburger) */
.app-shell{transition:grid-template-columns .25s ease}
.sidebar{transition:transform .25s ease, opacity .2s ease}
body.sidebar-collapsed .app-shell{grid-template-columns:0 1fr}
body.sidebar-collapsed .sidebar{transform:translateX(-100%);opacity:0;pointer-events:none}

/* Avatar button (top right) */
.avatar-btn{
  width:42px;height:42px;border-radius:50%;
  background:rgba(20,214,180,0.12);border:2px solid rgba(20,214,180,0.35);
  cursor:pointer;padding:0;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.avatar-btn:hover{border-color:var(--accent-teal);box-shadow:0 0 0 4px rgba(20,214,180,0.1)}
.avatar-btn img{width:100%;height:100%;object-fit:cover}
.avatar-initials{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:14px;color:var(--accent-teal);letter-spacing:.5px}

/* Dropdown menu */
.avatar-menu{
  position:absolute;top:64px;right:20px;z-index:60;
  width:260px;
  background:rgba(17,26,46,0.96);backdrop-filter:blur(20px);
  border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:0 12px 60px rgba(0,0,0,0.45);
  opacity:0;pointer-events:none;transform:translateY(-6px);
  transition:opacity .15s ease, transform .15s ease;
  overflow:hidden;
}
.avatar-menu.open{opacity:1;pointer-events:auto;transform:translateY(0)}
.avatar-menu-header{padding:18px 16px;border-bottom:1px solid var(--border);background:rgba(20,214,180,0.04)}
.avatar-menu-name{font-weight:700;font-size:14px;color:var(--text-primary);margin-bottom:6px}
.avatar-menu-role{margin-bottom:6px}
.avatar-menu-email{font-size:12px;color:var(--text-muted);font-family:'JetBrains Mono',monospace}
.avatar-menu-item{
  display:block;width:100%;text-align:left;
  padding:12px 16px;font-size:14px;
  color:var(--text-secondary);background:none;border:none;cursor:pointer;
  font-family:inherit;text-decoration:none;
  transition:background .1s;
}
.avatar-menu-item:hover{background:rgba(20,214,180,0.08);color:var(--text-primary)}
.avatar-menu-divider{height:1px;background:var(--border);margin:4px 0}
.avatar-menu-logout{color:var(--danger)}
.avatar-menu-logout:hover{background:rgba(239,68,68,0.1);color:var(--danger)}

@media (max-width:900px){.topbar{padding:12px 20px}.main-content{padding:16px 20px 30px}}

/* Profile page */
.profile-grid{display:grid;grid-template-columns:280px 1fr;gap:20px}
@media (max-width:900px){.profile-grid{grid-template-columns:1fr}}
.profile-avatar-card{display:flex;flex-direction:column;align-items:center}
.profile-avatar-preview{
  width:180px;height:180px;border-radius:50%;
  background:rgba(20,214,180,0.1);border:3px solid rgba(20,214,180,0.3);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;margin:10px 0 20px;
}
.profile-avatar-preview img{width:100%;height:100%;object-fit:cover}
.profile-avatar-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}

/* ===== REPORTS PAGE ===== */
.report-section{padding:24px;background:#fff;color:#0b1120;border-radius:var(--radius);margin-top:12px}
.report-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:3px solid #14d6b4;padding-bottom:16px;margin-bottom:20px}
.report-logo{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:20px;color:#0b1120}
.report-title{font-size:14px;color:#6b7280;margin-top:4px;letter-spacing:1px;text-transform:uppercase}
.report-meta{text-align:right;font-size:13px;color:#4b5563;line-height:1.8}
.report-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}
.report-kpi{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:14px 16px}
.report-kpi-label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:#6b7280;font-family:'JetBrains Mono',monospace;margin-bottom:6px}
.report-kpi-value{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:24px;color:#0b1120}
.report-kpi-pct{font-size:12px;font-weight:500;color:#6b7280;margin-left:4px}
.report-section-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;color:#0b1120;margin:24px 0 10px;border-bottom:1px solid #e5e7eb;padding-bottom:8px}
.report-table th{background:#f3f4f6;color:#374151}
.report-table td{color:#1f2937}
.report-footer{margin-top:30px;padding-top:16px;border-top:1px solid #e5e7eb;font-size:11px;color:#6b7280;text-align:center}

/* Browser print rules — clean A4 output, hide admin chrome */
@media print {
  @page { size: A4; margin: 12mm; }
  body::before,body::after{display:none !important}
  .sidebar,.topbar,.no-print,.page-header > div:last-child{display:none !important}
  .app-shell{display:block !important}
  .main{padding:0 !important}
  .main-content{padding:0 !important}
  .card{background:#fff !important;color:#000 !important;border:none !important;backdrop-filter:none !important;box-shadow:none !important;padding:0 !important}
  .card-title{color:#000;border-bottom:1px solid #ccc;padding-bottom:8px}
  .report-section{padding:0;border-radius:0}
  /* Hide the form controls area when printing a generated report */
  #rptFrom,#rptTo,#rptDocType,#generateBtn,.form-row{display:none !important}
  /* Only the report-section itself prints */
  body *{visibility:hidden}
  #printableReport,#printableReport *{visibility:visible}
  #printableReport{position:absolute;left:0;top:0;width:100%}
}
.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.page-header h1{font-size:24px}
.page-header .page-subtitle{color:var(--text-secondary);font-size:14px;margin-top:4px}
.page-content{display:flex;flex-direction:column;gap:20px}

/* ===== CARDS ===== */
.card{
  background:var(--bg-card);backdrop-filter:blur(10px);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;
}
.card-title{font-size:16px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty-state .empty-icon{font-size:40px;margin-bottom:14px;opacity:.4}
.empty-state .empty-title{font-size:16px;color:var(--text-secondary);margin-bottom:6px}
.empty-state .empty-note{font-size:13px;color:var(--text-muted)}

/* ===== FORM ===== */
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-row label{font-size:13px;color:var(--text-secondary)}
.form-row input,.form-row select,.form-row textarea{
  padding:10px 12px;font-size:14px;font-family:inherit;
  background:rgba(0,0,0,0.25);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-primary);outline:none;transition:border-color .2s;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--accent-teal)}
.form-row .hint{font-size:12px;color:var(--text-muted);margin-top:2px}
.form-actions{display:flex;gap:10px;margin-top:20px}

/* ===== TABLES ===== */
table.data-table{width:100%;border-collapse:collapse}
table.data-table th{
  text-align:left;font-size:11px;letter-spacing:1px;text-transform:uppercase;
  color:var(--text-muted);padding:12px 14px;border-bottom:1px solid var(--border);
  font-family:'JetBrains Mono',monospace;font-weight:500;
}
table.data-table td{padding:14px;font-size:14px;border-bottom:1px solid var(--border)}
table.data-table tr:hover td{background:rgba(255,255,255,0.02)}
.badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;font-family:'JetBrains Mono',monospace;letter-spacing:.5px}
.badge-admin{background:rgba(239,68,68,0.12);color:var(--danger)}
.badge-supervisor{background:rgba(245,158,11,0.12);color:var(--warning)}
.badge-reviewer{background:rgba(79,126,247,0.12);color:var(--accent)}
.badge-active{background:rgba(34,197,94,0.12);color:var(--success)}
.badge-inactive{background:rgba(74,86,114,0.2);color:var(--text-muted)}

/* ===== TOAST ===== */
.toast-wrap{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{
  padding:12px 18px;border-radius:var(--radius-sm);font-size:14px;
  background:var(--bg-secondary);border:1px solid var(--border);
  box-shadow:0 8px 30px rgba(0,0,0,0.3);
  min-width:220px;animation:toastIn .2s ease-out;
}
@keyframes toastIn{from{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}
.toast.success{border-left:3px solid var(--success)}
.toast.error{border-left:3px solid var(--danger)}
.toast.info{border-left:3px solid var(--accent-teal)}

/* ===== SETTINGS PAGE ===== */
.settings-group{margin-bottom:24px}
.settings-group-title{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;
  color:var(--accent-teal);text-transform:uppercase;margin-bottom:12px;
}
.setting-row{
  display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.setting-row:last-child{border-bottom:none}
.setting-label{font-size:14px;font-weight:500}
.setting-description{font-size:12px;color:var(--text-muted);margin-top:3px}
.setting-input{min-width:200px}
.setting-input input,.setting-input select{width:100%}
.setting-row .save-cell{min-width:90px;text-align:right}

/* ===== VERDICT / STATUS / SEVERITY BADGES ===== */
.badge-pending{background:rgba(74,86,114,0.2);color:var(--text-muted)}
.badge-processing{background:rgba(20,214,180,0.12);color:var(--accent-teal);animation:pulseDim 1.5s ease-in-out infinite}
@keyframes pulseDim{0%,100%{opacity:1}50%{opacity:.6}}
.badge-danger{background:rgba(239,68,68,0.12);color:var(--danger)}
.badge-warning{background:rgba(245,158,11,0.12);color:var(--warning)}
.vb-green{background:rgba(34,197,94,0.12);color:var(--success)}
.vb-yellow{background:rgba(245,158,11,0.12);color:var(--warning)}
.vb-red{background:rgba(239,68,68,0.12);color:var(--danger)}
.pipeline-forensic{background:rgba(20,214,180,0.12);color:var(--accent-teal)}
.pipeline-vision{background:rgba(79,126,247,0.12);color:var(--accent)}
.pipeline-metadata{background:rgba(124,90,247,0.12);color:#7c5af7}

/* ===== FACTORY ANIMATION ===== */
.factory-panel{padding:10px 4px}
.factory-title{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px;text-align:center}
.factory-streams{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}
.fstream{background:rgba(0,0,0,0.2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.fstream-label{font-family:'Inter',sans-serif;font-weight:600;font-size:12px;letter-spacing:.5px}
.fs-forensic .fstream-label{color:var(--accent-teal)}
.fs-vision   .fstream-label{color:var(--accent)}
.fs-meta     .fstream-label{color:#7c5af7}
.fstream-sub{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-muted);margin:3px 0 8px}
.fstream-bar{height:6px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden}
.fstream-fill{height:100%;width:0%;transition:width .08s linear;border-radius:3px}
.fs-forensic .fstream-fill{background:var(--accent-teal)}
.fs-vision   .fstream-fill{background:var(--accent)}
.fs-meta     .fstream-fill{background:#7c5af7}
.factory-status{text-align:center;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--accent-teal);letter-spacing:1px}

/* ===== STREAM RESULT ROWS (document detail) — legacy ===== */
.stream-row{display:grid;grid-template-columns:120px 1fr 70px;gap:12px;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}
.stream-row:last-child{border-bottom:none}
.stream-name{font-weight:600;font-size:14px}
.stream-bar-wrap{height:6px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden}
.stream-bar{height:100%;border-radius:3px;transition:width .4s ease}
.stream-score{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:13px;text-align:right}
.stream-empty{font-size:13px;color:var(--text-muted);font-style:italic}

/* ===== GAUGE CARDS (review + detail pages) ===== */
.gauge-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.gauge-card{
  background:rgba(0,0,0,0.25);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 14px 0;
  display:flex;flex-direction:column;align-items:center;
  transition:all .2s;
}
.gauge-card:hover{border-color:rgba(20,214,180,0.25);transform:translateY(-2px)}
.gauge-svg{width:100%;max-width:220px;height:auto;display:block}
.gauge-footer{
  width:100%;margin-top:12px;padding:12px 10px;
  text-align:center;border-top:2px solid;
}
.gauge-stream-label{
  font-family:'Inter',sans-serif;font-weight:700;font-size:13px;letter-spacing:1px;
}
.gauge-stream-sub{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-muted);
  margin-top:3px;letter-spacing:.5px;
}
.gauge-stream-ms{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--accent-teal);
  margin-top:6px;letter-spacing:.5px;
}
.gauge-empty{
  padding:48px 16px;text-align:center;color:var(--text-muted);
}
.gauge-empty-icon{font-size:32px;margin-bottom:8px;opacity:.5}
.gauge-empty-label{font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--text-secondary)}
.gauge-empty-sub{font-family:'JetBrains Mono',monospace;font-size:11px;margin-top:4px}

@media (max-width:900px){
  .gauge-row{grid-template-columns:1fr;gap:12px}
}

/* ===== DASHBOARD (Phase 4) ===== */
.dashboard-stats{margin-bottom:0}
.stat-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}
.stat-card{
  background:rgba(17,26,46,0.55);backdrop-filter:blur(10px);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:22px 20px;transition:all .2s;
}
.stat-card:hover{border-color:rgba(20,214,180,0.3);transform:translateY(-2px)}
.stat-card-icon{font-size:22px;margin-bottom:10px;opacity:.85}
.stat-card-value{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:28px;color:var(--accent-teal);line-height:1}
.stat-card-label{font-size:13px;font-weight:600;color:var(--text-primary);margin-top:6px}
.stat-card-sub{font-size:11px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;margin-top:3px;letter-spacing:.5px}

.dashboard-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:20px}
@media (max-width:1100px){.dashboard-grid{grid-template-columns:1fr}}

.donut-legend{display:flex;flex-direction:column;gap:10px}
.donut-legend-row{display:grid;grid-template-columns:14px 1fr auto;gap:10px;align-items:center;font-size:14px}
.donut-legend-swatch{width:14px;height:14px;border-radius:4px}
.donut-legend-label{color:var(--text-primary);font-weight:500}
.donut-legend-value{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:var(--text-primary)}
.donut-legend-pct{color:var(--text-muted);font-weight:400;font-size:11px}

.breakdown-list{display:flex;flex-direction:column;gap:10px}
.breakdown-row{display:grid;grid-template-columns:140px 1fr 50px;gap:12px;align-items:center}
.breakdown-label{font-size:13px;color:var(--text-secondary)}
.breakdown-bar{display:flex;height:22px;background:rgba(0,0,0,0.2);border-radius:6px;overflow:hidden;min-width:30px}
.bd-seg{display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 1px rgba(0,0,0,0.4)}
.bd-g{background:#22c55e}
.bd-y{background:#f59e0b}
.bd-r{background:#ef4444}
.breakdown-total{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;text-align:right}

.trend-btn{padding:6px 14px !important;font-size:13px !important}
.trend-btn.active{background:rgba(20,214,180,0.12);border-color:var(--accent-teal);color:var(--accent-teal)}

/* Document detail — per-doc workflow strip */
.doc-workflow-card{padding:18px 20px}
.doc-workflow-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dw-stage{
  display:flex;align-items:center;gap:10px;
  padding:8px 14px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:rgba(0,0,0,0.2);
  min-width:140px;flex:1;max-width:260px;
}
.dw-stage-icon{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;flex-shrink:0;
}
.dw-stage-body{flex:1;min-width:0}
.dw-stage-label{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dw-stage-meta{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-muted);margin-top:2px}
.dw-done{border-color:rgba(34,197,94,0.4);background:rgba(34,197,94,0.06)}
.dw-done .dw-stage-icon{background:#22c55e;color:#062029}
.dw-done .dw-stage-label{color:var(--text-primary)}
.dw-active{border-color:var(--accent-teal);background:rgba(20,214,180,0.1);animation:dwPulse 2s ease-in-out infinite}
@keyframes dwPulse{0%,100%{box-shadow:0 0 0 0 rgba(20,214,180,0.3)}50%{box-shadow:0 0 0 6px rgba(20,214,180,0)}}
.dw-active .dw-stage-icon{background:var(--accent-teal);color:#062029}
.dw-active .dw-stage-label{color:var(--accent-teal)}
.dw-todo .dw-stage-icon{background:rgba(74,86,114,0.3);color:var(--text-muted)}
.dw-todo .dw-stage-label{color:var(--text-muted)}
.dw-connector{flex:0 0 24px;height:2px;background:rgba(74,86,114,0.4)}
.dw-conn-done{background:rgba(34,197,94,0.5)}
@media (max-width:900px){
  .doc-workflow-row{flex-direction:column;align-items:stretch}
  .dw-connector{height:12px;width:2px;margin-left:18px}
  .dw-stage{max-width:none}
}

/* Document detail — activity log list */
.doc-audit-list{display:flex;flex-direction:column;gap:6px}
.doc-audit-row{
  display:grid;grid-template-columns:32px 1fr auto;gap:12px;
  padding:10px 12px;background:rgba(0,0,0,0.15);border-radius:8px;
  align-items:center;
}
.doc-audit-icon{font-size:16px;text-align:center;opacity:.8}
.doc-audit-main{min-width:0}
.doc-audit-action code{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--accent-teal);background:none;padding:0}
.doc-audit-meta{font-size:12px;color:var(--text-muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis}
.doc-audit-time{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-muted);white-space:nowrap}

/* Featured Detection — "See What DocMind Catches" widget */
.featured-catch-card{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg, rgba(17,26,46,0.7), rgba(20,40,60,0.5));
  border:1px solid rgba(245,158,11,0.2);
}
.featured-catch-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, #f59e0b, #ef4444, transparent);
}
.fc-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:20px}
.fc-eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--accent-teal);text-transform:uppercase;margin-bottom:4px}
.fc-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:22px;margin-bottom:4px}
.fc-sub{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-muted)}

.fc-body{display:grid;grid-template-columns:1.1fr 1fr;gap:20px}
@media (max-width:900px){.fc-body{grid-template-columns:1fr}}

.fc-doc-panel{background:#f4f6fb;color:#1a2540;border-radius:12px;padding:22px;box-shadow:0 20px 60px rgba(0,0,0,0.3)}
.fc-doc-title{font-family:'JetBrains Mono',monospace;font-size:11px;color:#6b7a99;letter-spacing:1.5px;text-transform:uppercase;padding-bottom:10px;border-bottom:2px solid #1a2540;margin-bottom:14px}
.fc-doc-frame{display:flex;flex-direction:column;gap:6px}
.fc-field-row{display:grid;grid-template-columns:1fr auto;column-gap:12px;row-gap:3px;padding:9px 12px;border-radius:6px;font-size:13px;align-items:center}
.fc-field-name{font-weight:500;color:#374151}
.fc-field-status{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;letter-spacing:.5px}
.fc-field-issue{grid-column:1/-1;font-size:11px;color:#6b7280;font-style:italic;margin-top:2px}
.fc-field-ok{background:rgba(34,197,94,0.07)}
.fc-field-warn{background:rgba(245,158,11,0.12);border:1px dashed rgba(245,158,11,0.4)}
.fc-field-alert{background:rgba(239,68,68,0.12);border:2px solid rgba(239,68,68,0.45);animation:fcAlertPulse 2.4s ease-in-out infinite}
@keyframes fcAlertPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,0.3)}50%{box-shadow:0 0 0 6px rgba(239,68,68,0)}}
.fcs-green{background:rgba(34,197,94,0.15);color:#16a34a}
.fcs-yellow{background:rgba(245,158,11,0.15);color:#b45309}
.fcs-red{background:rgba(239,68,68,0.15);color:#b91c1c}

.fc-analysis{display:flex;flex-direction:column;gap:12px}
.fc-streams{display:flex;flex-direction:column;gap:10px}
.fc-stream{background:rgba(0,0,0,0.2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.fc-stream-header{display:flex;justify-content:space-between;margin-bottom:8px}
.fc-stream-name{font-family:'Inter',sans-serif;font-weight:600;font-size:13px}
.fc-stream-score{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:13px}
.fc-stream-bar{height:5px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden;margin-bottom:5px}
.fc-stream-fill{height:100%;border-radius:3px;transition:width .6s ease}
.fc-stream-sub{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-muted)}
.fc-verdict{padding:16px 18px;border-radius:10px;border:2px solid;text-align:center}
.fc-verdict-label{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-muted);letter-spacing:2px;margin-bottom:6px;text-transform:uppercase}
.fc-verdict-value{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:18px;margin-bottom:4px}
.fc-verdict-action{font-size:12px;color:var(--text-secondary)}

/* Workflow diagram */
.workflow-wrap{padding:10px 0;position:relative;overflow-x:auto}
.workflow-svg{width:100%;min-width:900px;height:auto}
.wf-line{
  fill:none;stroke:rgba(74,86,114,0.4);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:6 4;
  animation:wfDash 1.6s linear infinite;
}
@keyframes wfDash{to{stroke-dashoffset:-20}}
.wf-line-green{stroke:rgba(34,197,94,0.5)}
.wf-line-yellow{stroke:rgba(245,158,11,0.55)}
.wf-line-red{stroke:rgba(239,68,68,0.5)}
.wf-node rect{transition:all .3s}
.wf-active rect{animation:wfPulse 2s ease-in-out infinite}
@keyframes wfPulse{
  0%,100%{filter:drop-shadow(0 0 0 rgba(20,214,180,0))}
  50%{filter:drop-shadow(0 0 12px rgba(20,214,180,0.6))}
}

/* ===== REVIEW SCREEN ===== */
.review-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.review-panel{background:var(--bg-card);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:12px}
.review-panel-title{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;text-align:center}
.review-doc-container{position:relative;background:rgba(0,0,0,0.25);border-radius:8px;border:1px solid var(--border);overflow:hidden;min-height:400px;display:flex;align-items:center;justify-content:center}
.review-doc-img{max-width:100%;max-height:600px;display:block}
.heatmap-overlay{position:absolute;inset:0;pointer-events:none}
.heatmap-box{position:absolute;border:2px solid;border-radius:4px;pointer-events:auto;cursor:help;animation:heatPulse 2s ease-in-out infinite}
@keyframes heatPulse{0%,100%{opacity:1}50%{opacity:.5}}

.review-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px;flex-wrap:wrap}
.review-tab{background:transparent;border:none;color:var(--text-secondary);padding:10px 18px;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;font-family:inherit}
.review-tab:hover{color:var(--text-primary)}
.review-tab.active{color:var(--accent-teal);border-bottom-color:var(--accent-teal)}

.decision-banner{padding:18px 20px;border-radius:var(--radius);margin-bottom:20px;border:1px solid}
.banner-approved{background:rgba(34,197,94,0.08);border-color:rgba(34,197,94,0.3);color:var(--success)}
.banner-rejected{background:rgba(239,68,68,0.08);border-color:rgba(239,68,68,0.3);color:var(--danger)}
.banner-escalated{background:rgba(245,158,11,0.08);border-color:rgba(245,158,11,0.3);color:var(--warning)}

.tab-btn{padding:8px 16px !important;font-size:13px !important}
.tab-btn.active{background:rgba(20,214,180,0.1);border-color:var(--accent-teal);color:var(--accent-teal)}

/* Template reference gallery */
.ref-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.ref-tile{position:relative;background:rgba(0,0,0,0.25);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:all .2s;cursor:pointer}
.ref-tile:hover{border-color:var(--accent-teal);transform:translateY(-2px);box-shadow:0 8px 24px rgba(20,214,180,0.12)}
.ref-tile.ref-primary{border-color:rgba(20,214,180,0.4)}
.ref-tile img{width:100%;height:180px;object-fit:cover;background:#fff;display:block;border-bottom:1px solid var(--border)}
.ref-meta{padding:10px 12px}
.ref-label{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px}
.ref-source{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-muted)}
.ref-zoom-hint{
  position:absolute;top:10px;right:10px;
  background:rgba(11,17,32,0.85);color:var(--accent-teal);
  padding:4px 10px;border-radius:var(--radius-pill);
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.5px;
  opacity:0;transition:opacity .2s;pointer-events:none;
}
.ref-tile:hover .ref-zoom-hint{opacity:1}

.ref-lang-badge{
  position:absolute;top:10px;left:10px;
  padding:3px 9px;border-radius:var(--radius-pill);
  font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:1px;
  background:rgba(11,17,32,0.85);backdrop-filter:blur(4px);
}
.ref-side-badge{
  position:absolute;bottom:56px;left:10px;
  padding:3px 9px;border-radius:var(--radius-sm);
  font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:1px;
  background:rgba(11,17,32,0.85);color:var(--text-primary);
  border:1px solid rgba(255,255,255,0.1);backdrop-filter:blur(4px);
}
.ref-delete-btn{
  position:absolute;top:8px;right:8px;
  width:28px;height:28px;border-radius:50%;
  background:rgba(239,68,68,0.85);color:#fff;border:none;
  font-size:14px;font-weight:700;cursor:pointer;
  opacity:0;transition:all .2s;display:flex;align-items:center;justify-content:center;
}
.ref-tile:hover .ref-delete-btn{opacity:1}
.ref-delete-btn:hover{background:#ef4444;transform:scale(1.1)}
.lang-en,   .ref-lang-badge.lang-en    { color:#4f7ef7; border:1px solid rgba(79,126,247,0.4) }
.lang-ar,   .ref-lang-badge.lang-ar    { color:#14d6b4; border:1px solid rgba(20,214,180,0.4) }
.lang-mixed,.ref-lang-badge.lang-mixed { color:#f59e0b; border:1px solid rgba(245,158,11,0.4) }
.lang-other,.ref-lang-badge.lang-other { color:#7c5af7; border:1px solid rgba(124,90,247,0.4) }
.badge.lang-en   { background:rgba(79,126,247,0.12) }
.badge.lang-ar   { background:rgba(20,214,180,0.12) }
.badge.lang-mixed{ background:rgba(245,158,11,0.12) }
.badge.lang-other{ background:rgba(124,90,247,0.12) }

/* ===== GALLERY LIGHTBOX ===== */
.lightbox{
  position:fixed;inset:0;z-index:2000;
  background:rgba(4,8,18,0.94);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;gap:20px;
  padding:40px 80px;animation:lbFade .2s ease-out;
}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
.lightbox-stage{
  flex:1;max-width:1200px;max-height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
}
.lightbox-header{text-align:center;color:var(--text-primary)}
.lightbox-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:18px}
.lightbox-subtitle{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent-teal);letter-spacing:2px;margin-top:4px}
.lightbox-img{
  max-width:100%;max-height:70vh;
  background:#fff;border-radius:8px;
  box-shadow:0 20px 80px rgba(0,0,0,0.5), 0 0 0 1px rgba(20,214,180,0.2);
}
.lightbox-caption{
  color:var(--text-primary);text-align:center;font-size:14px;
  padding:10px 20px;background:rgba(17,26,46,0.7);border-radius:var(--radius-sm);
  max-width:90%;
}
.lightbox-dots{display:flex;gap:8px}
.lightbox-dot{
  width:10px;height:10px;border-radius:50%;
  background:rgba(255,255,255,0.2);cursor:pointer;transition:all .15s;
}
.lightbox-dot.active{background:var(--accent-teal);transform:scale(1.3)}
.lightbox-dot:hover{background:rgba(20,214,180,0.5)}

.lightbox-close{
  position:absolute;top:20px;right:20px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(17,26,46,0.8);border:1px solid var(--border);color:var(--text-primary);
  font-size:20px;cursor:pointer;transition:all .15s;
}
.lightbox-close:hover{background:var(--danger);border-color:var(--danger);color:#fff}
.lightbox-nav{
  background:rgba(17,26,46,0.8);border:1px solid var(--border);color:var(--text-primary);
  width:56px;height:56px;border-radius:50%;
  font-size:32px;line-height:1;cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.lightbox-nav:hover{background:var(--accent-teal);border-color:var(--accent-teal);color:#062029}
@media (max-width:900px){
  .lightbox{padding:20px 10px;gap:8px}
  .lightbox-nav{width:42px;height:42px;font-size:24px}
}

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .review-layout{grid-template-columns:1fr}
}
