/* ══════════════════════════════════════════════════════════════
   Firm2B Desktop — Premium Light Theme v4
   Inspired by Flow / Notion / Linear Light
   ══════════════════════════════════════════════════════════════ */
:root {
  --bg-0: #f7f5f2;
  --bg-1: #ffffff;
  --bg-2: #f0eeeb;
  --bg-card: #ffffff;
  --bg-card-h: #fafaf9;
  --bg-input: #ffffff;
  --bdr: #e8e5e1;
  --bdr-h: #d4d1cc;
  --bdr-focus: #1a1a1a;
  --text-1: #1a1a1a;
  --text-2: #6b6b6b;
  --text-3: #9e9e9e;
  --accent: #e8573a;
  --accent-h: #d44a2f;
  --accent-light: #fef0ed;
  --green: #1a8a4a;
  --green-bg: #edf7f0;
  --amber: #b8860b;
  --amber-bg: #fdf6e3;
  --red: #d44a2f;
  --red-bg: #fef0ed;
  --blue: #2563eb;
  --blue-bg: #eff4ff;
  --orange: #c2590a;
  --orange-bg: #fff3eb;
  --sb-w: 240px;
  --r: 10px;
  --rs: 8px;
}

/* ─── RESET ───────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg-0);color:var(--text-1);-webkit-font-smoothing:antialiased;overflow:hidden;height:100vh}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--accent-light);color:var(--accent)}

/* ─── AUTH SCREEN ──────────────────────────────────────────── */
.auth-wrapper{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--bg-0);overflow:hidden;z-index:200}
.auth-bg{position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 20%,rgba(232,87,58,0.06),transparent 50%),
             radial-gradient(ellipse at 70% 80%,rgba(37,99,235,0.04),transparent 50%);
  pointer-events:none}
.auth-card{position:relative;width:420px;background:#ffffff;border:1px solid var(--bdr);
  border-radius:16px;padding:40px;box-shadow:0 4px 24px rgba(0,0,0,0.06);z-index:1}
.auth-logo{text-align:center;margin-bottom:32px}
.auth-logo .icon{font-size:36px;margin-bottom:8px}
.auth-logo h1{font-size:28px;font-weight:800;color:var(--text-1);letter-spacing:-0.5px}
.auth-logo p{font-size:13px;color:var(--text-3);margin-top:4px;letter-spacing:0.2px}
.auth-tabs{display:flex;background:var(--bg-2);border-radius:var(--rs);padding:3px;margin-bottom:24px}
.auth-tab{flex:1;padding:9px;border-radius:6px;font-size:13px;font-weight:600;color:var(--text-3);background:none;border:none;transition:all 0.2s}
.auth-tab.active{background:#ffffff;color:var(--text-1);box-shadow:0 1px 3px rgba(0,0,0,0.08)}

/* ─── FORMS ──────────────────────────────────────────────── */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.5px}
.form-input{width:100%;padding:10px 14px;border-radius:var(--rs);background:var(--bg-input);border:1px solid var(--bdr);
  color:var(--text-1);font-size:14px;outline:none;transition:border-color 0.2s,box-shadow 0.2s}
.form-input:focus{border-color:var(--text-1);box-shadow:0 0 0 3px rgba(26,26,26,0.06)}
.form-input::placeholder{color:var(--text-3)}
.form-hint{font-size:11px;color:var(--accent);margin-top:4px}
.form-row{display:flex;gap:12px}
.form-row .form-group{flex:1}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239e9e9e'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.auth-link{font-size:12px;color:var(--accent);cursor:pointer;transition:color 0.2s;font-weight:500}
.auth-link:hover{color:var(--accent-h);text-decoration:underline}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;font-size:11px;color:var(--text-3)}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--bdr)}
.auth-footer{text-align:center;margin-top:24px;font-size:12px;color:var(--text-3)}
.trust-text{text-align:center;margin-top:20px;font-size:11px;color:var(--text-3);letter-spacing:0.3px}

