/* ============================================================
   CRM — amoCRM/Bitrix24 darajasidagi dizayn
   Light (default) + Dark mavzu. Mavzu html[data-theme] orqali.
   ============================================================ */

:root{
  --accent:#2c6ef2; --accent-2:#1b54c8; --accent-soft:#eaf1fe; --accent-ring:rgba(44,110,242,.22);
  --bg:#f4f6fb; --bg-2:#eef1f7;
  --surface:#ffffff; --surface-2:#f7f8fb; --surface-3:#eef0f5;
  --text:#1a2233; --text-2:#5a6478; --text-3:#9aa3b5;
  --border:#e7eaf1; --border-2:#dadfe9;
  --green:#0f9d6b; --green-bg:#e6f7f0;
  --amber:#c47d12; --amber-bg:#fdf3e2;
  --red:#dc4848; --red-bg:#fdecec;
  --purple:#6a5af0; --purple-bg:#edebfe;
  --teal:#0fae9e; --teal-bg:#e3f8f5;
  --radius:9px; --radius-lg:13px; --radius-xl:18px;
  --font:'Inter','Segoe UI',-apple-system,BlinkMacSystemFont,Roboto,sans-serif;
  --shadow-sm:0 1px 2px rgba(20,30,55,.06);
  --shadow:0 2px 8px rgba(20,30,55,.07),0 1px 2px rgba(20,30,55,.05);
  --shadow-md:0 6px 20px rgba(20,30,55,.10);
  --shadow-lg:0 18px 50px rgba(20,30,55,.20);
  --sidebar-bg:#111726; --sidebar-text:#aeb6c8; --sidebar-active:#2c6ef2; --sidebar-hover:rgba(255,255,255,.06);
}

:root[data-theme="dark"]{
  --accent:#5b8def; --accent-2:#7aa4f5; --accent-soft:#16233f; --accent-ring:rgba(91,141,239,.28);
  --bg:#0e1116; --bg-2:#0a0d11;
  --surface:#171b22; --surface-2:#1d222b; --surface-3:#262c36;
  --text:#e7eaf0; --text-2:#9aa4b6; --text-3:#6b7385;
  --border:#262b34; --border-2:#323845;
  --green:#3fd49a; --green-bg:#0d2a22;
  --amber:#f2b75a; --amber-bg:#2e2310;
  --red:#f07a7a; --red-bg:#33191a;
  --purple:#9b8cf7; --purple-bg:#211d3d;
  --teal:#43cfc0; --teal-bg:#0c2a29;
  --shadow-sm:0 1px 2px rgba(0,0,0,.3);
  --shadow:0 2px 10px rgba(0,0,0,.35);
  --shadow-md:0 8px 24px rgba(0,0,0,.45);
  --shadow-lg:0 20px 55px rgba(0,0,0,.6);
  --sidebar-bg:#0b0e13; --sidebar-text:#8b94a8; --sidebar-active:#5b8def; --sidebar-hover:rgba(255,255,255,.05);
}

/* Mavzu tanlanmagan bo'lsa — tizimga ergash */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --accent:#5b8def; --accent-2:#7aa4f5; --accent-soft:#16233f; --accent-ring:rgba(91,141,239,.28);
    --bg:#0e1116; --bg-2:#0a0d11;
    --surface:#171b22; --surface-2:#1d222b; --surface-3:#262c36;
    --text:#e7eaf0; --text-2:#9aa4b6; --text-3:#6b7385;
    --border:#262b34; --border-2:#323845;
    --green:#3fd49a; --green-bg:#0d2a22; --amber:#f2b75a; --amber-bg:#2e2310;
    --red:#f07a7a; --red-bg:#33191a; --purple:#9b8cf7; --purple-bg:#211d3d;
    --teal:#43cfc0; --teal-bg:#0c2a29;
    --shadow-sm:0 1px 2px rgba(0,0,0,.3); --shadow:0 2px 10px rgba(0,0,0,.35);
    --shadow-md:0 8px 24px rgba(0,0,0,.45); --shadow-lg:0 20px 55px rgba(0,0,0,.6);
    --sidebar-bg:#0b0e13; --sidebar-text:#8b94a8; --sidebar-active:#5b8def; --sidebar-hover:rgba(255,255,255,.05);
  }
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
#app{height:100vh}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:14px}
.i{font-size:18px;line-height:1;vertical-align:-2px}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:6px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:var(--text-3);background-clip:content-box}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border-2);background:var(--surface);color:var(--text);
  padding:8px 15px;border-radius:var(--radius);font-size:13px;font-weight:500;transition:.14s ease;white-space:nowrap;box-shadow:var(--shadow-sm)}
