@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@300;400;500;600;700&display=swap');

/* ═══════════════════════════════════════════════════════════
   TALABALAR MUROJAATLARI PLATFORMASI — Design System v3.0
   Aesthetic: "Crystalline Command" 
   Obsidian Dark × Electric Cyan × Precision Grid
═══════════════════════════════════════════════════════════ */

:root {
  /* Core palette */
  --obsidian:     #06090f;
  --void:         #0a0e1a;
  --deep:         #0f1526;
  --surface:      #141d2e;
  --card:         #192236;
  --card-hover:   #1e2940;
  --panel:        #1c2840;
  --input-bg:     #111827;

  /* Accent */
  --cyan:         #00e5cc;
  --cyan-bright:  #00fff0;
  --cyan-dim:     rgba(0,229,204,.12);
  --cyan-glow:    rgba(0,229,204,.35);
  --cyan-soft:    rgba(0,229,204,.06);

  /* Secondary accents */
  --gold:         #f5c518;
  --gold-dim:     rgba(245,197,24,.14);
  --crimson:      #ff4757;
  --crimson-dim:  rgba(255,71,87,.14);
  --violet:       #9b72ff;
  --violet-dim:   rgba(155,114,255,.14);
  --sky:          #38b2f8;
  --sky-dim:      rgba(56,178,248,.14);
  --emerald:      #00d68f;
  --emerald-dim:  rgba(0,214,143,.14);

  /* Text */
  --t1: #edf2ff;
  --t2: #7a8fb5;
  --t3: #3d5080;
  --t4: #1e3060;

  /* Borders */
  --b1: #1e2d4a;
  --b2: #263654;
  --b3: #0e2040;
  --b-glow: rgba(0,229,204,.2);

  /* Layout */
  --sidebar: 252px;
  --hdr: 60px;
  --r: 10px;
  --r-lg: 16px;
  --r-sm: 6px;
  --r-xs: 4px;

  /* Shadows */
  --s-card: 0 2px 24px rgba(0,0,0,.5), 0 1px 0 var(--b1);
  --s-glow: 0 0 40px rgba(0,229,204,.15);
  --s-popup: 0 32px 64px rgba(0,0,0,.8), 0 0 0 1px var(--b2);
  --s-btn:   0 4px 20px rgba(0,229,204,.3);

  /* Easing */
  --ease: all .2s cubic-bezier(.4,0,.2,1);
  --ease-spring: all .35s cubic-bezier(.34,1.56,.64,1);

  /* Font */
  --font: 'Plus Jakarta Sans', sans-serif;
  --mono: 'JetBrains Mono', monospace;
}

/* ── Reset ─────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);background:var(--obsidian);color:var(--t1);min-height:100vh;overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
button{font-family:var(--font);cursor:pointer;border:none;outline:none}
input,select,textarea{font-family:var(--font);outline:none}

/* ── Scrollbar ──────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--void)}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--cyan)}
::selection{background:rgba(0,229,204,.2);color:var(--cyan-bright)}

/* ═══════════════ LAYOUT ═══════════════ */
.app{display:grid;grid-template-columns:var(--sidebar) 1fr;grid-template-rows:var(--hdr) 1fr;min-height:100vh}

/* ═══════════════ SIDEBAR ═══════════════ */
.sidebar{
  grid-row:1/-1;
  background:var(--void);
  border-right:1px solid var(--b1);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
  overflow-y:auto;z-index:200;
}
.sidebar::after{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 30% at 50% 0%,rgba(0,229,204,.04) 0%,transparent 70%);
}

/* Logo */
.s-logo{padding:18px 16px 14px;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:11px}
.s-logo-icon{
  width:38px;height:38px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,var(--cyan),#007a6a);
  display:flex;align-items:center;justify-content:center;font-size:17px;
  box-shadow:0 4px 16px var(--cyan-glow);
}
.s-logo-name{font-size:12.5px;font-weight:800;line-height:1.25;color:var(--t1)}
.s-logo-ver{font-size:9px;color:var(--t3);font-family:var(--mono);margin-top:2px;letter-spacing:.5px}