/* ─── PLANS SCREEN ────────────────────────────────────────── */
.plans-wrapper{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-0);z-index:200;overflow-y:auto;padding:40px}
.plans-header{text-align:center;margin-bottom:36px}
.plans-header h2{font-size:28px;font-weight:800;margin-bottom:8px;letter-spacing:-0.5px}
.plans-header p{color:var(--text-2);font-size:14px}
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:960px;width:100%}
.plan-card{background:var(--bg-card);border:1px solid var(--bdr);border-radius:14px;padding:32px 28px;transition:all 0.3s;position:relative;display:flex;flex-direction:column}
.plan-card:hover{border-color:var(--bdr-h);transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,0.06)}
.plan-card.popular{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.plan-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;
  font-size:10px;font-weight:700;padding:4px 14px;border-radius:20px;text-transform:uppercase;letter-spacing:1px}
.plan-name{font-size:18px;font-weight:700;margin-bottom:4px}
.plan-price{font-size:36px;font-weight:800;font-family:'JetBrains Mono',monospace;margin:16px 0 4px;letter-spacing:-1px}
.plan-price span{font-size:16px;font-weight:400;color:var(--text-3)}
.plan-desc{font-size:13px;color:var(--text-2);margin-bottom:20px}
.plan-features{list-style:none;margin-bottom:24px;flex:1}
.plan-features li{font-size:13px;color:var(--text-2);padding:5px 0;display:flex;align-items:center;gap:8px}
.plan-features li::before{content:'✓';color:var(--green);font-weight:700;font-size:14px}
.plan-features .section-label{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:0.5px;margin-top:8px}
.plan-features .section-label::before{display:none}
.plans-footer{text-align:center;margin-top:28px;color:var(--text-3);font-size:13px}
.plans-footer a{color:var(--accent);text-decoration:underline}

/* ─── BUTTONS ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--rs);font-size:13px;font-weight:600;border:none;transition:all 0.2s;position:relative;overflow:hidden}
.btn-primary{background:var(--accent);color:#ffffff;box-shadow:0 1px 3px rgba(232,87,58,0.3)}
.btn-primary:hover{background:var(--accent-h);box-shadow:0 2px 8px rgba(232,87,58,0.35);transform:translateY(-1px)}
.btn-primary:disabled{opacity:0.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn-secondary{background:transparent;color:var(--text-2);border:1px solid var(--bdr)}
.btn-secondary:hover{border-color:var(--bdr-h);color:var(--text-1);background:var(--bg-2)}
.btn-success{background:var(--green-bg);color:var(--green);border:1px solid rgba(26,138,74,0.2)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid rgba(212,74,47,0.2)}
.btn-warning{background:var(--amber-bg);color:var(--amber);border:1px solid rgba(184,134,11,0.2)}
.btn-ghost{background:none;color:var(--text-2);border:none;padding:8px 12px}
.btn-ghost:hover{color:var(--text-1);background:var(--bg-2)}
.btn-lg{padding:12px 28px;font-size:15px;border-radius:var(--r)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-block{width:100%}
.btn .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin 0.6s linear infinite}
.btn-google{background:#ffffff;color:var(--text-1);border:1px solid var(--bdr);padding:12px 20px;font-size:14px;font-weight:500;gap:10px}
.btn-google:hover{background:var(--bg-2);border-color:var(--bdr-h);transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,0.06)}
.btn-google svg{flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── APP SHELL ───────────────────────────────────────────── */
.app-container{display:flex;height:100vh;overflow:hidden}
.hidden{display:none!important}

/* ─── SIDEBAR ─────────────────────────────────────────────── */
.sidebar{width:var(--sb-w);height:100vh;background:#ffffff;border-right:1px solid var(--bdr);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:50}
.sidebar-brand{height:56px;display:flex;align-items:center;padding:0 20px;gap:10px;border-bottom:1px solid var(--bdr)}
.sidebar-brand .icon{width:28px;height:28px;background:var(--text-1);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;filter:grayscale(1) brightness(5)}
.sidebar-brand .name{font-size:17px;font-weight:800;color:var(--text-1);letter-spacing:-0.3px}
.sidebar-section{padding:0 12px;margin-top:20px}
.sidebar-section-title{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:1.2px;padding:0 8px;margin-bottom:6px}
.sidebar-nav{display:flex;flex-direction:column;gap:1px;padding:0 10px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--rs);font-size:13px;font-weight:500;color:var(--text-2);
  cursor:pointer;transition:all 0.15s;border:none;border-left:2px solid transparent}
