*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w:220px;--sidebar-bg:#0b1423;--sidebar-text:#6b7a99;--sidebar-active-bg:#3b82f61f;--sidebar-active-text:#60a5fa;--bg:#f5f6f8;--card:#fff;--border:#e5e7eb;--border-light:#f3f4f6;--text:#374151;--text-secondary:#6b7280;--text-heading:#111827;--text-muted:#9ca3af;--blue:#2563eb;--blue-light:#eff6ff;--red:#dc2626;--green:#16a34a;--yellow:#d97706;--purple:#7c3aed;--cyan:#0891b2;--shadow:0 1px 2px #0f172a0a;--shadow-md:0 8px 18px #0f172a14;--radius:8px;--radius-lg:8px;--page-pad-x:24px;--module-gap:16px;--content-max-w:1480px}body{color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.6}#root{min-height:100vh}h1,h2,h3,h4{color:var(--text-heading);font-weight:600}a{color:inherit;text-decoration:none}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);z-index:100;flex-direction:column;display:flex;position:fixed;inset:0 auto 0 0}.sidebar-brand{border-bottom:1px solid #ffffff0f;flex-shrink:0;padding:20px 16px 14px}.brand-row{align-items:center;gap:10px;display:flex}.brand-icon{color:#fff;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;display:flex}.brand-icon.blue{background:linear-gradient(135deg,#2563eb,#60a5fa)}.brand-icon.green{background:linear-gradient(135deg,#16a34a,#4ade80)}.brand-icon.purple{background:linear-gradient(135deg,#7c3aed,#a78bfa)}.brand-name{color:#f1f5f9;letter-spacing:.3px;font-size:16px;font-weight:700}.brand-sub{color:var(--sidebar-text);margin-top:1px;padding-left:42px;font-size:11px}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:10px 8px;display:flex;overflow-y:auto}.nav-group-label{text-transform:uppercase;letter-spacing:1.2px;color:#6b7a9959;padding:14px 10px 4px;font-size:10px;font-weight:600}.nav-item{color:var(--sidebar-text);cursor:pointer;border-radius:6px;align-items:center;gap:9px;padding:8px 10px;font-size:13px;transition:all .15s;display:flex}.nav-item:hover{color:#d1d9e6;background:#ffffff0f}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text)}.nav-icon{text-align:center;opacity:.7;flex-shrink:0;width:18px;font-size:14px}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{color:#6b7a9966;border-top:1px solid #ffffff0f;flex-shrink:0;padding:14px 16px;font-size:11px}.main-content{margin-left:var(--sidebar-w);flex:1;min-width:0;min-height:100vh}.topbar{background:var(--card);border-bottom:1px solid var(--border);padding:0 var(--page-pad-x);z-index:50;position:sticky;top:0}.topbar-inner{width:100%;max-width:var(--content-max-w);justify-content:space-between;align-items:center;gap:18px;min-height:58px;margin:0 auto;padding:9px 0;display:flex}.topbar-left{flex-direction:column;gap:7px;min-width:360px;display:flex}.crumb-line{color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;display:flex}.crumb-line span{color:var(--text-heading);font-weight:500}.report-tabs{align-items:center;gap:2px;display:flex}.report-tab{color:var(--text-secondary);border:1px solid #0000;border-radius:4px;padding:5px 12px;font-size:12px;transition:all .15s}.report-tab:hover{color:var(--blue);background:#eff6ff}.report-tab.active{color:var(--blue);background:var(--blue-light);border-color:#bfdbfe;font-weight:600}.topbar-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.date-input{border:1px solid var(--border);color:var(--text);background:var(--bg);border-radius:5px;outline:none;padding:4px 10px;font-family:inherit;font-size:13px}.date-input:focus{border-color:var(--blue)}.btn{cursor:pointer;border:1px solid var(--border);background:var(--card);min-height:30px;color:var(--text);border-radius:4px;align-items:center;gap:5px;padding:5px 12px;font-family:inherit;font-size:12px;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--blue);color:var(--blue)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-primary:hover{color:#fff;background:#1d4ed8}.page{width:calc(100% - var(--page-pad-x) * 2);max-width:var(--content-max-w);margin:0 auto;padding:20px 0 40px}.page-hdr{margin-bottom:var(--module-gap);justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.page-hdr h1{letter-spacing:0;margin-bottom:3px;font-size:20px;font-weight:700}.page-meta{color:var(--text-secondary);align-items:center;gap:14px;font-size:13px;display:flex}.page-selector{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:8px;font-size:12px;font-weight:600;display:inline-flex}.page-selector select{border:1px solid var(--border);min-width:148px;height:32px;color:var(--text);background:var(--card);border-radius:4px;outline:none;padding:0 8px;font-family:inherit;font-size:13px}.page-selector select:focus{border-color:var(--blue);box-shadow:0 0 0 2px #2563eb14}.page-selector.static-selector{min-height:32px}.page-selector.static-selector strong{color:var(--text-heading);font-size:13px}.tag{background:var(--blue-light);color:var(--blue);border-radius:10px;padding:1px 10px;font-size:11px}.module-tabs{width:100%;margin:-2px 0 var(--module-gap);border-radius:var(--radius-lg);background:#eceff3;gap:2px;padding:3px;display:flex}.module-tab{height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:0;border-radius:5px;padding:0 14px;font-family:inherit;font-size:13px;font-weight:600}.module-tab.active{color:var(--blue);background:#fff;box-shadow:0 1px 2px #0f172a14}.module-tab:hover:not(.active){color:var(--text-heading)}.exec-summary{border-radius:var(--radius-lg);margin-bottom:var(--module-gap);color:var(--text-heading);background:#f8fafc;border:1px solid #dbeafe;padding:13px 16px;font-size:13px;line-height:1.9}.exec-summary .hl{color:var(--blue);font-weight:600}.exec-summary .hl.up{color:var(--red)}.exec-summary .hl.down{color:var(--green)}.exec-summary .hl.muted{color:var(--text-muted)}.exec-summary .br{display:block}.leader-brief-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:var(--module-gap);background:linear-gradient(#fff,#f8fafc);border:1px solid #dbeafe;padding:16px}.leader-brief-main{border-bottom:1px solid var(--border-light);justify-content:space-between;gap:18px;padding-bottom:12px;display:flex}.leader-brief-main h2{margin:4px 0 6px;font-size:20px;line-height:1.3}.leader-brief-main p{color:var(--text-secondary);font-size:13px;line-height:1.7}.leader-brief-date{text-align:right;min-width:150px;color:var(--text-muted);font-size:12px}.leader-brief-date strong{color:var(--text-heading);margin-top:4px;font-size:14px;display:block}.leader-brief-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding-top:12px;display:grid}.leader-brief-grid div{background:#fff;border:1px solid #e6ebf2;border-radius:6px;padding:10px 12px}.leader-brief-grid span,.section-label{color:var(--text-muted);font-size:12px;font-weight:600;display:block}.leader-brief-grid strong{color:var(--text-heading);margin-top:4px;font-size:15px;display:block}.leader-brief-grid em{color:var(--text-secondary);margin-top:2px;font-size:12px;font-style:normal;display:block}.stat-grid{gap:var(--module-gap);margin-bottom:var(--module-gap);grid-template-columns:repeat(4,minmax(0,1fr));display:grid}.stat-grid.branch-report-kpis,.stat-grid.purchase-total-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.stat-card{background:var(--card);border-radius:var(--radius-lg);min-height:116px;box-shadow:var(--shadow);border:1px solid var(--border);padding:14px 16px 13px;transition:box-shadow .2s,transform .2s;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card:before{content:"";background:var(--blue);height:3px;position:absolute;top:0;left:0;right:0}.stat-card.green:before{background:var(--green)}.stat-card.red:before{background:var(--red)}.stat-card.yellow:before{background:var(--yellow)}.stat-card.purple:before{background:var(--purple)}.stat-card.cyan:before{background:var(--cyan)}.stat-label{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:600}.stat-value{color:var(--text-heading);font-variant-numeric:tabular-nums;font-size:24px;font-weight:700;line-height:1.1}.stat-value .u{color:var(--text-muted);margin-left:2px;font-size:12px;font-weight:400}.stat-chg{margin-top:3px;font-size:12px;font-weight:500}.stat-chg.up{color:var(--red)}.stat-chg.down{color:var(--green)}.stat-meta{color:var(--text-muted);flex-wrap:wrap;gap:10px;margin-top:5px;font-size:11px;display:flex}.purchase-kpi-grid{gap:var(--module-gap);margin-bottom:var(--module-gap);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.purchase-kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:12px}.purchase-kpi-title{color:var(--text-heading);padding:0 2px 10px;font-size:13px;font-weight:700}.purchase-kpi-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.purchase-kpi-metrics .stat-card{min-height:104px;box-shadow:none;background:#fbfcfe;padding:13px}.card{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:var(--module-gap);overflow:hidden}.card-hdr{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;min-height:48px;padding:12px 16px;display:flex}.card-hdr h3{font-size:14px;font-weight:600}.card-body{padding:0;overflow-x:auto}.card-body.padded{padding:14px 16px}.card-hdr.card-note{border-top:1px solid var(--border-light);background:#fafbfc;border-bottom:none;min-height:auto;padding:10px 16px}.empty-card{text-align:center;color:var(--text-muted);padding:40px}.scroll-body{max-height:480px;overflow-y:auto}.modern-table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}.modern-table thead{border-bottom:2px solid var(--border)}.modern-table th{text-align:left;color:var(--text-secondary);white-space:nowrap;border-bottom:1px solid var(--border);background:#fafbfc;padding:10px 12px;font-size:12px;font-weight:600}.modern-table td{border-bottom:1px solid var(--border-light);vertical-align:middle;padding:10px 12px}.modern-table td.num{text-align:right;font-variant-numeric:tabular-nums}.modern-table th.c,.modern-table td.c{text-align:center}.modern-table th.r,.modern-table td.r{text-align:right}.modern-table tbody tr{transition:background .12s}.modern-table tbody tr:hover td{background:#f8fafc}.modern-table tbody tr.total td{background:#f3f6fb;border-top:1px solid #dbe3ef;font-weight:600}.modern-table .up{color:var(--red)}.modern-table .down{color:var(--green)}.report-table th{text-align:center}.report-table td:first-child,.report-table td:nth-child(2),.report-table td:nth-child(3),.report-table td:nth-child(4){white-space:nowrap}.report-table thead tr:first-child th{color:#374151;background:#eef4fb}.report-table thead tr:nth-child(2) th{background:#fafbfc}.branch-table-wrap{max-height:620px;overflow:auto}.branch-table-wrap thead th{z-index:2;box-shadow:inset 0 -1px 0 var(--border);position:sticky;top:0}.branch-table-wrap thead tr:nth-child(2) th{top:38px}.branch-table-wrap .modern-table{min-width:1380px}.drill-table-wrap{max-height:420px}.purchase-table{min-width:1760px!important}.purchase-table td,.purchase-table th{vertical-align:middle}.purchase-table td:nth-child(3),.purchase-table td:nth-child(12){white-space:normal;max-width:220px}.purchase-summary{border-bottom:1px solid var(--border-light);color:var(--text-secondary);background:linear-gradient(#fff,#fafbfc);grid-template-columns:repeat(6,minmax(140px,1fr));gap:10px;padding:12px 16px;font-size:12px;display:grid}.summary-pill{background:#fff;border:1px solid #e6ebf2;border-radius:6px;grid-template-columns:1fr auto;align-content:center;gap:2px 8px;min-height:62px;padding:9px 10px;display:grid}.summary-pill span{color:var(--text-secondary);grid-column:1/-1;font-size:12px}.summary-pill strong{color:var(--text-heading);font-variant-numeric:tabular-nums;font-size:16px;font-weight:700;line-height:1.3}.summary-pill em{color:var(--text-muted);align-self:end;font-size:11px;font-style:normal}.purchase-query-grid{border-bottom:1px solid var(--border-light);grid-template-columns:repeat(6,minmax(130px,1fr))}.filter-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}.purchase-company-summary{border-bottom:1px solid var(--border-light);background:linear-gradient(#fff,#fafbfc)}.summary-table-hdr{justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 16px 8px;display:flex}.summary-table-hdr h3{font-size:13px;font-weight:700;line-height:1.3}.summary-table-hdr span{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.summary-table-wrap{padding:0 16px 14px;overflow-x:auto}.company-summary-table{background:#fff;border:1px solid #e6ebf2;border-radius:6px;min-width:760px;overflow:hidden}.company-summary-table th,.company-summary-table td{padding:9px 12px}.company-summary-table tbody tr.total td{background:#eef4fb}.loss-text{color:var(--red)!important}.gas-badge{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;justify-content:center;align-items:center;min-width:42px;height:22px;padding:0 8px;font-size:11px;font-weight:700;display:inline-flex}.gas-badge.lng{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.link-btn{color:var(--blue);font:inherit;cursor:pointer;background:0 0;border:none;padding:0}.link-btn:hover{text-decoration:underline}.month-drill-btn{font-variant-numeric:tabular-nums;font-weight:700}.drill-card{margin-top:var(--module-gap);border-color:#bfdbfe}.charts-grid{gap:var(--module-gap);margin-bottom:var(--module-gap);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.management-charts-grid .chart-card:first-child{min-height:360px}.chart-card{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);min-width:0;padding:14px 16px 12px}.chart-card:hover{box-shadow:var(--shadow-md)}.chart-card h3{margin-bottom:10px;font-size:14px;font-weight:600}.chart-card.fw{grid-column:1/-1}.chart-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.chart-card-header h3{margin-bottom:0}.chart-controls{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.chart-empty{text-align:center;color:var(--text-muted);padding:48px 0;font-size:14px}.hq-summary-table-wrap{overflow:auto}.hq-report-card{border-color:#dbe3ef}.report-toolbar{background:#fbfcfe}.hq-system-table{min-width:1540px}.hq-system-table th{z-index:1;position:sticky;top:0}.hq-system-table .strong-cell{color:var(--text-heading);font-weight:700}.hq-system-table .drillable-row{cursor:default}.hq-system-table .template-row td{background:#fffdf7}.hq-system-table .summary-total-row td{background:#f3f6fb;border-top:1px solid #dbe3ef;font-weight:700}.hq-system-table .total-label{color:var(--text-heading)}.report-name-cell{flex-direction:column;gap:2px;min-width:116px;display:flex}.report-name-cell strong{color:var(--text-heading);font-size:13px}.report-name-cell span{color:var(--text-muted);font-size:11px}.row-status{border-radius:999px;justify-content:center;align-items:center;min-width:54px;height:22px;padding:0 8px;font-size:11px;font-weight:700;display:inline-flex}.row-status.good{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.row-status.warn{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.manual-panel{background:#fbfdff;border:1px solid #bfdbfe;border-radius:8px;margin:12px 16px 16px;box-shadow:0 10px 18px #0f172a0d}.manual-panel-hdr{border-bottom:1px solid #dbeafe;justify-content:space-between;align-items:center;gap:12px;min-height:52px;padding:12px 14px;display:flex}.manual-panel-hdr strong{color:var(--text-heading);font-size:14px;display:block}.manual-panel-hdr span{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.manual-grid{grid-template-columns:repeat(4,minmax(140px,1fr));gap:12px;padding:14px;display:grid}.manual-remark{grid-column:span 2}.manual-panel-actions{justify-content:flex-end;gap:8px;padding:0 14px 14px;display:flex}.table-empty{text-align:center;color:var(--text-muted);padding:32px 0;font-size:13px}.search-wrap{align-items:center;display:flex}.search-input{border:1px solid var(--border);background:var(--bg);border-radius:5px;outline:none;width:170px;padding:5px 10px;font-family:inherit;font-size:12px;transition:border-color .15s}.search-input:focus{border-color:var(--blue)}.sort-row{gap:4px;margin-bottom:10px;display:flex}.sort-btn{border:1px solid var(--border);background:var(--card);color:var(--text-secondary);cursor:pointer;border-radius:4px;padding:3px 10px;font-family:inherit;font-size:11px;transition:all .15s}.sort-btn:hover{border-color:var(--blue);color:var(--blue)}.sort-btn.active{background:var(--blue-light);color:var(--blue);border-color:var(--blue);font-weight:600}.sort-th{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.sort-th:hover{background:#eef2ff}.modern-table .row-dim td{color:var(--text-muted)}.modern-table .row-dim td strong{color:var(--text-muted);font-weight:400}.drill-link{background:var(--blue-light);width:26px;height:26px;color:var(--blue);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:700;transition:background .15s,transform .15s;display:inline-flex}.drill-link:hover{background:var(--blue);color:#fff;transform:scale(1.1)}.date-picker-wrap{align-items:center;display:flex}.date-input{min-width:140px}.table-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.date-query{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:inline-flex}.date-query input,.date-query select{border:1px solid var(--border);height:30px;color:var(--text);background:var(--card);border-radius:4px;outline:none;padding:0 8px;font-family:inherit;font-size:12px}.date-query input:focus,.date-query select:focus{border-color:var(--blue);box-shadow:0 0 0 2px #2563eb14}.query-card{overflow:visible}.filter-panel{background:linear-gradient(#fbfcfe,#fff)}.filter-panel-hdr{justify-content:space-between;align-items:flex-start;gap:12px;min-height:48px;padding:12px 16px 0;display:flex}.filter-panel-hdr h3{font-size:13px;font-weight:700;line-height:1.3}.filter-panel-hdr span{color:var(--text-muted);margin-top:2px;font-size:12px;display:block}.query-grid{grid-template-columns:repeat(5,minmax(140px,1fr));gap:14px;padding:12px 16px 16px;display:grid}.detail-query-grid{grid-template-columns:repeat(5,minmax(150px,1fr))}.query-field{flex-direction:column;gap:6px;min-width:0;display:flex}.query-field span{color:var(--text-secondary);font-size:12px;font-weight:600}.query-field input,.query-field select{border:1px solid var(--border);height:34px;color:var(--text);background:var(--card);border-radius:4px;outline:none;padding:0 8px;font-family:inherit;font-size:13px}.query-field input:disabled,.query-field select:disabled{color:var(--text-secondary);cursor:not-allowed;background:#f3f4f6}.query-field input:focus,.query-field select:focus{border-color:var(--blue);box-shadow:0 0 0 2px #2563eb14}.pagination-bar{border-top:1px solid var(--border-light);min-height:48px;color:var(--text-secondary);background:#fbfcfe;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;font-size:12px;display:flex}.pagination-info strong{color:var(--text-heading);font-variant-numeric:tabular-nums}.pagination-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pagination-actions label{align-items:center;gap:6px;display:inline-flex}.pagination-actions select{border:1px solid var(--border);height:30px;color:var(--text);background:var(--card);border-radius:4px;padding:0 6px;font-size:12px}.pagination-actions .btn{min-height:30px;padding:4px 10px}.pagination-actions .btn:disabled{color:var(--text-muted);border-color:var(--border-light);cursor:not-allowed;background:#f3f4f6}.pagination-page{text-align:center;min-width:48px;color:var(--text-heading);font-variant-numeric:tabular-nums}.alert{border-radius:var(--radius);color:#92400e;background:#fffbeb;border:1px solid #fde68a;margin-bottom:20px;padding:9px 14px;font-size:12px;line-height:1.7}.alert-warning{color:#92400e;background:#fffbeb;border-color:#fde68a}.alert-info{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.alert-success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.info-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:18px;padding:14px 18px}.info-box h4{margin-bottom:8px;font-size:13px;font-weight:600}.info-box ul{color:var(--text-secondary);padding-left:16px;font-size:13px;line-height:2}.switch-group{background:#f3f4f6;border-radius:6px;gap:2px;padding:2px;display:flex}.switch-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.switch-group.compact .switch-btn{padding:3px 10px;font-size:11px}.switch-btn.active{background:var(--card);color:var(--text-heading);box-shadow:0 1px 2px #0000000f}.switch-btn:hover:not(.active){color:var(--text)}.gas-tabs{background:#f3f4f6;border-radius:6px;gap:2px;padding:2px;display:inline-flex}.gas-tabs.compact .gas-tab{padding:4px 9px;font-size:11px}.gas-tabs.page-tabs{margin-bottom:var(--module-gap)}.gas-tab{color:#6b7280;cursor:pointer;letter-spacing:0;background:0 0;border:none;border-radius:4px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.gas-tab.active{color:#2563eb;background:#fff;box-shadow:0 1px 2px #0f172a14}.gas-tab:hover:not(.active){color:#2563eb}.role-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:8px;padding:1px 8px;font-size:10px;font-weight:600}.role-badge.hq{color:#2563eb;background:#eff6ff}.role-badge.branch{color:#16a34a;background:#f0fdf4}.sidebar-prototype{border-top:1px solid #ffffff0f;padding:12px 0 8px}.prototype-label{color:#6b7a9980;letter-spacing:1px;padding:0 12px 5px;font-size:10px;font-weight:600}.prototype-current{color:#d1d9e6;white-space:nowrap;text-overflow:ellipsis;background:#ffffff0a;border-radius:5px;margin:4px 12px 0;padding:6px 8px;font-size:11px;overflow:hidden}.sidebar-role{gap:4px;padding:0 12px 4px;display:flex}.role-btn{color:var(--sidebar-text);cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:5px;flex:1;padding:5px 8px;font-family:inherit;font-size:11px;transition:all .15s}.role-btn.active{color:#60a5fa;background:#3b82f626;border-color:#3b82f64d}.role-btn:hover:not(.active){background:#ffffff0d}.sidebar-role-select{padding:4px 12px 8px}.role-select{color:#d1d9e6;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:4px;outline:none;width:100%;padding:4px 8px;font-family:inherit;font-size:11px}.role-select option{color:#e2e8f0;background:#1e293b}.cascade-date{align-items:center;gap:3px;display:flex}.date-select{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:4px;outline:none;padding:4px 6px;font-family:inherit;font-size:12px;transition:border-color .15s}.date-select:focus{border-color:var(--blue)}.quick-dates{gap:2px;display:flex}.quick-date-btn{border:1px solid var(--border);background:var(--card);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:4px;padding:4px 8px;font-family:inherit;font-size:11px;transition:all .15s}.quick-date-btn:hover{border-color:var(--blue);color:var(--blue);background:#eff6ff}.breadcrumb{color:var(--text-secondary);align-items:center;gap:2px;font-size:13px;display:flex}.breadcrumb .sep{color:var(--border);margin:0 4px}.breadcrumb .current{color:var(--text-heading);font-weight:500}.section-label{color:var(--text-heading);margin-top:4px;margin-bottom:12px;font-size:13px;font-weight:600}.branch-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:24px;display:grid}.branch-card{background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--border);border-top:3px solid var(--blue);box-shadow:var(--shadow);cursor:pointer;padding:16px 18px 12px;transition:box-shadow .2s,transform .2s}.branch-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.branch-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.branch-card-name{color:var(--text-heading);font-size:14px;font-weight:600}.branch-card-tag{color:#fff;border-radius:8px;padding:1px 8px;font-size:10px}.branch-card-value{color:var(--text-heading);font-size:22px;font-weight:700}.branch-card-value .u{color:var(--text-muted);font-size:11px;font-weight:400}.branch-card-yoy{margin-top:2px;font-size:12px;font-weight:500}.branch-card-yoy.up{color:var(--red)}.branch-card-yoy.down{color:var(--green)}.branch-card-meta{color:var(--text-muted);align-items:center;gap:6px;margin-top:4px;font-size:11px;display:flex}.branch-card-meta .dot{color:var(--border)}.branch-card-chart{height:40px;margin-top:8px}.region-ranking{padding:4px 0}.ranking-title{color:var(--text-heading);margin-bottom:10px;font-size:13px;font-weight:600}.ranking-row{align-items:center;gap:10px;margin-bottom:7px;display:flex}.ranking-rank{width:20px;height:20px;color:var(--text-secondary);background:var(--border-light);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.ranking-rank.gold{color:#d97706;background:#fef3c7}.ranking-rank.last{color:#dc2626;background:#fef2f2}.ranking-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;overflow:hidden}.ranking-bar-wrap{background:var(--border-light);border-radius:3px;flex:2;height:6px;overflow:hidden}.ranking-bar{background:var(--blue);border-radius:3px;height:100%;transition:width .3s}.ranking-val{color:var(--text-heading);text-align:right;width:55px;font-size:12px;font-weight:600}.region-struct{flex-direction:column;gap:2px;display:flex}.struct-bar-row{align-items:center;gap:10px;padding:4px 0;display:flex}.struct-label{color:var(--text);min-width:80px;font-size:12px;font-weight:500}.struct-bar-wrap{background:var(--border-light);border-radius:4px;flex:1;height:8px;display:flex;overflow:hidden}.struct-bar{background:var(--blue);border-radius:4px;min-width:2px;height:100%;transition:width .3s}.struct-bar.blue{background:var(--blue)}.struct-val{text-align:right;width:70px;color:var(--text-heading);font-size:12px;font-weight:600}.struct-pct{color:var(--text-muted);text-align:right;width:45px;font-size:11px}.rate-badge{border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.rate-badge.high{color:#16a34a;background:#f0fdf4}.rate-badge.mid{color:#d97706;background:#fffbeb}.rate-badge.low{color:#dc2626;background:#fef2f2}.modern-table .warn-row td{background:#fffbeb}.temp-analysis{flex-direction:column;gap:14px;display:flex}.temp-insight{width:100%;color:var(--text);background:#f8fafc;border-radius:6px;margin:0;padding:8px 12px;font-size:13px;line-height:1.7}.ranking-chart-wrap{padding:10px 16px 14px}.rank-list{padding:2px 0}.contract-row .struct-label{min-width:80px;font-size:11px}.contract-row .struct-bar-wrap,.contract-total .struct-bar-wrap{flex:2}.contract-row .struct-val{width:90px;font-size:12px}.contract-row .rate-badge,.contract-total .rate-badge{text-align:center;width:55px}.contract-row>span:last-child{color:#9ca3af;text-align:right;width:70px;font-size:10px}.contract-total{border-top:1px solid var(--border-light);margin-top:6px;padding-top:10px}.contract-total .struct-label{min-width:80px;font-weight:600}.contract-total .struct-val{width:90px;font-weight:600}@media (width<=1024px){.sidebar{width:56px}.sidebar .nav-label,.sidebar .brand-name,.sidebar .brand-sub,.sidebar .nav-group-label,.sidebar .sidebar-footer,.sidebar .sidebar-prototype{display:none}.sidebar-brand{padding:12px 8px}.brand-icon{margin:0 auto}.sidebar-nav{align-items:center;padding:6px 4px}.nav-item{justify-content:center;padding:9px}.nav-icon{font-size:16px}.main-content{margin-left:56px}.page{padding:14px}.topbar{flex-wrap:wrap;gap:6px;padding:8px 14px}.topbar-left{min-width:100%}.charts-grid,.leader-brief-grid{grid-template-columns:1fr}.stat-grid,.stat-grid.branch-report-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.stat-grid.purchase-total-kpis,.purchase-kpi-grid{grid-template-columns:1fr}.query-grid,.detail-query-grid,.purchase-query-grid,.purchase-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=720px){.page-hdr{display:block}.page-meta{flex-wrap:wrap}.leader-brief-main{flex-direction:column}.leader-brief-date{text-align:left;min-width:0}.stat-grid,.stat-grid.branch-report-kpis,.stat-grid.purchase-total-kpis,.purchase-kpi-metrics,.query-grid,.detail-query-grid,.purchase-query-grid,.purchase-summary{grid-template-columns:1fr}.filter-panel-hdr,.summary-table-hdr,.card-hdr,.pagination-bar{flex-direction:column;align-items:stretch}.filter-actions,.table-actions,.topbar-right{justify-content:flex-start}}@media print{.sidebar,.topbar{display:none!important}.main-content{margin-left:0!important}.page{padding:0!important}.stat-card,.card,.chart-card{break-inside:avoid;box-shadow:none}}.modal-overlay{z-index:1000;background:#0f172a73;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;width:100%;max-width:520px;max-height:80vh;display:flex;box-shadow:0 20px 40px #0f172a1f}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.modal-header h3{font-size:15px;font-weight:700}.modal-close{cursor:pointer;width:28px;height:28px;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:20px;display:flex}.modal-close:hover{background:var(--border-light);color:var(--text-heading)}.modal-body{flex:1;padding:16px 18px;overflow-y:auto}.modal-desc{color:var(--text-secondary);margin-bottom:16px;font-size:13px;line-height:1.5}.modal-form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.modal-form-info{border:1px solid var(--border-light);background:#f8fafc;border-radius:6px;gap:18px;margin-top:16px;padding:12px 14px;font-size:13px;display:flex}.modal-form-info strong{color:var(--text-heading)}.modal-footer{border-top:1px solid var(--border-light);justify-content:flex-end;align-items:center;gap:8px;padding:12px 18px;display:flex}.view-detail-table{width:100%}.view-detail-table td{border-bottom:1px solid var(--border-light);padding:8px 12px;font-size:13px}.view-detail-table .label-cell{color:var(--text-secondary);white-space:nowrap;width:110px;font-weight:600}.section-divider{background:linear-gradient(#fafbfc,#f5f6f8);border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:10px 16px;display:flex}.section-divider:before{content:"";background:var(--blue);border-radius:2px;flex-shrink:0;width:3px;height:16px;display:block}.section-divider h3{color:#374151;margin:0;font-size:14px;font-weight:700}.custom-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:8px 12px;font-size:13px;line-height:1.8;box-shadow:0 4px 12px #00000014}.pie-legend-inline{color:#6b7280;justify-content:center;gap:28px;margin-top:8px;font-size:12px;display:flex}.pie-legend-inline .item{align-items:center;gap:6px;display:flex}.pie-legend-inline .dot{border-radius:2px;flex-shrink:0;width:10px;height:10px;display:inline-block}.pie-legend-inline strong{color:#374151}.mini-monthly-chart{height:62px;margin:8px -4px 0;overflow:hidden}.mini-monthly-chart svg{display:block}.dual-metric-grid{grid-template-columns:1fr auto 1fr;align-items:center;gap:0;min-height:70px;margin:6px 0 2px;display:grid}.dual-metric-col{text-align:center;padding:2px 4px}.dual-metric-col:first-child{text-align:left;padding-left:0}.dual-metric-col:last-child{text-align:right;padding-right:0}.dual-metric-label{color:var(--text-muted);letter-spacing:.3px;margin-bottom:4px;font-size:11px;font-weight:500}.dual-metric-value{color:var(--text-heading);font-variant-numeric:tabular-nums;word-break:break-all;font-size:20px;font-weight:700;line-height:1.1}.dual-metric-unit{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:400}.dual-metric-divider{background:var(--border);flex-shrink:0;width:1px;height:48px;margin:0 12px}.stat-card.blue .dual-metric-value{color:#1e40af}.stat-card.green .dual-metric-value{color:#166534}.stat-card.yellow .dual-metric-value{color:#92400e}.stat-card.purple .dual-metric-value{color:#6b21a8}.stat-card.cyan .dual-metric-value{color:#155e75}
