:root{--bg-page: #f5f6f8;--bg-surface: #ffffff;--bg-muted: #f1f3f5;--bg-hover: #e9ecef;--border: #e1e5ea;--border-strong: #ced4da;--text-1: #1f2937;--text-2: #4b5563;--text-3: #9ca3af;--sidebar-bg: #2c3e50;--sidebar-bg-2: #34495e;--sidebar-text: #cbd5e1;--sidebar-text-active: #ffffff;--sidebar-active-bg: #3a536c;--sidebar-section: #7f8c9b;--topbar-bg: #ffffff;--topbar-border: #e1e5ea;--accent: #20b884;--accent-strong: #1ba276;--accent-soft: #20b88415;--info: #2bb6c9;--info-soft: #2bb6c918;--success: #20b884;--success-soft: #20b88418;--warning: #f0a020;--warning-soft: #f0a02018;--danger: #e74c3c;--danger-soft: #e74c3c18;--neutral: #95a5a6;--neutral-soft: #95a5a618;--r-sm: 4px;--r-md: 6px;--r-lg: 10px;--shadow-1: 0 1px 2px rgba(20, 30, 50, .04);--shadow-2: 0 4px 12px rgba(20, 30, 50, .08);--shadow-3: 0 8px 28px rgba(20, 30, 50, .12);--font-body: "Inter", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "Cascadia Code", monospace}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg-page);color:var(--text-1);font-family:var(--font-body);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}a{color:var(--info);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;color:var(--text-1)}h1{font-size:20px}h2{font-size:17px}h3{font-size:15px}h4{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2)}button{font-family:inherit}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.sidebar{background:var(--sidebar-bg);color:var(--sidebar-text);position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;display:flex;flex-direction:column}.sidebar .user-block{padding:18px 16px;background:var(--sidebar-bg-2);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:12px}.sidebar .user-block .avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--info),var(--accent));display:grid;place-items:center;color:#fff;font-weight:700;flex-shrink:0}.sidebar .user-block .name{color:#fff;font-weight:500;font-size:13px}.sidebar .user-block .sub{font-size:11px;color:var(--sidebar-section);margin-top:2px}.sidebar .user-block .logout{color:var(--sidebar-section);font-size:11px;cursor:pointer;background:transparent;border:none;padding:2px 0}.sidebar .user-block .logout:hover{color:#fff;text-decoration:underline}.sidebar .nav-list{flex:1;padding:8px 0}.sidebar .group-title{font-size:10px;color:var(--sidebar-section);text-transform:uppercase;letter-spacing:.1em;padding:14px 16px 6px;font-weight:600}.sidebar a.nav{display:flex;align-items:center;gap:10px;padding:9px 16px;color:var(--sidebar-text);text-decoration:none;font-size:13px;position:relative;border-left:3px solid transparent}.sidebar a.nav:hover{background:#ffffff0a;color:#fff;text-decoration:none}.sidebar a.nav.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);border-left-color:var(--accent)}.sidebar a.nav .icon{width:18px;text-align:center;opacity:.85;font-size:14px}.sidebar a.nav .badge{margin-left:auto;background:var(--danger);color:#fff;font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;min-width:18px;text-align:center}.topbar{background:var(--topbar-bg);border-bottom:1px solid var(--topbar-border);height:56px;display:flex;align-items:center;padding:0 24px;gap:18px;position:sticky;top:0;z-index:50}.topbar h1{margin-right:auto}.topbar-search{flex:1;max-width:460px;position:relative}.topbar-search input{width:100%;height:32px;padding:0 12px 0 36px;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--r-md);font-size:13px;color:var(--text-1)}.topbar-search input:focus{outline:none;border-color:var(--info);background:#fff}.topbar-search:before{content:"🔍";position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:12px;opacity:.5;pointer-events:none}.main{display:flex;flex-direction:column;min-width:0}.page{padding:22px 24px;flex:1}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.page-header .actions{display:flex;gap:8px}.breadcrumb{font-size:12px;color:var(--text-3);margin-bottom:4px}.breadcrumb a{color:var(--text-3)}.breadcrumb a:hover{color:var(--info)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-1)}.card-body{padding:18px 20px}.card-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-header h2,.card-header h3{font-size:14px;font-weight:600}.card+.card{margin-top:16px}.card.callout{border-left:3px solid var(--info);background:var(--info-soft);border-color:transparent;padding:14px 18px;font-size:13px;color:var(--text-2)}.card.callout.accent{border-left-color:var(--accent);background:var(--accent-soft)}.card.callout.warning{border-left-color:var(--warning);background:var(--warning-soft)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:20px}.stat{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--shadow-1);position:relative;overflow:hidden}.stat:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--info)}.stat.accent:before{background:var(--accent)}.stat.warning:before{background:var(--warning)}.stat.danger:before{background:var(--danger)}.stat .label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-weight:600}.stat .value{font-size:24px;font-weight:700;color:var(--text-1);line-height:1.1}.stat .delta{font-size:11px;color:var(--text-3);margin-top:4px}.stat .delta.up{color:var(--success)}.stat .delta.down{color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;font-family:var(--font-body);border:1px solid var(--border);background:var(--bg-surface);border-radius:var(--r-md);cursor:pointer;color:var(--text-1);transition:all .12s;text-decoration:none;white-space:nowrap}.btn:hover{background:var(--bg-muted);border-color:var(--border-strong);text-decoration:none}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-strong);border-color:var(--accent-strong);color:#fff}.btn-info{background:var(--info);border-color:var(--info);color:#fff}.btn-info:hover{background:#229bac;border-color:#229bac;color:#fff}.btn-danger{color:var(--danger);border-color:var(--danger);background:transparent}.btn-danger:hover{background:var(--danger);color:#fff}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}.btn-ghost:hover{background:var(--bg-muted);color:var(--text-1)}.btn-sm{padding:4px 10px;font-size:12px}.btn-icon{padding:6px 8px}.btn-row{display:flex;gap:8px}.field{margin-bottom:14px}.field label{display:block;font-size:12px;font-weight:500;color:var(--text-2);margin-bottom:5px}.field input,.field select,.field textarea{width:100%;padding:7px 11px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-1);font-family:inherit;font-size:13px;transition:border-color .12s,box-shadow .12s}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--info);box-shadow:0 0 0 3px var(--info-soft)}*:focus-visible{outline:2px solid var(--info);outline-offset:2px}button:focus-visible{outline:2px solid var(--info);outline-offset:2px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field .hint{font-size:11px;color:var(--text-3);margin-top:4px}.checkbox-row{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer}.toolbar{display:flex;gap:10px;align-items:center;padding:14px 0;flex-wrap:wrap}.toolbar .field{margin-bottom:0}.toolbar input,.toolbar select{height:32px;min-width:140px}.toolbar .grow{flex:1}table.data{width:100%;border-collapse:collapse;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-1)}table.data th{text-align:left;padding:11px 14px;background:var(--bg-muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);border-bottom:1px solid var(--border);white-space:nowrap}table.data td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-1);vertical-align:middle}table.data tbody tr:last-child td{border-bottom:none}table.data tbody tr{transition:background-color .08s}table.data tbody tr:hover td{background:var(--bg-muted)}table.data tbody tr.selected td{background:var(--accent-soft)}table.data td.numeric{text-align:right;font-variant-numeric:tabular-nums}table.data td.actions{text-align:right;white-space:nowrap}table.data th.numeric{text-align:right}table.data th[onclick],table.data th[style*=cursor]:hover{background:var(--bg-hover)}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:12px;font-size:11px;font-weight:600;background:var(--neutral-soft);color:var(--neutral);border:none;text-transform:uppercase;letter-spacing:.03em}.chip-success{background:var(--success-soft);color:var(--success)}.chip-warning{background:var(--warning-soft);color:var(--warning)}.chip-danger{background:var(--danger-soft);color:var(--danger)}.chip-info{background:var(--info-soft);color:var(--info)}.chip-accent{background:var(--accent-soft);color:var(--accent)}.chip-mono{font-family:var(--font-mono)}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--neutral);vertical-align:middle;margin-right:6px}.dot.success{background:var(--success)}.dot.warning{background:var(--warning)}.dot.danger{background:var(--danger)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:100;padding:16px;animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-surface);border-radius:var(--r-lg);width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-3);animation:modalIn .2s}@keyframes modalIn{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-body{padding:20px}.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--bg-muted)}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:16px}.tab{padding:10px 16px;background:transparent;border:none;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-2);border-bottom:2px solid transparent;margin-bottom:-1px}.tab.active{color:var(--info);border-bottom-color:var(--info)}.kv-list{display:grid;grid-template-columns:max-content 1fr;gap:8px 18px;font-size:13px}.kv-list dt{color:var(--text-3);font-weight:500}.kv-list dd{color:var(--text-1)}.empty-state{padding:48px 16px;text-align:center;color:var(--text-3);background:var(--bg-surface)}.empty-state .icon{font-size:32px;margin-bottom:8px;opacity:.4}.toast-wrap{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:200;max-width:360px}.toast{padding:11px 16px;background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid var(--info);border-radius:var(--r-md);box-shadow:var(--shadow-2);font-size:13px;animation:slideIn .25s}.toast.success{border-left-color:var(--success)}.toast.error{border-left-color:var(--danger)}.toast.warning{border-left-color:var(--warning)}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.login-shell{min-height:100vh;display:grid;place-items:center;background:radial-gradient(ellipse 800px 400px at 50% 0%,rgba(32,184,132,.06),transparent),var(--bg-page);padding:24px}.login-card{width:100%;max-width:380px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-2)}.login-card .brand{display:flex;align-items:center;gap:10px;margin-bottom:24px;font-size:18px;font-weight:600}.login-card .brand .mark{width:36px;height:36px;display:grid;place-items:center;background:var(--accent);color:#fff;border-radius:var(--r-md);font-style:italic;font-weight:700}.skeleton{background:linear-gradient(90deg,var(--bg-muted) 0%,var(--bg-hover) 50%,var(--bg-muted) 100%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-md);height:14px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.row{display:flex;align-items:center;gap:8px}.row.between{justify-content:space-between}.row.gap-md{gap:16px}.row.wrap{flex-wrap:wrap}.col{display:flex;flex-direction:column;gap:8px}.mt-0{margin-top:0!important}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mt-lg{margin-top:24px}.mb-sm{margin-bottom:8px}.mb-md{margin-bottom:16px}.mb-lg{margin-bottom:24px}.text-mono{font-family:var(--font-mono);font-size:12px}.text-sm{font-size:12px}.text-xs{font-size:11px}.text-muted{color:var(--text-3)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-right{text-align:right}.text-center{text-align:center}.no-wrap{white-space:nowrap}.divider{height:1px;background:var(--border);margin:16px 0}.map-container{width:100%;height:70vh;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-1)}.setting-row{display:grid;grid-template-columns:1fr 200px auto;gap:16px;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-row .meta{display:flex;flex-direction:column;gap:2px;min-width:0}.setting-row .key{font-family:var(--font-mono);font-size:11px;color:var(--text-3)}.setting-row .label{font-weight:600;font-size:13px;color:var(--text-1)}.setting-row .desc{font-size:12px;color:var(--text-3)}.setting-row input,.setting-row select{height:32px}.rule-editor{display:grid;grid-template-columns:1fr 1fr;gap:16px}.rule-editor textarea{font-family:var(--font-mono);font-size:12px;min-height:360px;line-height:1.6}@media (max-width: 900px){.layout{grid-template-columns:1fr}.sidebar{position:static;height:auto}.rule-editor,.field-row{grid-template-columns:1fr}.page{padding:16px}.setting-row{grid-template-columns:1fr}}.user-picker-selected{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg-1)}.user-picker-info{flex:1;min-width:0}.user-picker-name{font-weight:500;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-picker-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-picker-dropdown{position:absolute;left:0;right:0;top:calc(100% + 4px);background:var(--bg-1);border:1px solid var(--border);border-radius:6px;max-height:260px;overflow-y:auto;z-index:50;box-shadow:0 8px 20px #00000059}.user-picker-option{display:block;width:100%;text-align:left;padding:8px 12px;background:transparent;border:0;border-bottom:1px solid var(--border);cursor:pointer;color:var(--text-1)}.user-picker-option:last-child{border-bottom:0}.user-picker-option:hover{background:var(--bg-2)}.user-picker-empty{padding:12px;color:var(--text-3);font-size:13px;text-align:center}.chip.chip-sm{padding:1px 6px;font-size:10px}
