:root{--bg: #eef3f8;--surface: #ffffff;--panel: #1f3144;--panel-2: #263f58;--text: #102030;--muted: #6b7a8a;--line: #d6dde5;--accent: #2fa3e6;--accent-soft: #d9eefb}html,body,#root{height:100%}body{margin:0;font-family:Segoe UI Variable,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Noto Sans CJK SC,sans-serif;font-size:14px;line-height:1.5;font-weight:400;letter-spacing:.1px;color:var(--text);background:radial-gradient(circle at 15% 10%,#f8fbfe,#edf2f7 45%,#e4ebf2);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none}.container{max-width:860px;margin:48px auto;padding:0 16px}.shell{--sidebar-width: 320px;height:100vh;display:grid;grid-template-columns:var(--sidebar-width) 8px 1fr;overflow:hidden}.sidebar{background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);color:#d7e4f1;padding:20px 12px;border-right:1px solid rgba(255,255,255,.12);overflow:hidden;display:flex;flex-direction:column;height:100vh;min-height:0}.sidebar-head{display:flex;gap:8px;align-items:center}.icon-toggle{width:34px;min-width:34px;height:34px;border-radius:3px;border:1px solid rgba(255,255,255,.22);background:#ffffff17;color:#dce9f5;font-weight:700;padding:0}.brand{flex:1;display:flex;align-items:center;gap:10px;background:#2fa3e62e;border:1px solid rgba(47,163,230,.45);border-radius:3px;padding:12px;min-width:0}.brand-link{text-decoration:none;color:inherit}.brand-logo{width:40px;height:40px;border-radius:10px;object-fit:cover;background:#2fa3e6;border:1px solid rgba(255,255,255,.22);flex-shrink:0}.brand-title{font-size:16px;font-weight:700}.brand-subtitle{font-size:12px;opacity:.8}.user-block{padding:12px;border-radius:3px;background:#ffffff12;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:10px}.avatar{width:34px;min-width:34px;height:34px;border-radius:999px;background:#2fa3e6e6;color:#fff;display:grid;place-items:center;font-weight:700}.user-email{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu{margin-top:18px;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(133,165,196,.55) rgba(255,255,255,.08)}.menu::-webkit-scrollbar{width:8px}.menu::-webkit-scrollbar-track{background:#ffffff14;border-radius:999px}.menu::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#8fb1d2bf,#6e91b2bf);border-radius:999px;border:1px solid rgba(255,255,255,.18)}.menu::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#a5c3e0e6,#7ea0c0e6)}.ai-box{margin-top:10px;margin-bottom:14px;padding:10px;border-radius:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.14);display:grid;gap:8px}.ai-box-title{font-size:12px;font-weight:700;color:#dce9f5}.ai-box-input{width:100%;box-sizing:border-box;border-radius:6px;border:1px solid rgba(255,255,255,.22);background:#ffffff24;color:#f0f6fb;padding:8px;resize:vertical}.ai-box-input::placeholder{color:#dce9f5b8}.ai-result-card{margin-bottom:14px}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}.menu-group{margin-bottom:8px}.menu-group-button{width:100%;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:3px;color:#dce9f5;font-weight:700;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;cursor:pointer}.menu-title{display:flex;align-items:center;gap:8px;min-width:0}.menu-svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;min-width:16px}.menu-chevron{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .15s ease}.menu-chevron.is-open{transform:rotate(180deg)}.menu-children{margin-top:6px;display:grid;gap:4px}.menu-item{color:#bad0e4;border-radius:3px;padding:9px 12px;display:block}.sidebar .secondary{border-radius:3px}.menu-item:hover{background:#ffffff14}.menu-item.active{background:var(--accent-soft);color:#12476a;font-weight:700}.sidebar-footer{margin-top:12px}.footer-row{display:flex;align-items:center;gap:8px}.footer-row .user-block{flex:1;min-width:0;height:50px;box-sizing:border-box;padding:0 12px}.footer-row .secondary{height:50px;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;white-space:nowrap}.sidebar-footer .secondary{display:inline-flex;align-items:center;gap:8px}.icon-only{display:none}.resize-handle{cursor:col-resize;background:linear-gradient(180deg,#dfe7f0,#edf2f7);border-right:1px solid #d0d9e3}.resize-handle:hover{background:#ccd9e7}.main{padding:14px 20px 20px;overflow-y:auto;height:100vh;box-sizing:border-box}.page-header{margin-bottom:10px}.breadcrumb-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:#f3f6fa;border:1px solid #e0e7ef;border-radius:999px;padding:8px 12px}.breadcrumb-item{color:#2b5d83;font-size:15px;font-weight:500}.breadcrumb-item.is-current{color:#4a5565;font-weight:600}.breadcrumb-sep{color:#9aa7b6;font-size:16px;line-height:1}.card h2{font-size:36px;font-weight:600;letter-spacing:.15px}.main .card>h2:first-child{display:none}.card{border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:16px;box-shadow:0 8px 24px #1425380f}input,select,button{font:inherit}input,select{width:100%;box-sizing:border-box;background:#fff;color:var(--text);border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-size:15px}button{cursor:pointer;background:var(--accent);color:#fff;border:0;border-radius:8px;padding:10px 12px;font-weight:700}button.secondary{background:transparent;color:inherit;border:1px solid rgba(255,255,255,.35)}.row{display:flex;gap:12px;flex-wrap:wrap}.row>*{flex:1;min-width:220px}table{width:100%;border-collapse:collapse;margin-top:14px}.monitor-last-time{font-size:9px;color:#5a6b85;line-height:1.1}.monitor-last-time-stale{font-size:12px;color:#d90429;font-weight:800;animation:gc-blink-alert 1s steps(2,start) infinite}@keyframes gc-blink-alert{0%{opacity:1}50%{opacity:.2}to{opacity:1}}th,td{border-bottom:1px solid #e6ecf2;padding:12px 10px;font-size:15px;line-height:1.45;text-align:center;vertical-align:middle}th{color:var(--muted);font-weight:600;white-space:nowrap;position:sticky;top:0;z-index:2;background:#f7fafc}.th-break{white-space:pre-line;display:inline-block;line-height:1.2}.actions-table tr.actions-main-row td:not([rowspan]){border-bottom:1px dashed #c6d1de}.actions-table tr.actions-main-row td[rowspan],.actions-table tr.actions-sub-row td{border-bottom:1px solid #b8c6d6}.muted{color:var(--muted)}.error{color:#b00020}.loading-text{color:#c73333;font-weight:600}button.syncing-btn{background:#d32f2f;border-color:#d32f2f;color:#fff}.mailchimp-table th,.mailchimp-table td{padding:8px 6px;font-size:13px;line-height:1.25;white-space:nowrap}.mailchimp-title-cell{min-width:260px;max-width:320px;white-space:normal!important;overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35;max-height:2.7em}.mailchimp-title-cell a{white-space:normal!important;overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35;max-height:2.7em}.graphic-chart-wrap{margin-top:6px}.graphic-legend{display:flex;flex-wrap:wrap;gap:8px 16px;margin-bottom:8px}.legend-item{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#2f4459;white-space:nowrap}.legend-dot{width:9px;height:9px;border-radius:999px;border:1px solid rgba(0,0,0,.2)}.graphic-chart{width:100%;min-width:1020px;border-radius:10px;box-shadow:inset 0 0 0 1px #ffffff0d}.grid-line-x,.grid-line-y{stroke:#2e3c50;stroke-width:.75}.axis-line{stroke:#8aa4be;stroke-width:1}.axis-label{fill:#c4d4e6;font-size:11px}.hover-line{stroke:#ffffffa6;stroke-width:1;stroke-dasharray:4 4}.hover-point{stroke:#00000080;stroke-width:1}.tooltip-bg{fill:#091422e0;stroke:#94b1ce80;stroke-width:1}.tooltip-title{fill:#d7e6f4;font-size:12px;font-weight:700}.tooltip-item{fill:#c4d4e6;font-size:12px}.is-collapsed .label-content{display:none}.is-collapsed .brand,.is-collapsed .user-block,.is-collapsed .menu-group-button,.is-collapsed .sidebar-footer .secondary{justify-content:center}.is-collapsed .menu-group-button{padding-left:8px;padding-right:8px}.is-collapsed .menu-item,.is-collapsed .menu-children{display:none}.is-collapsed .icon-only{display:inline}@media (max-width: 980px){.shell{grid-template-columns:1fr}.resize-handle{display:none}.sidebar{border-right:0;border-bottom:1px solid rgba(255,255,255,.12)}.main{padding:16px}.container{margin:20px auto}.is-collapsed .label-content{display:inline}.is-collapsed .menu-item,.is-collapsed .menu-children{display:grid}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;box-sizing:border-box}.login-card{width:min(960px,100%)}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;box-sizing:border-box}.login-logo-wrap{margin-bottom:12px}.login-logo{width:84px;height:84px;border-radius:16px;object-fit:cover;box-shadow:0 10px 22px #162c442e}.login-card{width:min(860px,100%)}.login-form-col{max-width:520px;margin:0 auto}.login-field{margin-bottom:12px}.login-actions{justify-content:center}.table-scroll{overflow:auto;max-height:calc(100vh - 220px);border-radius:8px}.table-scroll table{margin-top:0}
