
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
--w:#f4f5f9;--w2:#eceef5;--w3:#e4e7f0;--w4:#d8dce9;--w5:#ccd2e3;
--t1:#0a0d1a;--t2:#2d3556;--t3:#6b7494;--t4:#a8b0cc;
--a1:#2563eb;--a2:#7c3aed;--a3:#0ea5e9;--a4:#10b981;--a5:#f59e0b;--a6:#ef4444;
--g1:linear-gradient(135deg,#2563eb,#7c3aed);
--g2:linear-gradient(135deg,#0ea5e9,#2563eb);
--g3:linear-gradient(135deg,#10b981,#0ea5e9);
--glow1:rgba(37,99,235,.14);--glow2:rgba(124,58,237,.11);
--danger:#ef4444;--dbg:rgba(239,68,68,.07);--dborder:rgba(239,68,68,.2);
--success:#10b981;--sbg:rgba(16,185,129,.07);--sborder:rgba(16,185,129,.2);
--warn:#f59e0b;--wbg:rgba(245,158,11,.07);
--border:#e2e7f2;--border2:#cdd4e8;
--sh1:0 1px 3px rgba(0,0,0,.05),0 4px 14px rgba(0,0,0,.05);
--sh2:0 4px 24px rgba(0,0,0,.09),0 1px 3px rgba(0,0,0,.05);
--sh3:0 20px 60px rgba(0,0,0,.13),0 4px 16px rgba(0,0,0,.07);
--r:14px;--rs:9px;--rss:6px;
--font:'Inter',system-ui,sans-serif;--mono:'JetBrains Mono',monospace;
--sb-w:252px;
}
html{font-size:15px;scroll-behavior:smooth}
body{background:var(--w2);color:var(--t1);font-family:var(--font);min-height:100vh;-webkit-font-smoothing:antialiased}

@keyframes rgbBorder{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes rgbGlow{0%,100%{box-shadow:0 0 12px rgba(37,99,235,.4)}33%{box-shadow:0 0 18px rgba(124,58,237,.5)}66%{box-shadow:0 0 18px rgba(14,165,233,.5)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes popIn{from{opacity:0;transform:scale(.93)}to{opacity:1;transform:none}}
@keyframes slideIn{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes dotPing{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.9);opacity:.4}}
@keyframes cardRise{from{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:none}}
@keyframes iconPulse{0%,100%{box-shadow:0 8px 32px var(--glow1)}50%{box-shadow:0 8px 52px rgba(37,99,235,.3)}}
@keyframes shake{0%,100%{transform:none}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
@keyframes sbIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}
@keyframes tick{from{opacity:.7}to{opacity:1}}
@keyframes orbA{0%,100%{transform:translate(0,0)}50%{transform:translate(-50px,40px)}}
@keyframes orbB{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-50px)}}
@keyframes rgbPulse{0%{border-color:rgba(37,99,235,.5)}33%{border-color:rgba(124,58,237,.5)}66%{border-color:rgba(14,165,233,.5)}100%{border-color:rgba(37,99,235,.5)}}

/* LOGIN */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#eef2ff 0%,#fafbff 50%,#f5f0ff 100%);position:relative;overflow:hidden}
.login-page::before,.login-page::after{content:'';position:absolute;border-radius:50%;pointer-events:none}
.login-page::before{width:700px;height:700px;background:radial-gradient(circle,rgba(37,99,235,.06),transparent 70%);top:-250px;right:-200px;animation:orbA 22s ease-in-out infinite}
.login-page::after{width:600px;height:600px;background:radial-gradient(circle,rgba(124,58,237,.05),transparent 70%);bottom:-180px;left:-180px;animation:orbB 28s ease-in-out infinite}
.lcard{background:var(--w);border:1.5px solid var(--border);border-radius:22px;padding:52px 48px;width:100%;max-width:440px;box-shadow:var(--sh3);position:relative;z-index:1;animation:cardRise .6s cubic-bezier(.22,1,.36,1)}
.lcard::before{content:'';position:absolute;inset:-1px;border-radius:22px;border:1.5px solid transparent;background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(124,58,237,.1),rgba(14,165,233,.1)) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;animation:rgbPulse 4s infinite;pointer-events:none}
.llogo{text-align:center;margin-bottom:40px}
.licon{width:74px;height:74px;background:var(--g1);border-radius:20px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:18px;animation:iconPulse 3s ease-in-out infinite;overflow:hidden}
.licon img{width:100%;height:100%;object-fit:cover;border-radius:20px}
.llogo h1{font-size:1.5rem;font-weight:900;color:var(--t1);letter-spacing:-.6px;margin-bottom:5px}
.llogo p{font-size:.75rem;color:var(--t4);font-weight:700;letter-spacing:.6px;text-transform:uppercase}
.fg{margin-bottom:18px}
.fg label{display:block;font-size:.68rem;font-weight:800;color:var(--t3);text-transform:uppercase;letter-spacing:.9px;margin-bottom:7px}
.pw-wrap{position:relative}
.finp{width:100%;background:var(--w2);border:1.5px solid var(--border);border-radius:var(--rs);padding:12px 15px;color:var(--t1);font-family:var(--font);font-size:.93rem;font-weight:500;outline:none;transition:all .2s}
.pw-wrap .finp{padding-right:44px}
.finp:focus{border-color:var(--a1);background:var(--w);box-shadow:0 0 0 3px var(--glow1)}
.finp::placeholder{color:var(--t4);font-weight:400}
.eye-btn{position:absolute;right:13px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--t4);display:flex;align-items:center;transition:color .2s}
.eye-btn:hover{color:var(--a1)}
.lerr{background:var(--dbg);border:1.5px solid var(--dborder);color:var(--danger);border-radius:var(--rss);padding:12px 15px;font-size:.82rem;font-weight:700;margin-bottom:18px;display:flex;align-items:center;gap:8px;animation:shake .4s ease}
.lbtn{width:100%;padding:13px;background:var(--g1);border:none;border-radius:var(--rs);color:#fff;font-family:var(--font);font-size:.97rem;font-weight:800;cursor:pointer;transition:all .2s;box-shadow:0 4px 24px var(--glow1);margin-top:6px}
.lbtn:hover{transform:translateY(-2px);box-shadow:0 8px 36px rgba(37,99,235,.28)}
.lbtn:active{transform:none}
.lmeta{text-align:center;margin-top:20px;font-size:.72rem;color:var(--t4);font-weight:600}

/* APP */
#app{display:flex;flex-direction:column;height:100vh;overflow:hidden}

/* TOPBAR */
.topbar{height:62px;background:var(--w);border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 22px;flex-shrink:0;box-shadow:var(--sh1);position:relative;z-index:50}
.topbar::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:linear-gradient(90deg,#2563eb,#7c3aed,#0ea5e9,#10b981,#f59e0b,#2563eb);background-size:400% 100%;animation:rgbBorder 5s linear infinite}
.tl{display:flex;align-items:center;gap:14px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer}
.logo-icon{width:38px;height:38px;background:var(--g1);border-radius:11px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px var(--glow1);overflow:hidden;flex-shrink:0}
.logo-icon img{width:100%;height:100%;object-fit:cover;border-radius:11px}
.logo-text{font-size:.92rem;font-weight:900;color:var(--t1);letter-spacing:-.3px;line-height:1.25}
.logo-text span{display:block;font-size:.6rem;font-weight:600;color:var(--t4);letter-spacing:.4px;text-transform:uppercase}
.tabs{display:flex;gap:2px;background:var(--w3);border:1.5px solid var(--border);border-radius:11px;padding:3px}
.tab{padding:7px 15px;border-radius:8px;font-size:.85rem;font-weight:700;color:var(--t3);cursor:pointer;transition:all .2s;border:none;background:none;font-family:var(--font);display:flex;align-items:center;gap:5px;white-space:nowrap}
.tab.active{background:var(--w);color:var(--a1);box-shadow:var(--sh1);border:1px solid var(--border)}
.tab:hover:not(.active){color:var(--t2);background:rgba(255,255,255,.6)}
.tr{display:flex;align-items:center;gap:10px}
.est-clock{font-family:var(--mono);font-size:.73rem;font-weight:700;color:var(--t3);background:var(--w3);border:1.5px solid var(--border);border-radius:7px;padding:5px 10px;animation:tick .5s ease infinite alternate;white-space:nowrap}
.dual-clock{display:flex;align-items:center;gap:6px;background:var(--w3);border:1.5px solid var(--border);border-radius:9px;padding:5px 12px;animation:tick .5s ease infinite alternate;white-space:nowrap}
.dc-zone{display:flex;flex-direction:column;align-items:center;gap:1px}
.dc-lbl{font-size:.55rem;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--t4);line-height:1}
.dc-time{font-family:var(--mono);font-size:.8rem;font-weight:700;color:var(--t2);line-height:1}
.dc-time.est{color:var(--a1)}
.dc-time.pkt{color:#10b981}
.dc-sep{color:var(--border2);font-size:.9rem;padding:0 2px}
.role-badge{font-size:.66rem;font-weight:800;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.rb-super{background:linear-gradient(135deg,rgba(37,99,235,.1),rgba(124,58,237,.1));color:var(--a1);border:1.5px solid rgba(37,99,235,.2)}
.rb-admin{background:var(--sbg);color:var(--success);border:1.5px solid var(--sborder)}
.user-chip{display:flex;align-items:center;gap:7px;font-size:.8rem;font-weight:700;color:var(--t2)}
.user-av{width:30px;height:30px;background:var(--g1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.72rem;font-weight:900;overflow:hidden;flex-shrink:0}
.user-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.btn-out{background:var(--dbg);border:1.5px solid var(--dborder);color:var(--danger);border-radius:var(--rss);padding:5px 12px;font-size:.73rem;font-weight:800;cursor:pointer;font-family:var(--font);transition:all .18s}
.btn-out:hover{background:rgba(239,68,68,.13)}

/* ── DATE FILTER BAR ── */
.df-bar{background:var(--w);border:1.5px solid var(--border);border-radius:var(--r);padding:12px 16px;margin-bottom:10px;box-shadow:var(--sh1)}
.df-presets{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.df-btn{padding:5px 13px;border-radius:20px;border:1.5px solid var(--border);background:var(--w3);color:var(--t3);font-size:.75rem;font-weight:700;cursor:pointer;font-family:var(--font);transition:all .18s;white-space:nowrap}
.df-btn:hover{border-color:var(--a1);color:var(--a1)}
.df-btn.active{background:var(--a1);color:#fff;border-color:var(--a1);box-shadow:0 0 0 3px rgba(37,99,235,.18);position:relative;overflow:hidden}
.df-btn.active::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.18) 50%,transparent 100%);background-size:200% 100%;animation:shimmerSlide 1.4s ease infinite}
@keyframes shimmerSlide{0%{background-position:200% 0}100%{background-position:-200% 0}}
.df-row2{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.df-col-sel{padding:6px 10px;border:1.5px solid var(--border);border-radius:var(--rss);background:var(--w);color:var(--t2);font-size:.78rem;font-family:var(--font);cursor:pointer}
.df-date-in{padding:6px 10px;border:1.5px solid var(--border);border-radius:var(--rss);background:var(--w);color:var(--t2);font-size:.78rem;font-family:var(--font)}
.df-sep{color:var(--t4);font-weight:700;font-size:.8rem}
/* export dropdown */
.exp-wrap{position:relative;display:inline-flex}
.exp-dd{position:absolute;top:calc(100% + 5px);right:0;background:var(--w);border:1.5px solid var(--border);border-radius:12px;box-shadow:var(--sh3);min-width:180px;z-index:200;padding:6px;animation:popIn .15s ease}
.exp-opt{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:.8rem;font-weight:700;color:var(--t2);transition:background .13s}
.exp-opt:hover{background:var(--w3);color:var(--a1)}
.exp-opt .exp-badge{font-size:.62rem;font-weight:800;padding:1px 6px;border-radius:4px;border:1.5px solid;margin-left:auto}
/* col filter dropdowns */
.cf-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:10px 16px;background:var(--w3);border:1px solid var(--border);border-radius:var(--rss);margin-bottom:8px}
.cf-lbl{font-size:.67rem;font-weight:800;color:var(--t4);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap}
.layout{display:flex;flex:1;overflow:hidden}
.sidebar{width:var(--sb-w);min-width:var(--sb-w);background:linear-gradient(180deg,#0d1424 0%,#0b1020 100%);display:flex;flex-direction:column;overflow:hidden;position:relative;transition:width .28s cubic-bezier(.4,0,.2,1),min-width .28s cubic-bezier(.4,0,.2,1)}
.sidebar.collapsed{width:0;min-width:0}
.sidebar::after{content:'';position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,rgba(37,99,235,.6),rgba(124,58,237,.5),rgba(14,165,233,.4),rgba(16,185,129,.3));animation:rgbBorder 6s linear infinite}
.sb-toggle{position:fixed;top:50%;left:var(--sb-w);transform:translateY(-50%);z-index:200;background:#0d1424;border:1.5px solid rgba(255,255,255,.12);border-left:none;color:rgba(255,255,255,.5);cursor:pointer;padding:8px 5px;border-radius:0 8px 8px 0;font-size:.75rem;line-height:1;transition:left .28s cubic-bezier(.4,0,.2,1),background .18s;display:flex;align-items:center}
.sb-toggle:hover{color:#fff;background:#1a2540}
.sidebar.collapsed~.sb-toggle{left:0;border-left:1.5px solid rgba(255,255,255,.12);border-right:none;border-radius:8px 0 0 8px}
/* DB color palette for sidebar items */
.sbi[data-color="0"]{--db-clr:#2563eb;--db-clr-a:rgba(37,99,235,.18);--db-clr-b:rgba(37,99,235,.45)}
.sbi[data-color="1"]{--db-clr:#7c3aed;--db-clr-a:rgba(124,58,237,.18);--db-clr-b:rgba(124,58,237,.45)}
.sbi[data-color="2"]{--db-clr:#0ea5e9;--db-clr-a:rgba(14,165,233,.18);--db-clr-b:rgba(14,165,233,.45)}
.sbi[data-color="3"]{--db-clr:#10b981;--db-clr-a:rgba(16,185,129,.18);--db-clr-b:rgba(16,185,129,.45)}
.sbi[data-color="4"]{--db-clr:#f59e0b;--db-clr-a:rgba(245,158,11,.18);--db-clr-b:rgba(245,158,11,.45)}
.sbi[data-color="5"]{--db-clr:#ef4444;--db-clr-a:rgba(239,68,68,.18);--db-clr-b:rgba(239,68,68,.45)}
.sbi[data-color="6"]{--db-clr:#ec4899;--db-clr-a:rgba(236,72,153,.18);--db-clr-b:rgba(236,72,153,.45)}
.sbi[data-color="7"]{--db-clr:#14b8a6;--db-clr-a:rgba(20,184,166,.18);--db-clr-b:rgba(20,184,166,.45)}
.sbi[data-color].active{background:var(--db-clr-a)!important;border-color:var(--db-clr-b)!important}
.sbi[data-color].active .sbi-indicator{background:var(--db-clr)!important}
.sbi[data-color] .sbi-tag.on{background:rgba(0,0,0,.25);color:var(--db-clr,#10b981);border-color:var(--db-clr,#10b981)}
.sb-head{padding:16px 14px 12px;border-bottom:1px solid rgba(255,255,255,.05)}
.sb-brand{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.sb-brand-icon{width:30px;height:30px;border-radius:8px;overflow:hidden;background:var(--g1);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 16px var(--glow1)}
.sb-brand-icon img{width:100%;height:100%;object-fit:cover}
.sb-brand-text{font-size:.76rem;font-weight:800;color:rgba(255,255,255,.88);letter-spacing:-.2px;line-height:1.3}
.sb-brand-sub{font-size:.58rem;font-weight:600;color:rgba(255,255,255,.35);letter-spacing:.5px;text-transform:uppercase}
.sb-search{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:7px 10px}
.sb-search svg{color:rgba(255,255,255,.3);flex-shrink:0}
.sb-search input{background:none;border:none;outline:none;font-family:var(--font);font-size:.78rem;color:rgba(255,255,255,.8);flex:1;font-weight:500}
.sb-search input::placeholder{color:rgba(255,255,255,.28)}
.sb-section{padding:10px 14px 4px;font-size:.58rem;font-weight:800;color:rgba(255,255,255,.28);text-transform:uppercase;letter-spacing:1.3px}
.db-list{flex:1;overflow-y:auto;padding:5px 8px}
.db-list::-webkit-scrollbar{width:2px}
.db-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1)}

/* SIDEBAR ITEMS */
.sbi{display:flex;align-items:center;gap:8px;padding:10px 10px;border-radius:10px;cursor:pointer;transition:all .18s;font-size:.88rem;color:rgba(255,255,255,.5);font-weight:600;border:1.5px solid transparent;margin-bottom:3px;position:relative;overflow:hidden;animation:sbIn .3s ease both}
.sbi::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(124,58,237,.08));opacity:0;transition:opacity .2s;border-radius:9px}
.sbi:hover{color:rgba(255,255,255,.82);background:rgba(255,255,255,.05)}
.sbi:hover::before{opacity:1}
.sbi.active{color:#fff;background:rgba(37,99,235,.16);border-color:rgba(37,99,235,.45);box-shadow:inset 0 0 20px rgba(37,99,235,.1)}
.sbi.active::before{opacity:1}
.sbi-indicator{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--g1);border-radius:0 3px 3px 0;opacity:0;transition:opacity .2s}
.sbi.active .sbi-indicator{opacity:1}
.sbi-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:all .3s}
.sbi-dot.online{background:#10b981;box-shadow:0 0 0 3px rgba(16,185,129,.2)}
.sbi-dot.online-active{animation:dotPing 2.5s ease-in-out infinite}
.sbi-dot.offline{background:rgba(255,255,255,.2)}
.sbi-dot.all{background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 0 8px rgba(37,99,235,.5)}
.sbi-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.87rem}
.sbi-tag{font-size:.57rem;font-weight:800;padding:1px 6px;border-radius:20px;white-space:nowrap;flex-shrink:0}
.sbi-tag.on{background:rgba(16,185,129,.18);color:#10b981;border:1px solid rgba(16,185,129,.3)}
.sbi-tag.off{background:rgba(255,255,255,.06);color:rgba(255,255,255,.3);border:1px solid rgba(255,255,255,.08)}
.sbi-mini{display:flex;gap:2px;opacity:0;transition:opacity .15s;flex-shrink:0}
.sbi:hover .sbi-mini{opacity:1}
.mini-btn{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.3);padding:3px 5px;border-radius:4px;font-size:.76rem;transition:all .15s;line-height:1}
.mini-btn:hover{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8)}
.mini-btn.del:hover{color:#ef4444}
.sb-add{padding:8px 10px}
.sb-footer{padding:10px 10px 8px;border-top:1px solid rgba(255,255,255,.05)}
.sb-clock{padding:0 4px 8px;font-family:var(--mono);font-size:.78rem;font-weight:600;color:rgba(255,255,255,.6);animation:tick .5s ease infinite alternate}
.sb-clock-lbl{font-size:.57rem;font-weight:700;color:rgba(255,255,255,.28);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px}

/* MAIN */
.main{flex:1;overflow-y:auto;display:flex;flex-direction:column;background:var(--w2)}
.view{display:none;padding:26px 28px;flex-direction:column;gap:18px;animation:fadeUp .3s ease}
.view.active{display:flex}
.view-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.view-title{font-size:1.1rem;font-weight:900;color:var(--t1);letter-spacing:-.4px}
.view-sub{font-size:.76rem;color:var(--t3);margin-top:3px;font-weight:500}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--rs);font-family:var(--font);font-size:.82rem;font-weight:700;cursor:pointer;border:none;transition:all .18s;white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}
.btn-primary{background:var(--g1);color:#fff;box-shadow:0 2px 14px var(--glow1)}
.btn-primary:hover:not(:disabled){box-shadow:0 6px 26px var(--glow1);transform:translateY(-1px)}
.btn-sm{padding:6px 13px;font-size:.75rem}
.btn-xs{padding:4px 9px;font-size:.69rem}
.btn-ghost{background:var(--w);border:1.5px solid var(--border);color:var(--t2);box-shadow:var(--sh1)}
.btn-ghost:hover{background:var(--w3);color:var(--t1)}
.btn-danger{background:var(--dbg);border:1.5px solid var(--dborder);color:var(--danger)}
.btn-danger:hover{background:rgba(239,68,68,.13)}
.btn-success{background:var(--sbg);border:1.5px solid var(--sborder);color:var(--success)}
.btn-success:hover{background:rgba(16,185,129,.13)}
.btn-warn{background:var(--wbg);border:1.5px solid rgba(245,158,11,.2);color:var(--warn)}
.btn-full{width:100%;justify-content:center}

/* CARDS */
.card{background:var(--w);border:1.5px solid var(--border);border-radius:var(--r);box-shadow:var(--sh1)}
.card-pad{padding:20px 22px}

/* HOME STAT CARDS */
.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.dsc{background:var(--w);border:1.5px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--sh1);transition:all .22s;cursor:pointer;position:relative}
.dsc-rgb-bar{height:3px;background-size:400% 100%;animation:rgbBorder 4s linear infinite;opacity:.85;transition:opacity .3s}
.dsc[data-ci="0"] .dsc-rgb-bar{background:linear-gradient(90deg,#2563eb,#7c3aed,#2563eb)}
.dsc[data-ci="1"] .dsc-rgb-bar{background:linear-gradient(90deg,#7c3aed,#ec4899,#7c3aed)}
.dsc[data-ci="2"] .dsc-rgb-bar{background:linear-gradient(90deg,#0ea5e9,#10b981,#0ea5e9)}
.dsc[data-ci="3"] .dsc-rgb-bar{background:linear-gradient(90deg,#f59e0b,#ef4444,#f59e0b)}
.dsc[data-ci="4"] .dsc-rgb-bar{background:linear-gradient(90deg,#10b981,#14b8a6,#10b981)}
.dsc[data-ci="5"] .dsc-rgb-bar{background:linear-gradient(90deg,#ef4444,#f59e0b,#ef4444)}
.dsc[data-ci="6"] .dsc-rgb-bar{background:linear-gradient(90deg,#ec4899,#a855f7,#ec4899)}
.dsc[data-ci="7"] .dsc-rgb-bar{background:linear-gradient(90deg,#14b8a6,#0ea5e9,#14b8a6)}
.dsc[data-ci="0"]{--card-glow:rgba(37,99,235,.08)}
.dsc[data-ci="1"]{--card-glow:rgba(124,58,237,.08)}
.dsc[data-ci="2"]{--card-glow:rgba(14,165,233,.08)}
.dsc[data-ci="3"]{--card-glow:rgba(245,158,11,.08)}
.dsc[data-ci="4"]{--card-glow:rgba(16,185,129,.08)}
.dsc[data-ci="5"]{--card-glow:rgba(239,68,68,.08)}
.dsc[data-ci="6"]{--card-glow:rgba(236,72,153,.08)}
.dsc[data-ci="7"]{--card-glow:rgba(20,184,166,.08)}
.dsc:hover{box-shadow:0 8px 30px var(--card-glow,rgba(37,99,235,.08)),var(--sh2);transform:translateY(-3px);border-color:rgba(37,99,235,.2)}
.dsc-head{padding:16px 18px 12px;display:flex;align-items:flex-start;justify-content:space-between}
.dsc-name{font-weight:800;font-size:.95rem;color:var(--t1);display:flex;align-items:center;gap:8px}
.dsc-live{width:8px;height:8px;border-radius:50%;background:var(--success);animation:dotPing 2.5s ease-in-out infinite}
.dsc-status{display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:800;padding:3px 10px;border-radius:20px;border:1.5px solid}
.dsc-status.online{color:var(--success);background:var(--sbg);border-color:var(--sborder)}
.dsc-status.offline{color:var(--t3);background:var(--w3);border-color:var(--border)}
.dsc-metrics{padding:0 18px 14px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.dsc-m{background:var(--w2);border:1px solid var(--border);border-radius:9px;padding:9px 10px;text-align:center;position:relative;overflow:hidden}
.dsc-m-val{font-size:1rem;font-weight:800;color:var(--t1);margin-bottom:2px;font-family:var(--mono);transition:color .3s}
.dsc-m-val.good{color:var(--success)}
.dsc-m-val.warn{color:var(--warn)}
.dsc-m-val.bad{color:var(--danger)}
.dsc-m-lbl{font-size:.6rem;font-weight:800;color:var(--t4);text-transform:uppercase;letter-spacing:.5px}
.shimmer{background:linear-gradient(90deg,var(--w3) 25%,var(--w4) 50%,var(--w3) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:5px;height:18px;width:60%;margin:0 auto 4px}
.dsc-foot{padding:10px 18px;border-top:1px solid var(--border);background:var(--w3);display:flex;align-items:center;justify-content:space-between}
.dsc-tz{font-size:.7rem;color:var(--t4);font-weight:700}

/* SEARCH */
.search-hero{background:var(--w);border:1.5px solid var(--border);border-radius:var(--r);padding:20px 22px;box-shadow:var(--sh1);position:relative;overflow:hidden}
.search-hero::before{content:'';position:absolute;top:-40px;right:-40px;width:220px;height:220px;background:radial-gradient(circle,rgba(37,99,235,.05),transparent 70%);pointer-events:none}
.si-row{display:flex;gap:10px;align-items:center}
.si-wrap{flex:1;position:relative}
.si-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--t4);pointer-events:none}
.si{width:100%;background:var(--w2);border:1.5px solid var(--border);border-radius:var(--rs);padding:11px 12px 11px 38px;color:var(--t1);font-family:var(--font);font-size:.92rem;font-weight:500;outline:none;transition:all .2s}
.si:focus{border-color:var(--a1);background:var(--w);box-shadow:0 0 0 3px var(--glow1)}
.si::placeholder{color:var(--t4);font-weight:400}
.search-hint{margin-top:9px;display:flex;gap:14px;flex-wrap:wrap;font-size:.71rem;color:var(--t4)}

/* DATA TABLE */
.tbl-outer{background:var(--w);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh1)}
.tbl-toolbar{padding:10px 14px;background:var(--w3);border-bottom:1.5px solid var(--border);display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:space-between}
.tbl-info{font-size:.84rem;color:var(--t3);font-weight:600}
.tbl-info strong{color:var(--t1)}
.tbl-scroll{overflow-x:auto;max-height:56vh}
.tbl-scroll::-webkit-scrollbar{width:5px;height:5px}
.tbl-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
table.dt{width:100%;border-collapse:collapse;font-size:.78rem}
table.dt thead{position:sticky;top:0;z-index:10}
table.dt thead tr{background:var(--w3);border-bottom:2px solid var(--border2)}
table.dt thead th{padding:10px 13px;text-align:left;color:var(--t3);font-weight:800;font-size:.75rem;text-transform:uppercase;letter-spacing:.7px;white-space:nowrap;cursor:pointer;user-select:none;position:relative;transition:color .15s;min-width:80px}
table.dt thead th:hover{color:var(--a1);background:rgba(37,99,235,.04)}
table.dt thead th.sa::after,table.dt thead th.sd::after{content:'';display:inline-block;width:0;height:0;margin-left:5px;border-left:4px solid transparent;border-right:4px solid transparent;vertical-align:middle}
table.dt thead th.sa::after{border-bottom:5px solid var(--a1)}
table.dt thead th.sd::after{border-top:5px solid var(--a1)}
.col-rsz{position:absolute;right:0;top:0;bottom:0;width:4px;cursor:col-resize;background:transparent;transition:background .15s}
.col-rsz:hover{background:var(--a1)}
table.dt tbody tr{border-bottom:1px solid var(--border);transition:background .1s}
table.dt tbody tr:last-child{border-bottom:none}
table.dt tbody tr:hover{background:rgba(37,99,235,.023)}
table.dt tbody td{padding:10px 13px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--mono);font-size:.83rem;max-width:260px}
table.dt tbody td.td-act{font-family:var(--font);width:78px;max-width:78px}
.drag-ov{background:rgba(37,99,235,.07)!important;color:var(--a1)!important}
.hl{background:rgba(37,99,235,.1);color:var(--a1);border-radius:3px;padding:0 2px;font-weight:700}
.null-v{color:var(--t4);font-style:italic}
.pager{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--w3);border-top:1px solid var(--border);flex-wrap:wrap;font-size:.84rem;color:var(--t3);font-weight:700}

/* RESULTS */
.sum-bar{display:flex;align-items:center;gap:12px;padding:9px 14px;background:var(--w);border:1.5px solid var(--border);border-radius:var(--rss);font-size:.77rem;color:var(--t3);flex-wrap:wrap;box-shadow:var(--sh1)}
.sum-bar strong{color:var(--t1);font-weight:700}
.vsep{color:var(--border2)}
.r-group{background:var(--w);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh1);animation:fadeUp .25s ease}
.rg-head{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:var(--w3);border-bottom:1.5px solid var(--border);gap:8px;flex-wrap:wrap}
.rg-title{display:flex;align-items:center;gap:8px;font-weight:800;font-size:.83rem}
.badge{font-size:.65rem;font-weight:800;padding:2px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border:1.5px solid}
.b-db{color:var(--a2);background:rgba(124,58,237,.07);border-color:rgba(124,58,237,.18)}
.b-tbl{color:var(--a1);background:var(--glow1);border-color:rgba(37,99,235,.18)}
.b-cnt{color:var(--t3);background:var(--w4);border-color:var(--border)}
.b-warn{color:var(--warn);background:var(--wbg);border-color:rgba(245,158,11,.2)}

/* STATE */
.state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:54px 20px;color:var(--t4);text-align:center}
.state h3{font-size:.92rem;color:var(--t3);font-weight:700}
.state p{font-size:.77rem;line-height:1.65}
.spin{width:28px;height:28px;border:2.5px solid var(--border2);border-top-color:var(--a1);border-radius:50%;animation:spin .7s linear infinite}
.spin-sm{width:15px;height:15px;border-width:2px}
.spin-xs{width:11px;height:11px;border-width:2px}

/* DB MANAGER */
.grid2{display:grid;grid-template-columns:repeat(auto-fill,minmax(295px,1fr));gap:15px}
.grid3{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:13px}
.db-card{background:var(--w);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh1);transition:all .22s;animation:fadeUp .3s ease}
.db-card-bar{height:3px;background:var(--g1);background-size:300% 100%;animation:rgbBorder 4s linear infinite;opacity:0;transition:opacity .3s}
.db-card:hover .db-card-bar{opacity:1}
.db-card:hover{box-shadow:var(--sh2);transform:translateY(-2px);border-color:var(--border2)}
.dcp{padding:16px 18px}
.dc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.dc-name{font-weight:800;font-size:.93rem;color:var(--t1);display:flex;align-items:center;gap:8px}
.dc-meta{display:grid;grid-template-columns:auto 1fr;gap:3px 10px;font-size:.75rem}
.ml{color:var(--t4);font-weight:700}
.mv{color:var(--t2);font-family:var(--mono);font-size:.72rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dc-foot{padding:10px 18px;border-top:1px solid var(--border);background:var(--w3);display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;font-weight:800;padding:3px 9px;border-radius:20px;border:1.5px solid}
.pill-on{color:var(--success);background:var(--sbg);border-color:var(--sborder)}
.pill-off{color:var(--t3);background:var(--w3);border-color:var(--border)}

/* USERS */
.user-card{background:var(--w);border:1.5px solid var(--border);border-radius:var(--r);padding:16px 18px;box-shadow:var(--sh1);transition:all .2s;animation:fadeUp .3s ease}
.user-card:hover{border-color:var(--border2);box-shadow:var(--sh2);transform:translateY(-1px)}
.uc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:11px}
.uc-name{display:flex;align-items:center;gap:8px;font-weight:800;font-size:.9rem;color:var(--t1)}
.uc-av{width:34px;height:34px;background:var(--g1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.74rem;font-weight:900;flex-shrink:0}
.uc-info{font-size:.72rem;color:var(--t3);margin-top:2px}
.pw-show{display:flex;align-items:center;gap:7px;background:var(--w3);border:1px solid var(--border);border-radius:var(--rss);padding:5px 9px;font-family:var(--mono);font-size:.73rem;color:var(--t2);margin-top:9px}
.pw-val{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pw-eye{background:none;border:none;cursor:pointer;color:var(--t4);padding:0;transition:color .15s;display:flex;align-items:center}
.pw-eye:hover{color:var(--a1)}
.tgl-row{display:flex;align-items:center;gap:8px;margin-top:9px;font-size:.76rem;color:var(--t3);font-weight:700}
.tgl{width:38px;height:20px;background:var(--w4);border-radius:20px;position:relative;cursor:pointer;transition:all .22s;flex-shrink:0;border:1.5px solid var(--border)}
.tgl.on{background:var(--a1);border-color:var(--a1)}
.tgl::after{content:'';position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:1px;left:1px;transition:transform .22s;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.tgl.on::after{transform:translateX(18px)}

/* IP */
.ip-master{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--w);border:1.5px solid var(--border);border-radius:var(--r);box-shadow:var(--sh1);margin-bottom:16px}
.ip-master h4{font-size:.89rem;font-weight:800;color:var(--t1);margin-bottom:3px}
.ip-master p{font-size:.75rem;color:var(--t3)}
.big-tgl{width:54px;height:28px;background:var(--w4);border-radius:28px;cursor:pointer;position:relative;transition:all .25s;border:2px solid var(--border);flex-shrink:0}
.big-tgl.on{background:var(--a1);border-color:var(--a1);box-shadow:0 2px 14px var(--glow1);animation:rgbGlow 3s infinite}
.big-tgl::after{content:'';position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform .25s;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.big-tgl.on::after{transform:translateX(26px)}
.ip-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ip-tbl{width:100%;border-collapse:collapse;font-size:.78rem}
.ip-tbl th{padding:7px 11px;text-align:left;font-size:.63rem;font-weight:800;color:var(--t3);text-transform:uppercase;letter-spacing:.8px;background:var(--w3);border-bottom:1.5px solid var(--border)}
.ip-tbl td{padding:7px 11px;border-bottom:1px solid var(--border);color:var(--t2);font-family:var(--mono);font-size:.76rem}
.ip-tbl tr:last-child td{border-bottom:none}
.ip-tbl tr:hover td{background:var(--w3)}
.add-ip-row{display:flex;gap:6px;align-items:center;margin-top:9px;flex-wrap:wrap}

/* LOGS */
.log-head,.log-row{display:flex;gap:10px;padding:7px 13px;align-items:flex-start}
.log-head{background:var(--w3);border-bottom:1.5px solid var(--border);font-size:.62rem;font-weight:800;color:var(--t4);text-transform:uppercase;letter-spacing:.8px;position:sticky;top:0}
.log-row{border-bottom:1px solid var(--border);font-size:.73rem;transition:background .1s}
.log-row:hover{background:var(--w3)}
.log-row:last-child{border-bottom:none}
.log-ts{color:var(--t4);white-space:nowrap;font-family:var(--mono);font-size:.69rem;min-width:128px}
.log-user{color:var(--a1);font-weight:800;min-width:85px;font-size:.73rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.log-act{font-weight:800;min-width:115px;font-size:.72rem;white-space:nowrap}
.log-act.LOGIN_FAIL,.log-act.LOGIN_BLOCKED{color:var(--danger)}
.log-act.LOGIN{color:var(--success)}
.log-act.DELETE_RECORD,.log-act.DELETE_DB{color:var(--warn)}
.log-act.ADD_DB,.log-act.ADD_USER,.log-act.MIGRATION{color:var(--a1)}
.log-act.CLEAR_CACHE{color:var(--a2)}
.log-detail{color:var(--t3);flex:1;font-family:var(--mono);font-size:.7rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.log-ip{color:var(--t4);font-family:var(--mono);font-size:.69rem;white-space:nowrap;min-width:95px}

/* MODAL */
.mo{display:none;position:fixed;inset:0;background:rgba(10,14,26,.38);z-index:400;align-items:center;justify-content:center;backdrop-filter:blur(7px)}
.mo.open{display:flex}
.mc{background:var(--w);border:1.5px solid var(--border);border-radius:18px;padding:26px;max-width:520px;width:93%;box-shadow:var(--sh3);animation:popIn .22s cubic-bezier(.22,1,.36,1);max-height:90vh;overflow-y:auto}
/* JSON MODAL */
.mc-json{max-width:820px;padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:88vh}
.json-mo-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1.5px solid var(--border);gap:12px;flex-wrap:wrap;background:var(--w)}
.json-mo-icon{width:36px;height:36px;background:linear-gradient(135deg,#0ea5e9,#2563eb);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem;font-weight:900;flex-shrink:0;box-shadow:0 4px 14px rgba(37,99,235,.25)}
.json-meta-bar{display:flex;gap:10px;align-items:center;padding:8px 22px;background:var(--w3);border-bottom:1px solid var(--border);flex-wrap:wrap;font-size:.75rem;min-height:36px}
.json-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:.69rem;font-weight:800;border:1.5px solid}
.json-badge.type-obj{color:#7c3aed;background:rgba(124,58,237,.07);border-color:rgba(124,58,237,.2)}
.json-badge.type-arr{color:#0ea5e9;background:rgba(14,165,233,.07);border-color:rgba(14,165,233,.2)}
.json-badge.type-str{color:#10b981;background:rgba(16,185,129,.07);border-color:rgba(16,185,129,.2)}
.json-badge.keys-badge{color:var(--t3);background:var(--w4);border-color:var(--border)}
.json-viewer-wrap{flex:1;overflow:auto;background:#0d1117;border-radius:0 0 18px 18px}
.json-viewer{margin:0;padding:20px 24px;font-family:var(--mono);font-size:.82rem;line-height:1.7;color:#e6edf3;white-space:pre;tab-size:2}
.jk{color:#79c0ff}.jstr{color:#a5d6ff}.jnum{color:#f8c555}.jbool{color:#ff7b72}.jnull{color:#8b949e}.jpunct{color:#6e7681}
/* JSON cell button */
.json-btn{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:5px;background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.25);color:#0ea5e9;font-size:.67rem;font-weight:800;cursor:pointer;font-family:var(--font);transition:all .15s;white-space:nowrap;vertical-align:middle;margin-left:4px}
.json-btn:hover{background:rgba(14,165,233,.2);border-color:rgba(14,165,233,.5)}
/* Soft reset button */
.btn-soft-reset{background:rgba(245,158,11,.08);border:1.5px solid rgba(245,158,11,.25);color:#f59e0b;border-radius:var(--rss);padding:5px 11px;font-size:.75rem;font-weight:800;cursor:pointer;font-family:var(--font);transition:all .18s;display:inline-flex;align-items:center;gap:5px}
.btn-soft-reset:hover{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.5)}
.mc-title{font-size:.98rem;font-weight:900;color:var(--t1);margin-bottom:4px;display:flex;align-items:center;gap:8px}
.mc-sub{color:var(--t3);font-size:.78rem;margin-bottom:20px}
.fg2{margin-bottom:13px}
.fg2 label{display:block;font-size:.67rem;font-weight:800;color:var(--t3);text-transform:uppercase;letter-spacing:.7px;margin-bottom:5px}
.fi{width:100%;background:var(--w2);border:1.5px solid var(--border);border-radius:var(--rss);padding:10px 12px;color:var(--t1);font-family:var(--font);font-size:.87rem;font-weight:500;outline:none;transition:all .2s}
.fi:focus{border-color:var(--a1);background:var(--w);box-shadow:0 0 0 3px var(--glow1)}
.fi::placeholder{color:var(--t4);font-weight:400}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.fg-full{grid-column:1/-1}
.mc-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
.del-preview{background:var(--w3);border:1.5px solid var(--border);border-radius:var(--rss);padding:10px 13px;font-family:var(--mono);font-size:.76rem;color:var(--warn);margin:12px 0;word-break:break-all;line-height:1.65}
.err-bar{background:var(--dbg);border:1.5px solid var(--dborder);color:var(--danger);padding:10px 13px;border-radius:var(--rss);font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:8px}

/* TABLE SELECT */
.tbl-sel{background:var(--w);border:1.5px solid var(--border);border-radius:var(--rs);padding:7px 11px;color:var(--t1);font-family:var(--font);font-size:.82rem;font-weight:600;outline:none;cursor:pointer;transition:border-color .2s}
.tbl-sel:focus{border-color:var(--a1)}

/* TOAST */
#toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:7px;z-index:9999}
.toast{background:var(--w);border:1.5px solid var(--border);border-radius:var(--rs);padding:11px 15px;font-size:.8rem;font-weight:700;min-width:210px;max-width:340px;display:flex;align-items:center;gap:8px;box-shadow:var(--sh3);animation:slideIn .25s ease;color:var(--t1)}
.toast.ok{border-color:var(--sborder);color:var(--success)}
.toast.err{border-color:var(--dborder);color:var(--danger)}
.toast.info{border-color:rgba(37,99,235,.25);color:var(--a1)}

::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--t4)}

</head>
<body>

