@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--teal:#1ab394;--teal-light:#e8f6f3;--teal-hover:#18a689;--teal-bg:#1ab3940a;--blue:#1c84c6;--blue-light:#e8f4fc;--red:#ed5565;--red-light:#fcedef;--yellow:#f8ac59;--yellow-light:#fef6ec;--green:#23c6c8;--green-light:#e6f8f8;--purple:#8b5cf6;--purple-light:#f0ebff;--bg:#f7f8fa;--white:#fff;--text:#1a2332;--ts:#64748b;--tm:#94a3b8;--border:#e8ecf1;--bl:#f1f4f7;--sidebar-w:56px;--topbar-h:56px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}.sidebar{width:var(--sidebar-w);z-index:100;background:#1e2a3a;flex-direction:column;align-items:center;padding:12px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar .logo{background:var(--teal);color:#fff;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;margin-bottom:20px;font-size:14px;font-weight:700;display:flex}.sidebar nav{flex-direction:column;flex:1;gap:4px;display:flex}.sidebar nav a{color:#64748b;cursor:pointer;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;text-decoration:none;transition:all .2s;display:flex;position:relative}.sidebar nav a:hover{color:#cbd5e1;background:#ffffff0f}.sidebar nav a.active{color:#fff;background:#1ab3942e}.sidebar nav a.active:before{content:"";background:var(--teal);border-radius:0 3px 3px 0;width:3px;position:absolute;top:8px;bottom:8px;left:-4px}.sidebar .avatar-bottom{background:linear-gradient(135deg, var(--teal), var(--blue));color:#fff;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;margin-top:auto;font-size:11px;font-weight:600;display:flex}.topbar{top:0;left:var(--sidebar-w);height:var(--topbar-h);background:var(--white);border-bottom:1px solid var(--border);z-index:90;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:fixed;right:0}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-title{font-size:17px;font-weight:700}.topbar .badge-admin{background:var(--teal-light);color:var(--teal);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.topbar-right{color:var(--ts);align-items:center;gap:16px;font-size:13px;display:flex}.main{margin-left:var(--sidebar-w);margin-top:var(--topbar-h);min-height:calc(100vh - var(--topbar-h));padding:24px 28px 40px}.g4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.g3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.g2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.mb16{margin-bottom:16px}.mb24{margin-bottom:24px}.card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:20px;transition:box-shadow .2s,transform .15s;box-shadow:0 1px 3px #0000000a,0 1px 2px #00000005}.card:hover{box-shadow:0 4px 12px #0000000f}.card-title{text-transform:uppercase;letter-spacing:.5px;color:var(--ts);align-items:center;gap:8px;margin-bottom:12px;font-size:12px;font-weight:600;display:flex}.card-title .dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.kpi-card{position:relative;overflow:hidden}.kpi-card .kpi-left-border{border-radius:16px 0 0 16px;width:4px;position:absolute;top:0;bottom:0;left:0}.kpi-card .kpi-body{justify-content:space-between;align-items:flex-end;display:flex}.kpi-card .kpi-info{flex:1}.kpi-card .kpi-num{font-size:28px;font-weight:700;line-height:1.1}.kpi-card .kpi-secondary{color:var(--ts);margin-top:4px;font-size:13px}.kpi-card .kpi-delta{margin-top:4px;font-size:12px;font-weight:500}.kpi-card .kpi-delta.up{color:var(--teal)}.kpi-card .kpi-delta.down{color:var(--red)}.mini-bars{align-items:flex-end;gap:2px;height:36px;display:flex}.mini-bars .bar{border-radius:2px;width:7px;min-height:2px;transition:height .3s}.group-hdr{color:var(--tm);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;margin:24px 0 10px;font-size:11px;font-weight:700;display:flex}.group-hdr:first-child{margin-top:0}.group-hdr .gh-bar{border-radius:2px;flex-shrink:0;width:4px;height:14px}.kpi-conv{text-align:center}.kpi-conv .conv-label{color:var(--tm);margin-bottom:6px;font-size:11px}.kpi-conv .conv-val{font-size:22px;font-weight:700;line-height:1}.kpi-conv .conv-sub{color:var(--ts);margin-top:4px;font-size:11px}.kpi-conv .conv-delta{margin-top:4px;font-size:11px;font-weight:600}.day-tbl{border-collapse:collapse;width:100%;font-size:13px}.day-tbl th{text-transform:uppercase;letter-spacing:.4px;color:var(--tm);text-align:right;border-bottom:2px solid var(--border);padding:8px 10px;font-size:10px;font-weight:700}.day-tbl th:first-child{text-align:left}.day-tbl td{border-bottom:1px solid var(--bl);text-align:right;padding:8px 10px}.day-tbl td:first-child{text-align:left;color:var(--ts);font-weight:500}.day-tbl tr:hover td{background:var(--teal-bg)}.day-tbl .col-today{color:var(--text);background:var(--teal-light);font-weight:700}.day-tbl .col-total{color:var(--teal);font-weight:700}.day-tbl .col-avg{color:var(--ts);font-weight:600}.day-tbl .row-header td{color:var(--text);font-weight:600}.tbl{border-collapse:collapse;width:100%}.tbl th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--ts);border-bottom:2px solid var(--border);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:600}.tbl td{border-bottom:1px solid var(--bl);white-space:nowrap;padding:10px 12px;font-size:13px}.tbl tr:hover td{background:var(--teal-bg)}.tbl .total td{background:var(--bl);border-top:2px solid var(--border);font-weight:600}.badge{white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-green{background:var(--teal-light);color:var(--teal)}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-yellow{background:var(--yellow-light);color:var(--yellow)}.badge-red{background:var(--red-light);color:var(--red)}.badge-purple{background:var(--purple-light);color:var(--purple)}.badge-muted{background:var(--bl);color:var(--tm)}.filters{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.fpill{border:1px solid var(--border);background:var(--white);cursor:pointer;color:var(--ts);border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.fpill:hover{border-color:var(--teal);color:var(--teal)}.fpill.active{background:var(--teal);color:#fff;border-color:var(--teal)}.fpill .cnt{font-size:11px;font-weight:600}.tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab{color:var(--ts);cursor:pointer;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:13px;font-weight:500;transition:all .2s}.tab:hover{color:var(--text)}.tab.active{color:var(--teal);border-bottom-color:var(--teal);font-weight:600}.prog{background:var(--bl);border-radius:4px;height:8px;display:flex;overflow:hidden}.prog .seg{height:100%;transition:width .3s}.search-bar{gap:10px;margin-bottom:16px;display:flex}.search-input{border:1px solid var(--border);border-radius:10px;outline:none;flex:1;padding:8px 14px;font-family:inherit;font-size:13px;transition:border .2s}.search-input:focus{border-color:var(--teal)}.btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.btn-teal{background:var(--teal);color:#fff}.btn-teal:hover{background:var(--teal-hover)}.btn-outline{background:var(--white);border:1px solid var(--border);color:var(--ts)}.btn-outline:hover{border-color:var(--teal);color:var(--teal)}.btn-sm{border-radius:8px;padding:5px 12px;font-size:12px}.detail-overlay{z-index:200;opacity:0;pointer-events:none;background:#00000040;transition:opacity .25s;position:fixed;inset:0}.detail-overlay.open{opacity:1;pointer-events:all}.detail-panel{background:var(--white);z-index:210;width:500px;padding:28px;transition:right .3s;position:fixed;top:0;bottom:0;right:-520px;overflow-y:auto;box-shadow:-4px 0 24px #00000014}.detail-panel.open{right:0}.detail-panel .dp-header{align-items:center;gap:14px;margin-bottom:24px;display:flex}.detail-panel .dp-avatar{background:var(--teal-light);width:48px;height:48px;color:var(--teal);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.detail-panel .dp-name{font-size:18px;font-weight:700}.detail-panel .dp-email{color:var(--ts);font-size:13px}.detail-panel .dp-close{background:var(--bl);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.detail-panel .dp-close:hover{background:var(--red-light);color:var(--red)}.detail-panel .dp-actions{gap:8px;margin-bottom:24px;display:flex}.detail-panel .dp-section{margin-bottom:20px}.detail-panel .dp-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--ts);border-bottom:1px solid var(--bl);margin-bottom:10px;padding-bottom:6px;font-size:12px;font-weight:600}.detail-panel .dp-row{justify-content:space-between;padding:6px 0;font-size:13px;display:flex}.detail-panel .dp-row .dp-label{color:var(--ts)}.detail-panel .dp-row .dp-val{font-weight:500}.detail-panel .dp-check{color:var(--teal);margin-right:6px}.detail-panel .dp-notes textarea{border:1px solid var(--border);resize:vertical;border-radius:10px;outline:none;width:100%;min-height:80px;padding:10px 12px;font-family:inherit;font-size:13px}.detail-panel .dp-notes textarea:focus{border-color:var(--teal)}.toast-container{z-index:300;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast-msg{color:#fff;background:#1e2a3a;border-radius:10px;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:500;animation:.3s toastIn,.3s 2.7s forwards toastOut;display:flex;box-shadow:0 4px 12px #00000026}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.client-yellow{font-weight:600;color:var(--yellow)!important}.client-red{font-weight:600;color:var(--red)!important}.client-muted{color:var(--tm)!important}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--tm)}.tbl tr[data-client],.tbl tr.clickable{cursor:pointer}