/* Nav */
.s-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:1px}
.s-section{font-size:8.5px;font-weight:700;letter-spacing:1.8px;color:var(--t4);text-transform:uppercase;font-family:var(--mono);padding:14px 8px 5px}
.nav-a{
  display:flex;align-items:center;gap:10px;padding:9px 10px;
  border-radius:var(--r-sm);color:var(--t2);font-size:13px;font-weight:500;
  transition:var(--ease);position:relative;overflow:hidden;
}
.nav-a .ni{font-size:15px;width:18px;text-align:center;flex-shrink:0;transition:var(--ease)}
.nav-a .nb{
  margin-left:auto;background:var(--cyan-dim);color:var(--cyan);
  font-size:9.5px;font-weight:700;font-family:var(--mono);
  padding:1px 6px;border-radius:12px;border:1px solid var(--b-glow);
}
.nav-a:hover{background:var(--card);color:var(--t1)}
.nav-a.active{
  background:linear-gradient(90deg,var(--cyan-dim),transparent);
  color:var(--cyan-bright);border-left:2px solid var(--cyan);
}
.nav-a.active .ni{filter:drop-shadow(0 0 5px var(--cyan))}

/* Footer user */
.s-foot{padding:12px 10px;border-top:1px solid var(--b1)}
.s-user{
  display:flex;align-items:center;gap:9px;padding:9px 10px;
  border-radius:var(--r-sm);background:var(--card);border:1px solid var(--b1);
  cursor:pointer;transition:var(--ease);
}
.s-user:hover{border-color:var(--b2)}
.s-av{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;color:var(--obsidian);
}
.s-uname{font-size:12px;font-weight:700;color:var(--t1);line-height:1.2}
.s-urole{font-size:9.5px;color:var(--cyan);font-family:var(--mono)}
.s-user-cog{margin-left:auto;color:var(--t3);font-size:13px}

/* ═══════════════ HEADER ═══════════════ */
.hdr{
  background:var(--void);border-bottom:1px solid var(--b1);
  display:flex;align-items:center;padding:0 22px;gap:14px;
  position:sticky;top:0;z-index:100;
  backdrop-filter:blur(10px);
}
.hdr-left{flex:1}
.hdr-title{font-size:15px;font-weight:800;color:var(--t1)}
.hdr-sub{font-size:10px;color:var(--t3);font-family:var(--mono);margin-top:1px}

.hdr-search{
  display:flex;align-items:center;gap:8px;
  background:var(--input-bg);border:1px solid var(--b1);
  border-radius:var(--r-sm);padding:0 11px;width:220px;
  transition:var(--ease);
}
.hdr-search:focus-within{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-dim)}
.hdr-search input{background:none;border:none;color:var(--t1);font-size:12.5px;padding:7px 0;width:100%}
.hdr-search input::placeholder{color:var(--t3)}

.hdr-acts{display:flex;align-items:center;gap:7px}
.hbtn{
  width:34px;height:34px;border-radius:var(--r-sm);border:1px solid var(--b1);
  background:var(--card);color:var(--t2);font-size:15px;
  display:flex;align-items:center;justify-content:center;
  transition:var(--ease);position:relative;
}
.hbtn:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-dim)}
.hbtn .dot{
  position:absolute;top:5px;right:5px;width:6px;height:6px;
  background:var(--crimson);border-radius:50%;border:1px solid var(--void);
  animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}

/* ═══════════════ MAIN ═══════════════ */
.main{padding:22px;overflow-y:auto;max-height:calc(100vh - var(--hdr))}

/* ═══════════════ GRIDS ═══════════════ */
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.g-7-5{display:grid;grid-template-columns:1.4fr 1fr;gap:14px}
.g-6-4{display:grid;grid-template-columns:3fr 2fr;gap:14px}

/* ═══════════════ CARDS ═══════════════ */
.card{
  background:var(--card);border:1px solid var(--b1);
  border-radius:var(--r-lg);padding:18px;
  position:relative;overflow:hidden;
  transition:var(--ease);animation:up .4s ease both;
}
.card:hover{border-color:var(--b2);box-shadow:var(--s-card)}
@keyframes up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title{
  font-size:10.5px;font-weight:700;letter-spacing:.9px;
  color:var(--t3);text-transform:uppercase;font-family:var(--mono);
  display:flex;align-items:center;gap:6px;
}
.card-acts{display:flex;gap:5px}