.btn:hover{background:var(--surface-2);border-color:var(--text-3)}
.btn:active{transform:translateY(.5px)}
.btn.pri{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-ring)}
.btn.pri:hover{background:var(--accent-2);border-color:var(--accent-2)}
.btn.green{background:var(--green);border-color:var(--green);color:#fff}
.btn.green:hover{filter:brightness(1.06)}
.btn.red{background:var(--red-bg);border-color:transparent;color:var(--red);box-shadow:none}
.btn.red:hover{background:var(--red);color:#fff}
.btn.amber{background:var(--amber-bg);border-color:transparent;color:var(--amber);box-shadow:none}
.btn.amber:hover{filter:brightness(.97)}
.btn.sm{padding:6px 11px;font-size:12px;border-radius:7px}
.btn.ghost{border-color:transparent;background:transparent;box-shadow:none}
.btn.ghost:hover{background:var(--surface-3);border-color:transparent}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}

/* ---- inputs ---- */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:12px;color:var(--text-2);font-weight:500}
.inp{width:100%;height:40px;padding:0 13px;border:1px solid var(--border-2);border-radius:var(--radius);
  background:var(--surface);color:var(--text);transition:.14s}
.inp::placeholder{color:var(--text-3)}
.inp:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3.5px var(--accent-ring)}
select.inp{cursor:pointer}
textarea.inp{height:auto;padding:11px 13px;resize:vertical;min-height:76px;line-height:1.5}
.search{position:relative;flex:1;min-width:180px}
.search .i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:18px}
.search input{width:100%;height:40px;padding:0 13px 0 38px;border:1px solid var(--border-2);border-radius:var(--radius);
  background:var(--surface);color:var(--text);transition:.14s}
.search input::placeholder{color:var(--text-3)}
.search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3.5px var(--accent-ring)}

/* ---- pills ---- */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:4px 11px;border-radius:20px;line-height:1}
.pill::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.85}
.pill.new{background:var(--accent-soft);color:var(--accent)}
.pill.in_progress{background:var(--amber-bg);color:var(--amber)}
.pill.pending{background:var(--surface-3);color:var(--text-2)}
.pill.delivering{background:var(--purple-bg);color:var(--purple)}
.pill.completed{background:var(--green-bg);color:var(--green)}
.pill.canceled{background:var(--red-bg);color:var(--red)}
.pill.later{background:var(--amber-bg);color:var(--amber)}
.tag{display:inline-flex;align-items:center;font-size:10.5px;font-weight:500;padding:3px 9px;border-radius:6px;background:var(--accent-soft);color:var(--accent)}

/* ---- shell ---- */
.shell{display:flex;height:100vh;overflow:hidden}
.sidebar{width:236px;flex-shrink:0;background:var(--sidebar-bg);display:flex;flex-direction:column;color:var(--sidebar-text)}
.brand{display:flex;align-items:center;gap:11px;padding:20px 20px 18px;font-weight:700;font-size:17px;color:#fff;letter-spacing:.2px}
.brand .logo-badge{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--accent),var(--purple));
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:19px}
.nav{flex:1;padding:8px 12px;overflow-y:auto}
.nav-sec{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--sidebar-text);opacity:.5;
  padding:14px 12px 7px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 13px;border-radius:var(--radius);color:var(--sidebar-text);
  font-size:13.5px;font-weight:500;margin-bottom:2px;cursor:pointer;transition:.14s;position:relative}
