:root{color:#142033;background:#f4f7fb;font-family:Inter,system-ui,Arial}body{margin:0}a{color:#0b65c2;text-decoration:none}header,.top{z-index:2;background:#fff;border-bottom:1px solid #dbe4ef;align-items:center;gap:18px;padding:16px 32px;display:flex;position:sticky;top:0}.brand{color:#0b2d5c;font-weight:800}nav{gap:16px;margin-left:auto;display:flex}.home,main{max-width:1220px;margin:auto;padding:32px}.hero{color:#fff;background:linear-gradient(135deg,#0b2d5c,#0b6fae);border-radius:28px;grid-template-columns:1.2fr .8fr;align-items:center;gap:28px;padding:36px;display:grid}.hero h1{margin:0;font-size:56px}.lead{font-size:22px}.upload{color:#142033;text-align:center;background:#fff;border:2px dashed #7db7de;border-radius:22px;padding:28px}.upload.over{background:#e8f7ff}.btn{color:#fff;cursor:pointer;background:#08a6c9;border:0;border-radius:10px;margin:6px;padding:10px 14px;display:inline-block}.ghost{color:#0b2d5c;background:#edf4fb}.grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.card,.metric{background:#fff;border:1px solid #dbe4ef;border-radius:18px;padding:18px;box-shadow:0 8px 28px #15324a12}.analysis{grid-template-columns:330px 1fr;gap:20px;max-width:none;padding:20px;display:grid}.analysis aside,.panel{background:#fff;border:1px solid #dbe4ef;border-radius:18px;padding:18px;overflow:auto}.tree{padding-left:16px;list-style:none}.tree span{color:#0b2d5c;font-weight:700}.tree em{color:#667085}.tabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.tabs button{cursor:pointer;background:#f8fafc;border:1px solid #cbd8e6;border-radius:999px;padding:9px 12px}.tabs .active{color:#fff;background:#0b2d5c}.summary{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;display:grid}.metric b{color:#526174;font-size:13px;display:block}.metric span{font-size:18px}.table{overflow:auto}table{border-collapse:collapse;background:#fff;width:100%}th,td{text-align:left;vertical-align:top;border-bottom:1px solid #e5edf5;padding:10px}th{color:#526174;background:#f8fafc}.xml{color:#d6e7ff;background:#0b1220;border-radius:14px;max-height:70vh;padding:16px;overflow:auto}.empty{text-align:center;color:#667085;background:#f8fafc;border-radius:16px;padding:32px}.status{color:#fff;border-radius:999px;padding:7px 10px}.success{background:#159947}.warning{background:#d97706}.error{background:#dc2626}.warn{background:#fff7ed;border-left:4px solid #f59e0b;padding:12px}.loader{padding:40px}@media (width<=800px){.hero,.analysis{grid-template-columns:1fr}.top,header{flex-wrap:wrap}.hero h1{font-size:38px}}.analysis{max-width:1280px;display:block}.panel{background:#fff;border:1px solid #dbe4ef;border-radius:18px;padding:18px;overflow:auto}.treeBox{background:#fbfdff;border:1px solid #e5edf5;border-radius:16px;padding:12px}.treeControls{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.tree,.tree ul{margin:0;padding-left:0;list-style:none}.tree li{margin:2px 0}.tree li ul{border-left:1px dashed #d5e1ef;margin-left:22px;padding-left:12px}.treeRow{border-radius:10px;align-items:flex-start;gap:8px;min-width:0;padding:7px 8px;display:flex}.treeRow:hover{background:#eef6ff}.treeName{color:#0b2d5c;font-weight:600}.branch>.treeRow .treeName{font-weight:800}.treeValue{color:#667085;text-overflow:ellipsis;overflow-wrap:anywhere;overflow:hidden}.treeToggle{color:#0b2d5c;cursor:pointer;background:#e6eef8;border:0;border-radius:6px;flex:none;width:24px;height:24px}.treeSpacer{flex:none;width:24px}.leaf .treeRow{padding-left:8px}@media (width<=800px){.analysis{padding:12px;display:block}.panel{padding:12px}.tree li ul{margin-left:10px;padding-left:8px}.treeRow{display:block}.treeToggle,.treeSpacer{margin-right:6px}.treeName{display:inline}.treeValue{margin-top:4px;margin-left:30px;display:block}}.badge{color:#1e40af;background:#dbeafe;border-radius:999px;margin-left:.5rem;padding:.15rem .5rem;font-size:.8rem;font-weight:700;display:inline-block}.eventCards{gap:16px;display:grid}.eventCard{background:#fff;border:1px solid #dbe4ef;border-radius:18px;padding:18px;box-shadow:0 8px 28px #15324a12}.eventCard h3{margin-top:0}.assignment{background:#eff6ff;border-left:4px solid #0b65c2;border-radius:14px;margin:12px 0;padding:12px}.eventData{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;display:grid}.jsonBlock{background:#f8fafc;border:1px solid #e5edf5;border-radius:12px;max-height:260px;padding:12px;overflow:auto}.badge.ok{color:#166534;background:#dcfce7}.badge.muted{color:#475569;background:#f1f5f9}label{margin:.75rem 0;font-weight:600;display:block}input,select,textarea{box-sizing:border-box;background:#fff;border:1px solid #cbd5e1;border-radius:10px;width:100%;margin-top:.35rem;padding:.65rem}textarea{min-height:110px}label input[type=checkbox]{width:auto;margin-right:.5rem}.panel{background:#fff;border:1px solid #e2e8f0;border-radius:18px;margin:1rem 0;padding:1rem}.jsonBlock{white-space:pre-wrap}
