:root{--primary:#20a53a;--primary-dark:#1a8c30;--primary-light:#e8f5e9;--primary-bg:rgba(32,165,58,.08);--bg:#f1f1f1;--sidebar-bg:#fff;--card:#fff;--border:#e6e6e6;--border-light:#f0f0f0;--text:#333;--muted:#888;--heading:#222;--danger:#e74c3c;--warn:#e6a23c;--info:#409eff;--success:#20a53a;--shadow:0 1px 4px rgba(0,0,0,.08);--radius:3px;--sidebar-w:220px}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font:14px/1.6 "Microsoft YaHei","PingFang SC","Helvetica Neue",sans-serif;color:var(--text);background:var(--bg)}
a{color:var(--primary);text-decoration:none}
::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;background:var(--sidebar-bg);border-right:1px solid var(--border);z-index:10}
.brand{padding:14px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.logo{width:36px;height:36px;border-radius:6px;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}
.brand h1{font-size:16px;font-weight:600}
.brand-sub{font-size:11px;color:var(--muted);margin-top:2px}
.nav-title{font-size:12px;color:var(--muted);padding:14px 18px 6px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;color:#555;cursor:pointer;transition:all .15s;font-size:13px;border-left:3px solid transparent;text-decoration:none}
.nav-item:hover{background:#f5f5f5;color:var(--primary)}
.nav-item.active{background:var(--primary-light);color:var(--primary);border-left-color:var(--primary);font-weight:600}
.nav-icon{width:20px;text-align:center;font-size:16px;flex-shrink:0;font-style:normal}
.main{display:grid;grid-template-rows:auto 1fr;min-width:0;background:var(--bg)}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 20px;height:74px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}
.search-wrap{flex:1;max-width:480px;position:relative}
.search{display:flex;align-items:center;gap:8px;padding:0 10px;height:32px;border-radius:var(--radius);background:#f5f5f5;border:1px solid var(--border)}
.search:focus-within{background:#fff;border-color:var(--primary)}
.search input{flex:1;border:0;outline:0;background:transparent;color:var(--text);font-size:13px}
.search-dropdown{display:none;position:absolute;top:38px;left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 6px 24px rgba(0,0,0,.12);max-height:480px;overflow:auto;z-index:30}
.search-dropdown.active{display:block}
.search-group{padding:6px 0;border-bottom:1px solid var(--border-light)}
.search-group:last-child{border-bottom:0}
.search-group-title{padding:6px 14px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:6px}
.search-group-title .iconfont{font-size:13px}
.search-item{display:block;padding:8px 14px;text-decoration:none;color:var(--text);transition:background .12s}
.search-item:hover,.search-item.focus{background:var(--primary-bg)}
.search-item strong{display:block;font-size:13px;color:var(--heading);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-item small{display:block;font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-item mark{background:#fff7c0;color:var(--heading);padding:0 1px;border-radius:2px}
.top-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.topbar-user{display:flex;align-items:center;gap:8px;padding-left:8px;border-left:1px solid var(--border);cursor:pointer}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}
.user-info{display:flex;flex-direction:column;line-height:1.3}
.user-name{font-size:13px;font-weight:600;color:var(--heading)}
.user-role{font-size:11px;color:var(--muted)}
.sidebar-footer{margin:12px;padding:12px;border-radius:var(--radius);background:#f9f9f9;border:1px solid var(--border);color:var(--muted);font-size:12px;line-height:1.7}
.content{padding:14px 20px 24px;display:grid;gap:16px;align-content:start}
.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;min-width:0}
.panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:#fafafa}
.panel-header h2{font-size:14px;font-weight:600;color:var(--heading)}
.panel-header p{margin-top:2px;color:var(--muted);font-size:12px}
.panel-body{padding:14px 16px}
.btn{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:var(--radius);padding:6px 14px;cursor:pointer;transition:all .15s;font-size:13px;font-family:inherit;display:inline-flex;align-items:center;gap:4px;text-decoration:none}
.btn:hover{border-color:#ccc;background:#fafafa}
.btn-primary{border-color:var(--primary);background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-danger{border-color:var(--danger);color:var(--danger)}
.btn-sm{padding:3px 10px;font-size:12px}
.btn-block{width:100%;justify-content:center}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px 12px;border-bottom:1px solid var(--border-light);font-size:13px;text-align:left;vertical-align:top}
.table th{color:var(--muted);font-weight:600;background:#fafafa;border-bottom-color:var(--border)}
.table tr:hover td{background:#f9fdf9}
.table-sites{table-layout:fixed}.table-sites td,.table-sites th{vertical-align:middle}.table-sites td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-sites td:nth-child(2){white-space:normal;line-height:1.5}.table-sites td:nth-child(2) span{display:-webkit-box;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius);font-size:12px;white-space:nowrap}
.badge-green{color:var(--success);background:#e8f5e9;border:1px solid #c8e6c9}
.badge-blue{color:var(--info);background:#e3f2fd;border:1px solid #bbdefb}
.badge-yellow{color:var(--warn);background:#fdf6ec;border:1px solid #faecd8}
.badge-red{color:var(--danger);background:#fef0f0;border:1px solid #fde2e2}
.badge-gray{color:#6b7280;background:#f3f4f6;border:1px solid #e5e7eb}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.stats-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;text-align:center}
.stat-card .stat-label{font-size:13px;color:var(--muted);margin-bottom:4px}
.stat-card .stat-value{font-size:26px;font-weight:700;color:var(--heading)}
.stat-card.stat-green .stat-value{color:#20a53a}
.stat-card.stat-red .stat-value{color:#e74c3c}
.stat-card.stat-blue .stat-value{color:var(--info)}
.stat-card.stat-yellow .stat-value{color:var(--warn)}
.form-group{margin-bottom:12px}
.form-group label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px;font-weight:600}
.form-group input,.form-group select,.form-group textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text);font-size:13px;font-family:inherit;padding:7px 10px;outline:0;transition:border .15s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary)}
.form-group textarea{min-height:100px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.page-head{display:flex;justify-content:space-between;align-items:center;gap:12px;height:60px}
.page-title h2{font-size:16px;font-weight:600;color:var(--heading);margin:0 0 2px}
.page-title p{color:var(--muted);font-size:12px;margin:0}
.hero{display:grid;grid-template-columns:1.4fr .9fr .9fr .9fr;gap:12px;margin-bottom:2px}
.stat{padding:16px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);min-height:100px;position:relative}
.stat b{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
.stat .num{font-size:28px;font-weight:700;color:var(--heading)}
.stat span{color:var(--muted);font-size:12px;line-height:1.6}
.stat.main-stat{border-left:3px solid var(--primary);display:flex;flex-direction:column;justify-content:space-between}
.stat.main-stat .num{color:var(--primary)}
.tabs{display:flex;gap:0;flex-wrap:wrap}
.tab{border:1px solid var(--border);background:#fff;color:var(--text);padding:5px 12px;font-size:12px;cursor:pointer;margin-left:-1px;text-decoration:none}
.tab:first-child{border-radius:var(--radius) 0 0 var(--radius)}.tab:last-child{border-radius:0 var(--radius) var(--radius) 0}
.tab.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary);font-weight:600;position:relative;z-index:1}
.stack{display:grid;gap:10px}
.panel+.panel{margin-top:4px}
.mini-card{padding:12px;border-radius:var(--radius);background:#fafafa;border:1px solid var(--border-light)}
.mini-card b{display:block;margin-bottom:4px;font-size:13px;color:var(--heading)}
.mini-card span{color:var(--muted);font-size:12px;line-height:1.6}
.progress{margin-top:8px;height:8px;border-radius:4px;background:#eee;overflow:hidden}
.progress>i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--primary),#6fcf97)}
.list{display:grid;gap:8px}
.list-item{padding:10px 12px;border-radius:var(--radius);background:#fafafa;border:1px solid var(--border-light);display:flex;justify-content:space-between;gap:10px;align-items:flex-start;cursor:pointer;transition:all .15s}
.list-item:hover{border-color:var(--primary);background:var(--primary-bg)}
.list-item strong{display:block;margin-bottom:2px;font-size:13px;color:var(--heading)}
.list-item small{color:var(--muted);font-size:12px;line-height:1.6;display:block}
.list-item em{font-style:normal;color:var(--heading);white-space:nowrap;font-size:13px}
.pager{display:flex;align-items:center;justify-content:flex-end;padding:10px 0;font-size:12px;color:var(--muted);margin-top:8px}
.pager-btns{display:flex;gap:4px}
.pager-btns button,.pager-btns a{width:28px;height:28px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text);font-size:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.pager-btns .active{background:var(--primary);color:#fff;border-color:var(--primary)}
.pager .pagination{display:flex;gap:4px;list-style:none;padding:0;margin:0;flex-wrap:wrap}
.pager .pagination li{display:inline-flex}
.pager .pagination li a,.pager .pagination li span{min-width:28px;height:28px;padding:0 8px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text);font-size:12px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;line-height:1}
.pager .pagination li a:hover{border-color:var(--primary);color:var(--primary)}
.pager .pagination li.active span,.pager .pagination li.active a{background:var(--primary);color:#fff;border-color:var(--primary)}
.pager .pagination li.disabled span{color:#c0c4cc;background:#f5f7fa;cursor:not-allowed}
.grid-2{display:grid;grid-template-columns:1.2fr .8fr;gap:16px}
.grid-2>:only-child{grid-column:1/-1}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}

.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-box{width:380px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.login-box h1{font-size:20px;color:var(--heading);margin-bottom:24px;text-align:center}
.btn-login{width:100%;margin-top:12px;padding:10px;justify-content:center}

.filter-select,.filter-bar select,.filter-bar input[type="text"],.filter-bar input[type="search"],.filter-bar input[type="month"],.filter-bar input[type="date"],.filter-bar input[type="number"]{height:34px;box-sizing:border-box;border:1px solid var(--border);border-radius:var(--radius);padding:0 10px;font-size:13px;line-height:32px;background:#fff;color:var(--text);outline:0;transition:border .15s}
.filter-select:focus,.filter-bar select:focus,.filter-bar input:focus{border-color:var(--primary)}
.filter-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.filter-bar .btn{height:34px;box-sizing:border-box;line-height:32px;padding:0 14px}
.btn-danger:hover{background:var(--danger);color:#fff}
.notify-bell{cursor:pointer;font-size:18px;color:var(--muted);position:relative}
.notify-dot{position:absolute;top:-2px;right:-4px;width:8px;height:8px;background:var(--danger);border-radius:50%;display:block;font-style:normal}
code{background:#f5f5f5;padding:1px 5px;border-radius:2px;font-size:12px;color:#555}
.text-muted{color:var(--muted)}.text-sm{font-size:12px}
.site-name-link{color:var(--primary);font-weight:600;cursor:pointer;text-decoration:none}
.site-name-link:hover{text-decoration:underline}
.sp-tabs{display:flex;gap:0;padding:0 18px;border-bottom:1px solid var(--border);background:#fafafa}
.sp-tab{padding:10px 16px;font-size:13px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;text-decoration:none}
.sp-tab:hover{color:var(--text)}.sp-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}
.sp-panel{display:none;animation:fade .15s ease}.sp-panel.active{display:block}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:12px;color:var(--muted);font-weight:600}
.field input,.field select,.field textarea{border:1px solid var(--border);border-radius:var(--radius);padding:7px 10px;font-size:13px;font-family:inherit;outline:0;background:#fff;color:var(--text);transition:border .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary)}
.field textarea{min-height:80px;resize:vertical}
.form-actions{display:flex;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border-light)}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;align-items:center;justify-content:center;padding:20px;z-index:50}
.modal.active{display:flex}
.modal-card{width:min(920px,100%);max-height:88vh;overflow:auto;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 20px rgba(0,0,0,.15)}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border);background:#fafafa}
.modal-head b{font-size:15px;color:var(--heading)}
.modal-body{padding:16px 18px 20px}
.close{width:32px;height:32px;border-radius:var(--radius);border:1px solid var(--border);background:#fff;color:var(--text);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}
.close:hover{background:#f5f5f5}
.modal-sm{width:min(540px,100%)}
.notify-head-actions{display:flex;align-items:center;gap:8px}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:50px 20px;text-align:center;color:var(--muted)}
.empty-state .iconfont{font-size:56px;color:#dcdcdc;margin-bottom:12px;line-height:1}
.empty-state p{font-size:14px;color:var(--heading);margin:0 0 4px;font-weight:500}
.empty-state span{font-size:12px;color:var(--muted);line-height:1.6}
.empty-error .iconfont{color:var(--danger);opacity:.6}
.notify-danger{border-left:3px solid var(--danger)}
.notify-warn{border-left:3px solid var(--warn)}
.notify-success{border-left:3px solid var(--success)}
.notify-info{border-left:3px solid var(--info)}
.list{display:grid;gap:8px}
.list-item{padding:10px 12px;border-radius:var(--radius);background:#fafafa;border:1px solid var(--border-light);display:flex;justify-content:space-between;gap:10px;align-items:flex-start;cursor:pointer;transition:all .15s}
.list-item:hover{border-color:var(--primary);background:var(--primary-bg)}
.list-item strong{display:block;margin-bottom:2px;font-size:13px;color:var(--heading)}
.list-item small{color:var(--muted);font-size:12px;line-height:1.6;display:block}
.list-item em{font-style:normal;color:var(--heading);white-space:nowrap;font-size:13px}
.coming-soon-body{text-align:center;padding:60px 20px}
.coming-soon-icon{font-size:48px;margin-bottom:16px}
.coming-soon-title{font-size:18px;color:var(--heading);margin-bottom:8px}
.coming-soon-desc{color:var(--muted);font-size:13px}
#toastBox{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{pointer-events:auto;min-width:280px;max-width:400px;padding:12px 16px 8px;border-radius:var(--radius);background:#fff;box-shadow:0 6px 24px rgba(0,0,0,.12);display:flex;align-items:center;gap:10px;position:relative;overflow:hidden;transform:translateX(110%);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--border)}
.toast.show{transform:translateX(0);opacity:1}
.toast.hide{transform:translateX(110%);opacity:0}
.toast-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.toast-success .toast-icon{background:var(--primary-light);color:var(--primary)}
.toast-error .toast-icon{background:#fde8e8;color:var(--danger)}
.toast-warn .toast-icon{background:#fdf6ec;color:var(--warn)}
.toast-info .toast-icon{background:#ecf5ff;color:var(--info)}
.toast-msg{font-size:13px;color:var(--heading);font-weight:500;flex:1}
.toast-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--border-light)}
.toast-progress i{display:block;height:100%;border-radius:0 3px 3px 0;animation:toastShrink linear forwards}
.toast-success .toast-progress i{background:var(--primary)}
.toast-error .toast-progress i{background:var(--danger)}
.toast-warn .toast-progress i{background:var(--warn)}
.toast-info .toast-progress i{background:var(--info)}
@keyframes toastShrink{from{width:100%}to{width:0}}
.confirm-card{width:min(380px,90%);border-radius:var(--radius)}
.confirm-body{padding:28px 24px 16px;text-align:center}
.confirm-icon{display:inline-flex;width:48px;height:48px;border-radius:50%;background:#fdf6ec;color:var(--warn);font-size:22px;align-items:center;justify-content:center;margin-bottom:14px}
.confirm-body p{font-size:14px;color:var(--text);line-height:1.7}
.confirm-foot{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid var(--border);background:#fafafa;border-radius:0 0 var(--radius) var(--radius)}
.btn-danger{border-color:var(--danger);background:var(--danger);color:#fff}
@keyframes fade{from{opacity:.6;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}
.empty-state{padding:56px 20px;text-align:center}
.empty-state-icon{width:60px;height:60px;margin:0 auto 14px;border-radius:50%;background:var(--bg);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center}
.empty-state-icon::after{content:'';display:block;width:26px;height:26px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26' fill='none' stroke='%23bbb' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 9l5.5-5 5.5 5'/%3E%3Cpath d='M3 9v11a2 2 0 002 2h16a2 2 0 002-2V9'/%3E%3Cpath d='M23 9l-5.5-5L12 9'/%3E%3Cline x1='10' y1='16' x2='16' y2='16'/%3E%3C/svg%3E") no-repeat center/contain}
.empty-state p{color:var(--muted);font-size:13px;margin:0}
.empty-state .btn{margin-top:14px}
.settings-tabs{display:flex;gap:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.tab-item{padding:10px 20px;font-size:13px;color:#555;border-right:1px solid var(--border);text-decoration:none;transition:all .15s}
.tab-item:last-child{border-right:0}
.tab-item:hover{background:#f5f5f5;color:var(--primary)}
.tab-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}
.input-full{width:100%}
@media(max-width:1200px){.hero,.grid-2,.grid-3{grid-template-columns:1fr}.app{grid-template-columns:1fr}.sidebar{position:relative;height:auto;border-right:0;border-bottom:1px solid var(--border)}}
