@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700&family=Barlow:wght@300;400;500&family=DM+Mono:wght@400;500&display=swap');
:root{--bg:#0d0f14;--bg2:#13161e;--bg3:#1a1e2a;--bg4:#1f2433;--bgi:#161a24;--border:#2a2f3f;--border2:#333a50;--accent:#4a7eff;--accentL:rgba(74,126,255,.15);--danger:#ff4a4a;--dangerL:rgba(255,74,74,.15);--success:#2ecc8a;--successL:rgba(46,204,138,.12);--warn:#f5a623;--warnL:rgba(245,166,35,.12);--txt:#e8ecf5;--txt2:#8892a8;--txt3:#4e566a;--rep1:#ff6b35;--rep0:#3a9e6e;--r:4px;--r2:8px;--r3:12px;--navH:60px;--fd:'Barlow Condensed',sans-serif;--fb:'Barlow',sans-serif;--fm:'DM Mono',monospace}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{background:var(--bg);color:var(--txt);font-family:var(--fb);min-height:100vh;line-height:1.6}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* LOGIN */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:16px;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(74,126,255,.08),transparent),var(--bg)}
.login-box{width:100%;max-width:400px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r3);padding:32px 24px}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.login-mark{width:42px;height:42px;background:var(--accent);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:700;font-size:18px;color:#fff;flex-shrink:0}
.login-name{font-family:var(--fd);font-size:17px;font-weight:600;color:var(--txt);line-height:1.2}
.login-sub{font-family:var(--fm);font-size:10px;color:var(--txt3);letter-spacing:1.5px;text-transform:uppercase}
.login-box h1{font-family:var(--fd);font-size:26px;font-weight:700;margin-bottom:4px}
.login-box p{color:var(--txt2);font-size:13px;margin-bottom:24px}
.login-err{background:var(--dangerL);border:1px solid var(--danger);border-radius:var(--r);color:var(--danger);padding:10px 13px;font-size:13px;margin-bottom:16px}

/* LAYOUT MOBILE */
.app{display:flex;flex-direction:column;min-height:100vh}
.tb-mob{display:flex;align-items:center;justify-content:space-between;height:52px;padding:0 16px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200}
.tb-brand{display:flex;align-items:center;gap:10px;font-family:var(--fd);font-weight:600;font-size:16px}
.tb-mark{width:30px;height:30px;background:var(--accent);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:700;font-size:14px;color:#fff}
.tb-desk{display:none}
.main-wrap{flex:1;padding-bottom:calc(var(--navH) + env(safe-area-inset-bottom))}
.page{padding:16px}

/* BOTTOM NAV */
.bnav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--navH);background:var(--bg2);border-top:1px solid var(--border);z-index:200;padding-bottom:env(safe-area-inset-bottom)}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--txt3);font-family:var(--fm);font-size:10px;letter-spacing:.5px;text-transform:uppercase;-webkit-tap-highlight-color:transparent}
.bn svg{width:20px;height:20px}
.bn.on{color:var(--accent)}

/* DRAWER */
.drawer-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:300}
.drawer-bg.open{display:block}
.drawer{position:fixed;top:0;left:0;bottom:0;width:260px;background:var(--bg2);border-right:1px solid var(--border);z-index:301;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .25s ease}
.drawer.open{transform:translateX(0)}
.dhead{display:flex;align-items:center;justify-content:space-between;padding:20px 16px;border-bottom:1px solid var(--border)}
.dhead-info .dn{font-family:var(--fd);font-size:16px;font-weight:600}
.dhead-info .ds{font-family:var(--fm);font-size:10px;color:var(--txt3);letter-spacing:1.5px;text-transform:uppercase;margin-top:2px}
.d-close{background:none;border:none;color:var(--txt3);cursor:pointer;padding:4px}
.d-nav{flex:1;padding:12px;overflow-y:auto}
.d-foot{padding:12px;border-top:1px solid var(--border)}

/* SIDEBAR (desktop) */
.sidebar{display:none}

/* NAV ITEMS */
.nav-sep{font-family:var(--fm);font-size:10px;color:var(--txt3);letter-spacing:1.5px;text-transform:uppercase;padding:10px 8px 4px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r2);color:var(--txt2);font-size:14px;font-weight:500;transition:background .15s,color .15s;cursor:pointer;border:1px solid transparent;background:none;width:100%;text-align:left}
.nav-item:hover{background:var(--bg3);color:var(--txt)}
.nav-item.on{background:var(--accentL);color:var(--accent);border-color:rgba(74,126,255,.2)}
.nav-item svg{width:16px;height:16px;flex-shrink:0}
.nav-item.red{color:var(--danger)}

