:root{--bg: #f3f6f8;--panel: #ffffff;--ink: #13222e;--muted: #5c6e79;--accent: #0d8c73;--line: #d4dee4;--warn: #be4a2f}*{box-sizing:border-box}body{margin:0;color:var(--ink);background:radial-gradient(circle at 20% 0%,#dbeef0,#f3f6f8 42%,#eff3f5);font-family:Segoe UI,Aptos,sans-serif}.shell{padding:18px}.topbar{align-items:center;background:linear-gradient(120deg,#112734,#1b3f4f 56%,#276068);border-radius:14px;color:#f8fdff;display:flex;justify-content:space-between;margin-bottom:14px;padding:16px 18px}.topbar h1{font-size:22px;margin:0}.brand-row{align-items:center;display:flex;gap:10px}.brand-logo{border-radius:8px;height:30px;object-fit:contain;width:30px}.topbar p{color:#ccedf0;margin:4px 0 0}.filters{display:flex;gap:10px}.filters label{display:flex;flex-direction:column;font-size:12px;gap:4px}select,input[type=date]{background:#f6fbfd;border:1px solid #acd5dc;border-radius:9px;min-width:148px;padding:7px 9px}input[type=text]{background:#f6fbfd;border:1px solid #acd5dc;border-radius:9px;padding:8px 10px;width:100%}button{background:#0e7f6a;border:1px solid #0b6b5a;border-radius:9px;color:#f4fffb;cursor:pointer;min-width:90px;padding:8px 10px}button:disabled{background:#93b7b0;border-color:#88aca5;cursor:not-allowed}.grid{display:grid;gap:12px;grid-template-columns:24% 38% 38%}.panel{display:flex;flex-direction:column;gap:12px}.panel-left{height:100%}.panel-left>.card:first-child{flex:0 0 40%;overflow:hidden}.panel-left>.card:last-child{flex:1 1 60%;overflow:auto}.panel-left>.card:first-child{padding:10px}.panel-left>.card:first-child h2{margin:0 0 8px}.panel-left>.card:first-child .cards{gap:6px;grid-template-columns:repeat(2,minmax(0,1fr))}.panel-left>.card:first-child .kpi{border-radius:8px;padding:7px 8px}.panel-left>.card:first-child .kpi strong{font-size:15px}.panel-left>.card:first-child .kpi-title{font-size:10px;margin-bottom:6px}.panel-left>.card:first-child .kpi-subtitle{font-size:10px}.panel-left>.card:first-child .kpi-compare-grid{gap:6px;margin-bottom:6px}.panel-left>.card:first-child .kpi-delta{font-size:11px;padding:3px 7px}.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 20px #112a3d0f;padding:14px}.card h2{font-size:14px;margin:0 0 10px}.cards{display:grid;gap:8px;grid-template-columns:repeat(1,1fr)}.kpi{background:linear-gradient(100deg,#f7fbff,#eef8f5);border:1px solid #d0e7de;border-radius:9px;padding:10px}.kpi strong{display:block;font-size:18px}.kpi span{color:var(--muted);font-size:12px}.kpi-title{color:#183848;display:block;font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.kpi-compare-grid{display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:8px}.kpi-subtitle{color:#5f7482;display:block;font-size:11px;margin-bottom:2px}.kpi-delta{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:700;gap:4px;padding:4px 8px}.kpi-delta.up{background:#e9f7ef;color:#147a45}.kpi-delta.down{background:#ffeceb;color:#b13a2d}.kpi-arrow{font-size:14px;line-height:1}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid #ecf1f4;font-size:12px;padding:8px 5px;text-align:left}.chart-wrap{height:260px;width:100%}.donut-legend{display:grid;gap:6px;grid-template-columns:1fr 1fr;margin-top:6px}.donut-legend span{align-items:center;color:#3f5c6c;display:inline-flex;font-size:11px;gap:6px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.donut-legend i{border-radius:999px;display:inline-block;height:8px;width:8px}.driver-legend{display:grid;gap:6px;grid-template-columns:1fr 1fr;margin-top:6px}.driver-legend span{align-items:center;color:#3f5c6c;display:inline-flex;font-size:11px;gap:6px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.driver-legend i{border-radius:999px;display:inline-block;height:8px;width:8px}.risk-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.risk{background:#fff9f5;border-left:4px solid var(--warn);border-radius:7px;font-size:12px;padding:8px 10px}.risk.low{background:#f1faf5;border-left-color:#2d9f6f}.risk.info{background:#f1f7ff;border-left-color:#477fc3}.suggestions{display:flex;flex-direction:column;gap:8px}.ai-summary-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.ai-summary-item{background:#f5fafc;border:1px solid #dbe8ef;border-radius:8px;color:#2a4452;font-size:12px;line-height:1.45;padding:8px 10px}.ai-summary-item strong{color:#17384a}.suggestions button{background:#f4fbf8;border:1px solid #c7e6d8;border-radius:9px;color:#173f35;cursor:pointer;padding:8px;text-align:left}textarea{background:#f8fbfe;border:1px solid #d9e5eb;border-radius:8px;color:#3b505d;padding:10px;resize:vertical;width:100%}.panel-right textarea{min-height:260px}@media (max-width: 980px){.grid{grid-template-columns:1fr}.panel-left>.card:first-child,.panel-left>.card:last-child{flex:0 0 auto;overflow:visible}.panel-left>.card:first-child .cards{grid-template-columns:1fr}.topbar{align-items:flex-start;flex-direction:column;gap:12px}.filters{width:100%}}