/* ═══════════════ STAT CARDS ═══════════════ */
.scard{
  background:var(--card);border:1px solid var(--b1);border-radius:var(--r-lg);
  padding:20px;position:relative;overflow:hidden;
  transition:var(--ease);animation:up .4s ease both;cursor:default;
}
.scard::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--ac,var(--cyan)),transparent)}
.scard::after{content:'';position:absolute;top:-50px;right:-50px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,var(--ac-a,var(--cyan-dim)) 0%,transparent 70%)}
.scard:hover{border-color:var(--ac,var(--cyan));box-shadow:0 0 30px var(--ac-a,var(--cyan-dim));transform:translateY(-2px)}
.scard.c{--ac:var(--cyan);--ac-a:var(--cyan-glow)}
.scard.g{--ac:var(--gold);--ac-a:rgba(245,197,24,.35)}
.scard.r{--ac:var(--crimson);--ac-a:rgba(255,71,87,.35)}
.scard.v{--ac:var(--violet);--ac-a:rgba(155,114,255,.35)}
.scard.e{--ac:var(--emerald);--ac-a:rgba(0,214,143,.35)}

.sc-icon{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px;position:relative;z-index:1;border:1px solid var(--ac,var(--cyan));background:var(--ac-a,var(--cyan-dim))}
.sc-label{font-size:10px;font-weight:700;letter-spacing:.9px;color:var(--t3);text-transform:uppercase;font-family:var(--mono);margin-bottom:5px;position:relative;z-index:1}
.sc-val{font-size:32px;font-weight:800;color:var(--t1);font-family:var(--mono);line-height:1;margin-bottom:8px;position:relative;z-index:1}
.sc-trend{display:flex;align-items:center;gap:5px;font-size:11px;font-family:var(--mono);position:relative;z-index:1}
.up-c{color:var(--emerald)}.dn-c{color:var(--crimson)}

/* ═══════════════ TABLE ═══════════════ */
.tbl-wrap{overflow-x:auto;border-radius:var(--r)}
table{width:100%;border-collapse:collapse;font-size:12.5px}
thead th{
  background:var(--surface);color:var(--t3);
  font-size:9.5px;font-weight:700;letter-spacing:1.1px;text-transform:uppercase;
  font-family:var(--mono);padding:9px 13px;text-align:left;
  border-bottom:1px solid var(--b1);white-space:nowrap;
}
tbody tr{border-bottom:1px solid var(--b3);transition:var(--ease)}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--card-hover)}
tbody td{padding:11px 13px;color:var(--t1);vertical-align:middle}

/* ═══════════════ BADGES ═══════════════ */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:20px;
  font-size:10.5px;font-weight:700;font-family:var(--mono);white-space:nowrap;
}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}

.b-new{background:rgba(0,229,204,.1);color:var(--cyan);border:1px solid rgba(0,229,204,.3)}
.b-new::before{background:var(--cyan);box-shadow:0 0 4px var(--cyan);animation:blink 1.4s infinite}
.b-prog{background:rgba(245,197,24,.1);color:var(--gold);border:1px solid rgba(245,197,24,.3)}
.b-prog::before{background:var(--gold)}
.b-res{background:rgba(0,214,143,.1);color:var(--emerald);border:1px solid rgba(0,214,143,.3)}
.b-res::before{background:var(--emerald)}
.b-rej{background:rgba(255,71,87,.1);color:var(--crimson);border:1px solid rgba(255,71,87,.3)}
.b-rej::before{background:var(--crimson)}
.b-cl{background:rgba(122,143,181,.1);color:var(--t2);border:1px solid rgba(122,143,181,.2)}
.b-cl::before{background:var(--t2)}

