*{box-sizing:border-box}body{margin:0;color:#15202b;background:#f4f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:0}button{font:inherit}button:focus-visible,label:focus-within{outline:3px solid rgba(0,168,157,.24);outline-offset:2px}.app-shell{display:grid;grid-template-columns:256px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;background:#0f1720;color:#eaf0f5;display:flex;flex-direction:column;padding:22px 16px;gap:26px}.brand{display:flex;align-items:center;gap:12px;padding:0 8px}.brand-mark{width:38px;height:38px;display:grid;place-items:center;border-radius:8px;background:#00a89d;color:#fff;font-weight:800}.brand strong,.brand span{display:block}.brand strong{font-size:15px;line-height:1.2}.brand span{margin-top:2px;color:#9aa8b4;font-size:12px}.nav-list{display:grid;gap:5px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;min-height:40px;border:0;border-radius:8px;background:transparent;color:#aeb9c4;padding:0 12px;cursor:pointer;text-align:left}.nav-item.active,.nav-item:hover{background:#1b2733;color:#fff}.nav-item:active{transform:translateY(1px)}.source-card{margin-top:auto;display:grid;grid-template-columns:24px 1fr auto;gap:10px;align-items:center;padding:14px;border:1px solid #273747;border-radius:8px;background:#14202b}.source-card span,.source-card strong{display:block}.source-card span{color:#95a4b1;font-size:12px;line-height:1.35}.source-card b{color:#00d1c2}.workspace{min-width:0;padding:24px}.section-anchor{scroll-margin-top:18px}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:20px}.topbar h1{margin:0;font-size:30px;line-height:1.1;font-weight:760}.topbar p{margin:7px 0 0;color:#66727d;font-size:13px}.top-actions{display:flex;align-items:flex-start;justify-content:flex-end;gap:8px}.language-toggle{display:inline-flex;align-items:center;gap:7px;min-height:36px;border:1px solid #d9e1e8;border-radius:8px;background:#fff;color:#26333f;padding:0 11px;cursor:pointer;white-space:nowrap}.filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.filter-shell{position:relative}.filters>.filter-shell>button{display:inline-flex;align-items:center;gap:8px;min-height:36px;border:1px solid #d9e1e8;border-radius:8px;background:#fff;color:#26333f;padding:0 11px;cursor:pointer}.filter-name{color:#74818d;font-size:11px;font-weight:700}.filter-menu{position:absolute;right:0;top:calc(100% + 7px);z-index:20;width:min(280px,80vw);padding:12px;border:1px solid #dbe5ec;border-radius:8px;background:#fff;box-shadow:0 14px 34px #0f172029}.filter-menu span,.filter-menu strong{display:block}.filter-menu span{color:#687682;font-size:12px;font-weight:700}.filter-menu strong{margin-top:5px;color:#172433;font-size:14px;line-height:1.35}.filter-menu p{margin:9px 0 12px;color:#61707d;font-size:12px;line-height:1.4}.filter-menu button{min-height:34px;width:100%;border:0;border-radius:8px;background:#edf7f6;color:#08746d;cursor:pointer;font-weight:750}.notice-bar{margin:-8px 0 14px;padding:9px 12px;border:1px solid #cce8e5;border-radius:8px;background:#eefdfb;color:#096b64;font-size:13px;font-weight:700}.ingest-panel{display:grid;grid-template-columns:minmax(0,1fr) minmax(180px,280px) auto;gap:10px;align-items:center;margin-bottom:14px;padding:12px;border:1px solid #d7e3ea;border-radius:8px;background:#fff}.ingest-panel strong,.ingest-panel span{display:block}.ingest-panel strong{font-size:14px;line-height:1.2}.ingest-panel span{margin-top:4px;color:#62707c;font-size:12px;line-height:1.35}.file-picker{display:flex;align-items:center;min-height:38px;min-width:0;border:1px dashed #b9c8d4;border-radius:8px;color:#32424f;background:#f7fafc;padding:0 11px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-picker input{display:none}.ingest-panel button{min-height:38px;border:0;border-radius:8px;background:#00a89d;color:#fff;padding:0 13px;cursor:pointer;white-space:nowrap}.ingest-panel button:disabled{background:#b8c5cf;cursor:not-allowed}.kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:14px}.kpi-card,.panel{background:#fff;border:1px solid #dde5ec;border-radius:8px;box-shadow:0 1px 2px #0f17200a}.kpi-card{min-height:104px;padding:16px;display:grid;align-content:space-between}.kpi-card span{color:#64717d;font-size:12px;font-weight:650}.kpi-card strong{font-size:23px;line-height:1.15}.kpi-card em{font-style:normal;font-size:12px;font-weight:700}.tone-good{color:#047857}.tone-warn{color:#b45309}.tone-neutral{color:#66727d}.content-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.85fr);gap:14px}.panel{min-width:0;padding:16px}.panel-large,.table-panel{grid-column:span 1}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.panel-header h2{margin:0;font-size:16px;line-height:1.2}.panel-header p{margin:5px 0 0;color:#6a7682;font-size:12px}.legend{display:flex;flex-wrap:wrap;gap:10px;color:#5f6b76;font-size:12px}.legend span{display:inline-flex;align-items:center;gap:5px}.dot{width:8px;height:8px;border-radius:999px;display:inline-block}.core{background:#00a89d}.big{background:#356bb6}.long{background:#d98a16}.trend-bars{height:258px;display:grid;grid-template-columns:repeat(7,1fr);gap:14px;align-items:end;padding:10px 8px 2px}.trend-day{display:grid;gap:8px;justify-items:center;min-width:0}.bar-stack{height:218px;width:100%;display:flex;align-items:end;justify-content:center;gap:5px;border-bottom:1px solid #dce4eb}.bar{width:min(18px,22%);min-height:12px;border-radius:5px 5px 0 0}.bar-core{background:#00a89d}.bar-big{background:#356bb6}.bar-long{background:#d98a16}.trend-label{color:#6a7682;font-size:11px;white-space:nowrap}.alert-list{display:grid;gap:8px}.alert-row{display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:8px;min-height:44px;border:1px solid #e1e7ed;border-radius:8px;background:#fff;padding:0 10px;color:#26333f;text-align:left;cursor:pointer}.alert-row.selected{border-color:#00a89d;background:#effdfb}.alert-row strong{color:#61707d;font-size:12px}.severity-p0,.severity-p1,.severity-p2{display:inline-grid;place-items:center;min-width:32px;height:22px;border-radius:6px;font-size:11px;font-weight:800}.severity-p0{background:#fee2e2;color:#b91c1c}.severity-p1{background:#fff2cc;color:#9a5b00}.severity-p2{background:#e8eef7;color:#244a7f}.action-detail{margin-top:14px;border-top:1px solid #e3e9ef;padding-top:14px}.action-detail h3{margin:10px 0 5px;font-size:15px}.action-detail p{margin:0 0 12px;color:#697681;font-size:13px}.action-detail button{display:inline-flex;align-items:center;gap:8px;min-height:36px;border:0;border-radius:8px;background:#00a89d;color:#fff;padding:0 12px;cursor:pointer}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:650px}th,td{border-bottom:1px solid #e4ebf1;padding:11px 8px;text-align:left;font-size:12px}th{color:#6f7d89;font-weight:750}td{color:#2b3945}.trend-badge{display:inline-block;min-width:45px;border-radius:6px;padding:4px 7px;text-align:center;font-weight:750;font-size:11px}.trend-badge.up{background:#e7f8ee;color:#047857}.trend-badge.flat{background:#e8eef7;color:#315a88}.trend-badge.down{background:#fff2cc;color:#9a5b00}.opportunity-list,.quality-list{display:grid;gap:10px}.opportunity{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:10px;min-height:60px;border:1px solid #e4ebf1;border-radius:8px;padding:10px}.score-ring{width:38px;height:38px;display:grid;place-items:center;border:3px solid #00a89d;border-radius:999px;font-weight:800;color:#0a716b}.opportunity strong,.opportunity span{display:block}.opportunity strong{font-size:13px;line-height:1.25}.opportunity span{margin-top:3px;color:#6c7883;font-size:12px}.opportunity em{font-style:normal;color:#047857;font-weight:800;white-space:nowrap}.quality-row{display:grid;grid-template-columns:24px 1fr auto;gap:10px;align-items:center;min-height:52px;border:1px solid #e4ebf1;border-radius:8px;padding:9px 10px}.quality-row svg{color:#00a89d}.quality-row strong,.quality-row span{display:block}.quality-row strong{font-size:13px}.quality-row span{margin-top:2px;color:#6d7984;font-size:12px}.quality-row b{border-radius:6px;padding:4px 7px;font-size:11px}.quality-row b.pass{background:#e7f8ee;color:#047857}.quality-row b.warn{background:#fff2cc;color:#9a5b00}@media(max-width:1100px){.app-shell{grid-template-columns:76px 1fr}.brand div:not(.brand-mark),.nav-item span,.source-card div,.source-card b{display:none}.sidebar{padding:18px 10px;align-items:center}.nav-item{justify-content:center;padding:0}.source-card{display:grid;grid-template-columns:1fr;place-items:center;padding:12px}.kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.content-grid{grid-template-columns:1fr}.topbar,.top-actions{display:grid;justify-content:stretch}.filters{justify-content:flex-start}}@media(max-width:720px){.app-shell{grid-template-columns:1fr}.sidebar{position:sticky;top:0;height:auto;z-index:5;flex-direction:row;overflow-x:auto;padding:10px}.brand,.source-card{display:none}.nav-list{display:flex;gap:6px}.nav-item{width:42px;min-width:42px}.workspace{padding:16px}.topbar{display:grid}.top-actions{display:grid;width:100%}.language-toggle{justify-content:center}.filters{justify-content:flex-start}.filter-shell{width:100%}.filters>.filter-shell>button{width:100%;justify-content:space-between}.filter-menu{left:0;right:auto;width:100%}.ingest-panel{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.trend-bars{gap:8px}.alert-row{grid-template-columns:36px 1fr}.alert-row strong{grid-column:2}}
