@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --c1:rgb(0,128,96);--c1d:rgb(0,102,76);--c1l:#edf7f3;--c1x:rgba(0,128,96,.07);
  --bg:#f7f9f8;--card:#fff;--t1:#1b2329;--t2:#5f6d7e;--t3:#8c99a6;
  --bd:#dfe3e8;--bd2:#f0f2f1;--r:10px;--r2:8px;--sh:0 1px 3px rgba(0,0,0,.06),0 1px 8px rgba(0,0,0,.02);
  --red:#c9372c;--green:#1f845a;--yellow:#946f00;--blue:#0c66e4;--purple:#6e5dc6;
  --bgr:#ffeeed;--bgg:#e2f6ee;--bgy:#fdf6e3;--bgb:#e9f2ff;--bgp:#f2eeff;--bggray:#f1f2f4;
}
body,button,input,select,textarea{font-family:'DM Sans',system-ui,sans-serif;font-size:14px;color:var(--t1)}
a{color:var(--c1);text-decoration:none}
/* ── Layout ── */
.app{display:flex;height:100vh;background:var(--bg);overflow:hidden}
.sidebar{width:232px;background:#162127;color:#fff;display:flex;flex-direction:column;flex-shrink:0}
.sidebar .logo{padding:18px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar .logo-icon{width:28px;height:28px;border-radius:8px;background:var(--c1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar .logo-text{font-size:17px;font-weight:600;letter-spacing:-.4px}
.sidebar nav{flex:1;overflow-y:auto;padding:8px 0}
.nav-group{padding:0 10px;margin-bottom:2px}
.nav-label{font-size:10px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.3);padding:14px 8px 5px}
.nav-item{display:flex;align-items:center;gap:9px;padding:7px 12px;border-radius:7px;color:rgba(255,255,255,.55);cursor:pointer;font-size:13.5px;transition:all .12s;border-left:3px solid transparent}
.nav-item:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85)}
.nav-item.active{background:rgba(0,128,96,.2);color:#5cebba;font-weight:500;border-left-color:var(--c1)}
.nav-item svg{width:18px;height:18px;flex-shrink:0}
.sidebar-bottom{padding:10px;border-top:1px solid rgba(255,255,255,.06)}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:56px;background:var(--card);border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 24px;gap:12px;flex-shrink:0;box-shadow:0 1px 3px rgba(0,30,20,.04)}
.topbar .page-title{font-size:16px;font-weight:600;flex:1}
.topbar .user-pill{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--r2)}
.topbar .user-pill:hover{background:#f5f5f5}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--c1l);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--c1);font-size:12px}
.content{flex:1;overflow-y:auto;padding:24px}
/* ── Card ── */
.card{background:var(--card);border-radius:var(--r);border:1px solid var(--bd);box-shadow:var(--sh)}
.card-head{padding:14px 20px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.card-head h3{font-size:14px;font-weight:600}
.card-body{padding:20px}
/* ── Stat ── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:20px}
.stat-card{padding:18px 20px;border-left:3px solid var(--c1);position:relative}
.stat-card:nth-child(2){border-left-color:var(--blue)}
.stat-card:nth-child(3){border-left-color:var(--purple)}
.stat-card:nth-child(4){border-left-color:var(--red)}
.stat-card .s-label{font-size:12px;color:var(--t2);font-weight:500;margin-bottom:2px}
.stat-card .s-value{font-size:24px;font-weight:600;letter-spacing:-.5px}
.stat-card .s-sub{font-size:12px;color:var(--t2);margin-top:2px}
/* ── Button ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r2);border:1px solid var(--bd);background:var(--card);cursor:pointer;font-weight:500;font-size:13px;transition:all .12s;white-space:nowrap}
.btn:hover{border-color:#ccc;background:#fafafa}
.btn-p{background:var(--c1);color:#fff;border-color:var(--c1);box-shadow:0 1px 3px rgba(0,128,96,.25)}
.btn-p:hover{background:var(--c1d);box-shadow:0 2px 6px rgba(0,128,96,.3)}
.btn-sm{padding:4px 10px;font-size:12px;border-radius:6px}
.btn-d{color:var(--red);border-color:var(--red);background:#fff}
.btn-d:hover{background:var(--bgr)}
.btn-g{display:inline-flex;gap:0}.btn-g .btn{border-radius:0}.btn-g .btn:first-child{border-radius:var(--r2) 0 0 var(--r2)}.btn-g .btn:last-child{border-radius:0 var(--r2) var(--r2) 0}.btn-g .btn+.btn{margin-left:-1px}
/* ── Input ── */
.input{padding:8px 12px;border:1px solid var(--bd);border-radius:var(--r2);outline:none;width:100%;transition:border .12s;background:#fff;font-size:14px}
.input:focus{border-color:var(--c1);box-shadow:0 0 0 2px var(--c1x)}
select.input{appearance:none;background:url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23637381' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 12px center #fff;padding-right:30px}
textarea.input{resize:vertical;min-height:60px}
.field{margin-bottom:14px}
.field>label{display:block;font-size:11px;font-weight:600;color:var(--t2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
/* ── Table ── */
.table-wrap{overflow-x:auto;transition:opacity .15s}
.table-wrap.loading{opacity:.45;pointer-events:none}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:10px 16px;font-size:12px;font-weight:600;color:var(--t2);border-bottom:1px solid var(--bd);white-space:nowrap;background:#fafbfb}
td{padding:13px 16px;border-bottom:1px solid var(--bd2);font-size:13.5px}
tr:hover td{background:#f5f7f6}
td.mono{font-family:'DM Mono',monospace;font-size:12px;font-weight:500}
td.ellip{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
td.money{font-weight:600}
td.date{font-size:12px;color:var(--t2);white-space:nowrap}
td.right{text-align:right}
/* ── Badge ── */
.badge{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.2px}
.badge-green{background:var(--bgg);color:var(--green)}
.badge-yellow{background:var(--bgy);color:var(--yellow)}
.badge-red{background:var(--bgr);color:var(--red)}
.badge-blue{background:var(--bgb);color:var(--blue)}
.badge-gray{background:var(--bggray);color:#626f86}
.badge-purple{background:var(--bgp);color:var(--purple)}
/* ── Tabs ── */
.tabs{display:flex;border-bottom:2px solid var(--bd);margin-bottom:18px;gap:2px}
.tab{padding:9px 16px;cursor:pointer;font-weight:500;font-size:13px;color:var(--t3);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .12s;border-radius:6px 6px 0 0}
.tab:hover{color:var(--t1);background:var(--c1x)}.tab.active{color:var(--c1);border-bottom-color:var(--c1);background:var(--c1x)}
/* ── Pager ── */
.pager{display:flex;align-items:center;justify-content:center;gap:5px;padding:14px 0}
.pager button{width:30px;height:30px;border-radius:6px;border:1px solid var(--bd);background:#fff;cursor:pointer;font-size:12px;font-weight:500}
.pager button.cur{background:var(--c1);color:#fff;border-color:var(--c1)}
.pager button:disabled{opacity:.35;cursor:default}
.pager .p-info{font-size:12px;color:var(--t2);margin-left:8px}
/* ── Toast ── */
#toast{position:fixed;top:20px;right:20px;padding:11px 20px;border-radius:var(--r);font-size:13px;font-weight:500;z-index:999;display:none;max-width:360px;color:#fff;animation:slideD .2s}
#toast.ok{background:var(--c1)}#toast.err{background:var(--red)}#toast.info{background:#1a1a1a}
/* ── Modal ── */
.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeI .12s}
.modal-box{background:#fff;border-radius:14px;width:92%;max-width:520px;max-height:85vh;overflow-y:auto;animation:slideD .18s}
.modal-box.wide{max-width:700px}
.modal-head{padding:18px 24px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.modal-head h3{font-size:15px;font-weight:600}
.modal-body{padding:24px}
/* ── Filter bar ── */
.filter-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.filter-bar .search-wrap{position:relative;flex:1;min-width:200px}
.filter-bar .search-wrap input{padding-left:34px}
.filter-bar .search-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);opacity:.35}
/* ── Empty ── */
.empty{text-align:center;padding:48px 20px;color:var(--t3)}.empty p{margin-top:6px;color:var(--t2)}
/* ── Utilities ── */
.row{display:flex;gap:14px;align-items:center}.flex-1{flex:1}
.mb-14{margin-bottom:14px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mt-14{margin-top:14px}
.text-r{text-align:right}.text-c{text-align:center}
.hidden{display:none!important}
@keyframes fadeI{from{opacity:0}to{opacity:1}}
@keyframes slideD{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:768px){.sidebar{width:60px}.sidebar .logo-text,.sidebar .nav-label,.sidebar .nav-item span{display:none}.nav-item{justify-content:center;padding:10px}.content{padding:16px}.stat-grid{grid-template-columns:1fr 1fr}.grid-2,.grid-3{grid-template-columns:1fr}}
/* ── Scrollbar ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--t3)}
/* ── Lang switcher ── */
.lang-switch{position:relative}
.lang-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;color:var(--t2);border:1px solid var(--bd)}
.lang-btn:hover{border-color:var(--c1);color:var(--c1)}
.lang-dd{position:absolute;top:100%;right:0;margin-top:4px;background:var(--card);border:1px solid var(--bd);border-radius:var(--r2);box-shadow:0 4px 12px rgba(0,0,0,.1);min-width:120px;z-index:50;padding:4px}
.lang-opt{padding:6px 12px;font-size:13px;cursor:pointer;border-radius:4px}
.lang-opt:hover{background:var(--c1l)}
.lang-opt.active{color:var(--c1);font-weight:600}

/* ── Notification bell ── */
.notif-wrap{position:relative}
.notif-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--bd);background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;color:var(--t2);transition:all .12s}
.notif-btn:hover{border-color:var(--c1);color:var(--c1);background:var(--c1x)}
.notif-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:var(--red);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--card)}
.notif-dd{position:absolute;top:100%;right:0;margin-top:8px;width:320px;background:var(--card);border:1px solid var(--bd);border-radius:var(--r);box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:60;overflow:hidden}
.notif-head{padding:12px 16px;font-size:13px;font-weight:600;border-bottom:1px solid var(--bd2)}
.notif-list{max-height:300px;overflow-y:auto}
.notif-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:13px;text-decoration:none;color:var(--t1);border-bottom:1px solid var(--bd2);transition:background .1s}
.notif-item:hover{background:var(--c1x)}
.notif-item.notif-err{border-left:3px solid var(--red)}
.notif-item.notif-warn{border-left:3px solid var(--yellow)}
.notif-item.notif-info{border-left:3px solid var(--blue)}
.notif-icon{font-size:16px;flex-shrink:0;width:24px;text-align:center}
.notif-empty{padding:24px;text-align:center;font-size:13px;color:var(--t3)}

/* ── Global alert banner ── */
.g-alert{padding:10px 24px;font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:space-between;gap:12px}
.g-alert-red{background:var(--bgr);color:var(--red)}
.g-alert-yellow{background:var(--bgy);color:var(--yellow)}
.g-alert-link{font-weight:700;white-space:nowrap;text-decoration:underline}