.b-ac{background:var(--violet-dim);color:var(--violet);border:1px solid rgba(155,114,255,.3)}
.b-ad{background:var(--sky-dim);color:var(--sky);border:1px solid rgba(56,178,248,.3)}
.b-fi{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(245,197,24,.3)}
.b-te{background:var(--crimson-dim);color:var(--crimson);border:1px solid rgba(255,71,87,.3)}
.b-ot{background:var(--cyan-dim);color:var(--cyan);border:1px solid var(--b-glow)}

/* ═══════════════ BUTTONS ═══════════════ */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 16px;border-radius:var(--r-sm);
  font-size:12.5px;font-weight:700;font-family:var(--font);
  cursor:pointer;transition:var(--ease);border:none;white-space:nowrap;
}
.btn-p{background:linear-gradient(135deg,var(--cyan),#009e8e);color:var(--obsidian);box-shadow:var(--s-btn)}
.btn-p:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 28px var(--cyan-glow)}
.btn-s{background:var(--panel);color:var(--t1);border:1px solid var(--b2)}
.btn-s:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-g{background:transparent;color:var(--t2);border:1px solid var(--b1)}
.btn-g:hover{border-color:var(--b2);color:var(--t1)}
.btn-d{background:var(--crimson-dim);color:var(--crimson);border:1px solid rgba(255,71,87,.3)}
.btn-d:hover{background:var(--crimson);color:#fff}
.btn-sm{padding:5px 11px;font-size:11.5px}
.btn-lg{padding:11px 22px;font-size:13.5px}
.btn-icon{padding:7px}

/* ═══════════════ FORM ═══════════════ */
.fg{display:flex;flex-direction:column;gap:5px}
.flabel{font-size:10px;font-weight:700;letter-spacing:.8px;color:var(--t3);text-transform:uppercase;font-family:var(--mono)}
.fctl{
  background:var(--input-bg);border:1px solid var(--b1);
  border-radius:var(--r-sm);padding:8px 11px;
  color:var(--t1);font-size:13px;font-family:var(--font);
  transition:var(--ease);width:100%;
}
.fctl:focus{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-dim)}
.fctl::placeholder{color:var(--t4)}
select.fctl{cursor:pointer}
option{background:var(--surface)}
textarea.fctl{resize:vertical;min-height:90px}

/* ═══════════════ MODAL ═══════════════ */
.overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.75);
  backdrop-filter:blur(8px);z-index:500;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s ease;
}
.overlay.open{opacity:1;pointer-events:all}
.modal{
  background:var(--card);border:1px solid var(--b2);border-radius:var(--r-lg);
  padding:26px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;
  box-shadow:var(--s-popup);
  transform:scale(.93) translateY(20px);
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
}
.overlay.open .modal{transform:scale(1) translateY(0)}
.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
.modal-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--b1)}
.modal-title{font-size:16px;font-weight:800;color:var(--t1)}
.modal-x{width:28px;height:28px;border-radius:5px;background:var(--surface);border:1px solid var(--b1);color:var(--t3);font-size:17px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--ease)}
.modal-x:hover{color:var(--crimson);border-color:var(--crimson)}
.modal-b{display:flex;flex-direction:column;gap:13px}
.modal-f{margin-top:20px;padding-top:14px;border-top:1px solid var(--b1);display:flex;justify-content:flex-end;gap:9px}

/* ═══════════════ PROGRESS ═══════════════ */
.prog-wrap{width:100%}
.prog-label{display:flex;justify-content:space-between;font-size:10.5px;font-family:var(--mono);color:var(--t2);margin-bottom:5px}
.prog-bar{height:4px;background:var(--card-hover);border-radius:2px;overflow:hidden}
.prog-fill{height:100%;border-radius:2px;transition:width .9s cubic-bezier(.4,0,.2,1)}

/* ═══════════════ FILTER BAR ═══════════════ */
.fbar{
  display:flex;align-items:center;gap:9px;
  padding:12px;background:var(--card);border:1px solid var(--b1);
  border-radius:var(--r);margin-bottom:14px;flex-wrap:wrap;
}
.fsearch{
  flex:1;min-width:200px;display:flex;align-items:center;gap:8px;
  background:var(--input-bg);border:1px solid var(--b1);
  border-radius:var(--r-sm);padding:0 11px;
}
.fsearch:focus-within{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-dim)}
.fsearch input{background:none;border:none;color:var(--t1);font-size:12.5px;padding:7px 0;flex:1;font-family:var(--font)}
.fsearch input::placeholder{color:var(--t4)}

