:root{color:#1e1e1e;background:#f4f5f7;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}*,*:before,*:after{box-sizing:border-box;margin:0}button,input,textarea,select{font:inherit}.page{min-height:100vh;display:flex;flex-direction:column}.topbar{background:linear-gradient(90deg,#1a3a5c,#2a5fa0);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:10px 24px;gap:16px;flex-wrap:wrap}.topbar h1{font-size:1.1rem;font-weight:600;white-space:nowrap;color:#fff}.topbar-left{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.topbar-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.sync-date-field{display:inline-flex;align-items:center;gap:6px;color:#dbeafe;font-size:.8rem;font-weight:600}.sync-date-field input{width:145px;min-height:32px;border-color:#ffffff59;background:#fffffff2;color:#1f2937}.logo{display:flex;align-items:center;gap:8px}.logo-icon{color:#7ec8f6;flex-shrink:0}.last-sync-label{color:#c0d8f0;font-size:.85rem}.pills{display:flex;gap:6px}.pill{padding:2px 10px;border-radius:999px;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:4px}.pill-ok{background:#d4f5dc;color:#0d6630}.pill-bad{background:#fde8e8;color:#a0121e}.pill-info{background:#fff3;color:#e0ecf8}.c-ok{color:#0d6630}.c-bad{color:#a0121e}.c-new{color:#0b7a3a;font-weight:600}.c-upd{color:#b07000;font-weight:600}.c-del{color:#7c3aed;font-weight:600}.c-muted{font-weight:600}.btn{border:1px solid #bbb;border-radius:6px;background:#fff;color:#333;cursor:pointer;font-weight:500;padding:6px 14px;display:inline-flex;align-items:center;gap:5px;transition:background .12s,box-shadow .12s}.btn:hover:not(:disabled){box-shadow:0 1px 3px #0000001a}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-green{background:#ecfdf5;color:#065f46;border-color:#6ee7b7}.btn-green:hover:not(:disabled){background:#d1fae5}.btn-blue{background:#eff6ff;color:#1e40af;border-color:#93c5fd}.btn-blue:hover:not(:disabled){background:#dbeafe}.btn-red{background:#fef2f2;color:#991b1b;border-color:#fca5a5}.btn-red:hover:not(:disabled){background:#fee2e2}.notice{background:#fef9c3;border-bottom:1px solid #fde047;padding:8px 24px;font-size:.88rem;display:flex;align-items:center;gap:6px;color:#713f12}.main{flex:1;display:grid;grid-template-columns:360px 1fr;gap:0;overflow:hidden}.col-left{border-right:1px solid #d9d9d9;background:#fafafa;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.col-right{overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.half-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}.data-panels{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;align-items:start}.card{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:16px;border-top:3px solid #cbd5e1}.card h2{font-size:.9rem;font-weight:600;color:#333;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;gap:6px}.card-large-data{min-height:260px}.card-large-data .tbl-wrap{max-height:420px;overflow:auto}.card-large-data th,.card-large-data td{padding:8px 12px;max-width:520px}.card-demo{border-top-color:#a78bfa}.card-source{border-top-color:#60a5fa}.card-obs{border-top-color:#38bdf8}.card-events{border-top-color:#fb923c}.card-synced{border-top-color:#34d399}.card-runs{border-top-color:#2dd4bf}.card-history{border-top-color:#818cf8}.card-config{border-top-color:#64748b}.ico-purple{color:#7c3aed}.ico-blue{color:#2563eb}.ico-orange{color:#ea580c}.ico-green{color:#059669}.ico-teal{color:#0d9488}.ico-indigo{color:#4f46e5}.ico-gray{color:#64748b}.count-badge{margin-left:auto;min-width:22px;height:20px;padding:1px 7px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:.72rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.demo-row{display:flex;gap:12px;margin-bottom:12px}.field{display:flex;flex-direction:column;min-width:120px}.field-grow{flex:1}.field label{font-size:.8rem;font-weight:600;color:#555;margin-bottom:4px}input,textarea{border:1px solid #ccc;border-radius:6px;padding:6px 10px;width:100%;resize:vertical;background:#fafbfc}input:focus,textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f;background:#fff}.demo-actions{display:flex;gap:6px}.credential-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:10px}.credential-grid .field span{font-size:.8rem;font-weight:600;color:#555;margin-bottom:4px}.credential-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.credential-state{font-size:.8rem;color:#64748b;font-weight:600}.credential-state-on{color:#0d6630}.tbl-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;padding:6px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px;border-bottom:1px solid #f0f0f0}th{color:#888;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}tr:hover td{background:#f8fafc}.empty{color:#999;font-size:.88rem}.events{max-height:320px;overflow-y:auto}.event-row{display:grid;grid-template-columns:130px 120px 1fr;gap:8px;padding:5px 8px;border-bottom:1px solid #f5f5f5;font-size:.82rem;align-items:baseline;border-radius:4px}.event-row.ev-red{background:#fef2f2}.event-row.ev-purple{background:#f5f3ff}.event-row.ev-blue{background:#eff6ff}.event-row.ev-green{background:#ecfdf5}.event-row.ev-orange{background:#fff7ed}.ev-time{color:#999}.ev-type{font-weight:600}.ev-msg{color:#444;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 900px){.main{grid-template-columns:1fr}.col-left{border-right:none;border-bottom:1px solid #d9d9d9;max-height:50vh}.half-cards,.data-panels,.credential-grid{grid-template-columns:1fr}.demo-row{flex-direction:column}.topbar{padding:8px 16px}.col-left,.col-right{padding:12px}}@media (max-width: 560px){.event-row{grid-template-columns:1fr}.ev-time{font-size:.75rem}}.config-section{margin-bottom:18px}.config-section:last-child{margin-bottom:0}.config-section h3{font-size:.82rem;font-weight:600;color:#475569;margin-bottom:8px;display:flex;align-items:center;gap:5px}.config-hint{font-size:.82rem;color:#64748b;margin-bottom:8px}.config-hint code{background:#f1f5f9;padding:1px 5px;border-radius:4px;font-size:.78rem;color:#334155}.obs-objects{display:flex;flex-direction:column;gap:4px;max-height:160px;overflow-y:auto;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:8px}.obs-object{display:flex;justify-content:space-between;align-items:center;font-size:.78rem;padding:3px 0;border-bottom:1px solid #f1f5f9}.obs-object:last-child{border-bottom:none}.obs-key{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;color:#0369a1;word-break:break-all}.obs-meta{color:#94a3b8;white-space:nowrap;margin-left:8px;font-size:.72rem}.config-grid{display:grid;grid-template-columns:1fr;gap:6px}.config-item{display:flex;flex-direction:column;gap:2px;padding:6px 8px;background:#f8fafc;border-radius:6px;font-size:.8rem}.config-label{font-weight:600;color:#475569;text-transform:capitalize;font-size:.75rem}.config-value{color:#334155;line-height:1.4}.edge-cases{display:flex;flex-direction:column;gap:6px}.edge-case{display:flex;flex-direction:column;gap:2px;padding:6px 8px;background:#f8fafc;border-radius:6px;font-size:.8rem}.edge-case-title{font-weight:600;color:#475569;text-transform:capitalize;font-size:.75rem}.edge-case-desc{color:#334155;line-height:1.4}.config-explain{font-size:.82rem;color:#64748b;margin-bottom:8px}.config-explain code{background:#f1f5f9;padding:1px 5px;border-radius:4px;font-size:.78rem;color:#334155}.config-list{margin:0;padding-left:18px;font-size:.82rem;color:#334155}.config-list li{margin-bottom:4px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:#f8fafc;border-radius:8px;margin-bottom:8px;border:1px solid #e2e8f0}.setting-label{display:flex;flex-direction:column;gap:2px;flex:1}.setting-name{font-weight:600;color:#334155;font-size:.85rem}.setting-desc{color:#64748b;font-size:.78rem;line-height:1.35}.setting-select{font:inherit;padding:6px 10px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#334155;font-size:.82rem;min-width:220px;cursor:pointer}.setting-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.setting-select:disabled{opacity:.5;cursor:not-allowed}.toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;border:1px solid #cbd5e1;background:#fff;cursor:pointer;font-weight:600;font-size:.82rem;min-width:80px;justify-content:center}.toggle:hover:not(:disabled){background:#f1f5f9}.toggle:disabled{opacity:.5;cursor:not-allowed}.toggle-on{color:#065f46;border-color:#6ee7b7;background:#ecfdf5}.toggle-off{color:#991b1b;border-color:#fca5a5;background:#fef2f2}