.nav-item:hover{background:var(--sidebar-hover);color:#fff}
.nav-item.active{background:var(--sidebar-active);color:#fff;box-shadow:0 4px 14px var(--accent-ring)}
.nav-item .i{font-size:19px}
.sidebar-foot{padding:12px;border-top:1px solid rgba(255,255,255,.07)}
.userbox{display:flex;align-items:center;gap:11px;padding:8px;border-radius:var(--radius)}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--purple));color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0}
.userbox .un{font-size:13px;font-weight:600;color:#fff}
.userbox .ur{font-size:11px;color:var(--sidebar-text);opacity:.7}
.icon-btn{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  color:var(--sidebar-text);cursor:pointer;transition:.14s;border:none;background:transparent}
.icon-btn:hover{background:var(--sidebar-hover);color:#fff}

.content{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}
.topbar{height:62px;flex-shrink:0;display:flex;align-items:center;gap:14px;padding:0 26px;
  border-bottom:1px solid var(--border);background:var(--surface)}
.topbar h1{font-size:18px;font-weight:600;letter-spacing:-.2px}
.topbar .spacer{flex:1}
.top-icon{position:relative;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  color:var(--text-2);cursor:pointer;transition:.14s;border:1px solid transparent}
.top-icon:hover{background:var(--surface-2);border-color:var(--border)}
.bell{overflow:visible}
.bell .badge{position:absolute;top:0;right:0;transform:translate(35%,-35%);min-width:20px;height:20px;border-radius:10px;
  background:var(--red);color:#fff;font-size:11px;line-height:1;display:flex;align-items:center;justify-content:center;
  padding:0 5px;font-weight:700;border:2px solid var(--surface);box-sizing:border-box;z-index:2;pointer-events:none;
  box-shadow:0 1px 4px rgba(0,0,0,.18)}
.bell .badge.badge-wide{min-width:26px;padding:0 4px;font-size:10px;letter-spacing:-.2px}
.online{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--green);font-weight:600;
  background:var(--green-bg);padding:6px 12px;border-radius:20px}
.online .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px var(--green-bg)}
.online.off{color:var(--text-3);background:var(--surface-3)} .online.off .dot{background:var(--text-3);box-shadow:none}
.presence-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--text-3);margin-right:6px;vertical-align:middle;flex-shrink:0}
.presence-dot.on{background:var(--green);box-shadow:0 0 0 2px var(--green-bg)}
.online-user{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}
.online-user:last-child{border-bottom:none}
.online-list .muted{font-size:12px}
.page{flex:1;min-height:0;overflow-y:auto;padding:24px 26px}

/* ---- stats ---- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:22px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-sm);transition:.16s}
.stat:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.stat .lbl{font-size:12.5px;color:var(--text-2);display:flex;align-items:center;gap:7px;font-weight:500}
.stat .lbl .i{font-size:17px;color:var(--accent)}
.stat .val{font-size:28px;font-weight:700;margin-top:10px;letter-spacing:-.5px}
.stat .sub{font-size:11.5px;margin-top:5px;color:var(--text-3)}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.card-h{display:flex;align-items:center;gap:9px;padding:15px 18px;border-bottom:1px solid var(--border);font-weight:600;font-size:14px}
.card-h .i{color:var(--text-2);font-size:19px}
.card-b{padding:18px}
.two-col{display:grid;grid-template-columns:1.3fr 1fr;gap:18px}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}

/* ---- toolbar / tabs ---- */
.toolbar{display:flex;align-items:center;gap:11px;flex-wrap:wrap;margin-bottom:18px}
.toolbar select.inp{width:auto;min-width:130px;height:40px}
.tabs{display:inline-flex;gap:3px;background:var(--surface-3);padding:4px;border-radius:11px;margin-bottom:18px}
.tabs-scroll{overflow-x:auto;overflow-y:hidden;max-width:100%;margin-bottom:18px;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.tabs-scroll .tabs{margin-bottom:0;min-width:min-content}
.tabs-scroll .tab{flex-shrink:0}
.stage-tabs .stage-tab .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.stage-tabs .stage-tab:not(.active):hover{filter:brightness(1.05)}
.tab{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;
  color:var(--text-2);cursor:pointer;transition:.14s;white-space:nowrap}
.tab:hover{color:var(--text)}
.tab.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm);font-weight:600}

