/* ================================================================
   XPlatforms CRM — Design System
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ── Tokens ───────────────────────────────────────────────────── */
:root {
  --bg:#0d1117; --bg2:#161b22; --bg3:#21262d; --bg4:#30363d; --bg5:#3d444d;
  --b:#30363d;  --b2:#484f58;
  --t1:#e6edf3; --t2:#8b949e; --t3:#484f58;
  --blue:#4f8ef7;   --blue2:#316ff3;  --blue-a:rgba(79,142,247,.12);
  --green:#3fb950;  --green2:#2da44e; --green-a:rgba(63,185,80,.12);
  --amber:#f0883e;  --amber2:#d4710a; --amber-a:rgba(240,136,62,.12);
  --red:#f85149;    --red2:#da3633;   --red-a:rgba(248,81,73,.12);
  --purple:#bc8cff; --purple2:#9a6fdb;--purple-a:rgba(188,140,255,.12);
  --teal:#20e3b2;   --teal2:#1ab89e;  --teal-a:rgba(32,227,178,.12);
  --coral:#fa7970;  --coral-a:rgba(250,121,112,.12);
  --r:10px; --rs:7px; --rm:14px;
  --shadow:0 1px 3px rgba(0,0,0,.4),0 4px 12px rgba(0,0,0,.3);
  --shadow-lg:0 8px 32px rgba(0,0,0,.5);
  --sidebar-w:220px; --topbar-h:56px;
  --font:'Plus Jakarta Sans','Segoe UI',system-ui,sans-serif;
}

/* ── Reset ────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);background:var(--bg);color:var(--t1);line-height:1.6}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
button{cursor:pointer;font-family:var(--font)}
input,select,textarea{font-family:var(--font)}

/* ── App Shell ────────────────────────────────────────────────── */
.app-shell{display:flex;height:100vh;overflow:hidden}

/* ── Sidebar ──────────────────────────────────────────────────── */
.sidebar{width:var(--sidebar-w);height:100vh;background:var(--bg2);border-right:1px solid var(--b);
  display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;overflow-x:hidden;
  scrollbar-width:thin;scrollbar-color:var(--bg4) transparent}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}
.sb-logo{display:flex;align-items:center;gap:10px;padding:18px 16px 14px;border-bottom:1px solid var(--b)}
.sb-logo-icon{width:30px;height:30px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px}
.sb-logo-name{font-weight:800;font-size:15px;letter-spacing:-.02em}
.sb-logo-name span{color:var(--blue)}
.sb-section{font-size:10px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;padding:14px 16px 5px}
.sb-link{display:flex;align-items:center;gap:9px;padding:8px 12px;margin:1px 6px;border-radius:var(--rs);
  color:var(--t2);font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;position:relative}
.sb-link:hover{background:var(--bg3);color:var(--t1);text-decoration:none}
.sb-link.active{background:var(--blue-a);color:var(--blue)}
.sb-link i{font-size:15px;width:18px;flex-shrink:0}
.sb-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}
.sb-user{margin-top:auto;padding:12px 14px;border-top:1px solid var(--b);display:flex;align-items:center;gap:10px}
.sb-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.sb-user-name{font-size:12.5px;font-weight:700}
.sb-user-role{font-size:11px;color:var(--t3)}
.sb-role-pill{font-size:9px;font-weight:700;padding:3px 10px;border-radius:10px;margin:8px 10px 4px;text-align:center;letter-spacing:.06em}

/* ── Main ─────────────────────────────────────────────────────── */
.main-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden}

/* ── Topbar ───────────────────────────────────────────────────── */
.topbar{height:var(--topbar-h);background:var(--bg2);border-bottom:1px solid var(--b);
  display:flex;align-items:center;gap:12px;padding:0 20px;flex-shrink:0}
.topbar-title{font-size:15px;font-weight:700}
.topbar-search{flex:1;max-width:360px;position:relative}
.topbar-search input{width:100%;background:var(--bg3);border:1px solid var(--b);border-radius:var(--r);
  padding:7px 14px 7px 36px;color:var(--t1);font-size:13px;outline:none;transition:border-color .15s}
.topbar-search input:focus{border-color:var(--blue)}
.topbar-search i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--t3);font-size:14px}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.tb-icon-btn{width:34px;height:34px;border-radius:var(--rs);background:transparent;border:none;
  color:var(--t2);font-size:17px;display:flex;align-items:center;justify-content:center;transition:all .15s;position:relative}
