*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f0f2f5;color:#1a1a2e;font-size:14px;-webkit-tap-highlight-color:transparent}.header{background:linear-gradient(135deg,#00a651,#007a3d);color:#fff;padding:14px 16px;text-align:center;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #00000026}.header h1{font-size:16px;font-weight:700;margin-bottom:2px;padding:0 46px}.header .subtitle{font-size:11px;opacity:.85;padding:0 46px}.header .data-info{font-size:10px;opacity:.65;margin-top:4px;padding:0 46px}.update-btn{position:absolute;top:50%;transform:translateY(-50%);right:12px;display:inline-flex;align-items:center;justify-content:center;gap:6px;width:38px;height:38px;padding:0;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:50%;font-size:18px;font-weight:600;cursor:pointer;line-height:1}.update-btn:active{background:#ffffff59}.update-btn .ub-text{display:none}@media (min-width:620px){.header h1{padding:0 120px}.update-btn{width:auto;height:auto;border-radius:20px;padding:8px 14px;font-size:12px}.update-btn .ub-icon{font-size:14px}.update-btn .ub-text{display:inline}}.date-controls{background:#fff;border-bottom:1px solid #e0e0e0;padding:8px 12px;position:sticky;top:58px;z-index:99}.date-presets{display:flex;flex-wrap:wrap;gap:6px;padding-bottom:2px}.date-presets::-webkit-scrollbar{display:none}.preset-btn{flex:1 1 auto;min-width:72px;text-align:center;padding:9px 12px;border:1px solid #ddd;border-radius:20px;background:#fff;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.preset-btn.active{background:#00a651;color:#fff;border-color:#00a651}.custom-range{display:flex;gap:8px;align-items:center;margin-top:8px;flex-wrap:wrap}.custom-range.hidden{display:none}.custom-range label{font-size:11px;color:#666;font-weight:600}.custom-range input[type=date]{padding:6px 8px;border:1px solid #ddd;border-radius:6px;font-size:13px;flex:1;min-width:120px;max-width:150px}.apply-btn{padding:7px 16px;background:#00a651;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer}.apply-btn:active{background:#007a3d}.container{padding:12px;max-width:800px;margin:0 auto}.summary-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}.summary-card{background:#fff;border-radius:12px;padding:14px 10px;text-align:center;box-shadow:0 1px 4px #00000012}.summary-card .num{font-size:28px;font-weight:800;color:#00a651}.summary-card .label{font-size:9px;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.summary-card.alert .num{color:#e74c3c}.summary-card .trend{font-size:11px;margin-top:4px}.trend-up{color:#e74c3c;font-weight:600}.trend-down{color:#27ae60;font-weight:600}.trend-flat{color:#999}.period-info{text-align:center;padding:8px 12px;background:#e8f5e9;border-radius:8px;margin-bottom:12px;font-size:11px;color:#2e7d32;font-weight:600}.search-box{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;margin-bottom:12px;background:#fff}.search-box:focus{outline:none;border-color:#00a651;box-shadow:0 0 0 3px #00a6511a}.region-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.region-card{background:#fff;border-radius:12px;padding:14px;box-shadow:0 1px 4px #00000012;cursor:pointer;transition:all .15s;border:2px solid transparent}.region-card:active{transform:scale(.97)}.region-card:hover{border-color:#00a651}.region-card .r-name{font-size:12px;font-weight:700;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.region-card .r-count{font-size:26px;font-weight:800;color:#00a651;line-height:1}.region-card .r-label{font-size:10px;color:#666;margin-top:4px}.region-card .r-flagged{font-size:11px;color:#e74c3c;font-weight:600;margin-top:6px}.dsr-list{background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000012;overflow:hidden;margin-bottom:16px}.dsr-list-header{padding:12px 14px;background:#f8f9fa;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.dsr-list-header h3{font-size:15px;font-weight:700}.dsr-list-header .count{font-size:12px;color:#666}.dsr-item{padding:12px 14px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.dsr-item:last-child{border-bottom:none}.dsr-item.flagged{background:#fff5f5;border-left:4px solid #e74c3c}.dsr-info{flex:1;min-width:0}.dsr-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dsr-name .flag-icon{color:#e74c3c;font-size:11px;margin-left:4px;font-weight:800}.dsr-detail{font-size:11px;color:#777;margin-top:3px}.dsr-detail span{margin-right:6px}.dsr-stats{text-align:right;flex-shrink:0;margin-left:10px}.dsr-stats .incident-count{font-size:24px;font-weight:800;color:#1a1a2e;line-height:1}.dsr-stats .incident-label{font-size:9px;color:#aaa;text-transform:uppercase;margin-top:2px}.dsr-stats .incident-trend{font-size:11px;margin-top:4px}.back-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:13px;cursor:pointer;margin-bottom:12px;font-weight:600;box-shadow:0 1px 2px #0000000a}.back-btn:active{background:#f5f5f5}.sort-bar{display:flex;gap:6px;margin-bottom:10px;overflow-x:auto}.sort-btn{padding:5px 10px;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:11px;cursor:pointer;white-space:nowrap}.sort-btn.active{background:#1a1a2e;color:#fff;border-color:#1a1a2e}.no-data{text-align:center;padding:40px;color:#aaa;font-size:14px}.hidden{display:none!important}@media (max-width:400px){.summary-card .num{font-size:22px}.region-grid{gap:6px}.region-card{padding:10px}.region-card .r-count{font-size:22px}}.tab-bar{display:flex;gap:6px;margin-bottom:8px}.tab-btn{flex:1;padding:9px 10px;border:1px solid #ddd;border-radius:8px;background:#fff;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s}.tab-btn.active{background:#00a651;color:#fff;border-color:#00a651;box-shadow:0 2px 6px #00a65140}.insight{background:#fff;border-radius:14px;padding:16px 16px 14px;margin-bottom:12px;box-shadow:0 1px 6px #00000014;border-left:6px solid #00a651}.insight.bad{border-left-color:#e74c3c}.insight.flat{border-left-color:#999}.insight .headline{font-size:19px;font-weight:800;line-height:1.25;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.insight .pct{font-size:26px;font-weight:900}.insight.good .pct,.insight.good .headline .dir{color:#27ae60}.insight.bad .pct,.insight.bad .headline .dir{color:#e74c3c}.insight.flat .pct{color:#999}.insight .sub{font-size:12px;color:#666;margin-top:8px;line-height:1.5}.insight .sub b{color:#1a1a2e}.kpi-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}@media (min-width:620px){.kpi-row{grid-template-columns:repeat(4,1fr)}}.kpi-card{background:#fff;border-radius:12px;padding:14px 12px;box-shadow:0 1px 4px #00000012}.kpi-card .k-label{font-size:9px;color:#888;text-transform:uppercase;letter-spacing:.5px;font-weight:700}.kpi-card .k-num{font-size:30px;font-weight:800;color:#00a651;line-height:1.1;margin-top:4px}.kpi-card.alert .k-num{color:#e74c3c}.kpi-card .k-trend{font-size:11px;margin-top:4px}.chart-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:16px}@media (min-width:760px){.chart-grid{grid-template-columns:1fr 1fr}.chart-card.wide{grid-column:1/-1}}.chart-card{background:#fff;border-radius:14px;padding:14px;box-shadow:0 1px 6px #00000014}.chart-card h3{font-size:14px;font-weight:700;margin-bottom:10px}.chart-card h3 .chart-sub{font-size:11px;font-weight:500;color:#999;margin-left:6px}.chart-wrap{position:relative;height:240px}.chart-wrap.tall{height:320px}.chart-empty{text-align:center;color:#bbb;font-size:13px;padding:60px 10px}.empty-state{text-align:center;padding:48px 20px;color:#666}.empty-state .es-icon{font-size:40px;margin-bottom:10px}.empty-state h2{font-size:16px;margin-bottom:6px;color:#1a1a2e}.empty-state p{font-size:13px;margin-bottom:16px}.empty-state .apply-btn{display:inline-block}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.modal.hidden{display:none}.modal-card{background:#fff;border-radius:14px;padding:20px;width:100%;max-width:440px;box-shadow:0 10px 40px #00000040}.modal-card h2{font-size:17px;font-weight:700;margin-bottom:6px}.modal-sub{font-size:12px;color:#666;margin-bottom:14px;line-height:1.5}.modal-card input[type=file]{width:100%;padding:10px;border:1px dashed #bbb;border-radius:8px;font-size:13px;background:#fafafa;margin-bottom:12px}.file-preview{font-size:12px;color:#2e7d32;background:#e8f5e9;border-radius:8px;padding:10px;margin-bottom:12px;display:none}.file-preview.show{display:block}.upload-status{font-size:12px;margin-bottom:12px;min-height:16px}.upload-status.err{color:#e74c3c}.upload-status.ok{color:#27ae60}.upload-status.busy{color:#888}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.btn-secondary{padding:9px 16px;background:#f0f0f0;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer}.btn-primary{padding:9px 16px;background:#00a651;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer}.btn-primary:disabled{background:#a5d6b8;cursor:not-allowed}.dsr-item{cursor:pointer;transition:background .12s}.dsr-item:hover{background:#f6fbf7}.dsr-item:active{background:#eef7f0}.dsr-item .dsr-name{color:#0a7a3f}.dsr-item .chev{color:#bbb;font-size:18px;margin-left:8px;flex-shrink:0}.modal-close{position:absolute;top:10px;right:12px;width:32px;height:32px;border:none;background:#f0f0f0;border-radius:50%;font-size:20px;line-height:1;color:#555;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:active{background:#e0e0e0}.dsr-modal-card{position:relative;max-width:460px;max-height:88vh;overflow-y:auto;padding:22px 18px 18px}.dsr-d-name{font-size:19px;font-weight:800;color:#1a1a2e;padding-right:34px;line-height:1.2}.dsr-d-name .flag-icon{display:inline-block;color:#fff;background:#e74c3c;font-size:10px;font-weight:800;padding:2px 7px;border-radius:10px;margin-left:6px;vertical-align:middle;letter-spacing:.4px}.dsr-d-meta{font-size:12px;color:#777;margin-top:6px;line-height:1.7}.dsr-d-meta span{display:inline-block;margin-right:12px;white-space:nowrap}.dsr-d-region{cursor:pointer;color:#0a7a3f;font-weight:600;text-decoration:underline;text-decoration-style:dotted}.dsr-d-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}.dsr-d-stat{background:#f7f8fa;border-radius:10px;padding:10px 12px}.dsr-d-stat .v{font-size:22px;font-weight:800;color:#00a651;line-height:1.1}.dsr-d-stat.alert .v{color:#e74c3c}.dsr-d-stat .l{font-size:10px;color:#888;text-transform:uppercase;letter-spacing:.4px;margin-top:2px}.dsr-d-stat .v .trend-up,.dsr-d-stat .v .trend-down,.dsr-d-stat .v .trend-flat{font-size:12px;margin-left:4px}.dsr-d-period{text-align:center;padding:7px 10px;background:#e8f5e9;border-radius:8px;margin-top:12px;font-size:11px;color:#2e7d32;font-weight:600}.dsr-d-tl-head{font-size:13px;font-weight:700;margin:16px 0 8px;color:#1a1a2e}.dsr-d-tl-head .sub{font-size:11px;font-weight:500;color:#999;margin-left:4px}.timeline{display:flex;flex-direction:column;gap:6px}.tl-row{display:flex;align-items:center;gap:10px}.tl-date{font-size:12px;font-weight:600;color:#444;width:74px;flex-shrink:0}.tl-date .tl-dow{color:#aaa;font-weight:700;margin-right:4px;font-size:11px}.tl-track{flex:1;height:18px;background:#f2f3f5;border-radius:5px;position:relative;overflow:hidden}.tl-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#00a651,#33c178);border-radius:5px;min-width:4px}.tl-row.multi .tl-fill{background:linear-gradient(90deg,#e74c3c,#ff7a6b)}.tl-count{font-size:12px;font-weight:800;color:#1a1a2e;width:18px;text-align:right;flex-shrink:0}.tl-times{font-size:10px;color:#999;margin-top:2px;width:100%;padding-left:84px}.dsr-d-empty{text-align:center;padding:30px;color:#aaa;font-size:13px}
