@import"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&family=Roboto+Mono:wght@400;500;600&display=swap";:root{--bg: #f4f5f7;--surface: #ffffff;--surface-2: #fafbfc;--line: #e5e7eb;--line-2: #d7dae0;--txt: #1f2329;--txt-dim: #6b7280;--txt-faint: #9ca3af;--brand: #dc143b;--brand-dim: #b91032;--brand-soft:#fdecef;--ok: #16a34a;--ok-soft: #e7f6ec;--warn: #d97706;--warn-soft: #fdf0e0;--purple: #7c3aed;--purple-soft:#f1ebfd;--info: #2563eb;--danger: #dc2626;--danger-soft:#fdeaea;--radius: 10px;--sans: "Roboto", system-ui, -apple-system, sans-serif;--mono: "Roboto Mono", ui-monospace, monospace;--sidebar-w: 220px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--txt);font-family:var(--sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}a{color:var(--info)}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:5px}::-webkit-scrollbar-track{background:transparent}.app{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar .brand{display:flex;align-items:center;gap:10px;padding:18px 18px 16px;font-weight:700;font-size:16px;letter-spacing:-.3px}.sidebar .brand .mark{width:28px;height:28px;border-radius:7px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:700;font-size:15px}.sidebar .nav{display:flex;flex-direction:column;gap:2px;padding:6px 10px;flex:1}.sidebar .nav button{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:var(--txt-dim);padding:9px 12px;border-radius:8px;font-size:13.5px;font-weight:500;text-align:left}.sidebar .nav button:hover{background:var(--bg);color:var(--txt)}.sidebar .nav button.active{background:var(--brand-soft);color:var(--brand);font-weight:600}.sidebar .nav button .ico{width:18px;text-align:center;font-size:15px}.sidebar .actions{padding:12px 12px 16px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}.content{flex:1;min-width:0;padding:26px 30px 60px}.btn{border:1px solid var(--line-2);background:var(--surface);color:var(--txt);padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:.12s}.btn:hover{border-color:var(--brand);color:var(--brand)}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}.btn.primary:hover{background:var(--brand-dim);border-color:var(--brand-dim);color:#fff}.btn.ghost{background:none;border-color:transparent;color:var(--txt-dim)}.btn.ghost:hover{color:var(--txt);background:var(--bg)}.btn.danger{color:var(--danger);border-color:transparent;background:none}.btn.danger:hover{background:var(--danger-soft)}.btn.sm{padding:5px 10px;font-size:12px}.btn.block{width:100%}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}.page-head{display:flex;align-items:center;gap:14px;margin-bottom:20px;flex-wrap:wrap}.page-head h1{font-size:21px;margin:0;font-weight:700;letter-spacing:-.4px}.page-head .spacer{flex:1}.muted{color:var(--txt-dim)}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:22px}.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px}.stat .num{font-family:var(--mono);font-size:24px;font-weight:600;letter-spacing:-1px}.stat .lbl{color:var(--txt-dim);font-size:12px;margin-top:3px}.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}input[type=text],input[type=tel],input[type=email],input[type=url],input[type=number],input[type=date],select,textarea{background:var(--surface);border:1px solid var(--line-2);color:var(--txt);padding:8px 11px;border-radius:8px;font-size:13px;outline:none;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.search{min-width:250px}textarea{resize:vertical;min-height:70px;line-height:1.5}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}table{border-collapse:collapse;width:100%;font-size:13px}thead th{text-align:left;padding:11px 13px;background:var(--surface-2);color:var(--txt-dim);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:1px solid var(--line);-webkit-user-select:none;user-select:none}thead th.sortable{cursor:pointer}thead th.sortable:hover{color:var(--txt)}tbody td{padding:10px 13px;border-bottom:1px solid var(--line);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-2)}.cell-name{font-weight:600}.cell-sub{color:var(--txt-faint);font-size:12px}.mono{font-family:var(--mono)}.right{text-align:right}.center{text-align:center}.nowrap{white-space:nowrap}.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}.pill.red{background:var(--danger-soft);color:var(--danger)}.pill.green{background:var(--ok-soft);color:var(--ok)}.pill.yellow{background:var(--warn-soft);color:var(--warn)}.pill.purple{background:var(--purple-soft);color:var(--purple)}.pill.blue{background:#e8f0fe;color:var(--info)}.pill.gray{background:#eef0f3;color:var(--txt-dim)}.tag{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;background:var(--bg);color:var(--txt-dim);border:1px solid var(--line-2);margin:1px 3px 1px 0}.empty{text-align:center;padding:60px 20px;color:var(--txt-faint)}.empty .big{font-size:38px;margin-bottom:8px;opacity:.4}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14161c59;display:flex;justify-content:flex-end;z-index:100;animation:fade .15s}@keyframes fade{0%{opacity:0}}.drawer{width:580px;max-width:100vw;height:100%;background:var(--surface);border-left:1px solid var(--line);overflow-y:auto;animation:slide .2s;display:flex;flex-direction:column}@keyframes slide{0%{transform:translate(30px);opacity:.6}}.drawer-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surface);z-index:2}.drawer-head h2{margin:0;font-size:17px;flex:1}.drawer-body{padding:20px;flex:1}.drawer-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px;position:sticky;bottom:0;background:var(--surface)}.modal-center{display:flex;align-items:center;justify-content:center}.modal-box{width:480px;max-width:92vw;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-row{display:flex;flex-direction:column;gap:5px}.form-row.full{grid-column:1 / -1}.form-row label{font-size:12px;color:var(--txt-dim);font-weight:500}.section-title{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--brand);font-weight:700;margin:24px 0 12px;padding-bottom:6px;border-bottom:1px solid var(--line)}.section-title:first-child{margin-top:0}.pipe-table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px;min-width:1300px}.pipe-table th{position:sticky;top:0;background:var(--surface-2);z-index:1;padding:10px;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--txt-dim);border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}.pipe-table td{padding:6px 8px;border-bottom:1px solid var(--line);vertical-align:middle}.pipe-table tr:hover td{background:var(--surface-2)}.pipe-table input,.pipe-table select{padding:6px 8px;font-size:12.5px;border-color:var(--line)}.pipe-table input:focus,.pipe-table select:focus{box-shadow:none;border-color:var(--brand)}.cell-min{min-width:90px}.pipe-table .cell-note{min-height:34px;min-width:150px;resize:vertical;line-height:1.4;white-space:pre-wrap}.pipe-table td.note-cell{vertical-align:top}.ac{position:relative}.ac-list{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--line-2);border-radius:8px;box-shadow:0 8px 24px #00000024;z-index:9999;max-height:240px;overflow-y:auto;margin-top:2px}.ac-item{padding:8px 11px;cursor:pointer;display:flex;justify-content:space-between;gap:10px}.ac-item:hover,.ac-item.active{background:var(--brand-soft)}.ac-item .sub{color:var(--txt-faint);font-size:12px}.tmpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.tmpl{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:10px}.tmpl h3{margin:0;font-size:14.5px}.tmpl .body{color:var(--txt-dim);font-size:13px;white-space:pre-wrap;flex:1;max-height:140px;overflow:auto;background:var(--bg);padding:10px;border-radius:8px;border:1px solid var(--line)}.tmpl .actions{display:flex;gap:8px}.log-line{display:flex;gap:14px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}.log-line:last-child{border-bottom:none}.log-time{font-family:var(--mono);color:var(--txt-faint);font-size:12px;white-space:nowrap;min-width:150px}.log-action{font-weight:600;min-width:140px}.log-detail{color:var(--txt-dim)}.hist{border:1px solid var(--line);border-radius:9px;padding:12px;margin-bottom:10px;background:var(--surface-2)}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%);background:var(--txt);color:#fff;padding:10px 20px;border-radius:9px;font-weight:500;font-size:13px;z-index:200;animation:fade .15s}.alert{display:flex;align-items:center;gap:10px;padding:12px 15px;border-radius:var(--radius);margin-bottom:18px;font-size:13px}.alert.warn{background:var(--warn-soft);border:1px solid #f3d19e;color:#92580a}.stars{display:inline-flex;gap:2px}.star{color:var(--line-2);font-size:16px}.star.on{color:#f59e0b}.linkout{color:var(--info);text-decoration:none;font-size:12.5px}.linkout:hover{text-decoration:underline}@media (max-width: 820px){.app{flex-direction:column}.sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center}.sidebar .nav{flex-direction:row;flex-wrap:wrap;flex:1 1 100%}.sidebar .actions{flex-direction:row;border-top:none;flex:1 1 100%}.content{padding:18px 14px 40px}.form-grid{grid-template-columns:1fr}}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.login-box{width:420px;max-width:100%;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:40px 36px;box-shadow:0 16px 50px #00000014;text-align:center}.login-logo{display:flex;justify-content:center;margin-bottom:18px}.login-logo .mark{width:60px;height:60px;border-radius:15px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:700;font-size:30px;box-shadow:0 6px 18px #dc143b4d}.login-box h2{font-size:24px!important;margin:0 0 4px!important}.login-box .muted{font-size:14px!important;margin:0 0 22px!important}.login-box input[type=password]{height:48px;font-size:15px;padding:0 16px;border-radius:10px;text-align:center;margin-top:0!important}.login-box .btn.primary{height:48px;font-size:15px;border-radius:10px;margin-top:14px!important}.login-err{background:var(--danger-soft);color:var(--danger);border-radius:8px;padding:10px 12px;font-size:13px;margin-top:12px}