/* ---- table ---- */
.tbl-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:13px 18px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;
  color:var(--text-3);border-bottom:1px solid var(--border);background:var(--surface-2)}
td{padding:13px 18px;border-bottom:1px solid var(--border);font-size:13.5px;color:var(--text-2)}
tr:last-child td{border-bottom:none}
tbody tr{transition:.12s}
tbody tr:hover{background:var(--surface-2)}
.row-click{cursor:pointer}
td .strong{color:var(--text);font-weight:600}
.muted{color:var(--text-3)}
.pager{display:flex;align-items:center;gap:10px;padding:14px 18px;font-size:12.5px;color:var(--text-2);justify-content:space-between;
  border-top:1px solid var(--border);background:var(--surface-2)}

/* ---- kanban (Bitrix24-style) ---- */
.kanban-root{display:flex;flex-direction:column;gap:12px;min-height:0;flex:1}
.kanban-summary{display:flex;gap:10px;padding:0 2px;flex-wrap:wrap}
.kanban-summary > span{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;padding:6px 14px;border-radius:20px}
.kanban-summary .ks-leads{background:var(--surface-3);color:var(--text-2)}
.kanban-summary .ks-sum{background:var(--green-bg);color:var(--green)}
.kanban-summary .i{font-size:16px}
.kanban-mount{min-height:0;flex:1}
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:10px;align-items:stretch;
  height:calc(100vh - 250px);min-height:420px}
.kcol{min-width:272px;width:272px;flex-shrink:0;background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:0;display:flex;flex-direction:column;max-height:100%;min-height:0;overflow:hidden}
/* rangli yuqori chiziq — stage rangi */
.kcol-h{position:relative;padding:14px 14px 12px;flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border)}
.kcol-h::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--stage-color,#888)}
.kcol-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600}
.kcol-title .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.kcol-title .kcol-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kcol-title .cnt{font-size:11px;font-weight:700;color:var(--text-2);background:var(--surface-3);border-radius:20px;padding:2px 9px;flex-shrink:0}
.kcol-sum{font-size:12.5px;font-weight:700;color:var(--green);margin-top:7px}
.kcol-body{flex:1;overflow-y:auto;min-height:0;padding:10px}
.kcol-more{width:100%;margin:2px 0 4px;justify-content:center}
/* won/lost ustun tuslari */
.kcol.kind-won{background:linear-gradient(var(--green-bg),var(--surface-2) 80px)}
.kcol.kind-lost{background:linear-gradient(var(--red-bg),var(--surface-2) 80px)}
.kcol.kind-lost .kcol-sum{color:var(--red)}
.kcard{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:9px;cursor:grab;
  box-shadow:var(--shadow-sm);transition:.14s}
.kcard:hover{box-shadow:var(--shadow);border-color:var(--border-2);transform:translateY(-1px)}
.kcard:active{cursor:grabbing}
.kcard.drag{opacity:.35;transform:rotate(1.5deg)}
.kcard.kcard-pending{opacity:.55;pointer-events:none;border-style:dashed}
.kcard.kcard-error{animation:kanban-shake .45s ease;border-color:var(--red)}
@keyframes kanban-shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
.kcard .nm{font-size:13.5px;font-weight:600}
.kcard .ph{font-size:12px;color:var(--text-3);margin-top:3px}
.kcard .ft{display:flex;align-items:center;gap:7px;margin-top:11px;flex-wrap:wrap}
.kcard .amt{margin-left:auto;font-size:13px;font-weight:700;color:var(--green)}
.kcol.over{outline:2px dashed var(--accent);outline-offset:-4px}
.kcol.over .kcol-body{background:var(--accent-soft)}