.tb-icon-btn:hover{background:var(--bg3);color:var(--t1)}
.tb-badge{position:absolute;top:2px;right:2px;width:16px;height:16px;background:var(--red);
  color:#fff;font-size:8px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}

/* ── Page Content ─────────────────────────────────────────────── */
.page-content{flex:1;overflow-y:auto;padding:24px}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.page-header h1{font-size:20px;font-weight:800;letter-spacing:-.02em}
.page-header p{font-size:13px;color:var(--t3);margin-top:2px}
.page-actions{display:flex;align-items:center;gap:8px}

/* ── Card ─────────────────────────────────────────────────────── */
.card{background:var(--bg2);border:1px solid var(--b);border-radius:var(--r)}
.card-header{padding:16px 20px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:14px;font-weight:700}
.card-body{padding:20px}

/* ── Stat Grid ────────────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:14px;margin-bottom:20px}
.stat-card{background:var(--bg2);border:1px solid var(--b);border-radius:var(--r);padding:16px 18px}
.stat-val{font-size:26px;font-weight:800;letter-spacing:-.03em}
.stat-lbl{font-size:12px;color:var(--t3);font-weight:600;margin-top:2px}
.stat-sub{font-size:11.5px;color:var(--t3);margin-top:4px;display:flex;align-items:center;gap:3px}
.stat-sub.up{color:var(--green)} .stat-sub.down{color:var(--red)}

/* ── Buttons ──────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--rs);
  font-size:13px;font-weight:700;border:none;outline:none;transition:all .15s;cursor:pointer;white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue2);transform:translateY(-1px)}
.btn-secondary{background:var(--bg3);color:var(--t1);border:1px solid var(--b)}
.btn-secondary:hover{background:var(--bg4)}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--b)}
.btn-ghost:hover{background:var(--bg3);color:var(--t1)}
.btn-danger{background:var(--red-a);color:var(--red);border:1px solid rgba(248,81,73,.3)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-success{background:var(--green-a);color:var(--green);border:1px solid rgba(63,185,80,.3)}
.btn-success:hover{background:var(--green);color:#fff}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-lg{padding:11px 22px;font-size:14px}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* ── Table ────────────────────────────────────────────────────── */
.table-wrap{background:var(--bg2);border:1px solid var(--b);border-radius:var(--r);overflow:hidden}
.crm-table{width:100%;border-collapse:collapse}
.crm-table thead tr{background:var(--bg3);border-bottom:1px solid var(--b)}
.crm-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;color:var(--t3);
  text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
.crm-table td{padding:12px 14px;border-bottom:1px solid var(--b);font-size:13px;color:var(--t2);vertical-align:middle}
.crm-table tr:last-child td{border-bottom:none}
.crm-table tbody tr{transition:background .12s;cursor:pointer}
.crm-table tbody tr:hover{background:var(--bg3)}
.table-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;
  border-top:1px solid var(--b);font-size:12px;color:var(--t3)}

/* ── Filters ──────────────────────────────────────────────────── */
.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.fpill{background:var(--bg3);border:1px solid var(--b);color:var(--t2);padding:5px 12px;
  border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.fpill:hover,.fpill.active{background:var(--blue-a);border-color:var(--blue);color:var(--blue)}
.fselect{background:var(--bg3);border:1px solid var(--b);color:var(--t1);padding:6px 12px;
  border-radius:var(--rs);font-size:12.5px;outline:none;cursor:pointer}
.fselect:focus{border-color:var(--blue)}

/* ── Tags ─────────────────────────────────────────────────────── */
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:6px;font-size:11.5px;font-weight:700}
.tag-new{background:var(--blue-a);color:var(--blue)}
.tag-contact{background:var(--purple-a);color:var(--purple)}
.tag-qual{background:var(--amber-a);color:var(--amber)}
.tag-proposal{background:var(--teal-a);color:var(--teal)}
.tag-conv{background:var(--green-a);color:var(--green)}
.tag-lost{background:var(--bg3);color:var(--t3)}
.tag-hot{background:var(--coral-a);color:var(--coral)}
.tag-warm{background:var(--amber-a);color:var(--amber)}
.tag-risk{background:rgba(240,136,62,.2);color:var(--amber)}
.tag-pending{background:var(--amber-a);color:var(--amber)}
.tag-approved{background:var(--green-a);color:var(--green)}
.tag-rejected{background:var(--red-a);color:var(--red)}

/* ── Avatar ───────────────────────────────────────────────────── */
.av{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;
  justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}

/* ── Score Bar ────────────────────────────────────────────────── */
.score-wrap{display:flex;align-items:center;gap:6px}
.score-bar{flex:1;max-width:80px;height:5px;background:var(--bg4);border-radius:3px;overflow:hidden}
.score-fill{height:100%;border-radius:3px}

/* ── Form ─────────────────────────────────────────────────────── */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:12.5px;font-weight:600;color:var(--t2);margin-bottom:6px}
.form-label .req{color:var(--red);margin-left:3px}
.form-control{width:100%;background:var(--bg3);border:1px solid var(--b);border-radius:var(--rs);
  padding:9px 14px;color:var(--t1);font-size:13.5px;outline:none;transition:border-color .15s}