.nav-item:hover{color:var(--text-1);background:var(--bg-2)}
.nav-item.active{color:var(--text-1);background:var(--bg-2);font-weight:600;border-left-color:var(--text-1)}
.nav-item .icon{width:18px;text-align:center;flex-shrink:0;font-size:15px}
.sidebar-footer{margin-top:auto;padding:14px;border-top:1px solid var(--bdr)}
.user-card{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--rs);transition:background 0.2s;cursor:pointer}
.user-card:hover{background:var(--bg-2)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--text-1);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#ffffff;flex-shrink:0}
.avatar-sm{width:26px;height:26px;border-radius:50%;font-size:10px}
.user-card .info .name{font-size:13px;font-weight:600}
.user-card .info .meta{display:flex;align-items:center;gap:6px}
.role-badge{font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;background:var(--bg-2);color:var(--text-2);text-transform:uppercase;letter-spacing:0.5px}
.plan-tag{font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;background:var(--accent-light);color:var(--accent);text-transform:uppercase;letter-spacing:0.5px}

/* ─── TOPBAR ──────────────────────────────────────────────── */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:20px 0 12px;margin-bottom:4px}
.topbar-left .breadcrumb{font-size:11px;color:var(--text-3);margin-bottom:2px}
.topbar-left h2{font-size:22px;font-weight:700;letter-spacing:-0.3px}
.topbar-right{display:flex;align-items:center;gap:8px}
.topbar-btn{width:36px;height:36px;border-radius:50%;background:#ffffff;border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;color:var(--text-3);cursor:pointer;transition:all 0.2s;position:relative;font-size:16px}
.topbar-btn:hover{border-color:var(--bdr-h);color:var(--text-1);background:var(--bg-2)}
.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid #ffffff}

/* ─── MAIN CONTENT ────────────────────────────────────────── */
.main-content{margin-left:var(--sb-w);flex:1;height:100vh;overflow-y:auto;padding:0 32px 32px}
.page{animation:fadeIn 0.25s ease}
.page.hidden{display:none}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ─── CARDS ───────────────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--bdr);border-radius:var(--r);padding:24px;margin-bottom:16px;transition:border-color 0.2s,box-shadow 0.2s}
.card:hover{border-color:var(--bdr-h)}
.card-title{font-size:14px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;color:var(--text-1)}