/* ---- transition matritsa (o'tish qoidalari) ---- */
.tr-matrix{border-collapse:collapse;font-size:12px;min-width:100%}
.tr-matrix th,.tr-matrix td{border:1px solid var(--border);padding:6px 8px;text-align:center;white-space:nowrap}
.tr-matrix thead th{background:var(--surface-3);font-weight:600;position:sticky;top:0;z-index:1}
.tr-matrix .tr-row-h,.tr-matrix .tr-corner{text-align:left;background:var(--surface-3);font-weight:600;position:sticky;left:0;z-index:1}
.tr-matrix .tr-corner{z-index:2}
.tr-dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle}
.tr-cell{min-width:62px}
.tr-cell.tr-self{color:var(--text-4);background:var(--surface-2)}
.tr-chip{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;
  border:1px solid var(--border);cursor:pointer;font-weight:700;font-size:11px;margin:0 1px;color:var(--text-3);background:var(--surface);user-select:none}
.tr-chip:hover{border-color:var(--border-2)}
.tr-chip.on{background:var(--accent);border-color:var(--accent);color:#fff}

/* ---- lead detail ---- */
.detail{display:grid;grid-template-columns:1fr 320px;gap:0;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
@media(max-width:900px){.detail{grid-template-columns:1fr}}
.detail-main{padding:24px;border-right:1px solid var(--border)}
.detail-side{padding:22px;background:var(--surface-2)}
.detail-head{display:flex;align-items:flex-start;gap:14px}
.detail-head .nm{font-size:19px;font-weight:700;letter-spacing:-.3px}
.detail-head .ph{font-size:13.5px;color:var(--accent);margin-top:4px;display:inline-flex;align-items:center;gap:5px}
.actbar{display:flex;gap:9px;flex-wrap:wrap;margin:20px 0}
.sec-t{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:700;margin:22px 0 12px}
.timeline{border-left:2px solid var(--border);padding-left:16px;margin-left:4px}
.timeline-item{position:relative;margin-bottom:15px}
.timeline-item .dot{position:absolute;left:-23px;top:3px;width:10px;height:10px;border-radius:50%;background:var(--accent);
  border:2px solid var(--surface);box-shadow:0 0 0 2px var(--border)}
.timeline-item .tx{font-size:13px}
.timeline-item .tm{font-size:11.5px;color:var(--text-3);margin-top:3px}
.kv{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px;gap:10px}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--text-3)} .kv .v{font-weight:600;text-align:right}
.comment{display:flex;gap:11px;margin-bottom:14px}
.comment .cb{font-size:13px;background:var(--surface-2);border-radius:10px;border-top-left-radius:2px;padding:9px 13px;flex:1}
.comment .cn{font-weight:600;font-size:12px;color:var(--text)}
.comment .ct{color:var(--text-2);margin-top:3px;line-height:1.5}

/* ---- bars / funnel ---- */
.bar-row{display:flex;align-items:center;gap:12px;margin-bottom:13px;font-size:13px}
.bar-row .nm{width:110px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.bar-track{flex:1;height:9px;background:var(--surface-3);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--accent),var(--purple))}
.bar-row .vv{width:46px;text-align:right;font-weight:700;font-size:12.5px}
.funnel-step{margin-bottom:9px}
.funnel-bar{height:38px;border-radius:8px;display:flex;align-items:center;padding:0 14px;color:#fff;font-size:12.5px;font-weight:600;
  transition:.2s;box-shadow:var(--shadow-sm)}

/* ---- login ---- */
.login-wrap{height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 600px at 50% -10%,var(--accent-soft),var(--bg) 60%)}
.login-card{width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:38px;box-shadow:var(--shadow-lg)}
.login-card .lg{display:flex;align-items:center;gap:12px;font-size:22px;font-weight:800;margin-bottom:8px;letter-spacing:-.3px}
.login-card .lg .logo-badge{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--accent),var(--purple));
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px}
.login-card .sub{color:var(--text-2);font-size:13.5px;margin-bottom:26px}
.err{background:var(--red-bg);color:var(--red);font-size:12.5px;padding:11px 14px;border-radius:var(--radius);margin-bottom:16px;
  display:flex;align-items:center;gap:8px;font-weight:500}

/* ---- toast / modal ---- */
#toast-root{position:fixed;top:22px;right:22px;z-index:9999;display:flex;flex-direction:column;gap:11px}
.toast{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--radius);
  padding:13px 17px;box-shadow:var(--shadow-lg);font-size:13px;min-width:250px;animation:slidein .22s ease;font-weight:500}