/* FORM */
.form-label{font-family:var(--fm);font-size:11px;color:#6878a0;letter-spacing:1px;text-transform:uppercase;display:block;margin-bottom:5px}
.form-input,.form-select,.form-textarea{width:100%;background:var(--bgi);border:1px solid var(--border);border-radius:var(--r);color:var(--txt);font-family:var(--fb);font-size:15px;padding:11px 12px;outline:none;transition:border-color .15s,box-shadow .15s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(74,126,255,.2)}
.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238892a8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
.form-select option{background:var(--bg3)}
.form-textarea{resize:vertical;min-height:80px;line-height:1.5}
.fg{margin-bottom:16px}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fr4{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.chk{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 0}
.chk input{width:20px;height:20px;accent-color:var(--rep1);cursor:pointer;flex-shrink:0}
.chk span{font-size:14px;color:var(--txt2)}

/* TAG INPUT */
.tagw{background:var(--bgi);border:1px solid var(--border);border-radius:var(--r);padding:6px 8px;display:flex;flex-wrap:wrap;gap:5px;align-items:center;min-height:46px}
.tagw:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(74,126,255,.2)}
.tag{display:inline-flex;align-items:center;gap:4px;background:var(--accentL);border:1px solid rgba(74,126,255,.3);color:var(--accent);border-radius:3px;padding:2px 8px;font-size:12px;font-family:var(--fm)}
.tag-x{cursor:pointer;opacity:.6;font-size:14px;line-height:1}
.tag-x:hover{opacity:1}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:var(--r);font-family:var(--fb);font-size:14px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.btn svg{width:15px;height:15px;flex-shrink:0}
.bfull{width:100%;justify-content:center}
.bsm{padding:7px 12px;font-size:12px}
.bsm svg{width:13px;height:13px}
.bp{background:var(--accent);color:#fff;border-color:var(--accent)}
.bp:hover{background:#6691ff;box-shadow:0 4px 16px rgba(74,126,255,.3)}
.bs{background:var(--bg3);color:var(--txt2);border-color:var(--border)}
.bs:hover{background:var(--bg4);color:var(--txt)}
.bsuc{background:var(--success);color:#0d1a12;border-color:var(--success)}
.bsuc:hover{box-shadow:0 4px 16px rgba(46,204,138,.25)}
.bdng{background:transparent;color:var(--danger);border-color:rgba(255,74,74,.3)}
.bdng:hover{background:var(--dangerL)}
.bico{background:none;border:none;cursor:pointer;padding:4px;color:var(--txt3)}
.bico:hover{color:var(--txt)}

/* BOX */
.box{background:var(--bg4);border:1px solid var(--border);border-radius:var(--r3);overflow:hidden;margin-bottom:16px}
.box-h{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.box-t{font-family:var(--fd);font-size:17px;font-weight:600}
.box-b{padding:16px}
.box-f{padding:12px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}

/* STATS */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.stat{background:var(--bg4);border:1px solid var(--border);border-radius:var(--r3);padding:14px 16px;position:relative;overflow:hidden}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.c1::before{background:var(--accent)}.c2::before{background:var(--rep1)}.c3::before{background:var(--success)}.c4::before{background:var(--warn)}
.sl{font-family:var(--fm);font-size:10px;color:var(--txt3);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.sv{font-family:var(--fd);font-size:32px;font-weight:700;line-height:1}
.sm{font-size:11px;color:var(--txt2);margin-top:4px}

/* BADGES */
.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:3px;font-family:var(--fm);font-size:10px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}
.br1{background:rgba(255,107,53,.15);color:var(--rep1);border:1px solid rgba(255,107,53,.3)}
.br0{background:rgba(58,158,110,.1);color:var(--rep0);border:1px solid rgba(58,158,110,.25)}
.bpos{background:var(--successL);color:var(--success);border:1px solid rgba(46,204,138,.3)}
.bneg{background:var(--dangerL);color:var(--danger);border:1px solid rgba(255,74,74,.3)}
.both{background:var(--warnL);color:var(--warn);border:1px solid rgba(245,166,35,.3)}

/* CARD LIST (mobile) */
.card-list{display:flex;flex-direction:column}
.ci{padding:13px 16px;border-bottom:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent}
.ci:last-child{border-bottom:none}
.ci:hover,.ci:active{background:var(--bg3)}
.ci-top{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.ci-gr{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--accent);min-width:28px;text-align:center;flex-shrink:0}
.ci-ev{font-size:13px;color:var(--txt);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.ci-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ci-date{font-family:var(--fm);font-size:11px;color:var(--txt3)}
.ci-cons{font-size:11px;color:var(--txt3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* TABLE (desktop) */
.tbl-wrap{display:none;overflow-x:auto}
.tbl{width:100%;border-collapse:collapse}
.tbl th{background:var(--bg3);padding:10px 14px;text-align:left;font-family:var(--fm);font-size:10px;color:var(--txt3);letter-spacing:1px;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap}
.tbl th.sort{cursor:pointer;user-select:none}
.tbl th.sort:hover{color:var(--txt2)}
.tbl th.asc::after{content:' ↑';color:var(--accent)}
.tbl th.desc::after{content:' ↓';color:var(--accent)}
.tbl td{padding:11px 14px;font-size:13px;color:var(--txt2);vertical-align:middle;border-bottom:1px solid var(--border)}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{cursor:pointer;transition:background .1s}
.tbl tbody tr:hover{background:var(--bg3)}
.tbl-act{display:flex;gap:5px;opacity:0;transition:opacity .15s}
.tbl tbody tr:hover .tbl-act{opacity:1}
.cmono{font-family:var(--fm);font-size:12px;white-space:nowrap}
.cgr{font-family:var(--fd);font-size:18px;font-weight:700;color:var(--accent);text-align:center}
.cclip{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* FILTER */
.filter{background:var(--bg4);border:1px solid var(--border);border-radius:var(--r3);padding:14px 16px;margin-bottom:16px;display:flex;flex-direction:column;gap:10px}

/* PAGES */
.pages{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border);flex-wrap:wrap;gap:8px}
.pi{font-family:var(--fm);font-size:11px;color:var(--txt3)}
.pbs{display:flex;gap:3px}
.pbn{min-width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--r);border:1px solid var(--border);background:var(--bg3);color:var(--txt2);font-family:var(--fm);font-size:12px;cursor:pointer;padding:0 6px;transition:all .15s}
.pbn:hover{color:var(--txt);border-color:var(--border2)}
.pbn.on{background:var(--accent);border-color:var(--accent);color:#fff}
.pbn:disabled{opacity:.3;cursor:not-allowed}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:500;align-items:flex-end;justify-content:center}
.modal-bg.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r3) var(--r3) 0 0;width:100%;max-height:92vh;overflow-y:auto;animation:slideUp .25s ease}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1}
.modal-t{font-family:var(--fd);font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}
.modal-b{padding:18px}
.modal-f{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid var(--border);flex-wrap:wrap}
.mid-badge{font-family:var(--fm);font-size:11px;color:var(--txt3);background:var(--bg3);border-radius:3px;padding:2px 8px}

/* DETAIL */
.dg{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.dg .full{grid-column:1/-1}
.dl{font-family:var(--fm);font-size:10px;color:var(--txt3);letter-spacing:1px;text-transform:uppercase;margin-bottom:3px}
.dv{font-size:14px;color:var(--txt);line-height:1.5}
.dv.mono{font-family:var(--fm)}
.dv.big{font-family:var(--fd);font-size:30px;font-weight:700;color:var(--accent);line-height:1}
.ddesc{background:var(--bg3);border-radius:var(--r);padding:12px 14px;font-size:13px;line-height:1.7;white-space:pre-wrap}

/* COMMENTS */
.cmt{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);padding:12px 14px;margin-bottom:10px}
.cmt-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.cmt-m{font-family:var(--fm);font-size:10px;color:var(--txt3)}
.cmt-d{background:none;border:none;color:var(--txt3);cursor:pointer;font-size:16px;opacity:.5;line-height:1}
.cmt-d:hover{opacity:1;color:var(--danger)}
.cmt-t{font-size:13px;color:var(--txt);white-space:pre-wrap;line-height:1.6}

/* UPLOAD */
.upl{border:2px dashed var(--border);border-radius:var(--r2);padding:22px 16px;text-align:center;cursor:pointer;position:relative;transition:border-color .2s,background .2s}
.upl:hover,.upl.drag{border-color:var(--accent);background:var(--accentL)}
.upl input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.upl p{font-size:13px;color:var(--txt2);margin-top:6px}
.upl small{font-family:var(--fm);font-size:10px;color:var(--txt3)}
.prev-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}
.prev-item{position:relative;aspect-ratio:1;border-radius:var(--r);overflow:hidden;border:1px solid var(--border)}
.prev-item img{width:100%;height:100%;object-fit:cover}
.img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.img-grid a{display:block;aspect-ratio:1;border-radius:var(--r);overflow:hidden;border:1px solid var(--border)}
.img-grid img{width:100%;height:100%;object-fit:cover}
.img-del{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.7);border:none;border-radius:50%;width:22px;height:22px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1}

/* TOAST */
.toasts{position:fixed;bottom:calc(var(--navH) + 12px);right:12px;z-index:9999;display:flex;flex-direction:column;gap:6px}
.toast{background:var(--bg4);border:1px solid var(--border);border-radius:var(--r2);padding:11px 15px;min-width:220px;max-width:calc(100vw - 24px);font-size:13px;display:flex;align-items:center;gap:8px;animation:slideIn .3s ease}
.toast.ok{border-left:3px solid var(--success)}
.toast.err{border-left:3px solid var(--danger)}
.toast.inf{border-left:3px solid var(--accent)}

/* MISC */
.alert{padding:12px 15px;border-radius:var(--r);font-size:13px;margin-bottom:14px}
.aok{background:var(--successL);border:1px solid rgba(46,204,138,.3);color:var(--success)}
.aerr{background:var(--dangerL);border:1px solid rgba(255,74,74,.3);color:var(--danger)}
.ainf{background:var(--accentL);border:1px solid rgba(74,126,255,.3);color:var(--accent)}
.divider{border:none;border-top:1px solid var(--border);margin:16px 0}
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--txt3);text-align:center}
.empty svg{width:40px;height:40px;margin-bottom:12px;opacity:.4}
.empty h3{font-family:var(--fd);font-size:17px;color:var(--txt2);margin-bottom:4px}
.empty p{font-size:13px}
.app-footer{text-align:center;padding:12px;font-family:var(--fm);font-size:10px;color:var(--txt3);letter-spacing:.8px;border-top:1px solid var(--border);margin-bottom:var(--navH)}