/* ═══════════════ PAGE HEADER ═══════════════ */
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px}
.ph-title{font-size:21px;font-weight:800;color:var(--t1);letter-spacing:-.3px}
.ph-sub{font-size:11px;color:var(--t3);font-family:var(--mono);margin-top:3px}
.ph-acts{display:flex;gap:8px;flex-shrink:0}

/* ═══════════════ TABS ═══════════════ */
.tab-bar{display:flex;border-bottom:1px solid var(--b1);margin-bottom:18px;gap:0}
.tab-btn{
  padding:9px 16px;font-size:12.5px;font-weight:700;color:var(--t3);
  background:none;border:none;border-bottom:2px solid transparent;
  margin-bottom:-1px;cursor:pointer;transition:var(--ease);font-family:var(--font);
}
.tab-btn:hover{color:var(--t1)}
.tab-btn.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.tab-pane{display:none}
.tab-pane.active{display:block}

/* ═══════════════ TOAST ═══════════════ */
.toasts{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:7px}
.toast{
  background:var(--panel);border:1px solid var(--b2);border-radius:var(--r);
  padding:11px 15px;display:flex;align-items:center;gap:9px;
  min-width:270px;max-width:340px;box-shadow:var(--s-popup);
  font-size:12.5px;animation:slideR .3s cubic-bezier(.34,1.56,.64,1);
}
.toast.s{border-left:3px solid var(--cyan)}
.toast.e{border-left:3px solid var(--crimson)}
.toast.w{border-left:3px solid var(--gold)}
.toast.i{border-left:3px solid var(--sky)}
@keyframes slideR{from{opacity:0;transform:translateX(110%)}to{opacity:1;transform:translateX(0)}}

/* ═══════════════ TIMELINE ═══════════════ */
.timeline{display:flex;flex-direction:column}
.tl-item{display:flex;gap:12px;padding-bottom:16px;position:relative}
.tl-item:not(:last-child)::before{content:'';position:absolute;left:13px;top:28px;bottom:0;width:1px;background:linear-gradient(180deg,var(--b2),transparent)}
.tl-dot{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--b2);background:var(--panel);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;z-index:1}
.tl-body{flex:1;padding-top:3px}
.tl-act{font-size:12.5px;font-weight:700;color:var(--t1)}
.tl-time{font-size:10px;color:var(--t3);font-family:var(--mono);margin-top:1px}
.tl-detail{font-size:11.5px;color:var(--t2);margin-top:3px}

/* ═══════════════ CHART ═══════════════ */
.chart-box{position:relative;width:100%}

/* ═══════════════ ANIMATIONS ═══════════════ */
.card:nth-child(1){animation-delay:.05s}
.card:nth-child(2){animation-delay:.1s}
.card:nth-child(3){animation-delay:.15s}
.scard:nth-child(1){animation-delay:.05s}
.scard:nth-child(2){animation-delay:.1s}
.scard:nth-child(3){animation-delay:.15s}
.scard:nth-child(4){animation-delay:.2s}

/* ═══════════════ MISC ═══════════════ */
.id-tag{font-family:var(--mono);font-size:10px;color:var(--cyan);background:var(--cyan-dim);padding:2px 7px;border-radius:var(--r-xs);border:1px solid var(--b-glow)}
.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}
.av-sm{width:26px;height:26px;font-size:10px}
.av-md{width:34px;height:34px;font-size:13px}
.av-lg{width:46px;height:46px;font-size:17px}

.prio-row{display:flex;align-items:center;gap:7px}
.prio-pips{display:flex;gap:3px}
.prio-pips i{display:block;width:7px;height:7px;border-radius:50%;background:var(--b2)}
.p1 .prio-pips i:nth-child(1){background:var(--sky)}
.p2 .prio-pips i:nth-child(-n+2){background:var(--gold)}
.p3 .prio-pips i{background:var(--crimson);box-shadow:0 0 4px var(--crimson)}