.form-control:focus{border-color:var(--blue)}
.form-control::placeholder{color:var(--t3)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b949e' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.form-textarea{resize:vertical;min-height:80px}
.form-error{font-size:11.5px;color:var(--red);margin-top:5px}
.form-hint{font-size:11.5px;color:var(--t3);margin-top:5px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .full{grid-column:1/-1}

/* ── Modal ────────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;
  display:flex;align-items:center;justify-content:center;padding:20px}
.modal-overlay.hidden{display:none}
.modal-box{background:var(--bg2);border:1px solid var(--b2);border-radius:var(--rm);
  padding:24px;width:100%;max-width:520px;box-shadow:var(--shadow-lg)}
.modal-box.lg{max-width:700px}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-title{font-size:16px;font-weight:800}
.modal-close{width:28px;height:28px;border-radius:6px;background:var(--bg3);border:none;
  color:var(--t2);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}

/* ── Toast ────────────────────────────────────────────────────── */
.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--rs);
  font-size:13px;font-weight:600;box-shadow:var(--shadow);animation:toastIn .25s ease;min-width:240px;max-width:380px}
.toast-ok{background:var(--bg2);border:1px solid var(--green);color:var(--green)}
.toast-err{background:var(--bg2);border:1px solid var(--red);color:var(--red)}
.toast-warn{background:var(--bg2);border:1px solid var(--amber);color:var(--amber)}
@keyframes toastIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── Skeleton ─────────────────────────────────────────────────── */
.skeleton{background:var(--bg3);border-radius:4px;animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── Empty State ──────────────────────────────────────────────── */
.empty-state{padding:60px 20px;text-align:center;color:var(--t3)}
.empty-state i{font-size:40px;display:block;margin-bottom:12px;opacity:.4}
.empty-state h3{font-size:15px;font-weight:700;color:var(--t2);margin-bottom:6px}

/* ── Pagination ───────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;gap:5px}
.page-btn{width:30px;height:30px;border-radius:6px;border:1px solid var(--b);background:var(--bg3);
  color:var(--t2);font-size:12.5px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.page-btn:hover,.page-btn.active{background:var(--blue-a);border-color:var(--blue);color:var(--blue)}
.page-btn:disabled{opacity:.4;cursor:not-allowed}

/* ── Progress ─────────────────────────────────────────────────── */
.progress{height:6px;background:var(--bg4);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;transition:width .4s}

/* ── Alert ────────────────────────────────────────────────────── */
.alert{padding:12px 16px;border-radius:var(--rs);font-size:13px;font-weight:600;
  display:flex;align-items:flex-start;gap:10px;margin-bottom:16px}
.alert-success{background:var(--green-a);border:1px solid rgba(63,185,80,.3);color:var(--green)}
.alert-error{background:var(--red-a);border:1px solid rgba(248,81,73,.3);color:var(--red)}
.alert-warning{background:var(--amber-a);border:1px solid rgba(240,136,62,.3);color:var(--amber)}
.alert-info{background:var(--blue-a);border:1px solid rgba(79,142,247,.3);color:var(--blue)}

/* ── Auth Layout ──────────────────────────────────────────────── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg)}
.auth-card{width:100%;max-width:420px;background:var(--bg2);border:1px solid var(--b2);
  border-radius:var(--rm);padding:36px;box-shadow:var(--shadow-lg)}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:28px}
.auth-logo-icon{width:40px;height:40px;background:var(--blue);border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}
.auth-logo-name{font-size:22px;font-weight:800;letter-spacing:-.03em}
.auth-logo-name span{color:var(--blue)}
.auth-title{font-size:20px;font-weight:800;margin-bottom:6px}
.auth-subtitle{font-size:13px;color:var(--t3);margin-bottom:24px}

/* ── Breadcrumb ───────────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--t3);margin-bottom:16px}
.breadcrumb a{color:var(--t3);font-weight:600}
.breadcrumb a:hover{color:var(--t1);text-decoration:none}
.breadcrumb .sep{font-size:11px}
.breadcrumb .current{color:var(--t2);font-weight:600}

/* ── Utilities ────────────────────────────────────────────────── */
.hidden{display:none!important}
.d-flex{display:flex} .align-center{align-items:center} .justify-between{justify-content:space-between}
.gap-2{gap:8px} .gap-3{gap:12px}
.mt-1{margin-top:4px} .mt-2{margin-top:8px} .mt-3{margin-top:12px} .mt-4{margin-top:16px}
.fw-700{font-weight:700} .fw-800{font-weight:800}
.text-muted{color:var(--t3)} .text-success{color:var(--green)}
.text-danger{color:var(--red)} .text-warning{color:var(--amber)} .text-primary{color:var(--blue)}

/* ── Scrollbar ────────────────────────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--bg5)}

/* ── Responsive ───────────────────────────────────────────────── */
@media(max-width:900px){
  .sidebar{width:56px}
  .sb-link span,.sb-section,.sb-logo-name,.sb-user-name,.sb-user-role,.sb-role-pill{display:none}
  .form-grid{grid-template-columns:1fr}
}