/* ─── STAT GRID ───────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.stat-card{background:var(--bg-card);border:1px solid var(--bdr);border-radius:var(--r);padding:20px;transition:all 0.2s}
.stat-card:hover{border-color:var(--bdr-h);box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.stat-card .sc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.stat-card .sc-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}
.stat-card .sc-trend{font-size:11px;font-weight:600;display:flex;align-items:center;gap:2px}
.trend-up{color:var(--green)}
.trend-down{color:var(--red)}
.trend-neutral{color:var(--text-3)}
.stat-card .sc-value{font-size:26px;font-weight:800;font-family:'JetBrains Mono',monospace;line-height:1;letter-spacing:-0.5px}
.stat-card .sc-label{font-size:12px;color:var(--text-3);margin-top:4px}

/* ─── DASHBOARD GRID ──────────────────────────────────────── */
.dash-grid{display:grid;grid-template-columns:5fr 3fr;gap:16px}
.activity-list{display:flex;flex-direction:column;gap:0}
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--bg-2);position:relative}
.activity-item:last-child{border-bottom:none}
.a-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}
.a-dot.green{background:var(--green)}.a-dot.blue{background:var(--blue)}.a-dot.amber{background:var(--amber)}.a-dot.red{background:var(--red)}.a-dot.purple{background:#7c3aed}
.activity-item .a-text{font-size:13px;color:var(--text-2)}
.activity-item .a-text strong{color:var(--text-1)}
.activity-item .a-time{font-size:11px;color:var(--text-3);margin-top:2px}
.action-cards{display:flex;flex-direction:column;gap:8px}
.action-card{display:flex;align-items:center;gap:14px;padding:14px;background:var(--bg-0);border:1px solid var(--bdr);border-radius:var(--rs);cursor:pointer;transition:all 0.2s}
.action-card:hover{border-color:var(--bdr-h);background:#ffffff;box-shadow:0 2px 6px rgba(0,0,0,0.04)}
.action-card .ac-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.action-card .ac-label{font-size:14px;font-weight:600}
.action-card .ac-desc{font-size:11px;color:var(--text-3)}
.action-card .ac-arrow{margin-left:auto;color:var(--text-3);font-size:16px;transition:transform 0.2s}
.action-card:hover .ac-arrow{transform:translateX(4px);color:var(--text-1)}

/* ─── DEADLINES ───────────────────────────────────────────── */
.deadline-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}
.deadline-card{background:var(--bg-0);border:1px solid var(--bdr);border-radius:var(--rs);padding:16px}
.deadline-card .dl-name{font-size:12px;font-weight:600;color:var(--text-2)}
.deadline-card .dl-date{font-size:18px;font-weight:700;font-family:'JetBrains Mono',monospace;margin-top:6px;letter-spacing:-0.3px}
.deadline-card .dl-days{font-size:11px;color:var(--amber);margin-top:4px;font-weight:600}

/* ─── CLIENT CARDS ────────────────────────────────────────── */
.search-bar{display:flex;align-items:center;gap:10px;background:#ffffff;border:1px solid var(--bdr);border-radius:var(--rs);padding:10px 14px;margin-bottom:16px;transition:border-color 0.2s}
.search-bar:focus-within{border-color:var(--text-1);box-shadow:0 0 0 3px rgba(26,26,26,0.04)}
.search-bar input{flex:1;background:none;border:none;color:var(--text-1);font-size:14px;outline:none}
.search-bar input::placeholder{color:var(--text-3)}
.search-bar .search-icon{color:var(--text-3);font-size:16px}
.filter-chips{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto}
.chip{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:var(--text-3);background:#ffffff;border:1px solid var(--bdr);cursor:pointer;transition:all 0.2s;white-space:nowrap}
.chip:hover{border-color:var(--bdr-h);color:var(--text-2)}
.chip.active{background:var(--text-1);color:#ffffff;border-color:var(--text-1)}
.client-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.client-card{background:var(--bg-card);border:1px solid var(--bdr);border-radius:var(--r);padding:20px;transition:all 0.2s;cursor:pointer}
.client-card:hover{border-color:var(--bdr-h);box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.client-card .cc-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.client-card .cc-name{font-size:15px;font-weight:600}
.client-card .cc-gstin{font-size:12px;color:var(--text-3);font-family:'JetBrains Mono',monospace;margin-top:2px}
.client-card .cc-stats{display:flex;gap:16px;margin-top:12px}
.client-card .cc-stat{font-size:11px;color:var(--text-3)}
.client-card .cc-stat strong{color:var(--text-2);font-size:13px;display:block}
.client-card .cc-actions{display:flex;gap:8px;margin-top:14px}
.risk-meter{display:flex;align-items:center;gap:8px}
.risk-track{width:80px;height:5px;border-radius:3px;background:var(--bg-2);overflow:hidden}
.risk-fill{height:100%;border-radius:3px;transition:width 0.5s}
.risk-label{font-size:11px;font-weight:600}
.empty-state{text-align:center;padding:60px 20px;color:var(--text-3)}
.empty-state .es-icon{font-size:48px;margin-bottom:16px}
.empty-state p{font-size:14px;margin-bottom:20px}

/* ─── UPLOAD STEPPER ──────────────────────────────────────── */
.stepper{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px}
.step{display:flex;align-items:center;gap:8px}
.step-circle{width:32px;height:32px;border-radius:50%;border:2px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-3);transition:all 0.3s}
.step.active .step-circle{border-color:var(--text-1);color:var(--text-1);box-shadow:0 0 0 4px rgba(26,26,26,0.06)}
.step.done .step-circle{border-color:var(--green);background:var(--green);color:#fff}
.step-label{font-size:12px;font-weight:600;color:var(--text-3)}
.step.active .step-label{color:var(--text-1)}
.step.done .step-label{color:var(--green)}
.step-line{width:60px;height:2px;background:var(--bdr);margin:0 12px}
.step-line.done{background:var(--green)}
.upload-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.upload-zone{border:2px dashed var(--bdr);border-radius:var(--r);padding:40px 20px;text-align:center;cursor:pointer;transition:all 0.3s;min-height:200px;
  display:flex;flex-direction:column;align-items:center;justify-content:center}
.upload-zone:hover{border-color:var(--bdr-h);background:var(--bg-2)}
.upload-zone.success{border-color:var(--green);border-style:solid;background:var(--green-bg)}
.upload-zone.error{border-color:var(--red);border-style:solid;background:var(--red-bg)}
.upload-zone .uz-icon{font-size:42px;margin-bottom:12px}
.upload-zone .uz-text{font-size:14px;color:var(--text-2)}
.upload-zone .uz-hint{font-size:12px;color:var(--text-3);margin-top:6px}
.upload-zone .uz-success{color:var(--green);font-weight:600;font-size:14px}
.upload-zone .uz-count{color:var(--green);font-size:12px;margin-top:4px}
.center-action{text-align:center;padding:20px 0}
.center-action .hint{font-size:12px;color:var(--text-3);margin-top:10px}
.progress-section{margin-top:16px}
.progress-bar{width:100%;height:6px;border-radius:3px;background:var(--bg-2);overflow:hidden}
.progress-fill{height:100%;border-radius:3px;background:var(--accent);transition:width 0.3s;animation:progressPulse 1.5s ease-in-out infinite}
@keyframes progressPulse{0%,100%{opacity:1}50%{opacity:0.6}}

/* ─── RESULTS ─────────────────────────────────────────────── */
.summary-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:16px}
.summary-m{background:var(--bg-card);border:1px solid var(--bdr);border-radius:var(--rs);padding:14px;text-align:center}
.summary-m .sm-icon{font-size:16px;margin-bottom:6px}
.summary-m .sm-val{font-size:22px;font-weight:800;font-family:'JetBrains Mono',monospace;letter-spacing:-0.5px}
.summary-m .sm-label{font-size:10px;color:var(--text-3);margin-top:2px;text-transform:uppercase;letter-spacing:0.5px}
.itc-bar{display:flex;align-items:center;gap:20px;flex-wrap:wrap;font-size:13px}
.itc-bar .sep{width:1px;height:24px;background:var(--bdr)}
.itc-bar .label{color:var(--text-3);font-size:12px}
.itc-bar .value{font-weight:700;font-family:'JetBrains Mono',monospace}
.tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--bg-2);border:1px solid var(--bdr);border-radius:var(--rs);padding:3px;overflow-x:auto}
.tab{padding:8px 14px;border-radius:6px;font-size:12px;font-weight:500;color:var(--text-3);cursor:pointer;background:none;border:none;white-space:nowrap;transition:all 0.2s}
.tab:hover{color:var(--text-2)}
.tab.active{background:#ffffff;color:var(--text-1);box-shadow:0 1px 3px rgba(0,0,0,0.06);font-weight:600}
.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px}
.data-table thead th{padding:10px 12px;text-align:left;font-weight:700;color:var(--text-3);font-size:10px;text-transform:uppercase;letter-spacing:0.6px;border-bottom:1px solid var(--bdr);position:sticky;top:0;background:#ffffff}
.data-table tbody td{padding:11px 12px;border-bottom:1px solid var(--bg-2);vertical-align:middle}
.data-table tbody tr{transition:background 0.12s;cursor:pointer}
.data-table tbody tr:hover{background:var(--bg-0)}
.data-table tbody tr.highlight{background:rgba(16,185,129,0.06);border-bottom:2px solid var(--green)}
.data-table tbody tr.highlight td{font-weight:700;color:var(--green)}
.badge-gray{color:var(--text-3);background:var(--bg-2);border-color:var(--bdr)}
.text-right{text-align:right!important}.text-center{text-align:center!important}
.mono{font-family:'JetBrains Mono',monospace;font-size:12px}

/* ─── BADGES ──────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;border:1px solid;letter-spacing:0.3px}
.badge-green{color:var(--green);background:var(--green-bg);border-color:rgba(26,138,74,0.2)}
.badge-blue{color:var(--blue);background:var(--blue-bg);border-color:rgba(37,99,235,0.2)}
.badge-amber{color:var(--amber);background:var(--amber-bg);border-color:rgba(184,134,11,0.2)}
.badge-red{color:var(--red);background:var(--red-bg);border-color:rgba(212,74,47,0.2)}
.badge-orange{color:var(--orange);background:var(--orange-bg);border-color:rgba(194,89,10,0.2)}
.badge-gray{color:var(--text-3);background:var(--bg-2);border-color:var(--bdr)}

/* ─── MODAL ───────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.3);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn 0.15s}
.modal-overlay.hidden{display:none}
.modal{background:#ffffff;border:1px solid var(--bdr);border-radius:14px;padding:28px;width:460px;max-height:85vh;overflow-y:auto;animation:slideUp 0.25s ease;box-shadow:0 16px 48px rgba(0,0,0,0.12)}
.modal-title{font-size:18px;font-weight:700;margin-bottom:20px}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:24px}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ─── DETAIL DRAWER ───────────────────────────────────────── */
.detail-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.2);display:flex;justify-content:flex-end;z-index:100}
.detail-overlay.hidden{display:none}
.detail-panel{width:520px;height:100vh;overflow-y:auto;background:#ffffff;border-left:1px solid var(--bdr);padding:28px;animation:slideIn 0.25s ease;box-shadow:-8px 0 30px rgba(0,0,0,0.06)}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.detail-header h3{font-size:18px;font-weight:700}
.detail-section{margin-bottom:20px}
.detail-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;color:var(--text-3)}
.detail-row{display:flex;justify-content:space-between;padding:5px 0;font-size:12px}
.detail-label{color:var(--text-3)}
.detail-value{font-weight:500;font-family:'JetBrains Mono',monospace}
.detail-columns{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ims-actions{display:flex;gap:8px;margin-top:20px}
.ims-actions .btn{flex:1}

/* ─── REPORTS ─────────────────────────────────────────────── */
.report-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.report-card{background:var(--bg-card);border:1px solid var(--bdr);border-radius:var(--r);padding:24px;display:flex;align-items:flex-start;gap:16px;transition:all 0.2s;cursor:pointer}
.report-card:hover{border-color:var(--bdr-h);box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.report-card .rc-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.report-card .rc-title{font-size:14px;font-weight:600;margin-bottom:4px}
.report-card .rc-desc{font-size:12px;color:var(--text-3)}

/* ─── TOAST ───────────────────────────────────────────────── */
.toast-container{position:fixed;bottom:20px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:var(--rs);font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;
  animation:toastIn 0.3s ease;box-shadow:0 4px 16px rgba(0,0,0,0.1);min-width:280px}
.toast-success{background:var(--green-bg);border:1px solid rgba(26,138,74,0.2);color:var(--green)}
.toast-error{background:var(--red-bg);border:1px solid rgba(212,74,47,0.2);color:var(--red)}
.toast-info{background:var(--blue-bg);border:1px solid rgba(37,99,235,0.2);color:var(--blue)}
@keyframes toastIn{from{opacity:0;transform:translateY(16px) scale(0.95)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ─── SCROLLBAR ───────────────────────────────────────────── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--bdr-h)}