.toast.success{border-left-color:var(--green)} .toast.error{border-left-color:var(--red)} .toast.info{border-left-color:var(--accent)}
.toast-action{display:flex;align-items:center;gap:12px;max-width:min(360px,calc(100vw - 44px))}
.toast-action-msg{flex:1;line-height:1.4}
.toast-action-btn{flex-shrink:0;border:none;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600;
  cursor:pointer;background:var(--accent);color:#fff;white-space:nowrap}
.toast-action-btn:hover{filter:brightness(1.08)}
@keyframes slidein{from{transform:translateX(24px);opacity:0}to{transform:none;opacity:1}}
#modal-root:empty{display:none}
.modal-bg{position:fixed;inset:0;background:rgba(10,15,30,.5);backdrop-filter:blur(3px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fade .15s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:460px;max-width:100%;max-height:90vh;
  overflow-y:auto;box-shadow:var(--shadow-lg);animation:pop .18s ease}
@keyframes pop{from{transform:scale(.96) translateY(8px);opacity:0}to{transform:none;opacity:1}}
.modal-h{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border);font-weight:600;font-size:15px}
.modal-h .x{margin-left:auto;cursor:pointer;color:var(--text-3);width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center}
.modal-h .x:hover{background:var(--surface-3);color:var(--text)}
.modal-b{padding:22px}
.modal-f{display:flex;gap:11px;justify-content:flex-end;padding:18px 22px;border-top:1px solid var(--border);background:var(--surface-2)}

.notif-pop{position:absolute;top:52px;right:0;width:350px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:500;overflow:hidden;animation:pop .16s}
.notif-h{display:flex;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border);font-weight:600;font-size:14px}
.notif-list{max-height:380px;overflow-y:auto}
.notif{padding:13px 18px;border-bottom:1px solid var(--border);cursor:pointer;transition:.12s}
.notif:hover{background:var(--surface-2)}
.notif.unread{background:var(--accent-soft)}
.notif .nt{font-size:13px;font-weight:600}
.notif .nb{font-size:12px;color:var(--text-2);margin-top:3px}
.notif .nd{font-size:11px;color:var(--text-3);margin-top:5px}

.empty{text-align:center;padding:56px 20px;color:var(--text-3)}
.empty .i{font-size:44px;display:block;margin-bottom:12px;opacity:.6}
.spinner{width:28px;height:28px;border:3px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%;
  animation:spin .7s linear infinite;margin:44px auto}
@keyframes spin{to{transform:rotate(360deg)}}
.checkbox{width:17px;height:17px;cursor:pointer;accent-color:var(--accent)}

/* ---- editable rows / switch / tags ---- */
.kv.edit{cursor:pointer;border-radius:7px;margin:0 -8px;padding:10px 8px}
.kv.edit:hover{background:var(--surface-3)}
.kv .edit-ic{font-size:14px;color:var(--text-3);margin-left:7px;opacity:0;transition:.12s}
.kv.edit:hover .edit-ic{opacity:1}
.switch{width:40px;height:23px;border-radius:14px;background:var(--surface-3);position:relative;cursor:pointer;transition:.16s;flex-shrink:0}
.switch::after{content:'';position:absolute;top:3px;left:3px;width:17px;height:17px;border-radius:50%;background:#fff;transition:.16s;box-shadow:var(--shadow-sm)}
.switch.on{background:var(--green)} .switch.on::after{left:20px}
.tags-box{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.tags-box .tag{gap:5px}
.tag-x{cursor:pointer;font-size:14px;opacity:.6;line-height:1}
.tag-x:hover{opacity:1}
.tag-input{border:1px dashed var(--border-2);background:transparent;border-radius:6px;padding:4px 9px;font-size:11px;color:var(--text);width:70px;outline:none}
.tag-input:focus{border-color:var(--accent)}

/* ---- task items ---- */
.task-item{display:flex;align-items:flex-start;gap:11px;padding:11px;border:1px solid var(--border);border-radius:10px;margin-bottom:9px;background:var(--surface)}
.task-item.overdue{border-color:var(--red);background:var(--red-bg)}
.task-check{width:22px;height:22px;border:2px solid var(--border-2);border-radius:50%;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;transition:.14s;margin-top:1px}
.task-check:hover{border-color:var(--green)}
.task-check.done{background:var(--green);border-color:var(--green)}
.task-title{font-size:13.5px;font-weight:500}
.task-title.done{text-decoration:line-through;color:var(--text-3)}
.task-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:11.5px;color:var(--text-3);margin-top:5px}
.task-meta .i{font-size:14px}

/* ---- kurier stepper / address ---- */
.addr-line{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--text-2);margin-top:12px;
  padding:9px 11px;background:var(--surface-2);border-radius:9px;cursor:pointer;transition:.12s}
