:root{--bg:#eff4f7;--bg2:#f8fbfd;--panel:#fffffff2;--txt:#132a35;--muted:#4e6673;--accent:#0b8ca2;--accent2:#2b6fc0;--line:#cad8e1;--warn:#fff2df;--err:#ffe4e8;--good:#1f874a;--bad:#b63040}
*{box-sizing:border-box}
body{margin:0;font-family:"IBM Plex Sans","Space Grotesk","Manrope","Avenir Next","Segoe UI",sans-serif;color:var(--txt);background:radial-gradient(circle at 12% -8%,rgba(11,140,162,.16),transparent 40%),radial-gradient(circle at 90% 110%,rgba(43,111,192,.16),transparent 36%),linear-gradient(145deg,var(--bg),var(--bg2))}
body:before{content:"";position:fixed;inset:0;z-index:-1;background:repeating-linear-gradient(0deg,transparent 0 25px,rgba(17,66,84,.05) 25px 26px),repeating-linear-gradient(90deg,transparent 0 25px,rgba(17,66,84,.05) 25px 26px);opacity:.4;pointer-events:none}
main{max-width:1320px;margin:0 auto;padding:14px 12px 24px;display:grid;gap:12px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 30px rgba(17,40,52,.11)}
header{padding:14px 15px;display:grid;gap:11px;position:relative;overflow:hidden}
header:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2),transparent)}
.eyebrow{margin:0;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}
h1{margin:4px 0 6px;font-size:clamp(1.34rem,2.3vw,1.85rem)}
.status{margin:0;color:var(--muted);font-size:.9rem}
.actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.btn{border:1px solid transparent;border-radius:999px;padding:8px 12px;font:600 .84rem inherit;cursor:pointer;background:#eff7fb;transition:transform .14s ease,border-color .14s ease,background .14s ease}
.btn.primary{background:linear-gradient(135deg,var(--accent),#0ca2b8);color:#fff;box-shadow:0 8px 21px rgba(11,140,162,.3)}
.btn.ghost{background:#f6fafd;border-color:#c4d8e4;color:#294552}
.btn.small{padding:6px 10px;font-size:.77rem}
.btn:hover{transform:translateY(-1px)}
.btn:focus-visible,input:focus-visible,summary:focus-visible,th button:focus-visible{outline:3px solid rgba(11,140,162,.33);outline-offset:2px}
input[type=file]{position:absolute;left:-9999px;opacity:0}
.sysbar{display:flex;flex-wrap:wrap;gap:7px}
.syschip{display:inline-flex;align-items:center;border:1px solid #c5d7e2;background:#f1f8fc;color:#22424f;border-radius:999px;padding:4px 9px;font-size:.76rem;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.banner{padding:9px 11px;border-radius:10px;font-size:.84rem;border:1px solid transparent;white-space:pre-wrap}
.warn{background:var(--warn);border-color:#f2c888;color:#7c4b07}.err{background:var(--err);border-color:#efadb6;color:#8f1625}.hide{display:none!important}
#empty{padding:13px 14px;line-height:1.5}
.p{margin:0;color:#314956;font-size:.9rem;line-height:1.5}
.grid{display:grid;gap:9px}.meta{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.kpi{grid-template-columns:repeat(auto-fit,minmax(145px,1fr))}.sched{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.signals{display:grid;grid-template-columns:1fr;gap:10px}
.signal-card{padding:10px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fcff);box-shadow:0 7px 20px rgba(24,52,64,.08)}
.signal-card h2{margin:0 0 8px;font-size:.88rem;text-transform:uppercase;letter-spacing:.08em;color:#2f4f5d}
.split{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:center}
.ring{--ratio:50%;width:118px;aspect-ratio:1;border-radius:50%;background:conic-gradient(var(--accent) 0 var(--ratio),var(--accent2) var(--ratio) 100%);display:grid;place-items:center}
.ring-core{width:74%;aspect-ratio:1;border-radius:50%;background:#fff;border:1px solid #cddce4;display:grid;place-items:center;text-align:center;line-height:1.05}
.ring-core strong{font-size:1.02rem}.ring-core span{font-size:.69rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.legend{display:grid;gap:7px}
.legend-item{border:1px solid #c7dae3;border-left-width:4px;border-radius:9px;padding:6px 8px;background:#fff;font-size:.8rem;display:flex;justify-content:space-between;align-items:center}
.legend-item.am{border-left-color:var(--accent)}.legend-item.pm{border-left-color:var(--accent2)}
.bars{display:grid;gap:8px}
.bar-row{display:grid;grid-template-columns:70px minmax(0,1fr) 30px;gap:8px;align-items:center;font-size:.79rem}
.bar-row .n{font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:#2c4d5b;font-weight:700}
.track{height:9px;border-radius:999px;background:#e9f1f6;border:1px solid #cfdee7;overflow:hidden}
.fill{height:100%;width:0;border-radius:999px;background:#6f8591}
.fill.good{background:linear-gradient(90deg,#20934f,#47b56d)}.fill.warn{background:linear-gradient(90deg,#b97c0d,#dea225)}.fill.bad{background:linear-gradient(90deg,#bb3041,#d16473)}.fill.muted{background:linear-gradient(90deg,#6e8491,#8ca2af)}
.insights{margin:0;padding:0;list-style:none;display:grid;gap:7px}
.insights li{display:grid;grid-template-columns:86px minmax(0,1fr);gap:7px;align-items:start;border:1px solid #cfdfe8;border-radius:10px;padding:7px 8px;background:#fff;color:#2e4753;font-size:.82rem;line-height:1.38}
.tone{display:inline-flex;align-items:center;justify-content:center;min-height:20px;width:100%;padding:0 8px;border-radius:999px;border:1px solid transparent;font-size:.66rem;font-weight:700;text-transform:none;letter-spacing:0;white-space:nowrap}
.tone.good{background:#e6f7ed;color:#1f6f3d;border-color:#c0e8d0}.tone.warn{background:#fff4e4;color:#8b5807;border-color:#f1d2a1}.tone.bad{background:#ffe8ec;color:#a32235;border-color:#f0bcc5}.tone.neutral{background:#edf5f9;color:#35505e;border-color:#cedee8}
.overview{display:grid;gap:10px;margin-bottom:12px}
.cluster{padding:10px;border:1px solid var(--line);border-radius:14px;background:#fffffff8;box-shadow:0 8px 20px rgba(22,50,59,.08)}
.cluster-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.cluster-head h2{margin:0;font-size:.95rem}
.tile{padding:9px;background:#fffffffb;border:1px solid var(--line);border-radius:11px;box-shadow:0 5px 13px rgba(30,64,74,.08)}
.label{margin:0 0 5px;font-size:.67rem;text-transform:none;letter-spacing:0;color:var(--muted);font-weight:700}
.value{margin:0;font-size:1rem;font-weight:700}.value.small{font-size:.9rem;font-weight:600}.chips{margin-top:6px;display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;border:1px solid #b7d2de;background:#edf7fb;color:#21424f;border-radius:999px;padding:3px 7px;font-size:.75rem}
.sections-wrap{border:1px solid var(--line);border-radius:14px;background:#fffffff8;padding:11px;box-shadow:0 8px 20px rgba(22,50,59,.08)}
.sections-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px}
.sections-head h2{margin:0;font-size:1rem}
.sections-tools{display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.sections-head input{min-width:250px;max-width:100%;padding:7px 10px;border:1px solid #bcd0d8;border-radius:8px;font:inherit;font-size:.84rem;background:#fcfeff}
.quicknav{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:10px}
.quicknav a{display:inline-flex;align-items:center;border:1px solid #b9d3df;background:#edf7fb;color:#20424d;text-decoration:none;border-radius:999px;padding:4px 9px;font-size:.77rem;font-weight:700}
.quicknav a:hover{background:#e4f1f7}
.sections{display:grid;gap:10px}
details{background:#fffffff8;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 8px 20px rgba(22,50,59,.08)}
summary{list-style:none;cursor:pointer;padding:10px 12px;font-weight:700;display:flex;justify-content:space-between;gap:10px;background:linear-gradient(180deg,rgba(231,243,248,.8),rgba(246,251,253,.8));border-bottom:1px solid #d8e5ea}
summary::-webkit-details-marker{display:none}.smeta{font-size:.76rem;color:var(--muted);font-weight:700;letter-spacing:.04em}.body{padding:11px;display:grid;gap:10px}
.sub{margin:3px 0 0;font-size:.98rem;color:#173543}
.list{border:1px solid #d5e4e8;border-radius:11px;background:#f8fbfc;padding:9px 11px}.list ul{margin:0;padding-left:20px;display:grid;gap:6px;color:#2f464f;font-size:.87rem}
.tcard{border:1px solid #d3e2e9;border-radius:11px;background:#fff;overflow:hidden}
.thead{padding:8px 10px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:9px;border-bottom:1px solid #dce8eb;background:#f6fbfc}
.thead h4{margin:0;font-size:.9rem}.tmeta{color:#4d6570;font-size:.78rem;font-weight:700}.tools input{min-width:170px;padding:6px 8px;border:1px solid #bcd0d6;border-radius:8px;font:inherit;font-size:.8rem}
.tw{overflow:auto;max-width:100%}table{border-collapse:collapse;width:100%;min-width:620px;font-size:.81rem}th,td{padding:7px 8px;border-bottom:1px solid #e4edf0;text-align:left;vertical-align:top}th{position:sticky;top:0;background:#edf5f8;z-index:1;font-size:.73rem;text-transform:none;letter-spacing:0;color:#32505d}
th button{all:unset;cursor:pointer;font-weight:700;color:inherit}tr:nth-child(even)td{background:#fafdfd}.empty-row{padding:10px 12px;color:#6b7f87;font-size:.83rem}
.tcard.lab-table{border-color:#c5dbe1;background:linear-gradient(180deg,#ffffff,#f8fcfd)}
.tcard.lab-table .thead{background:linear-gradient(180deg,#eaf5f8,#f6fbfc)}
.tcard.lab-marker-table table{min-width:1280px}
.tcard.lab-marker-table th,.tcard.lab-marker-table td{white-space:nowrap}
.tcard.lab-marker-table th:nth-child(1),.tcard.lab-marker-table td:nth-child(1){position:sticky;left:0;min-width:110px;background:#edf6f9}
.tcard.lab-marker-table th:nth-child(2),.tcard.lab-marker-table td:nth-child(2){position:sticky;left:110px;min-width:225px;background:#f4fafc}
.tcard.lab-marker-table td:nth-child(1),.tcard.lab-marker-table td:nth-child(2){z-index:2}
.tcard.lab-marker-table th:nth-child(1),.tcard.lab-marker-table th:nth-child(2){z-index:4}
.tcard.lab-batches-table table{min-width:840px}
.tcard.lab-batches-table th,.tcard.lab-batches-table td{white-space:nowrap}
.tcard.lab-batches-table th:nth-child(7),.tcard.lab-batches-table td:nth-child(7){white-space:normal;min-width:300px;max-width:520px;overflow-wrap:anywhere;word-break:break-word}
.flag{display:inline-flex;align-items:center;border-radius:999px;padding:3px 8px;font-size:.72rem;font-weight:700;border:1px solid transparent}
.flag.good{background:#e5f7ed;color:#185a32;border-color:#b8e7c9}
.flag.warn{background:#fff3e5;color:#8b5300;border-color:#f0cd9f}
.flag.bad{background:#ffe7e7;color:#962020;border-color:#f3b2b2}
.flag.muted{background:#eef3f6;color:#4b6470;border-color:#cfdde5}
.flag.neutral{background:#edf7f8;color:#1f3b45;border-color:#b7d3d9}
footer{margin-top:2px;font-size:.8rem;color:#556b74;text-align:center}
@keyframes up{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media(max-width:760px){main{padding:10px 8px 18px}.tools input{min-width:150px}table{min-width:540px}.sections-head input{min-width:100%}}