.dept-strip{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--b3)}
.dept-strip:last-child{border:none}
.dept-pip{width:3px;height:32px;border-radius:2px;flex-shrink:0}

.chk-wrap{display:flex;align-items:center;gap:7px;cursor:pointer;user-select:none}
.chk-wrap input{display:none}
.chk-box{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--b2);background:var(--input-bg);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--obsidian);transition:var(--ease)}
.chk-wrap input:checked+.chk-box{background:var(--cyan);border-color:var(--cyan)}

.empty-s{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:44px 20px;gap:9px;text-align:center}
.empty-s .ei{font-size:36px;opacity:.35}
.empty-s .et{font-size:14px;font-weight:700;color:var(--t2)}
.empty-s .es{font-size:11.5px;color:var(--t4)}

/* skeleton */
.skel{background:linear-gradient(90deg,var(--card) 25%,var(--card-hover) 50%,var(--card) 75%);background-size:400% 100%;animation:shim 1.3s ease infinite;border-radius:var(--r-sm)}
@keyframes shim{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* bg effects */
.bg-grid{position:fixed;inset:0;z-index:-2;pointer-events:none;background-image:linear-gradient(var(--b3) 1px,transparent 1px),linear-gradient(90deg,var(--b3) 1px,transparent 1px);background-size:36px 36px;opacity:.5}
.bg-spot-1{position:fixed;top:-300px;left:-300px;width:700px;height:700px;z-index:-1;pointer-events:none;background:radial-gradient(circle,rgba(0,229,204,.04) 0%,transparent 60%)}
.bg-spot-2{position:fixed;bottom:-300px;right:-300px;width:600px;height:600px;z-index:-1;pointer-events:none;background:radial-gradient(circle,rgba(155,114,255,.04) 0%,transparent 60%)}

/* pager */
.pager{display:flex;align-items:center;gap:5px;justify-content:center;padding:14px 0}
.pg-btn{width:30px;height:30px;border-radius:5px;border:1px solid var(--b1);background:var(--card);color:var(--t2);cursor:pointer;font-size:12px;font-family:var(--mono);transition:var(--ease)}
.pg-btn.on{background:var(--cyan);color:var(--obsidian);border-color:var(--cyan);font-weight:800}
.pg-btn:hover:not(.on){border-color:var(--b2);color:var(--t1)}
.pg-btn:disabled{opacity:.35;pointer-events:none}

/* bulk bar */
.bulk{display:none;align-items:center;gap:9px;padding:9px 12px;background:var(--cyan-dim);border:1px solid var(--b-glow);border-radius:var(--r);margin-bottom:11px}
.bulk.on{display:flex;animation:up .25s ease}

/* sort */
.sh{cursor:pointer;user-select:none}
.sh:hover{color:var(--t1)}
.sh.asc::after{content:' ↑';color:var(--cyan)}
.sh.desc::after{content:' ↓';color:var(--cyan)}

/* kanban */
.kb-wrap{display:flex;gap:11px;overflow-x:auto;padding-bottom:6px}
.kb-col{flex:0 0 220px;background:var(--panel);border:1px solid var(--b1);border-radius:var(--r-lg);padding:11px}
.kb-col-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px;padding-bottom:7px;border-bottom:1px solid var(--b1);font-size:11.5px;font-weight:800}
.kb-card{background:var(--card);border:1px solid var(--b1);border-radius:var(--r-sm);padding:10px;margin-bottom:7px;cursor:pointer;transition:var(--ease)}
.kb-card:hover{border-color:var(--b2);transform:translateY(-1px);box-shadow:var(--s-card)}

/* page footer */
.pfoot{margin-top:28px;padding-top:14px;border-top:1px solid var(--b1);display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--t4);font-family:var(--mono)}

/* responsive */
@media(max-width:1200px){.g4{grid-template-columns:repeat(2,1fr)}.g-7-5,.g-6-4{grid-template-columns:1fr}}
@media(max-width:860px){:root{--sidebar:0px}.app{grid-template-columns:1fr}.sidebar{display:none}.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.g4,.g3,.g2{grid-template-columns:1fr}.main{padding:12px}.hdr-search{display:none}}