.addr-line:hover{background:var(--surface-3)}
.addr-line .i{color:var(--red);flex-shrink:0;margin-top:1px}
.addr-line .edit-ic{color:var(--text-3);margin-left:auto;opacity:0}
.addr-line:hover .edit-ic{opacity:1}
.stepper{display:flex;align-items:center;margin-top:16px;gap:0}
.step{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;position:relative;color:var(--text-3)}
.step:not(:last-child)::after{content:'';position:absolute;top:15px;left:50%;width:100%;height:2px;background:var(--border);z-index:0}
.step.active:not(:last-child)::after{background:var(--green)}
.step-dot{width:32px;height:32px;border-radius:50%;background:var(--surface-3);display:flex;align-items:center;justify-content:center;
  font-size:16px;z-index:1;border:2px solid var(--surface);transition:.16s}
.step.active .step-dot{background:var(--green);color:#fff}
.step.current .step-dot{background:var(--accent);color:#fff;box-shadow:0 0 0 4px var(--accent-ring)}
.step-lbl{font-size:11px;font-weight:500}
.step.active .step-lbl{color:var(--text)}
.step:hover .step-dot{transform:scale(1.08)}

/* ---- settings stage chips ---- */
.stage-chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--border);
  border-radius:0 8px 8px 0;padding:7px 12px;font-size:12.5px;font-weight:500}

/* ---- top global search ---- */
.top-search{position:relative;display:flex;align-items:center;margin-left:14px;max-width:300px;flex:1}
.top-search .i{position:absolute;left:11px;color:var(--text-3);font-size:17px}
.top-search input{width:100%;height:38px;padding:0 12px 0 36px;border:1px solid var(--border-2);border-radius:20px;
  background:var(--surface-2);color:var(--text);font-size:13px;transition:.14s}
.top-search input:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-ring)}
.top-search input::placeholder{color:var(--text-3)}

/* ---- user menu ---- */
.userbox{cursor:pointer;transition:.12s}
.userbox:hover{background:var(--sidebar-hover)}
.userbox .i{color:var(--sidebar-text);font-size:18px}
.user-menu{position:absolute;bottom:100%;left:12px;right:12px;margin-bottom:8px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;
  display:none;z-index:600}
.user-menu.open{display:block;animation:pop .15s}
.user-menu-item{display:flex;align-items:center;gap:10px;padding:11px 15px;font-size:13.5px;color:var(--text);cursor:pointer;transition:.12s}
.user-menu-item:hover{background:var(--surface-2)}
.user-menu-item .i{font-size:18px;color:var(--text-2)}
.user-menu-item.danger{color:var(--red);border-top:1px solid var(--border)}
.user-menu-item.danger .i{color:var(--red)}

/* ---- mobile sidebar ---- */
.menu-btn{display:none}
.sidebar-overlay{display:none}

/* ---- notifications page ---- */
.notif-row{display:flex;align-items:center;gap:14px;padding:15px 18px;border-bottom:1px solid var(--border);cursor:pointer;transition:.12s}
.notif-row:last-child{border-bottom:none}
.notif-row:hover{background:var(--surface-2)}
.notif-row.unread{background:var(--accent-soft)}
.notif-ic{width:40px;height:40px;border-radius:10px;background:var(--surface-3);display:flex;align-items:center;justify-content:center;
  font-size:19px;color:var(--accent);flex-shrink:0}
