*{margin:0;padding:0;box-sizing:border-box}
:root{
  --pr:#2563EB;--pr-l:#EFF6FF;--pr-m:#BFDBFE;
  --gr:#059669;--gr-l:#ECFDF5;
  --am:#D97706;--am-l:#FFFBEB;
  --rd:#DC2626;--rd-l:#FEF2F2;
  --pu:#7C3AED;--pu-l:#F5F3FF;
  --cy:#0891B2;
  --g50:#F8FAFC;--g100:#F1F5F9;--g200:#E2E8F0;--g300:#CBD5E1;
  --g400:#94A3B8;--g500:#64748B;--g600:#475569;--g700:#334155;--g800:#1E293B;
  --sw:220px;--th:54px;
}
html,body{height:100%;font-family:'DM Sans',sans-serif;background:var(--g50);color:var(--g800);font-size:13px}
button,input,select,textarea{font-family:'DM Sans',sans-serif}
button{cursor:pointer}
a{text-decoration:none}

#ls{min-height:100vh;background:linear-gradient(135deg,#EFF6FF 0%,#F5F3FF 50%,#ECFDF5 100%);display:flex;align-items:center;justify-content:center}
.lcard{background:#fff;border-radius:20px;padding:38px;width:368px;border:1px solid var(--g200)}
.llogo{display:flex;align-items:center;gap:10px;margin-bottom:26px}
.llogo-icon{width:40px;height:40px;background:var(--pr);border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:19px}
.llogo-name{font-family:'Sora',sans-serif;font-size:18px;font-weight:600}
.llogo-sub{font-size:11px;color:var(--g400)}
.lh1{font-family:'Sora',sans-serif;font-size:21px;font-weight:600;margin-bottom:4px}
.lsub{font-size:13px;color:var(--g500);margin-bottom:24px}
.flbl{font-size:11px;font-weight:500;color:var(--g600);margin-bottom:5px;display:block}
.fwrap{margin-bottom:14px}
.finput{width:100%;padding:9px 13px;border:1.5px solid var(--g200);border-radius:9px;font-size:13px;color:var(--g800);background:var(--g50);outline:none;transition:border .15s}
.finput:focus{border-color:var(--pr);background:#fff}
.role-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:7px;margin-bottom:18px}
.rbtn{padding:9px 4px;border-radius:9px;border:1.5px solid var(--g200);background:#fff;font-size:11px;font-weight:500;color:var(--g500);text-align:center;transition:all .15s}
.rbtn i{display:block;font-size:16px;margin-bottom:3px}
.rbtn:hover{border-color:var(--pr);color:var(--pr)}
.rbtn.on{border-color:var(--pr);background:var(--pr-l);color:var(--pr)}
.lbtn{width:100%;padding:12px;background:var(--pr);color:#fff;border:none;border-radius:9px;font-size:14px;font-weight:500;transition:background .15s}
.lbtn:hover{background:#1D4ED8}
.lerr{background:var(--rd-l);color:var(--rd);border:1px solid #FECACA;border-radius:9px;padding:9px 12px;font-size:12px;margin-bottom:14px}

#app{height:100vh;overflow:hidden}
.shell{display:flex;height:100vh}

.sidebar{width:var(--sw);background:#fff;border-right:1px solid var(--g200);display:flex;flex-direction:column;flex-shrink:0}
.sb-head{padding:13px 15px;border-bottom:1px solid var(--g100);display:flex;align-items:center;gap:9px}
.sb-logo{width:28px;height:28px;background:var(--pr);border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px}
.sb-brand{font-family:'Sora',sans-serif;font-size:13px;font-weight:600}
.sb-nav{flex:1;padding:10px 9px;overflow-y:auto}
.nav-sec{font-size:10px;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.8px;padding:0 7px;margin:10px 0 5px;display:block}
.nitem{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:7px;font-size:12.5px;color:var(--g600);cursor:pointer;transition:all .15s;margin-bottom:1px;user-select:none}
.nitem i{font-size:15px;flex-shrink:0}
.nitem:hover{background:var(--g100);color:var(--g800)}
.nitem.on{background:var(--pr-l);color:var(--pr);font-weight:500}
.nbadge{margin-left:auto;background:var(--pr);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:20px;min-width:16px;text-align:center}
.nbadge.rd{background:var(--rd)}
.sb-user{padding:11px 14px;border-top:1px solid var(--g100);display:flex;align-items:center;gap:9px}
.uavatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}

.main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.topbar{height:var(--th);background:#fff;border-bottom:1px solid var(--g200);display:flex;align-items:center;padding:0 18px;gap:10px;flex-shrink:0}
.topbar-title{font-family:'Sora',sans-serif;font-size:14px;font-weight:600;flex:1}
.tsearch{display:flex;align-items:center;gap:7px;background:var(--g100);border-radius:7px;padding:5px 11px;width:200px}
.tsearch input{border:none;background:none;font-size:12px;outline:none;color:var(--g700);width:100%}
.ticon-btn{width:32px;height:32px;border-radius:7px;border:1px solid var(--g200);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--g500);font-size:15px;position:relative;transition:all .15s}
.ticon-btn:hover{background:var(--g100)}
.has-dot::after{content:'';position:absolute;top:5px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--rd);border:1.5px solid #fff}

.view{flex:1;overflow-y:auto;padding:18px}

.pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;white-space:nowrap}
.p-new{background:var(--pr-l);color:#1D4ED8}
.p-con{background:var(--am-l);color:#92400E}
.p-pro{background:var(--pu-l);color:#5B21B6}
.p-seg{background:#F0FDF4;color:#166534}
.p-won{background:var(--gr-l);color:#065F46}
.p-lost{background:var(--rd-l);color:#991B1B}
.p-act{background:var(--gr-l);color:#065F46}

.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:7px;border:1px solid var(--g200);background:#fff;color:var(--g600);font-size:12px;font-weight:500;transition:all .15s;cursor:pointer;white-space:nowrap}
.btn:hover{background:var(--g100)}
.btn.prim{background:var(--pr);color:#fff;border-color:var(--pr)}
.btn.prim:hover{background:#1D4ED8}
.btn.sm{padding:4px 10px;font-size:11px}

.card{background:#fff;border:1px solid var(--g200);border-radius:11px;padding:16px}
.card-ttl{font-size:13px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.card-sub{font-size:11px;color:var(--g400);font-weight:400}

.sec-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sec-ttl{font-family:'Sora',sans-serif;font-size:15px;font-weight:600}

.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.g5{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}

.bar-bg{background:var(--g100);border-radius:20px}
.bar-fill{border-radius:20px}

.kpi{background:#fff;border:1px solid var(--g200);border-radius:11px;padding:14px}
.kpi-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;margin-bottom:10px}
.kpi-num{font-family:'Sora',sans-serif;font-size:22px;font-weight:600;line-height:1}
.kpi-lbl{font-size:11px;color:var(--g400);margin-top:3px}
.kpi-delta{font-size:10px;margin-top:5px;display:flex;align-items:center;gap:3px}
.up{color:var(--gr)}.dn{color:var(--rd)}

.act-item{display:flex;gap:9px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--g100)}
.act-item:last-child{border-bottom:none;padding-bottom:0}
.av-sm{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