/* PRINT */
@media print{.tb-mob,.bnav,.drawer,.drawer-bg,.tb-desk,.filter,.pages,.btn,.modal-f,.tbl-act,.toasts,.cmt-form{display:none!important}.main-wrap{padding-bottom:0!important}body{background:#fff;color:#000}}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.fade-in{animation:fadeUp .3s ease}

/* TABLET 640 */
@media(min-width:640px){
.stats{grid-template-columns:repeat(4,1fr)}
.filter{flex-direction:row;flex-wrap:wrap}
.filter .fg{flex:1;min-width:140px}
.fr4{grid-template-columns:1fr 1fr 1fr 1fr}
.form-input,.form-select,.form-textarea{font-size:14px}
.prev-grid{grid-template-columns:repeat(5,1fr)}
.img-grid{grid-template-columns:repeat(5,1fr)}
}

/* DESKTOP 900 */
@media(min-width:900px){
.tb-mob{display:none}
.bnav{display:none}
.drawer-bg{display:none!important}
.drawer{display:none!important}
.sidebar{display:flex;flex-direction:column;width:240px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);position:fixed;top:0;left:0;height:100vh;z-index:100}
.sb-brand{padding:22px 18px 18px;border-bottom:1px solid var(--border)}
.sb-mark{width:34px;height:34px;background:var(--accent);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:700;font-size:15px;color:#fff;margin-bottom:8px}
.sb-name{font-family:var(--fd);font-weight:600;font-size:15px;color:var(--txt);line-height:1.2}
.sb-sub{font-family:var(--fm);font-size:10px;color:var(--txt3);letter-spacing:1.5px;text-transform:uppercase;margin-top:2px}
.sb-nav{flex:1;padding:14px 10px;overflow-y:auto}
.sb-foot{padding:12px 10px;border-top:1px solid var(--border)}
.tb-desk{display:flex;align-items:center;justify-content:space-between;height:60px;padding:0 28px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.tb-pg{font-family:var(--fd);font-size:21px;font-weight:600}
.app{flex-direction:row}
.app-inner{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh}
.main-wrap{padding-bottom:0}
.page{padding:28px}
.app-footer{margin-bottom:0}
.toasts{bottom:20px;right:20px}
.tbl-wrap{display:block}
.card-list{display:none}
.modal-bg{align-items:center;padding:24px}
.modal{border-radius:var(--r3);max-width:700px;animation:fadeUp .25s ease}
.modal-b{padding:24px}
.modal-h{padding:20px 24px 16px}
.modal-f{padding:16px 24px}
}
