:root{--bg: #f6f8fc;--surface: #ffffff;--surface-2: #f1f5f9;--surface-3: #e9eef6;--sidebar: #ffffff;--border: #e6ebf3;--border-strong: #d2dbe8;--text: #0f172a;--text-dim: #51607a;--text-faint: #94a3b8;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-tint: #eff5ff;--accent: #06b6d4;--green: #16a34a;--green-tint: #e7f7ec;--red: #dc2626;--red-tint: #fdeaea;--amber: #b45309;--amber-tint: #fdf2dc;--radius: 12px;--radius-sm: 9px;--shadow: 0 1px 2px rgba(15, 23, 42, .05), 0 1px 3px rgba(15, 23, 42, .04);--shadow-md: 0 6px 20px rgba(15, 23, 42, .08);--brand-grad: linear-gradient(135deg, #2563eb 0%, #06b6d4 100%)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.app{display:grid;grid-template-columns:248px 1fr;height:100vh}.sidebar{background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 12px;overflow-y:auto}.brand{display:flex;align-items:center;gap:8px;padding:6px 8px 18px}.logo{display:inline-flex;align-items:center;gap:9px}.logo-mark{width:30px;height:30px;flex:none;border-radius:9px;box-shadow:0 2px 6px #2563eb40}.logo-word{font-family:"Plus Jakarta Sans",inherit;font-size:17px;font-weight:800;letter-spacing:-.4px;color:var(--text)}.logo-word .sub{font-weight:600;color:var(--text-faint)}.env-pill{font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;letter-spacing:.03em;background:var(--green-tint);color:var(--green);border:1px solid color-mix(in srgb,var(--green) 25%,transparent)}.env-pill.test{background:var(--amber-tint);color:var(--amber);border-color:color-mix(in srgb,var(--amber) 30%,transparent)}.nav-group{margin-top:12px}.nav-group-title{font-size:10px;text-transform:uppercase;letter-spacing:.09em;color:var(--text-faint);padding:8px 10px 4px;font-weight:600}.nav-item{position:relative;display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;color:var(--text-dim);cursor:pointer;font-weight:500;border:none;background:none;width:100%;text-align:left;font-size:13.5px;transition:background .12s,color .12s}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--primary-tint);color:var(--primary);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--brand-grad)}.nav-item .ico{width:17px;text-align:center;opacity:.85}.sidebar-spacer{flex:1}.main{display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;align-items:center;gap:16px;padding:14px 26px;border-bottom:1px solid var(--border);background:var(--surface)}.topbar h1{font-size:18px;margin:0;font-weight:700;letter-spacing:-.3px}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}.balance-pill{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:6px 14px;font-size:13px;color:var(--text-dim)}.balance-pill b{color:var(--green)}.content{padding:26px;overflow-y:auto;flex:1;min-height:0}.content.listpage{overflow:hidden;display:flex;flex-direction:column}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);transition:box-shadow .15s}.card:hover{box-shadow:var(--shadow-md)}.card-label{font-size:12px;color:var(--text-dim);display:flex;justify-content:space-between;font-weight:500}.card-value{font-size:28px;font-weight:700;margin-top:8px;letter-spacing:-.6px;color:var(--text)}.card-sub{font-size:12px;color:var(--text-faint);margin-top:4px}.section-title{font-size:12px;font-weight:600;color:var(--text-faint);margin:28px 0 12px;text-transform:uppercase;letter-spacing:.06em}.progress{height:7px;background:var(--surface-2);border-radius:999px;overflow:hidden;margin-top:12px}.progress>div{height:100%;background:var(--brand-grad);border-radius:999px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.panel-head{display:flex;align-items:center;gap:12px;padding:15px 18px;border-bottom:1px solid var(--border)}.panel-head h2{font-size:15px;margin:0;font-weight:700;letter-spacing:-.2px}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);padding:11px 18px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface-2);font-weight:600;z-index:1}.tbl td{padding:12px 18px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text)}.tbl tbody tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--surface-2)}.tbl .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--text-dim)}.empty{padding:44px;text-align:center;color:var(--text-faint)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px}.badge.ok{background:var(--green-tint);color:var(--green)}.badge.fail{background:var(--red-tint);color:var(--red)}.badge.pending{background:var(--amber-tint);color:var(--amber)}.badge.neutral{background:var(--surface-2);color:var(--text-dim)}.dot{width:7px;height:7px;border-radius:999px;display:inline-block}.dot.ok{background:var(--green)}.dot.fail{background:var(--red)}.btn{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s;box-shadow:0 1px 2px #2563eb40}.btn:hover{background:var(--primary-hover)}.btn.ghost{background:var(--surface);color:var(--text);border:1px solid var(--border-strong);box-shadow:none}.btn.ghost:hover{background:var(--surface-2)}.btn.sm{padding:6px 11px;font-size:12px}.btn.danger{background:var(--red);box-shadow:none}.btn.danger:hover{background:#b91c1c}.input,select.input{background:var(--surface);border:1px solid var(--border-strong);color:var(--text);border-radius:var(--radius-sm);padding:9px 11px;font-size:13px;width:100%;outline:none;transition:border-color .12s,box-shadow .12s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint)}.input::placeholder{color:var(--text-faint)}.field{margin-bottom:12px}.field label{display:block;font-size:12px;color:var(--text-dim);margin-bottom:6px;font-weight:500}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.row{display:flex;gap:10px;align-items:center}.spacer{flex:1}.msg{font-size:13px;margin:8px 0}.msg.err{color:var(--red)}.msg.ok{color:var(--green)}.with-filters{display:grid;grid-template-columns:240px 1fr;gap:16px;align-items:start}.filter-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.listview{display:flex;flex-direction:column;gap:14px;flex:1;min-height:0;width:100%}.filterbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow)}.filterbar .fb-row{display:flex;flex-wrap:wrap;gap:10px 14px;align-items:flex-end}.filterbar .field{margin-bottom:0}.filterbar .field .input{width:auto;min-width:130px}.input.sm,select.input.sm{padding:6px 9px;font-size:12px;width:auto}.panel.fill{display:flex;flex-direction:column;flex:1;min-height:0}.panel.fill .table-wrap{flex:1;min-height:0;overflow:auto}.panel-foot{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:11px 18px;border-top:1px solid var(--border);background:var(--surface)}.panel-foot .totals{display:flex;flex-wrap:wrap;gap:16px;align-items:baseline}.panel-foot .pagesize{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-dim)}.panel-foot .pagesize select{width:auto;padding:5px 8px}.login-wrap{display:grid;place-items:center;height:100vh;background:radial-gradient(1200px 500px at 50% -10%,#eaf1ff 0%,transparent 60%),var(--bg)}.login-card{width:380px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:34px;box-shadow:0 20px 50px #0f172a1f}.login-card h1{margin:0 0 4px;font-size:24px;font-family:Plus Jakarta Sans,system-ui;letter-spacing:-.5px}.login-card p{color:var(--text-dim);margin:0 0 20px;font-size:13px}.qr{background:#fff;padding:12px;border-radius:8px;display:inline-block;border:1px solid var(--border)}.code{font-family:ui-monospace,monospace;background:var(--surface-2);padding:8px 10px;border-radius:6px;font-size:12px;word-break:break-all}.codeblock{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--surface-2);padding:12px 14px;border-radius:8px;font-size:12px;line-height:1.5;color:var(--text);white-space:pre-wrap;word-break:break-word;overflow-x:auto;margin:0;border:1px solid var(--border)}.subtabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.subtab{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.subtab:hover{background:var(--surface-2);color:var(--text)}.subtab.active{background:var(--primary-tint);color:var(--primary);border-color:color-mix(in srgb,var(--primary) 35%,transparent)}.subtab .cnt{min-width:18px;height:18px;padding:0 5px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;background:var(--surface-2);color:var(--text-dim)}.subtab.active .cnt{background:var(--primary);color:#fff}.subtab .cnt.warn{background:var(--red-tint, #fdecec);color:var(--red, #b3261e)}.decision-bar{position:sticky;top:0;z-index:6;display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 14px;margin:0 0 12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.helptip{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;margin-left:6px;flex:0 0 auto;border-radius:50%;border:1px solid var(--border);background:var(--surface-2, rgba(127,127,127,.08));color:var(--text-dim);font-size:10px;font-weight:700;cursor:help;position:relative;vertical-align:middle;-webkit-user-select:none;user-select:none}.helptip:hover,.helptip:focus-visible{color:var(--primary);border-color:var(--primary);outline:none}.helptip-pop{display:none;position:absolute;z-index:60;top:calc(100% + 7px);left:50%;transform:translate(-50%);width:max-content;max-width:290px;padding:8px 11px;border-radius:9px;font-size:12px;font-weight:400;line-height:1.45;text-align:left;white-space:normal;background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:0 8px 24px #0000002e}.helptip:hover .helptip-pop,.helptip:focus-visible .helptip-pop{display:block}.page-intro{border:1px solid var(--border);border-radius:12px;margin-bottom:14px;background:var(--surface);overflow:hidden;flex:0 0 auto;width:100%}.page-intro-bar{display:flex;align-items:center;gap:8px;padding:9px 14px;cursor:pointer;font-size:13px;color:var(--text)}.page-intro-bar:hover{background:var(--surface-2, rgba(127,127,127,.05))}.page-intro-ico{color:var(--text-dim);font-size:11px}.page-intro-teaser{color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:55%;font-size:12.5px}.page-intro-toggle{color:var(--primary);font-size:12.5px;font-weight:600}.page-intro-body{padding:2px 16px 13px;font-size:13px;color:var(--text);border-top:1px dashed var(--border)}.page-intro-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:7px 18px}.page-intro-action{display:flex;flex-direction:column;gap:1px;font-size:12.5px}.page-intro-action b{font-size:12.5px}.page-intro-action span{color:var(--text-dim);line-height:1.4}.page-intro-tips{margin:10px 0 0;padding-left:18px;color:var(--text-dim);font-size:12.5px}.page-intro-tips li{margin-bottom:3px}.guide-flows{padding:4px 16px 14px}.guide-flow{border:1px solid var(--border);border-radius:10px;margin-bottom:8px;padding:0 12px;background:var(--surface)}.guide-flow summary{cursor:pointer;padding:10px 2px;font-weight:600;font-size:13.5px}.guide-flow ol{margin:2px 0 12px;padding-left:22px;font-size:13px}.guide-flow li{margin-bottom:5px;line-height:1.5}.skeleton{border-radius:8px;height:14px;margin:6px 0;background:linear-gradient(90deg,var(--surface-2, rgba(127,127,127,.08)) 25%,rgba(127,127,127,.16) 50%,var(--surface-2, rgba(127,127,127,.08)) 75%);background-size:200% 100%;animation:skeleton-slide 1.2s infinite linear}@keyframes skeleton-slide{0%{background-position:200% 0}to{background-position:-200% 0}}.tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80}.tour-spot{position:fixed;z-index:81;border-radius:12px;pointer-events:none;box-shadow:0 0 0 9999px #0000008c;outline:2px solid var(--primary);transition:all .25s ease}.tour-pop{position:fixed;z-index:82;width:360px;max-width:calc(100vw - 24px);background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:13px 15px;box-shadow:0 12px 40px #00000059}
