:root{--primary: #1e40af;--primary-600: #1e40af;--accent: #f59e0b;--bg: #f8fafc;--surface: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #475569;--muted-2: #64748b;--good: #16a34a;--bad: #dc2626;--radius: 14px;--shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 4px 16px rgba(15, 23, 42, .06);--font: "Inter", system-ui, -apple-system, sans-serif;--mono: "Fira Code", ui-monospace, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary)}.num{font-family:var(--mono);font-feature-settings:"tnum";letter-spacing:-.02em}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(160deg,#f8fafc,#eef2ff)}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:32px}.login-logo{height:44px;margin-bottom:20px;object-fit:contain}.login-brand{font-size:20px;font-weight:700;margin:0 0 4px}.login-sub{color:var(--muted);font-size:14px;margin:0 0 24px}.field{margin-bottom:14px}.field label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:6px}.input{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:10px;font-size:15px;font-family:inherit;background:#fff;transition:border-color .18s,box-shadow .18s}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1e40af1f}.btn{width:100%;padding:12px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:filter .18s,opacity .18s;font-family:inherit}.btn:hover{filter:brightness(1.08)}.btn:disabled{opacity:.6;cursor:default}.err{color:var(--bad);font-size:13px;margin-top:10px}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:16px;padding:12px 24px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:700}.topbar .brand img{height:30px}.topbar .spacer{flex:1}.topbar .who{color:var(--muted);font-size:13px}.topbar-nav{border-bottom:none;margin-bottom:0}.topbar-nav button{padding:8px 12px}.user-menu{position:relative}.menu-pop{position:absolute;right:0;top:calc(100% + 8px);z-index:40;min-width:210px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 32px #0f172a24;padding:6px}.menu-pop .menu-head{padding:8px 10px 6px;font-size:12px;color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:4px;word-break:break-all}.menu-pop .menu-item{display:block;width:100%;text-align:left;padding:9px 10px;border:none;background:none;border-radius:8px;cursor:pointer;font-family:inherit;font-size:13.5px;color:var(--text)}.menu-pop .menu-item:hover{background:#f1f5f9}.menu-pop .menu-item.danger{color:var(--bad)}.menu-pop .menu-item.danger:hover{background:#fef2f2}.menu-pop .menu-sep{height:1px;background:var(--border);margin:4px 0}.ghost-btn{padding:7px 12px;border:1px solid var(--border);background:#fff;border-radius:9px;cursor:pointer;font-size:13px;color:var(--muted);font-family:inherit;transition:background .18s,color .18s}.ghost-btn:hover{background:#f1f5f9;color:var(--text)}.container{max-width:1240px;margin:0 auto;padding:22px 24px 60px}.nav{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:18px;overflow-x:auto}.nav button{padding:10px 16px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color .18s,border-color .18s}.nav button:hover{color:var(--text)}.nav button.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.actions{display:flex;gap:8px}.ghost-btn{display:inline-flex;align-items:center;gap:6px}.ghost-btn svg{width:15px;height:15px;flex:none}.pos-badge{display:inline-block;padding:2px 8px;border-radius:20px;background:#eef2ff;color:var(--primary);font-weight:600;font-size:13px}.muted-row td{color:var(--muted-2)}.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px}.toolbar h1{font-size:20px;margin:0;flex:1}.select,.date{padding:8px 11px;border:1px solid var(--border);border-radius:9px;font-size:14px;background:#fff;font-family:inherit;color:var(--text)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(195px,1fr));gap:14px;margin-bottom:18px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}.kpi .label{font-size:12.5px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.03em}.kpi .value{font-size:21px;font-weight:700;margin:6px 0 2px;white-space:nowrap;letter-spacing:-.04em}.kpi .delta{font-size:12.5px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.kpi .delta.up{color:var(--good)}.kpi .delta.down{color:var(--bad)}.kpi .delta.flat{color:var(--muted-2)}.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:14px}@media(max-width:880px){.grid-2{grid-template-columns:1fr}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}.panel h3{margin:0 0 12px;font-size:15px;font-weight:600}.chart{width:100%;height:300px}.chart.sm{height:260px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:10px 12px;text-align:right;white-space:nowrap}th:first-child,td:first-child{text-align:left}thead th{color:var(--muted);font-weight:600;font-size:12.5px;border-bottom:1px solid var(--border)}tbody tr{border-bottom:1px solid #f1f5f9;transition:background .15s}tbody tr:hover{background:#f8fafc}.empty{text-align:center;color:var(--muted);padding:48px 0}.skeleton{background:linear-gradient(90deg,#eef2f7 25%,#f6f8fb,#eef2f7 75%);background-size:200% 100%;animation:sk 1.3s infinite;border-radius:8px}@keyframes sk{0%{background-position:200% 0}to{background-position:-200% 0}}@media(prefers-reduced-motion:reduce){.skeleton{animation:none}}@media print{.topbar .actions,.nav,.toolbar .select,.ghost-btn{display:none!important}body{background:#fff}.panel,.kpi{box-shadow:none;break-inside:avoid}.topbar{position:static}.container{padding-top:8px}@page{margin:14mm}}.muted-2{color:var(--muted-2);font-size:13px}.btn-inline{width:auto;padding:9px 16px;font-size:14px}.btn.btn-inline:hover{filter:brightness(1.08)}.tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.tag-ok{background:#dcfce7;color:#166534}.tag-off{background:#f1f5f9;color:var(--muted-2)}.tag-bad{background:#fee2e2;color:#991b1b}.tag-run{background:#fef9c3;color:#854d0e}.prov-tag{display:inline-block;padding:2px 9px;border-radius:8px;background:#eef2ff;color:var(--primary);font-weight:600;font-size:12.5px}.row-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}.row-actions .ghost-btn{padding:5px 10px;font-size:12.5px}.ghost-btn.danger{color:var(--bad);border-color:#fecaca}.ghost-btn.danger:hover{background:#fef2f2;color:var(--bad)}.cell-main{display:flex;align-items:center;gap:9px;font-weight:500}.row-logo{height:22px;width:22px;object-fit:contain;border-radius:5px}.row-dot{height:12px;width:12px;border-radius:50%;flex:none}.ts{font-weight:400}a.ghost-btn{text-decoration:none}.detail-head{display:flex;align-items:center;gap:12px;margin-bottom:18px}.detail-head h1{font-size:20px;margin:0}.detail-head .spacer{flex:1}.form-panel{margin-bottom:16px}.form-panel h3{margin:0 0 14px}.grid-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.color-row{display:flex;align-items:center;gap:10px}.color-row input[type=color]{width:46px;height:34px;padding:0;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer}.logo-row{display:flex;align-items:center;gap:14px}.logo-preview{height:38px;object-fit:contain}.check-row{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--text);margin:4px 0 6px;cursor:pointer}.hint{margin:2px 0 10px}.save-msg{color:var(--good);font-size:13px;font-weight:600;align-self:center}.conn-card{margin-bottom:16px}.conn-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.conn-head h3{margin:0 0 2px}.conn-head p{margin:0}.warn-box{background:#fffbeb;border:1px solid #fde68a;color:#854d0e;border-radius:10px;padding:11px 13px;font-size:13px}.share-url{display:flex;gap:8px;align-items:center;margin-top:6px}.share-url .input{flex:1}.public-badge{font-size:12px;font-weight:600;color:var(--muted-2);background:#f1f5f9;padding:4px 10px;border-radius:20px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;z-index:50;padding:20px}.modal{width:100%;max-width:440px;background:var(--surface);border-radius:16px;box-shadow:var(--shadow);padding:24px}.modal-title{font-size:18px;font-weight:700;margin:0 0 18px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.lp{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(1100px 520px at 50% -10%,#eef2ff,#eef2ff00 60%),var(--bg)}.lp a{text-decoration:none}.lp-topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:22px;padding:16px 28px;background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.lp-logo{display:inline-flex;align-items:center;gap:10px}.lp-logo-mark{width:26px;height:26px;border-radius:8px;flex:none;background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:0 4px 12px #1e40af47}.lp-logo-text{font-weight:800;font-size:19px;letter-spacing:-.02em;color:var(--text)}.lp-logo-text.small{font-size:16px}.lp-logo-sub{color:var(--accent);margin-left:2px}.lp-nav{display:flex;gap:20px;margin-left:6px}.lp-nav a{color:var(--muted);font-size:14px;font-weight:500}.lp-nav a:hover{color:var(--text)}.lp-topbar .lp-cta{margin-left:auto}.lp-cta{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;font-weight:600;font-size:14px;padding:10px 18px;border-radius:10px;transition:transform .15s,box-shadow .15s,background .15s;box-shadow:0 6px 18px #1e40af38}.lp-cta:hover{background:#1b389c;transform:translateY(-1px);box-shadow:0 10px 24px #1e40af4d}.lp-cta.lg,.lp-ghost.lg{padding:13px 26px;font-size:15px;border-radius:12px}.lp-ghost{display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--text);font-weight:600;font-size:14px;padding:10px 18px;border-radius:10px;border:1px solid var(--border);transition:background .15s}.lp-ghost:hover{background:#f1f5f9}.lp-body{flex:1}.lp-hero{max-width:880px;margin:0 auto;padding:76px 24px 48px;text-align:center}.lp-badge{display:inline-block;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;color:var(--primary);background:#e6ecff;border:1px solid #d3ddff;margin-bottom:22px}.lp-title{font-size:clamp(32px,5vw,52px);line-height:1.08;letter-spacing:-.03em;margin:0 0 18px;font-weight:800}.lp-title span{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}.lp-lead{font-size:18px;line-height:1.6;color:var(--muted);max-width:660px;margin:0 auto 30px}.lp-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.lp-hint{margin-top:18px;font-size:13px;color:var(--muted-2)}.lp-features{max-width:1080px;margin:0 auto;padding:24px 24px 56px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.lp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}.lp-card h3{margin:0 0 8px;font-size:16px;font-weight:700}.lp-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}.lp-about{max-width:760px;margin:0 auto;padding:20px 24px 80px;text-align:center}.lp-about h2{font-size:26px;letter-spacing:-.02em;margin:0 0 14px}.lp-about p{color:var(--muted);font-size:16px;line-height:1.65;margin:0 0 26px}.lp-footer{border-top:1px solid var(--border);background:var(--surface);padding:22px 28px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.lp-foot-text{color:var(--muted-2);font-size:13px;margin-left:auto}@media(max-width:560px){.lp-nav{display:none}.lp-foot-text{margin-left:0}}.topbar .brand{gap:9px}.brand-mark{width:26px;height:26px;border-radius:8px;flex:none;background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:0 4px 12px #1e40af47}.brand-text{font-weight:800;font-size:17px;letter-spacing:-.02em;color:var(--text)}.brand-sub{color:var(--accent);margin-left:1px}.segmented{display:inline-flex;gap:2px;padding:3px;background:#eef1f6;border-radius:11px}.seg{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border:none;background:none;border-radius:8px;cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:600;color:var(--muted);white-space:nowrap;transition:background .18s,color .18s,box-shadow .18s}.seg:hover{color:var(--text)}.seg.active{background:#fff;color:var(--primary);box-shadow:0 1px 2px #0f172a14}.seg svg{opacity:.9}.user-trigger{display:inline-flex;align-items:center;gap:9px;padding:5px 10px 5px 5px;border:1px solid var(--border);background:#fff;border-radius:999px;cursor:pointer;font-family:inherit;color:var(--text);transition:background .18s,border-color .18s}.user-trigger:hover{background:#f8fafc}.user-trigger-name{font-size:13.5px;font-weight:600}.chev{color:var(--muted-2);transition:transform .2s}.chev.open{transform:rotate(180deg)}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;flex:none;font-size:13px;font-weight:700;color:#fff;letter-spacing:.02em;background:linear-gradient(135deg,var(--primary),#3b82f6)}.avatar.sm{width:28px;height:28px;font-size:11.5px}.menu-pop{animation:pop .14s ease}@keyframes pop{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.menu-pop .menu-head{display:flex;flex-direction:column;gap:2px}.menu-head-name{font-size:13px;font-weight:700;color:var(--text)}.menu-head-mail{font-size:12px;color:var(--muted)}.menu-pop .menu-item{display:flex;align-items:center;gap:9px}.menu-pop .menu-item svg{color:var(--muted-2);flex:none}.menu-pop .menu-item.danger svg{color:var(--bad)}.btn-primary,.btn-ghost,.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:10px;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .16s,box-shadow .16s,opacity .16s}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px #1e40af33}.btn-primary:hover:not(:disabled){background:#1b389c}.btn-ghost{background:#fff;color:var(--text);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:#f1f5f9}.btn-danger{background:var(--bad);color:#fff;box-shadow:0 4px 12px #dc26262e}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-primary:disabled,.btn-ghost:disabled,.btn-danger:disabled{opacity:.6;cursor:default}.icon-btn{width:34px;height:34px;border:1px solid var(--border);background:#fff;border-radius:9px;display:grid;place-items:center;cursor:pointer;color:var(--muted);transition:background .16s,color .16s,border-color .16s}.icon-btn:hover{background:#f1f5f9;color:var(--text)}.icon-btn.danger:hover{background:#fef2f2;color:var(--bad);border-color:#fecaca}.toolbar>:first-child{margin-right:auto}.toolbar h1{flex:initial}.toolbar-sub{margin:3px 0 0;font-size:13px;color:var(--muted)}.panel.pad-0{padding:0;overflow:hidden}.data-table th{padding:12px 16px}.data-table td{padding:13px 16px;vertical-align:middle}.col-actions{text-align:right;width:1%;white-space:nowrap}.user-cell{display:flex;align-items:center;gap:11px}.user-cell-text{display:flex;flex-direction:column;line-height:1.3;min-width:0}.user-name{font-weight:600;display:flex;align-items:center;gap:8px}.user-email{font-size:12.5px;color:var(--muted);font-family:var(--mono)}.t-actions{display:inline-flex;gap:6px;justify-content:flex-end}td.muted{color:var(--muted-2)}.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600}.chip-neutral{background:#eef2f7;color:var(--muted)}.chip-accent{background:#fef3c7;color:#92400e}.chip-soft{background:#e6ecff;color:var(--primary);font-size:11px;padding:1px 7px}.status{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600}.status i{width:7px;height:7px;border-radius:50%;display:inline-block}.status-on{color:#15803d}.status-on i{background:#22c55e;box-shadow:0 0 0 3px #22c55e26}.status-off{color:var(--muted-2)}.status-off i{background:#cbd5e1}.overlay{animation:fade .15s ease}.modal{animation:modal-in .18s cubic-bezier(.2,.8,.2,1)}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.modal-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}.modal-head .modal-title{margin:0}.modal-icon{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;flex:none;background:#e6ecff;color:var(--primary)}.modal-icon.danger{background:#fee2e2;color:var(--bad)}.modal-head-text{flex:1;min-width:0}.modal-sub{margin:3px 0 0;font-size:13px;color:var(--muted);word-break:break-word}.modal-x{margin:-4px -4px 0 0}.modal-body-text{margin:0 0 4px;font-size:14.5px;line-height:1.6;color:var(--muted)}.grid-2-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}.select.w-full{width:100%}@media(max-width:480px){.grid-2-fields{grid-template-columns:1fr}}.input-affix{position:relative;display:flex;align-items:center}.input-affix .input{width:100%;padding-right:44px}.affix-btn{position:absolute;right:6px;border:none;background:none;color:var(--muted-2);cursor:pointer;padding:7px;border-radius:7px;display:grid;place-items:center}.affix-btn:hover{background:#f1f5f9;color:var(--text)}.toaster{position:fixed;right:18px;bottom:18px;z-index:80;display:flex;flex-direction:column;gap:10px;max-width:calc(100vw - 36px)}.toast{display:flex;align-items:center;gap:10px;min-width:280px;max-width:380px;padding:12px 12px 12px 14px;background:#fff;border:1px solid var(--border);border-left:4px solid var(--muted-2);border-radius:12px;box-shadow:0 10px 30px #0f172a29;animation:toast-in .22s cubic-bezier(.2,.8,.2,1)}.toast-success{border-left-color:var(--good)}.toast-error{border-left-color:var(--bad)}.toast-info{border-left-color:var(--primary)}.toast-ico{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;flex:none;color:#fff}.toast-success .toast-ico{background:var(--good)}.toast-error .toast-ico{background:var(--bad)}.toast-info .toast-ico{background:var(--primary)}.toast-msg{flex:1;font-size:13.5px;color:var(--text);line-height:1.4}.toast-close{border:none;background:none;color:var(--muted-2);cursor:pointer;padding:4px;border-radius:6px;display:grid;place-items:center}.toast-close:hover{background:#f1f5f9;color:var(--text)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.seg:focus-visible,.icon-btn:focus-visible,.user-trigger:focus-visible,.menu-item:focus-visible,.btn-primary:focus-visible,.btn-ghost:focus-visible,.btn-danger:focus-visible,.ghost-btn:focus-visible,.affix-btn:focus-visible,.toast-close:focus-visible,.lp-cta:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media(max-width:640px){.topbar{padding:10px 14px;gap:10px}.user-trigger-name{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}