.notif-row .nt{font-size:14px}
.notif-row .nb{font-size:12.5px;color:var(--text-2);margin-top:3px}
.notif-row .nd{font-size:11.5px;color:var(--text-3);white-space:nowrap;flex-shrink:0}
.unread-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);flex-shrink:0}
.notif-foot{text-align:center;padding:12px;font-size:13px;font-weight:500;color:var(--accent);cursor:pointer;border-top:1px solid var(--border)}
.notif-foot:hover{background:var(--surface-2)}
.overdue-row{background:var(--red-bg)}

@media (max-width: 768px){
  .menu-btn{display:flex}
  .sidebar{position:fixed;left:0;top:0;bottom:0;z-index:1000;transform:translateX(-100%);transition:transform .22s ease}
  .sidebar.open{transform:none;box-shadow:var(--shadow-lg)}
  .sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:999;opacity:0;pointer-events:none;transition:.2s}
  .sidebar.open ~ .sidebar-overlay{opacity:1;pointer-events:auto}
  .top-search{max-width:none}
  .topbar h1{display:none}
  .two-col{grid-template-columns:1fr}
  .page{padding:16px}
}
/* ---- sort icons ---- */
.sort-ic{font-size:14px;opacity:.55;vertical-align:-2px}
th:hover .sort-ic{opacity:1}

/* ---- tag chips ---- */
.tag-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:20px;font-size:13px;font-weight:500}
.auto-ic{width:42px;height:42px;border-radius:11px;background:var(--amber-bg);color:var(--amber);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}

/* ---- calendar ---- */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-head{text-align:center;font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;padding:6px 0}
.cal-cell{min-height:92px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:6px;display:flex;flex-direction:column;gap:3px}
.cal-cell.other{opacity:.4}
.cal-cell.today{border-color:var(--accent);border-width:2px}
.cal-day{font-size:12px;font-weight:600;color:var(--text-2)}
.cal-task{font-size:10.5px;padding:2px 6px;border-radius:5px;background:var(--accent-soft);color:var(--accent);cursor:pointer;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-task.done{background:var(--green-bg);color:var(--green);text-decoration:line-through;opacity:.7}
.cal-task.overdue{background:var(--red-bg);color:var(--red)}

/* ---- score badge ---- */
.score-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:3px 9px;border-radius:20px;min-width:46px;justify-content:center}
.score-badge .i-sm{font-size:14px}

/* ---- contact modal ---- */
.contact-btn{display:flex;align-items:center;gap:13px;padding:13px 15px;border:1px solid var(--border);border-radius:var(--radius-lg);
  cursor:pointer;transition:.14s;color:var(--text)}
.contact-btn:hover{background:var(--surface-2);border-color:var(--border-2);transform:translateY(-1px)}
.contact-ic{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}

/* ---- merge options ---- */
.merge-opt{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:6px;cursor:pointer;font-size:13px}
.merge-opt:hover{background:var(--surface-2);border-color:var(--accent)}

/* ---- file rows ---- */
.file-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px}
.file-row:hover{background:var(--surface-2)}
.file-ic{width:38px;height:38px;border-radius:9px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}

/* ---- goals ---- */
.goal-bar{height:10px;background:var(--surface-3);border-radius:6px;overflow:hidden;margin-top:5px}
.goal-fill{height:100%;border-radius:6px;transition:width .3s}

/* ---- activity feed ---- */
.activity-feed{display:flex;flex-direction:column}
.act-row{display:flex;align-items:flex-start;gap:14px;padding:14px 18px;border-bottom:1px solid var(--border);cursor:pointer;transition:.12s}
.act-row:last-child{border-bottom:none}
.act-row:hover{background:var(--surface-2)}
.act-ic{width:38px;height:38px;border-radius:10px;background:var(--surface-3);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.act-main{font-size:13.5px;line-height:1.5}
.act-sub{font-size:12px;color:var(--text-3);margin-top:3px}
.act-date{font-size:11.5px;color:var(--text-3);white-space:nowrap;flex-shrink:0}

@media (max-width: 520px){
  .top-search{display:none}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .act-date{display:none}
}
