:root{color:#20242b;background:#f5f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html{min-width:320px;min-height:100%;background:#f5f6f8}body{margin:0;min-width:320px;min-height:100vh;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.62}.app-shell{display:grid;grid-template-columns:224px minmax(0,1fr);min-height:100vh;background:#f5f6f8}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;border-right:1px solid #e5e7eb;background:#fff}.brand{display:flex;align-items:center;justify-content:center;min-height:74px;width:100%;padding:15px 22px;border:0;border-bottom:1px solid #eceff3;background:#fff;color:#111827;text-align:left}.brand-logo{width:170px;height:auto;object-fit:contain}.brand span{display:none}.nav-list{display:grid;gap:6px;padding:18px 12px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:13px;min-height:42px;padding:0 13px;border:1px solid transparent;border-radius:7px;background:transparent;color:#374151;text-align:left}.nav-item svg{flex:0 0 auto;color:#4b5563}.nav-item:hover{background:#f7f8fa;border-color:#eceff3}.nav-item.active{background:#dc0b17;color:#fff;border-color:#dc0b17;box-shadow:0 9px 24px #dc0b172e}.nav-item.active svg{color:#fff}.sidebar-footer{margin-top:auto;padding:18px 22px 22px;border-top:1px solid #eceff3;color:#6b7280;font-size:12px;line-height:1.7}.sidebar-footer p,.sidebar-footer strong,.sidebar-footer span{display:block;margin:0}.sidebar-footer strong{color:#1f2937;font-weight:600}.workspace{min-width:0}.topbar{min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:0 24px;border-bottom:1px solid #e5e7eb;background:#fff}.topbar h1{margin:0;color:#dc0b17;font-size:20px;font-weight:800;line-height:1.15}.topbar p{margin:5px 0 0;color:#6b7280;font-size:13px}.top-actions{display:flex;align-items:center;gap:12px}.icon-button,.table-icon{position:relative;display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid #e4e7ec;border-radius:8px;background:#fff;color:#374151}.icon-button:hover,.table-icon:hover{border-color:#f3b8bd;color:#dc0b17}.dot{position:absolute;top:-5px;right:-4px;display:grid;place-items:center;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:#dc0b17;color:#fff;font-size:10px;font-weight:800}.user-chip{display:flex;align-items:center;gap:10px;min-height:42px;padding:6px 8px;border:1px solid transparent;border-radius:9px;background:#fff;color:#111827}.user-chip:hover{border-color:#e5e7eb;background:#fafafa}.user-chip strong,.user-chip small{display:block;text-align:left}.user-chip strong{font-size:13px}.user-chip small{color:#6b7280;font-size:12px}.filter-bar{display:grid;grid-template-columns:minmax(132px,.9fr) minmax(150px,1.1fr) repeat(5,minmax(116px,1fr)) 138px 118px;gap:10px;align-items:end;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#fff}.filter-select{display:grid;gap:7px;min-width:0}.filter-select span{color:#4b5563;font-size:12px}.filter-select select,.form-stack input,.form-stack select,.form-stack textarea,.search-box input,.login-panel input{width:100%;min-height:40px;border:1px solid #d9dee7;border-radius:7px;background:#fff;color:#1f2937;outline:none}.filter-select select{padding:0 28px 0 10px;font-size:14px}.filter-select select:focus,.form-stack input:focus,.form-stack select:focus,.form-stack textarea:focus,.search-box input:focus,.login-panel input:focus{border-color:#dc0b17;box-shadow:0 0 0 3px #dc0b1714}.primary-button,.secondary-button,.outline-red,.text-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:0 16px;border-radius:7px;font-weight:700;white-space:nowrap}.primary-button{border:1px solid #dc0b17;background:#dc0b17;color:#fff}.primary-button:hover{background:#bd0711}.secondary-button{border:1px solid #d9dee7;background:#fff;color:#1f2937}.secondary-button:hover{border-color:#f3b8bd;color:#dc0b17}.outline-red{border:1px solid #dc0b17;background:#fff;color:#dc0b17}.text-action{min-height:34px;padding:0;border:0;background:transparent;color:#dc0b17}.full{width:100%}.toast-row{display:flex;align-items:center;gap:8px;min-height:40px;margin:14px 24px 0;padding:0 14px;border:1px solid #d9f4df;border-radius:8px;background:#f3fbf5;color:#166534;font-size:13px}.backend-status{color:#4b5563}.ops-dashboard-page{padding:18px 24px 28px;background:#f3f6fa}.module-page.with-dashboard{background:#f3f6fa}.ops-dashboard-page.embedded{padding:0 0 16px;background:transparent}.ops-dashboard-header{display:grid;grid-template-columns:148px minmax(0,1fr) auto;gap:26px;align-items:center;min-height:92px;margin-bottom:26px;padding:18px 32px;border-radius:8px;background:#102b46;color:#fff}.ops-logo-lockup{display:grid;place-items:center;min-height:55px;padding:8px 16px;border-radius:10px;background:#fff}.ops-logo-lockup img{width:112px;max-height:42px;object-fit:contain}.ops-title-block h2,.ops-title-block p{margin:0}.ops-title-block h2{color:#fff;font-size:40px;font-weight:850;line-height:1.04}.ops-title-block p{margin-top:4px;color:#d5dde8;font-size:16px}.ops-scope-pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.ops-scope-pills button,.ops-inline-filters button{min-height:40px;padding:0 16px;border:1px solid #356184;border-radius:10px;background:#173d63;color:#edf6ff}.ops-metric-grid{display:grid;gap:16px;margin-bottom:28px}.ops-metric-grid.six{grid-template-columns:repeat(6,minmax(0,1fr))}.ops-metric-grid.five{grid-template-columns:repeat(5,minmax(0,1fr))}.ops-metric-card{position:relative;min-height:140px;padding:20px 24px;border:1px solid #dfe4eb;border-radius:12px;background:#fff;overflow:hidden}.ops-metric-card:before{content:"";position:absolute;inset:0 auto 0 0;width:8px;background:#d1d5db}.ops-metric-card.good:before{background:#16a34a}.ops-metric-card.warn:before{background:#f59e0b}.ops-metric-card.danger:before{background:#dc0b17}.ops-metric-card.info:before{background:#2563eb}.ops-metric-card span,.ops-metric-card small{display:block}.ops-metric-card span{color:#667085;font-size:16px}.ops-metric-card strong{display:block;margin-top:16px;color:#111827;font-size:36px;line-height:1}.ops-metric-card small{width:max-content;max-width:100%;margin-top:9px;padding:4px 10px;border-radius:999px;background:#eef2f7;color:#475467;font-size:14px}.ops-metric-card.good small{background:#dcfce7;color:#15803d}.ops-metric-card.warn small{background:#fef3c7;color:#b45309}.ops-metric-card.danger small{background:#fee2e2;color:#dc0b17}.ops-metric-card.info small{background:#dbeafe;color:#2563eb}.ops-grid{display:grid;gap:26px;margin-bottom:28px}.director-grid{grid-template-columns:minmax(0,1.35fr) minmax(0,.96fr) minmax(360px,.9fr)}.director-bottom-grid{grid-template-columns:minmax(0,1fr) minmax(410px,.52fr)}.ops-panel{min-width:0;padding:20px 24px;border:1px solid #dfe4eb;border-radius:12px;background:#fff}.ops-panel h3{margin:0 0 18px;color:#111827;font-size:22px;font-weight:850;line-height:1.2}.ops-panel.wide{min-width:0}.ops-chart{width:100%;height:220px}.ops-chart.medium{height:188px}.ops-chart.tall{height:275px}.ops-progress-list{display:grid;gap:20px;padding-top:14px}.ops-progress-list p{display:flex;justify-content:space-between;gap:18px;margin:0 0 9px;color:#111827;font-size:16px}.ops-progress-list strong{color:#667085;font-weight:500}.ops-progress-list i,.error-leader-list i{display:block;height:13px;border-radius:999px;background:#e9eef5;overflow:hidden}.ops-progress-list b,.error-leader-list b{display:block;height:100%;border-radius:inherit}.ops-link{min-height:34px;margin-top:16px;padding:0;border:0;background:transparent;color:#2563eb;font-weight:750}.ops-table-wrap{width:100%;overflow-x:auto}.ops-table{width:100%;min-width:620px;border-collapse:collapse;font-size:14px}.ops-table th,.ops-table td{padding:12px;border:0;white-space:nowrap}.ops-table th{border-radius:0;background:#f1f4f8;color:#667085;font-weight:500}.ops-table th:first-child{border-radius:10px 0 0 10px}.ops-table th:last-child{border-radius:0 10px 10px 0}.ops-table tbody tr:nth-child(2n){background:#f8fafc}.ops-table tbody tr:hover{background:#fff8f8}.ops-status-text.good{color:#16a34a}.ops-status-text.warn{color:#f59e0b}.ops-status-text.danger{color:#dc0b17}.ops-reference-note{display:flex;align-items:center;gap:8px;padding:12px 14px;border:1px solid #dbeafe;border-radius:8px;background:#eff6ff;color:#1d4ed8;font-size:13px}.ops-inline-filters{display:grid;grid-template-columns:repeat(5,minmax(160px,1fr));gap:14px;margin-bottom:26px}.ops-inline-filters input{min-height:46px;padding:0 18px;border:1px solid #dfe4eb;border-radius:12px;background:#fff;color:#111827;outline:none}.ops-inline-filters button{border-color:#dfe4eb;background:#fff;color:#667085;text-align:left}.production-dashboard-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(330px,.26fr);gap:26px;margin-bottom:26px}.kanban-board{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:10px;min-width:0;overflow-x:auto}.kanban-column{min-width:150px;min-height:548px;padding:12px;border:1px solid #dfe4eb;border-radius:12px;background:#f8fafc}.kanban-column header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}.kanban-column h3{margin:0;color:#111827;font-size:16px;font-weight:500}.kanban-count{min-width:34px;padding:5px 9px;border-radius:999px;background:#eef2f7;color:#667085;text-align:center;font-size:14px}.kanban-count.good{background:#dcfce7;color:#16a34a}.kanban-count.warn{background:#fef3c7;color:#f59e0b}.kanban-count.danger{background:#fee2e2;color:#dc0b17}.kanban-count.info{background:#dbeafe;color:#2563eb}.kanban-card-stack{display:grid;gap:20px}.kanban-card{position:relative;display:grid;gap:7px;min-height:113px;padding:13px 12px 10px 14px;border:1px solid #dfe4eb;border-radius:10px;background:#fff;color:#111827;text-align:left}.kanban-card:before,.machine-status-card:before{content:"";position:absolute;inset:0 auto 0 0;width:6px;border-radius:10px 0 0 10px;background:#d1d5db}.kanban-card.good:before,.machine-status-card.good:before{background:#16a34a}.kanban-card.warn:before,.machine-status-card.warn:before{background:#f59e0b}.kanban-card.danger:before,.machine-status-card.danger:before{background:#dc0b17}.kanban-card strong{font-size:14px;font-weight:500}.kanban-card span,.kanban-card em{color:#667085;font-style:normal}.kanban-card small{color:#16a34a;font-size:14px}.kanban-card.warn small{color:#f59e0b}.kanban-card.danger small{color:#dc0b17}.realtime-panel{min-height:548px}.realtime-alert-list{display:grid;gap:14px}.realtime-alert{display:grid;gap:8px;min-height:78px;padding:14px 18px;border:1px solid #dfe4eb;border-radius:12px;background:#fff;text-align:left}.realtime-alert.danger{border-color:#ff8f96;background:#fee2e2}.realtime-alert.warn{border-color:#fbbf24;background:#fef3c7}.realtime-alert.good{border-color:#22c55e;background:#dcfce7}.realtime-alert strong{color:#dc0b17;font-weight:500}.realtime-alert.warn strong{color:#f59e0b}.realtime-alert.good strong{color:#16a34a}.people-dashboard-grid{grid-template-columns:minmax(0,1fr) minmax(320px,.48fr)}.people-dashboard-grid .wide{grid-row:span 3}.tall-panel{min-height:660px}.ops-pie-wrap{position:relative;height:240px}.ops-pie-wrap strong{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#111827;font-size:22px}.ops-legend{display:grid;gap:6px;margin-top:8px;color:#667085;font-size:14px}.ops-legend.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-legend span{display:inline-flex;align-items:center;gap:8px}.ops-legend i{width:18px;height:18px;border-radius:5px}.error-leader-list{display:grid;gap:26px;padding-top:26px}.error-leader-list button{display:grid;grid-template-columns:minmax(0,1fr) 50px;gap:10px;align-items:center;border:0;background:transparent;color:#111827;text-align:left}.error-leader-list i{grid-column:1 / -1}.error-leader-list strong{color:#dc0b17;text-align:right}.machine-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:26px}.machine-status-card{position:relative;min-height:156px;padding:18px 26px 20px;border:1px solid #dfe4eb;border-radius:12px;background:#fff;color:#111827;text-align:left}.machine-status-card>span{position:absolute;top:22px;right:36px;padding:5px 12px;border-radius:999px;background:#eef2f7;color:#667085;font-size:14px}.machine-status-card.good>span{background:#dcfce7;color:#16a34a}.machine-status-card.warn>span{background:#fef3c7;color:#f59e0b}.machine-status-card.danger>span{background:#fee2e2;color:#dc0b17}.machine-status-card h3,.machine-status-card p{margin:0}.machine-status-card h3{font-size:22px;font-weight:850}.machine-status-card p{margin-top:8px;color:#667085}.machine-status-card strong{display:block;margin-top:28px;font-size:30px}.machine-status-card small{position:absolute;right:28px;bottom:28px;color:#16a34a;font-size:15px}.machine-status-card.warn small{color:#f59e0b}.machine-status-card.danger small{color:#dc0b17}.machine-status-card.neutral small{color:#667085}.machine-dashboard-grid{grid-template-columns:minmax(0,1fr) minmax(0,1.06fr)}.quality-dashboard-grid{grid-template-columns:minmax(280px,.8fr) minmax(0,1.2fr) minmax(0,1.1fr)}.module-hero-detail{margin-top:0;background:#fff}.kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;padding:14px 24px 0}.kpi-card,.panel{border:1px solid #e7eaf0;border-radius:8px;background:#fff}.kpi-card{min-height:192px;padding:18px 18px 16px}.kpi-label{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#111827;font-size:12px;font-weight:800;text-transform:uppercase}.kpi-value{margin-top:16px;font-size:28px;font-weight:850;line-height:1}.kpi-value small{color:#111827;font-size:13px;font-weight:700}.kpi-value.good,.kpi-value.ok{color:#16a34a}.kpi-value.watch,.kpi-value.danger,.kpi-card:first-child .kpi-value{color:#dc0b17}.kpi-card p{min-height:34px;margin:12px 0 0;color:#374151;font-size:13px;line-height:1.4}.kpi-sub{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:12px;color:#374151;font-size:13px}.kpi-sub strong{font-size:13px}.positive{color:#16a34a}.negative{color:#dc0b17}.progress-track{height:7px;margin:20px 0 0;border-radius:999px;background:#eef1f4;overflow:hidden}.progress-track i{display:block;height:100%;border-radius:inherit}.progress-track .ok,.progress-track .danger{background:#dc0b17}.progress-track .good{background:#16a34a}.progress-track .watch{background:#f59e0b}.status-pill{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 9px;border-radius:7px;font-size:12px;font-weight:800;white-space:nowrap}.kpi-card>.status-pill{float:right;margin-top:-10px}.status-pill.good,.status-pill.ok{background:#dcfce7;color:#15803d}.status-pill.watch,.status-pill.warn{background:#fef3c7;color:#b45309}.status-pill.danger{background:#fee2e2;color:#dc0b17}.status-pill.neutral{background:#eef2f7;color:#4b5563}.main-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(330px,.92fr) minmax(320px,.9fr);gap:12px;padding:12px 24px 0}.bottom-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1.25fr) minmax(284px,.72fr);gap:12px;padding:12px 24px 28px}.ranking-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;padding:12px 24px 0}.ranking-grid table{min-width:720px}.panel{min-width:0;padding:16px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:28px;margin-bottom:12px}.panel-header h2{margin:0;color:#111827;font-size:14px;font-weight:850;text-transform:uppercase}.panel-badge{padding:3px 7px;border:1px solid #ffb3b8;border-radius:6px;color:#dc0b17;font-size:12px;font-weight:800}.chart-legend{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin:0 0 8px;color:#374151;font-size:12px}.chart-legend span{display:inline-flex;align-items:center;gap:7px}.legend-dot{width:10px;height:10px;border-radius:999px}.legend-dot.red{background:#dc0b17}.legend-dot.pink{background:#f4a6ad}.legend-line{width:18px;border-top:2px dashed #b6bcc5}.chart-box{height:320px}.trend-svg,.donut-svg{display:block;width:100%;height:100%}.order-progress-layout{display:grid;grid-template-columns:210px minmax(0,1fr);gap:20px;align-items:center}.donut-wrap{position:relative;height:230px}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-content:center;text-align:center}.donut-center span,.donut-center small{color:#6b7280;text-transform:uppercase}.donut-center strong{color:#111827;font-size:26px;line-height:1}.status-list{display:grid;gap:17px;color:#374151;font-size:13px}.status-list div{display:grid;grid-template-columns:10px 1fr auto;gap:9px;align-items:center}.status-list i{width:9px;height:14px;border-radius:2px}.status-list strong{color:#111827;font-size:16px}.suggestion-list{display:grid;gap:9px}.suggestion{display:grid;grid-template-columns:28px minmax(0,1fr);gap:12px;min-height:66px;padding:9px 10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff}.suggestion h3,.suggestion p{margin:0}.suggestion h3{color:#dc0b17;font-size:12px;font-weight:850}.suggestion p{display:-webkit-box;margin-top:4px;overflow:hidden;color:#4b5563;font-size:11px;line-height:1.3;-webkit-box-orient:vertical;-webkit-line-clamp:2}.suggestion button{margin-top:5px;padding:0;border:0;background:transparent;color:#1f2937;font-size:11px;font-weight:700;text-align:left}.suggestion.danger{border-color:#ffc9cd}.suggestion.warn svg,.suggestion.warn h3{color:#f59e0b}.suggestion.good svg,.suggestion.good h3{color:#16a34a}.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.quick-action{position:relative;display:grid;grid-template-columns:28px 1fr;gap:10px;align-items:center;min-height:72px;padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;text-align:left}.quick-action:hover{border-color:#f3b8bd;color:#dc0b17}.quick-action strong{position:absolute;top:8px;right:9px;display:grid;place-items:center;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#dc0b17;color:#fff;font-size:11px}.quick-action.wide{grid-column:1 / -1}.table-toolbar{display:flex;justify-content:flex-end;margin-bottom:10px}.search-box{display:flex;align-items:center;gap:8px;width:min(100%,320px);min-height:38px;padding:0 10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#6b7280}.search-box input{min-height:34px;padding:0;border:0}.table-wrap{width:100%;overflow-x:auto}table{width:100%;min-width:620px;border-collapse:collapse;font-size:12px}th,td{padding:10px 9px;border-bottom:1px solid #edf0f4;text-align:left;vertical-align:middle;white-space:nowrap}th{background:#f4f5f7;color:#374151;font-weight:850}td{color:#1f2937}tbody tr:hover{background:#fff8f8}.table-icon{width:28px;height:28px;border-radius:6px}.daily-report-page{padding:18px 24px 28px}.daily-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:12px;padding:18px;border:1px solid #e7eaf0;border-radius:8px;background:#fff}.daily-header h2,.daily-header p{margin:0}.daily-header h2{color:#111827;font-size:22px;line-height:1.15}.daily-header p{margin-top:8px;color:#4b5563}.daily-kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:12px}.daily-kpi-card{position:relative;min-height:132px;padding:14px;border:1px solid #e7eaf0;border-radius:8px;background:#fff}.daily-kpi-card span,.daily-kpi-card small{display:block}.daily-kpi-card span{color:#4b5563;font-size:12px;font-weight:800;text-transform:uppercase}.daily-kpi-card strong{display:block;margin-top:14px;color:#111827;font-size:24px;line-height:1}.daily-kpi-card small{margin-top:10px;color:#4b5563;font-size:12px;line-height:1.35}.daily-kpi-card .status-pill{position:absolute;right:12px;bottom:12px}.daily-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(330px,.34fr);gap:12px;align-items:start}.daily-form-section{padding:14px 0;border-top:1px solid #edf0f4}.daily-form-section:first-child{padding-top:0;border-top:0}.daily-form-section h3,.auto-alerts h3{margin:0 0 12px;color:#111827;font-size:13px;font-weight:850;text-transform:uppercase}.daily-form-grid{display:grid;grid-template-columns:repeat(4,minmax(132px,1fr));gap:10px}.daily-note-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.daily-field,.daily-textarea,.zalo-summary{display:grid;gap:7px;min-width:0;color:#374151;font-size:12px;font-weight:750}.daily-field div{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;min-height:40px;border:1px solid #d9dee7;border-radius:7px;background:#fff}.daily-field input,.daily-textarea textarea,.zalo-summary textarea{width:100%;border:0;background:transparent;color:#1f2937;outline:none}.daily-field input{min-width:0;height:38px;padding:0 10px}.daily-field small{padding:0 10px 0 2px;color:#6b7280;font-size:11px}.daily-textarea textarea{min-height:74px;padding:10px;border:1px solid #d9dee7;border-radius:7px;resize:vertical}.score-box{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px;border:1px solid #f3b8bd;border-radius:8px;background:#fff7f7}.score-box span,.score-box small{display:block;color:#4b5563}.score-box strong{display:block;margin:8px 0 5px;color:#dc0b17;font-size:32px;line-height:1}.score-breakdown{display:grid;gap:10px;margin-top:14px}.score-breakdown div{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;color:#374151;font-size:12px}.score-breakdown strong{color:#111827}.score-breakdown i{grid-column:1 / -1;display:block;height:7px;border-radius:999px;background:#eef1f4;overflow:hidden}.score-breakdown b{display:block;height:100%;border-radius:inherit;background:#dc0b17}.auto-alerts{display:grid;gap:8px;margin-top:16px}.auto-alerts p{display:flex;align-items:center;gap:8px;margin:0;color:#374151;font-size:12px;line-height:1.35}.zalo-summary{margin-top:16px}.zalo-summary textarea{min-height:230px;padding:10px;border:1px solid #d9dee7;border-radius:7px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;line-height:1.45;resize:vertical}.daily-detail-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr) minmax(320px,.72fr);gap:12px;margin-top:12px}.module-page{padding:18px 24px 28px}.module-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:14px;padding:18px;border:1px solid #e7eaf0;border-radius:8px;background:#fff}.eyebrow{display:inline-flex;margin-bottom:8px;color:#dc0b17;font-size:12px;font-weight:850;text-transform:uppercase}.module-hero h2{margin:0;color:#111827;font-size:22px;line-height:1.15}.module-hero p{max-width:720px;margin:8px 0 0;color:#4b5563;line-height:1.5}.module-actions{display:flex;flex-wrap:wrap;gap:10px}.module-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.34fr);gap:12px;align-items:start}.module-table-panel table{min-width:760px}.module-side-panel{align-self:start}.form-stack{display:grid;gap:12px}.form-stack label,.login-panel label{display:grid;gap:7px;color:#374151;font-size:13px;font-weight:700}.form-stack input,.form-stack select,.form-stack textarea,.login-panel input{padding:0 12px}.form-stack textarea{min-height:82px;padding-top:10px;resize:vertical}.validation-box{display:grid;gap:9px;margin-top:18px;padding:14px;border:1px solid #fed7aa;border-radius:8px;background:#fff7ed}.validation-box h3{margin:0;color:#9a3412;font-size:14px}.validation-box p{display:flex;align-items:flex-start;gap:8px;margin:0;color:#9a3412;font-size:13px;line-height:1.4}.validation-box svg{flex:0 0 auto;margin-top:1px}.access-denied{display:grid;justify-items:center;gap:12px;padding:46px 20px;border:1px solid #fecaca;border-radius:8px;background:#fff7f7;color:#991b1b;text-align:center}.access-denied h2,.access-denied p{margin:0}.access-denied h2{color:#111827;font-size:20px}.access-denied p{max-width:560px;color:#4b5563;line-height:1.5}.task-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:12px}.task-summary-grid article{min-height:110px;padding:16px;border:1px solid #e7eaf0;border-radius:8px;background:#fff}.task-summary-grid span,.task-summary-grid small{display:block;color:#4b5563}.task-summary-grid span{font-size:12px;font-weight:850;text-transform:uppercase}.task-summary-grid strong{display:block;margin-top:12px;color:#dc0b17;font-size:30px;line-height:1}.task-summary-grid small{margin-top:8px;font-size:12px}.permission-list{display:grid;gap:10px}.permission-list div{display:grid;gap:5px;padding:10px;border:1px solid #edf0f4;border-radius:7px;background:#fafafa}.permission-list strong{color:#111827;font-size:13px}.permission-list span{color:#4b5563;font-size:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;padding:24px;background:#0f172a4d}.modal{width:min(100%,520px);padding:20px;border-radius:10px;background:#fff;box-shadow:0 24px 60px #0f172a38}.modal header{display:grid;grid-template-columns:42px 1fr;gap:12px;margin-bottom:16px}.modal-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:9px;background:#fee2e2;color:#dc0b17}.modal h2,.modal p{margin:0}.modal h2{color:#111827;font-size:18px}.modal p{margin-top:4px;color:#6b7280;font-size:13px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:#f5f6f8}.login-panel{width:min(100%,420px);display:grid;gap:16px;padding:26px;border:1px solid #e5e7eb;border-radius:10px;background:#fff}.login-brand{min-height:auto;padding:0;border:0}.login-panel h1{margin:12px 0 0;color:#111827;font-size:26px}.login-panel p{margin:0;color:#4b5563;line-height:1.5}.secure-note{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:12px}@media(max-width:1280px){.filter-bar{grid-template-columns:repeat(4,minmax(130px,1fr))}.ops-dashboard-header{grid-template-columns:132px minmax(0,1fr)}.ops-scope-pills{grid-column:1 / -1;justify-content:flex-start}.ops-metric-grid.six,.ops-metric-grid.five{grid-template-columns:repeat(3,minmax(0,1fr))}.director-grid,.director-bottom-grid,.production-dashboard-layout,.people-dashboard-grid,.machine-dashboard-grid,.quality-dashboard-grid{grid-template-columns:1fr}.people-dashboard-grid .wide{grid-row:auto}.machine-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-inline-filters{grid-template-columns:repeat(3,minmax(150px,1fr))}.kpi-grid,.daily-kpi-grid,.task-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.daily-form-grid{grid-template-columns:repeat(3,minmax(132px,1fr))}.main-grid,.ranking-grid,.bottom-grid,.daily-detail-grid{grid-template-columns:1fr}.order-progress-layout{grid-template-columns:220px 1fr}}@media(max-width:920px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;width:100%;max-width:100%;overflow:hidden}.nav-list{grid-auto-flow:column;grid-auto-columns:max-content;width:100%;max-width:100vw;min-width:0;overflow-x:auto;padding:12px}.sidebar-footer{display:none}.topbar{align-items:flex-start;flex-direction:column;padding:16px}.filter-bar,.kpi-grid,.main-grid,.ranking-grid,.bottom-grid,.ops-dashboard-page,.daily-report-page,.module-page{padding-left:16px;padding-right:16px}.ops-dashboard-page.embedded{padding-left:0;padding-right:0}.ops-dashboard-header{grid-template-columns:1fr;gap:14px;padding:18px}.ops-title-block h2{font-size:30px}.ops-title-block p{font-size:14px}.ops-scope-pills{justify-content:stretch}.ops-scope-pills button{flex:1 1 150px}.filter-bar{grid-template-columns:repeat(2,minmax(130px,1fr))}.module-layout,.daily-layout{grid-template-columns:1fr}.daily-form-grid{grid-template-columns:repeat(2,minmax(132px,1fr))}}@media(max-width:640px){.brand{padding:14px 16px}.top-actions{width:100%;flex-wrap:wrap}.filter-bar,.kpi-grid,.ops-metric-grid.six,.ops-metric-grid.five,.machine-card-grid,.ops-inline-filters,.daily-kpi-grid,.task-summary-grid,.daily-form-grid,.daily-note-grid{grid-template-columns:1fr}.ops-dashboard-page{padding-top:12px}.ops-logo-lockup{width:148px}.ops-title-block h2{font-size:25px}.ops-metric-card strong{font-size:30px}.ops-panel{padding:16px}.ops-panel h3{font-size:19px}.kanban-column{min-height:auto}.order-progress-layout{grid-template-columns:1fr}.chart-box{height:230px}.module-hero,.daily-header{flex-direction:column}.module-actions,.module-actions button,.primary-button,.secondary-button{width:100%}.quick-grid{grid-template-columns:1fr}}@media print{body{background:#fff}.sidebar,.top-actions,.filter-bar,.toast-row,.quick-panel,.modal-backdrop,.text-action,.table-toolbar{display:none!important}.app-shell{display:block}.topbar{border-bottom:2px solid #dc0b17}.workspace,.panel,.kpi-card{background:#fff}.kpi-grid,.main-grid,.bottom-grid{padding:12px 0}.panel,.kpi-card,.module-hero{break-inside:avoid;box-shadow:none}}
