:root{--crimson:#c62828;--crimson-bright:#e53935;--crimson-glow:#ef5350;--crimson-pale:#ffcdd2;--crimson-dark:#8b0000;--carbon:#0d0d0d;--carbon-2:#111111;--carbon-3:#161616;--carbon-4:#1c1c1c;--carbon-5:#222222;--carbon-6:#2a2a2a;--carbon-7:#363636;--steel:#90a4ae;--steel-light:#b0bec5;--steel-dim:#546e7a;--gold:#ffd54f;--gold-dim:#ff8f00;--jade:#4caf50;--ice:#e3f2fd;--text-1:#ffffff;--text-2:#d0d0d0;--text-3:#929292;--card:rgba(22,22,22,0.95);--card-border:rgba(183,28,28,0.2);--card-border-active:rgba(229,57,53,0.5);--glass:rgba(183,28,28,0.06)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Sarabun,sans-serif;font-weight:500;letter-spacing:0;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision;background:var(--carbon);color:var(--text-1);min-height:100vh;overflow-x:hidden}button,input,select,table,textarea{font-family:Sarabun,sans-serif;font-weight:600}.admin-section-title,.chart-title,.exec-value,.kpi-card-value,.login-logo-text h1,.mix-detail-title,.mix-summary-card .value,.modal-title,.page-hdr-left h2,.pmb-plant,.topbar-name{font-family:Sarabun,sans-serif!important;font-weight:800!important;letter-spacing:0!important}.chart-title,.exec-table-hdr,.mix-list-hdr,table.data-tbl th{color:#fff!important;font-weight:800!important}.exec-sub,.kpi-card-sub,.mix-detail-sub,.mix-info .label,.mix-item-meta,.mix-summary-card .label{color:#b8b8b8!important;font-weight:600}.btn-primary-sm,.btn-sm,.mix-item,.mix-tab,.month-btn,.nav-tab{font-weight:700!important}body::before{content:'';position:fixed;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 50% at 15% 10%,rgba(127,0,0,.12) 0,transparent 60%),radial-gradient(ellipse 40% 60% at 85% 90%,rgba(183,28,28,.08) 0,transparent 60%);z-index:0}#loginScreen{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--carbon);background-image:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(127,0,0,.18) 0,transparent 65%),repeating-linear-gradient(0deg,transparent,transparent 80px,rgba(255,255,255,.012) 80px,rgba(255,255,255,.012) 81px),repeating-linear-gradient(90deg,transparent,transparent 80px,rgba(255,255,255,.012) 80px,rgba(255,255,255,.012) 81px)}.login-card{width:420px;max-width:95vw;background:var(--carbon-4);border:1px solid rgba(183,28,28,.35);border-radius:20px;padding:44px 40px;box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 60px rgba(183,28,28,.12);animation:fadeUp .5s ease}@keyframes fadeUp{from{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:32px}.login-logo-icon{width:52px;height:52px;background:linear-gradient(135deg,var(--crimson-dark),var(--crimson));border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 8px 24px rgba(183,28,28,.4)}.login-logo-text h1{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;letter-spacing:1.5px;color:#fff}.login-logo-text p{font-size:11px;color:var(--steel);letter-spacing:3px;text-transform:uppercase;margin-top:2px}.login-title{font-size:13px;color:var(--text-2);margin-bottom:28px;line-height:1.6}.form-field{margin-bottom:18px}.form-field label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--crimson-glow);margin-bottom:8px}.form-field input{width:100%;background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:10px;color:var(--text-1);padding:13px 16px;font-family:Sarabun,sans-serif;font-size:14px;outline:0;transition:all .2s}.form-field input:focus{border-color:var(--crimson);box-shadow:0 0 0 3px rgba(183,28,28,.15)}.btn-login{width:100%;padding:14px;background:linear-gradient(135deg,var(--crimson-dark),var(--crimson-bright));border:none;border-radius:10px;color:#fff;font-family:Sarabun,sans-serif;font-size:15px;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .25s;box-shadow:0 8px 24px rgba(183,28,28,.35);margin-top:4px}.btn-login:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(183,28,28,.5)}.login-error{background:rgba(183,28,28,.12);border:1px solid rgba(183,28,28,.3);border-radius:8px;padding:10px 14px;font-size:13px;color:#ef9a9a;margin-top:14px;display:none}.security-note{margin-top:14px;padding:10px 12px;border-radius:9px;background:rgba(255,213,79,.08);border:1px solid rgba(255,213,79,.22);color:#ffe082;font-size:11px;line-height:1.55}.firebase-status-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:var(--text-3);font-size:10px;letter-spacing:.7px;white-space:nowrap}.firebase-status-chip.online{color:#a5d6a7;border-color:rgba(76,175,80,.35);background:rgba(76,175,80,.08)}.firebase-status-chip.offline{color:#ffd54f;border-color:rgba(255,213,79,.35);background:rgba(255,213,79,.08)}.login-divider{display:flex;align-items:center;gap:12px;margin:20px 0;font-size:11px;color:var(--text-3)}.login-divider::after,.login-divider::before{content:'';flex:1;height:1px;background:var(--carbon-7)}.demo-accounts{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:10px;padding:14px;font-size:12px}.demo-accounts p{color:var(--text-3);margin-bottom:8px;letter-spacing:1px;text-transform:uppercase}.demo-row{display:flex;justify-content:space-between;color:var(--text-2);margin-bottom:4px}.demo-row span:last-child{color:var(--crimson-pale);font-family:'DM Mono',monospace}#app{display:none;min-height:100vh;position:relative;z-index:1}.topbar{position:sticky;top:0;z-index:200;background:rgba(10,10,10,.92);backdrop-filter:blur(20px);border-bottom:1px solid rgba(183,28,28,.2);padding:0 16px;height:64px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 30px rgba(0,0,0,.5);min-width:0}.topbar-brand{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}.topbar-icon{width:38px;height:38px;background:linear-gradient(135deg,var(--crimson-dark),var(--crimson));border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 12px rgba(183,28,28,.4);flex-shrink:0}.topbar-name{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;letter-spacing:1px;color:#fff;white-space:nowrap}.topbar-sep{width:1px;height:28px;background:var(--carbon-7);flex-shrink:0}.nav-tabs{display:flex;gap:2px;flex:1;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;min-width:0;overscroll-behavior-inline:contain;touch-action:pan-x;cursor:grab;user-select:none}.nav-tabs:active{cursor:grabbing}.nav-tabs::-webkit-scrollbar{display:none}.nav-tab{background:0 0;border:none;color:var(--text-3);padding:8px 16px;border-radius:8px;font-family:Sarabun,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;white-space:nowrap}.nav-tab:hover{background:var(--glass);color:var(--text-2)}.nav-tab.active{background:var(--crimson);color:#fff;border-radius:8px}.nav-dot{width:6px;height:6px;border-radius:50%;background:var(--crimson-glow);box-shadow:0 0 6px var(--crimson-glow);display:none}.nav-tab.active .nav-dot{display:block}.topbar-right{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0}.plant-selector{background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:8px;color:var(--text-1);padding:7px 12px;font-family:Sarabun,sans-serif;font-size:13px;outline:0;cursor:pointer}.plant-selector:focus{border-color:var(--crimson)}.user-pill{display:flex;align-items:center;gap:8px;background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:20px;padding:6px 14px;font-size:12px;color:var(--text-2);cursor:pointer}.user-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--crimson-dark),var(--crimson));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.btn-sm{background:0 0;border:1px solid var(--carbon-7);border-radius:8px;color:var(--text-3);padding:7px 14px;font-family:Sarabun,sans-serif;font-size:12px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px}.btn-sm:hover{border-color:var(--crimson);color:var(--crimson-glow)}.btn-primary-sm{background:linear-gradient(135deg,var(--crimson-dark),var(--crimson-bright));border:none;border-radius:8px;color:#fff;padding:8px 16px;font-family:Sarabun,sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px;box-shadow:0 4px 12px rgba(183,28,28,.3)}.btn-primary-sm:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(183,28,28,.45)}.page{display:none;padding:24px 28px;max-width:1800px;margin:0 auto}.page.active{display:block}.plant-month-banner{margin-bottom:18px;padding:18px 24px;background:linear-gradient(135deg,rgba(127,0,0,.18) 0,rgba(22,22,22,.95) 100%);border:1px solid rgba(183,28,28,.25);border-radius:14px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;position:relative;overflow:hidden}.plant-month-banner::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(183,28,28,.03) 40px,rgba(183,28,28,.03) 41px);pointer-events:none}.pmb-left{display:flex;flex-direction:column;gap:4px}.pmb-plant{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:700;color:#fff;letter-spacing:1.5px;text-shadow:0 0 30px rgba(229,57,53,.3)}.pmb-plant span{color:var(--crimson-glow)}.pmb-sub{font-size:12px;color:var(--text-3);letter-spacing:2px;text-transform:uppercase}.pmb-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.month-btn{background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:8px;color:var(--text-2);padding:7px 14px;font-family:Sarabun,sans-serif;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.month-btn:hover{border-color:var(--crimson);color:var(--crimson-glow)}.month-btn.active{background:rgba(183,28,28,.2);border-color:var(--crimson);color:#fff;font-weight:600;box-shadow:0 0 12px rgba(183,28,28,.25)}.month-select-wrap{display:flex;align-items:center;gap:8px}.month-select-wrap select{background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:8px;color:var(--text-1);padding:8px 12px;font-family:Sarabun,sans-serif;font-size:13px;outline:0;min-width:160px}.month-select-wrap select:focus{border-color:var(--crimson)}.kpi-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:22px}.kpi-card{background:var(--carbon-3);border:1px solid rgba(255,255,255,.07);border-top:2px solid var(--crimson);border-radius:10px;padding:16px 18px;position:relative;overflow:hidden;transition:border-color .2s}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.4),0 0 20px rgba(183,28,28,.1)}.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--crimson),var(--crimson-glow),transparent)}.kpi-card-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--crimson-glow);margin-bottom:10px;font-weight:600}.kpi-card-value{font-family:'Barlow Condensed',sans-serif;font-size:34px;font-weight:700;color:#fff;line-height:1;letter-spacing:-.5px}.kpi-card-unit{font-size:14px;color:var(--text-2);font-weight:400;margin-left:4px;letter-spacing:0}.kpi-card-sub{font-size:11px;color:var(--text-3);margin-top:6px;letter-spacing:0;line-height:1.4}.kpi-card-icon{position:absolute;right:18px;top:16px;font-size:28px;opacity:.12}.kpi-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 0;font-size:10px;font-weight:500;margin-top:6px;text-transform:uppercase;letter-spacing:.8px;opacity:.55}.kpi-tag.up{color:#b0bec5}.kpi-tag.red{color:#b0bec5}.kpi-tag.gold{color:#b0bec5}.chart-grid-2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;margin-bottom:16px}.chart-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}.chart-grid-half{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.chart-grid-full{margin-bottom:16px}.chart-card{background:var(--card);border:1px solid var(--card-border);border-radius:14px;padding:22px;position:relative;overflow:hidden}.chart-card::after{content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;background:radial-gradient(circle,rgba(183,28,28,.07),transparent 70%);pointer-events:none}.chart-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.chart-title{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-1);display:flex;align-items:center;gap:8px}.chart-dot{width:7px;height:7px;border-radius:50%;background:var(--crimson-glow);box-shadow:0 0 7px var(--crimson-glow)}.chart-badge{font-size:10px;letter-spacing:1px;border-radius:10px;padding:3px 10px;background:rgba(183,28,28,.1);border:1px solid rgba(183,28,28,.2);color:var(--steel)}canvas{max-height:260px}.tbl-wrap{overflow-x:auto}table.data-tbl{width:100%;border-collapse:collapse;font-size:13px}table.data-tbl th{background:rgba(183,28,28,.08);color:var(--crimson-glow);font-size:10px;text-transform:uppercase;letter-spacing:1.5px;padding:11px 14px;text-align:left;border-bottom:1px solid var(--card-border);white-space:nowrap;font-weight:600}table.data-tbl td{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.03);color:var(--text-1);vertical-align:middle}table.data-tbl tr:hover td{background:rgba(183,28,28,.04)}table.data-tbl tr:last-child td{border-bottom:none}.rank-chip{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;font-family:'DM Mono',monospace;font-size:12px;font-weight:500}.r1{background:linear-gradient(135deg,#ffd54f,#ff8f00);color:#000}.r2{background:linear-gradient(135deg,#b0bec5,#78909c);color:#000}.r3{background:linear-gradient(135deg,#ff8a65,#bf360c);color:#fff}.rN{background:rgba(255,255,255,.06);color:var(--text-3)}.str-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;font-family:'DM Mono',monospace}.s84181002{background:rgba(176,190,197,.12);color:#b0bec5;border:1px solid rgba(176,190,197,.3)}.s84211002{background:rgba(144,164,174,.12);color:#90a4ae;border:1px solid rgba(144,164,174,.3)}.s84241002{background:rgba(198,40,40,.15);color:#ef9a9a;border:1px solid rgba(198,40,40,.35)}.s84241122{background:rgba(211,47,47,.15);color:#ffcdd2;border:1px solid rgba(211,47,47,.35)}.s84281002{background:rgba(229,57,53,.15);color:#ffcdd2;border:1px solid rgba(229,57,53,.35)}.s84321296{background:rgba(239,83,80,.12);color:#ffcdd2;border:1px solid rgba(239,83,80,.3)}.s84301002{background:rgba(120,144,156,.15);color:#cfd8dc;border:1px solid rgba(120,144,156,.35)}.s84361230{background:rgba(96,125,139,.15);color:#cfd8dc;border:1px solid rgba(96,125,139,.35)}.s84401002{background:rgba(84,110,122,.18);color:#eceff1;border:1px solid rgba(84,110,122,.4)}.s84401122{background:rgba(69,90,100,.18);color:#eceff1;border:1px solid rgba(69,90,100,.4)}.s84071002{background:rgba(55,71,79,.18);color:#b0bec5;border:1px solid rgba(55,71,79,.4)}.s84991081{background:rgba(38,50,56,.25);color:#78909c;border:1px solid rgba(38,50,56,.5)}.ot-cash{color:#a5d6a7;font-size:11px}.ot-credit{color:#90caf9;font-size:11px}.ot-maint{color:var(--text-3);font-size:11px}.ot-toll{color:#ffd54f;font-size:11px}.ot-donation{color:#ce93d8;font-size:11px}.mini-bar{height:5px;border-radius:3px;background:linear-gradient(90deg,var(--crimson-dark),var(--crimson-glow))}.admin-grid{display:grid;grid-template-columns:220px 1fr;gap:0;min-height:calc(100vh - 64px)}.admin-sidebar{background:var(--carbon-3);border-right:1px solid var(--carbon-5);padding:24px 16px}.admin-sidebar-title{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text-3);padding:0 12px;margin-bottom:12px;margin-top:8px}.admin-sidebar-btn{display:flex;align-items:center;gap:10px;width:100%;background:0 0;border:none;color:var(--text-2);padding:10px 12px;border-radius:9px;font-family:Sarabun,sans-serif;font-size:13px;cursor:pointer;transition:all .2s;text-align:left;margin-bottom:2px}.admin-sidebar-btn:hover{background:var(--glass);color:var(--text-1)}.admin-sidebar-btn.active{background:rgba(183,28,28,.15);color:var(--crimson-glow);box-shadow:inset 0 0 0 1px rgba(183,28,28,.25)}.admin-content{padding:28px;overflow-y:auto}.admin-section{display:none}.admin-section.active{display:block}.admin-section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--carbon-5)}.admin-section-title{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:700;letter-spacing:1px;color:#fff}.upload-zone{border:2px dashed var(--carbon-7);border-radius:14px;padding:40px;text-align:center;cursor:pointer;transition:all .2s;background:var(--carbon-4);margin-bottom:24px}.upload-zone.drag,.upload-zone:hover{border-color:var(--crimson);background:rgba(183,28,28,.06)}.upload-icon{font-size:40px;margin-bottom:12px;opacity:.6}.upload-text{color:var(--text-2);font-size:14px;margin-bottom:6px}.upload-hint{color:var(--text-3);font-size:12px}.upload-result{background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:10px;padding:16px;font-size:13px;display:none}.upload-result.success{border-color:rgba(76,175,80,.4);background:rgba(76,175,80,.06)}.upload-result.error{border-color:rgba(183,28,28,.4);background:rgba(183,28,28,.06)}.edit-controls{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.edit-controls input,.edit-controls select{background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:8px;color:var(--text-1);padding:8px 12px;font-family:Sarabun,sans-serif;font-size:13px;outline:0}.edit-controls input:focus,.edit-controls select:focus{border-color:var(--crimson)}.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);z-index:5000;align-items:center;justify-content:center}.modal-bg.open{display:flex}.modal-box{background:var(--carbon-4);border:1px solid rgba(183,28,28,.35);border-radius:16px;padding:30px;width:540px;max-width:95vw;box-shadow:0 24px 60px rgba(0,0,0,.6);animation:fadeUp .2s ease}.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--carbon-6)}.modal-title{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;letter-spacing:1px;color:#fff}.modal-close{width:30px;height:30px;background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:7px;color:var(--text-2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{background:var(--crimson-dark);color:#fff;border-color:var(--crimson)}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.form-col{display:flex;flex-direction:column;gap:6px}.form-col.full{grid-column:1/-1}.form-col label{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--crimson-glow)}.form-col input,.form-col select{background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:9px;color:var(--text-1);padding:11px 14px;font-family:Sarabun,sans-serif;font-size:13px;outline:0;transition:border .2s}.form-col input:focus,.form-col select:focus{border-color:var(--crimson);box-shadow:0 0 0 2px rgba(183,28,28,.12)}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;padding-top:16px;border-top:1px solid var(--carbon-6)}.toast{position:fixed;bottom:28px;right:28px;z-index:9999;background:linear-gradient(135deg,var(--crimson-dark),var(--crimson));color:#fff;padding:13px 22px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 8px 28px rgba(183,28,28,.4);animation:toastIn .3s ease;pointer-events:none;font-family:Sarabun,sans-serif}@keyframes toastIn{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--carbon-2)}::-webkit-scrollbar-thumb{background:var(--crimson-dark);border-radius:3px}.page-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px}.page-hdr-left h2{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:700;letter-spacing:1px;color:#fff}.page-hdr-left p{font-size:12px;color:var(--text-3);margin-top:4px;letter-spacing:1px}.page-hdr-right{display:flex;gap:10px;align-items:center}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}.filter-bar input,.filter-bar select{background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:8px;color:var(--text-1);padding:8px 12px;font-family:Sarabun,sans-serif;font-size:12px;outline:0}.filter-bar input:focus,.filter-bar select:focus{border-color:var(--crimson)}.exec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.exec-card{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:8px;padding:16px;min-height:112px}.exec-label{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-3);margin-bottom:8px}.exec-value{font-family:'Barlow Condensed',sans-serif;font-size:30px;font-weight:700;color:#fff;line-height:1}.exec-sub{font-size:12px;color:var(--text-3);margin-top:8px}.exec-sub.up{color:#a5d6a7}.exec-sub.down{color:#ef9a9a}.exec-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;margin-bottom:16px}.exec-table-wrap{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:8px;overflow:hidden}.exec-table-hdr{padding:14px 16px;border-bottom:1px solid var(--carbon-6);font-size:13px;font-weight:700;color:#fff}.exec-table{width:100%;border-collapse:collapse;font-size:12px}.exec-table td,.exec-table th{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.05);text-align:left}.exec-table th{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);background:rgba(255,255,255,.02)}.exec-table td:last-child,.exec-table th:last-child{text-align:right}@media(max-width:1100px){.exec-grid{grid-template-columns:repeat(2,1fr)}.exec-layout{grid-template-columns:1fr}}@media(max-width:640px){.exec-grid{grid-template-columns:1fr}}.mix-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.mix-toolbar input,.mix-toolbar select{background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:8px;color:var(--text-1);padding:9px 12px;font-family:Sarabun,sans-serif;font-size:12px;outline:0}.mix-toolbar input:focus,.mix-toolbar select:focus{border-color:var(--crimson)}.mix-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.mix-summary-card{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:8px;padding:14px}.mix-summary-card .label{font-size:10px;text-transform:uppercase;letter-spacing:1.6px;color:var(--text-3);margin-bottom:6px}.mix-summary-card .value{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:700;color:#fff;overflow-wrap:anywhere}.mix-category-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;overflow-x:auto;overscroll-behavior-inline:contain;-webkit-overflow-scrolling:touch;cursor:grab;user-select:none}.mix-category-tabs:active{cursor:grabbing}.mix-tab{border:1px solid var(--carbon-6);background:var(--carbon-4);color:var(--text-2);border-radius:8px;padding:8px 12px;font-family:Sarabun,sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.mix-tab:hover{border-color:rgba(229,57,53,.55);color:#fff}.mix-tab.active{background:linear-gradient(135deg,var(--crimson-dark),var(--crimson));border-color:var(--crimson);color:#fff;box-shadow:0 8px 22px rgba(183,28,28,.22)}.mix-layout{display:grid;grid-template-columns:360px 1fr;gap:16px;align-items:start}.mix-list{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:8px;overflow:hidden}.mix-list-hdr{padding:12px 14px;border-bottom:1px solid var(--carbon-6);font-size:12px;color:var(--text-3);display:flex;justify-content:space-between;gap:10px}.mix-list-body{max-height:560px;overflow:auto}.mix-item{width:100%;text-align:left;background:0 0;border:0;border-bottom:1px solid rgba(255,255,255,.05);padding:12px 14px;color:var(--text-1);cursor:pointer;font-family:Sarabun,sans-serif;display:block}.mix-item:hover{background:rgba(255,255,255,.035)}.mix-item.active{background:rgba(183,28,28,.16);box-shadow:inset 3px 0 0 var(--crimson)}.mix-item-code{font-family:'DM Mono',monospace;font-size:13px;font-weight:700;color:#ffd54f;margin-bottom:5px}.mix-item-meta{font-size:11px;color:var(--text-3);line-height:1.45}.mix-detail{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:8px;padding:18px;min-height:520px}.mix-detail-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;border-bottom:1px solid var(--carbon-6);padding-bottom:14px;margin-bottom:16px}.mix-detail-title{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:700;color:#fff;letter-spacing:1px}.mix-detail-sub{font-size:12px;color:var(--text-3);margin-top:4px}.mix-pill-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.mix-pill{border:1px solid var(--carbon-6);background:var(--carbon-4);border-radius:999px;padding:5px 9px;font-size:11px;color:var(--text-2)}.mix-info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.mix-info{background:var(--carbon-4);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:11px}.mix-info .label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:5px}.mix-info .value{font-size:15px;color:#fff;font-weight:700;overflow-wrap:anywhere}.mix-material-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.mix-material{background:var(--carbon-4);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:12px}.mix-material-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.mix-material-name{font-size:12px;color:var(--text-2);font-weight:700}.mix-material-value{font-family:'DM Mono',monospace;font-size:15px;color:#ffd54f;font-weight:700;white-space:nowrap}.mix-bar-track{height:7px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden}.mix-bar-fill{height:100%;background:linear-gradient(90deg,var(--crimson-dark),#7b6666,#455a64);border-radius:999px}.mix-empty{padding:50px 20px;text-align:center;color:var(--text-3);font-size:13px}@media(max-width:1100px){.mix-layout{grid-template-columns:1fr}.mix-summary{grid-template-columns:repeat(2,1fr)}.mix-info-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.mix-info-grid,.mix-material-grid,.mix-summary{grid-template-columns:1fr}.mix-detail-top{flex-direction:column}}.cost-hero{display:grid;grid-template-columns:1.15fr .85fr;gap:16px;margin-bottom:16px}.cost-panel{background:var(--card);border:1px solid var(--card-border);border-radius:14px;padding:20px;position:relative;overflow:hidden}.cost-panel::after{content:'';position:absolute;right:-40px;top:-50px;width:140px;height:140px;background:radial-gradient(circle,rgba(229,57,53,.1),transparent 70%);pointer-events:none}.cost-form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:14px}.cost-field{display:flex;flex-direction:column;gap:6px;min-width:0}.cost-field label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:1px;font-weight:700}.cost-field input,.cost-field select{background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:8px;color:var(--text-1);padding:9px 11px;font-family:Sarabun,sans-serif;font-size:13px;outline:0;width:100%}.cost-field input:focus,.cost-field select:focus{border-color:var(--crimson);box-shadow:0 0 0 2px rgba(183,28,28,.12)}.cost-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.cost-kpi{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:10px;padding:14px;border-top:2px solid rgba(229,57,53,.65)}.cost-kpi .label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.cost-kpi .value{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:800;color:#fff;line-height:1;overflow-wrap:anywhere}.cost-kpi .sub{font-size:11px;color:var(--text-3);margin-top:6px;line-height:1.35}.cost-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:10px}.cost-table td,.cost-table th{padding:9px 10px;border-bottom:1px solid rgba(255,255,255,.06);text-align:left}.cost-table th{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);background:rgba(255,255,255,.02)}.cost-table td:last-child,.cost-table th:last-child{text-align:right;font-family:'DM Mono',monospace}.cost-pill{display:inline-flex;align-items:center;padding:4px 9px;border:1px solid rgba(255,255,255,.1);border-radius:999px;color:var(--text-2);font-size:11px;background:rgba(255,255,255,.03);margin:3px 4px 0 0}.cost-note{font-size:12px;color:var(--text-3);line-height:1.65;margin-top:12px;border-left:3px solid var(--crimson);padding-left:12px;background:rgba(183,28,28,.04);border-radius:0 8px 8px 0;padding-top:8px;padding-bottom:8px}.cost-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.cost-status-good{color:#a5d6a7}.cost-status-warn{color:#ffd54f}.cost-status-bad{color:#ef9a9a}@media(max-width:1100px){.cost-hero{grid-template-columns:1fr}.cost-form-grid{grid-template-columns:repeat(2,1fr)}.cost-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.cost-form-grid,.cost-kpi-grid{grid-template-columns:1fr}.cost-panel{padding:15px}.cost-kpi .value{font-size:25px}}.pc-mix-actions{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0 12px}.pc-table-wrap{overflow-x:auto;overflow-y:visible;border:1px solid rgba(255,255,255,.06);border-radius:10px;background:rgba(0,0,0,.1)}.pc-mix-table{min-width:1680px;width:100%;border-collapse:collapse;font-size:12px}.pc-mix-table td,.pc-mix-table th{padding:8px 9px;border-bottom:1px solid rgba(255,255,255,.06);border-right:1px solid rgba(255,255,255,.05);text-align:right;white-space:nowrap}.pc-mix-table th{background:rgba(183,28,28,.55);color:#fff;font-size:10px;text-transform:uppercase;letter-spacing:.8px}.pc-mix-table td:first-child,.pc-mix-table th:first-child{text-align:left;position:sticky;left:0;background:var(--carbon-4);z-index:2}.pc-mix-table th:first-child{background:rgba(183,28,28,.85);z-index:3}.pc-mix-table input{min-width:86px}.pc-result-good{color:#a5d6a7!important;font-weight:900}.pc-result-bad{color:#ef9a9a!important;font-weight:900}.pc-total-row td{font-weight:900;background:rgba(183,28,28,.08)}.cost-subtabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.cost-subtab{border:1px solid var(--carbon-6);background:var(--carbon-4);color:var(--text-2);border-radius:10px;padding:9px 14px;font-family:Sarabun,sans-serif;font-size:12px;font-weight:800;cursor:pointer;transition:all .2s}.cost-subtab:hover{border-color:var(--crimson);color:#fff}.cost-subtab.active{background:linear-gradient(135deg,var(--crimson-dark),var(--crimson));border-color:var(--crimson);color:#fff;box-shadow:0 8px 22px rgba(183,28,28,.22)}.cost-subpage{display:none}.cost-subpage.active{display:block}.project-cost-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:16px;margin-bottom:16px}.project-cost-title{font-size:12px;color:#fff;font-weight:900;text-transform:uppercase;letter-spacing:1px;margin:14px 0 8px;border-bottom:1px solid var(--carbon-6);padding-bottom:8px}.project-mini-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:12px 0 16px}.project-mini-kpi{background:var(--carbon-4);border:1px solid rgba(255,255,255,.06);border-radius:9px;padding:12px}.project-mini-kpi .label{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.project-mini-kpi .value{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:800;color:#fff;line-height:1;overflow-wrap:anywhere}.formula-badge{font-family:'DM Mono',monospace;font-size:10px;color:#ffd54f;background:rgba(255,213,79,.08);border:1px solid rgba(255,213,79,.18);border-radius:6px;padding:2px 6px;white-space:nowrap}@media(max-width:1100px){.project-cost-grid{grid-template-columns:1fr}.project-mini-kpis{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.project-mini-kpis{grid-template-columns:1fr}.cost-subtab{flex:1 1 auto}}.fin-sim-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:16px;margin-bottom:16px}.fin-section-title{font-size:12px;color:#fff;font-weight:900;text-transform:uppercase;letter-spacing:1px;margin:16px 0 8px;border-bottom:1px solid var(--carbon-6);padding-bottom:8px}.fin-row-grid{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:8px;align-items:end;margin-bottom:8px}.fin-row-grid.six{grid-template-columns:1.05fr repeat(5,1fr)}.fin-row-grid .fin-label{font-size:11px;color:var(--text-3);font-weight:800;text-transform:uppercase;letter-spacing:.7px;padding-bottom:8px}.fin-input{background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:8px;color:var(--text-1);padding:8px 10px;font-family:Sarabun,sans-serif;font-size:12px;outline:0;width:100%;font-weight:700}.fin-input:focus{border-color:var(--crimson);box-shadow:0 0 0 2px rgba(183,28,28,.12)}.fin-name{font-size:12px;color:var(--text-2);font-weight:800;line-height:1.25;padding:8px 0}.fin-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.fin-kpi{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:10px;padding:14px;border-top:2px solid rgba(255,213,79,.65)}.fin-kpi .label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.fin-kpi .value{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;color:#fff;line-height:1;overflow-wrap:anywhere}.fin-kpi .sub{font-size:11px;color:var(--text-3);margin-top:6px;line-height:1.35}.fin-table-wrap{overflow-x:auto}.fin-table{width:100%;border-collapse:collapse;font-size:12px;min-width:880px;margin-top:10px}.fin-table td,.fin-table th{padding:9px 10px;border-bottom:1px solid rgba(255,255,255,.06);text-align:right;white-space:nowrap}.fin-table td:first-child,.fin-table th:first-child{text-align:left}.fin-table th{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);background:rgba(255,255,255,.02)}.fin-total-row td{font-weight:900;color:#fff;background:rgba(183,28,28,.07)}.fin-note{font-size:12px;color:var(--text-3);line-height:1.65;margin-top:12px;border-left:3px solid var(--gold);padding:8px 12px;background:rgba(255,213,79,.04);border-radius:0 8px 8px 0}@media(max-width:1100px){.fin-sim-grid{grid-template-columns:1fr}.fin-kpi-grid{grid-template-columns:repeat(2,1fr)}.fin-row-grid,.fin-row-grid.six{grid-template-columns:1fr 1fr}}@media(max-width:640px){.fin-kpi-grid{grid-template-columns:1fr}.fin-row-grid,.fin-row-grid.six{grid-template-columns:1fr}}@media(max-width:1200px){.kpi-strip{grid-template-columns:repeat(3,1fr)}.chart-grid-2{grid-template-columns:1fr}.chart-grid-3{grid-template-columns:1fr 1fr}}@media(max-width:768px){body{min-width:0}.login-card{width:calc(100vw - 28px);padding:32px 24px;border-radius:16px}.login-logo{align-items:flex-start;margin-bottom:24px}.login-logo-text h1{font-size:20px;line-height:1.2}.topbar{height:auto;min-height:64px;padding:10px 12px 12px;flex-wrap:wrap;gap:10px;align-items:center}.topbar-brand{gap:10px;min-width:0}.topbar-icon{width:74px!important;height:34px!important;flex-shrink:0}.topbar-name{font-size:15px;white-space:normal;line-height:1.15}.topbar-sep{display:none}.nav-tabs{order:3;flex:0 0 100%;overflow-x:auto;overflow-y:hidden;gap:6px;padding:2px 0 4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.nav-tabs::-webkit-scrollbar{display:none}.nav-tab{flex:0 0 auto;padding:9px 12px;font-size:12px;border:1px solid rgba(255,255,255,.05);background:rgba(255,255,255,.02)}.nav-dot{width:5px;height:5px}.topbar-right{margin-left:auto;gap:8px;flex:1 1 auto;justify-content:flex-end;min-width:0}.plant-selector{max-width:46vw;padding:8px 10px;font-size:12px}.user-pill{padding:5px 9px;gap:6px;max-width:34vw}#userName{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-avatar{width:24px;height:24px;flex-shrink:0}.topbar-right .btn-sm{padding:8px 10px;white-space:nowrap}.page{padding:14px 12px}.page-hdr{flex-direction:column;gap:12px;margin-bottom:16px}.page-hdr-left h2{font-size:21px;line-height:1.2}.page-hdr-left p{font-size:11px;letter-spacing:.4px}.page-hdr-right{width:100%;flex-wrap:wrap}.page-hdr-right .btn-primary-sm,.page-hdr-right .btn-sm{flex:1 1 150px;justify-content:center}.plant-month-banner{padding:16px;border-radius:12px;align-items:flex-start}.month-select-wrap,.month-select-wrap select,.pmb-left,.pmb-right{width:100%}.pmb-plant{font-size:22px;line-height:1.2;overflow-wrap:anywhere}.pmb-sub{font-size:10px;letter-spacing:1.2px;line-height:1.4}.pmb-right{gap:10px}.month-select-wrap select{min-width:0}#monthQuickBtns{width:100%;overflow-x:auto;flex-wrap:nowrap!important;padding-bottom:2px;-webkit-overflow-scrolling:touch}.month-btn{padding:8px 12px;font-size:12px;flex:0 0 auto}.kpi-strip{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:16px}.kpi-card{padding:16px 14px;border-radius:12px;min-width:0}.kpi-card-label{font-size:9px;letter-spacing:1.4px;line-height:1.35;padding-right:30px}.kpi-card-value{font-size:27px;overflow-wrap:anywhere}.kpi-card-unit{font-size:12px}.kpi-card-sub{font-size:10px;line-height:1.35}.kpi-card-icon{right:12px;top:12px;font-size:22px}.chart-grid-3,.chart-grid-half{grid-template-columns:1fr}.chart-card{padding:16px 14px;border-radius:12px;min-width:0}.chart-hdr{align-items:flex-start;gap:10px;flex-wrap:wrap;margin-bottom:14px}.chart-title{font-size:12px;line-height:1.35;letter-spacing:.7px;min-width:0}.chart-badge{font-size:9px;max-width:100%;white-space:normal;line-height:1.35}canvas{width:100%!important;max-height:230px}.tbl-wrap{margin:0 -2px;padding-bottom:4px}table.data-tbl{font-size:12px;min-width:720px}table.data-tbl td,table.data-tbl th{padding:9px 10px}.exec-table{min-width:520px}.exec-table-wrap{overflow-x:auto}.edit-controls,.filter-bar,.mix-toolbar{display:grid;grid-template-columns:1fr;gap:8px}#filterSearch,#mixSearch,.edit-controls input,.edit-controls select,.filter-bar input,.filter-bar select,.mix-toolbar input,.mix-toolbar select{width:100%!important;min-width:0}.edit-controls .btn-sm,.filter-bar .btn-sm{justify-content:center}.exec-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.exec-card{padding:14px;min-height:102px}.exec-value{font-size:25px;overflow-wrap:anywhere}.exec-layout{grid-template-columns:1fr;gap:12px}.mix-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.mix-layout{grid-template-columns:1fr}.mix-list-body{max-height:340px}.mix-detail{padding:14px;min-height:0}.mix-detail-title{font-size:23px;overflow-wrap:anywhere}.mix-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mix-material-grid{grid-template-columns:1fr}.mix-material-head{align-items:flex-start;flex-direction:column;gap:4px}.mix-material-value{white-space:normal}.admin-grid{grid-template-columns:1fr;min-height:0}.admin-sidebar{display:flex;gap:8px;overflow-x:auto;padding:12px;border-right:none;border-bottom:1px solid var(--carbon-5);position:sticky;top:0;z-index:5}.admin-sidebar-title{display:none}.admin-sidebar-btn{flex:0 0 auto;width:auto;margin:0;white-space:nowrap}.admin-content{padding:16px 12px}.admin-section-hdr{align-items:flex-start;flex-direction:column;gap:12px}.upload-zone{padding:28px 16px}#asec-upload label{align-items:flex-start!important}.modal-bg{align-items:flex-end;padding:10px}.modal-box{width:100%;max-width:100%;max-height:92vh;overflow:auto;padding:22px 18px;border-radius:16px 16px 12px 12px}.form-row-2{grid-template-columns:1fr;gap:12px}.modal-footer{flex-direction:column-reverse}.modal-footer .btn-primary-sm,.modal-footer .btn-sm{width:100%;justify-content:center}.toast{left:14px;right:14px;bottom:18px;text-align:center}}@media(max-width:520px){.topbar-right{flex-basis:100%;justify-content:space-between}.plant-selector{max-width:none;flex:1 1 auto;min-width:0}.user-pill{display:none}.topbar-right .btn-sm{flex:0 0 auto}.exec-grid,.kpi-strip,.mix-info-grid,.mix-summary{grid-template-columns:1fr}.kpi-card-value{font-size:30px}.chart-card{padding:14px 12px}canvas{max-height:210px}.page{padding:12px 10px}.btn-primary-sm,.btn-sm{min-height:38px}}@media(max-width:380px){.topbar-name{display:none}.topbar-icon{width:68px!important}.nav-tab{font-size:11px;padding:8px 10px}.pmb-plant{font-size:20px}.page-hdr-left h2{font-size:19px}}.pp-stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}.pp-stat{background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:10px;padding:12px 18px}.pp-stat .ps-num{font-family:'DM Mono',monospace;font-size:22px;font-weight:600;color:#fff;line-height:1}.pp-stat .ps-lbl{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:1px;margin-top:3px}.pp-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:20px;padding:14px 16px;background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:10px}.pp-filter-lbl{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:1px;white-space:nowrap}.pp-filter-btn{padding:5px 12px;border-radius:16px;font-size:11px;font-family:Sarabun,sans-serif;border:1px solid var(--carbon-7);background:0 0;color:var(--text-3);cursor:pointer;transition:all .2s;white-space:nowrap}.pp-filter-btn:hover{border-color:var(--crimson);color:var(--crimson-pale)}.pp-filter-btn.active{background:rgba(183,28,28,.15);border-color:var(--crimson);color:#fff;font-weight:600}.pp-search{padding:6px 14px;border-radius:16px;font-size:12px;font-family:Sarabun,sans-serif;border:1px solid var(--carbon-7);background:0 0;color:var(--text-1);outline:0;width:180px;transition:border-color .2s}.pp-search::placeholder{color:var(--text-3)}.pp-search:focus{border-color:var(--crimson)}.pp-sep{width:1px;height:18px;background:var(--carbon-7)}.pp-grid{display:grid;gap:12px}.pp-card{background:var(--carbon-4);border:1px solid var(--carbon-6);border-radius:12px;overflow:hidden;transition:border-color .2s}.pp-card:hover{border-color:var(--carbon-7)}.pp-card-hdr{display:grid;grid-template-columns:44px 1fr auto;gap:14px;align-items:start;padding:18px 20px;cursor:pointer}.pp-no{font-family:'DM Mono',monospace;font-size:20px;font-weight:500;color:var(--text-3);line-height:1;padding-top:2px}.pp-name{font-size:15px;font-weight:600;color:var(--text-1);line-height:1.3;margin-bottom:7px}.pp-badges{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.pp-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:4px;font-size:10px;font-weight:500;letter-spacing:.3px;white-space:nowrap;border:1px solid transparent}.pp-b-residential{background:rgba(168,85,247,.12);color:#c084fc;border-color:rgba(168,85,247,.2)}.pp-b-commercial{background:rgba(245,158,11,.12);color:#fbbf24;border-color:rgba(245,158,11,.2)}.pp-b-infrastructure{background:rgba(6,182,212,.12);color:#22d3ee;border-color:rgba(6,182,212,.2)}.pp-b-education{background:rgba(34,197,94,.12);color:#4ade80;border-color:rgba(34,197,94,.2)}.pp-b-industrial{background:rgba(249,115,22,.12);color:#fb923c;border-color:rgba(249,115,22,.2)}.pp-b-default{background:rgba(255,255,255,.05);color:var(--text-3);border-color:var(--carbon-7)}.pp-b-predev{background:rgba(96,165,250,.1);color:#93c5fd;border-color:rgba(96,165,250,.2)}.pp-b-bidding{background:rgba(245,158,11,.1);color:#fcd34d;border-color:rgba(245,158,11,.2)}.pp-b-construction{background:rgba(34,197,94,.1);color:#86efac;border-color:rgba(34,197,94,.2)}.pp-b-working{background:rgba(34,197,94,.1);color:#86efac;border-color:rgba(34,197,94,.2)}.pp-b-backlog{background:rgba(96,165,250,.1);color:#93c5fd;border-color:rgba(96,165,250,.2)}.pp-b-prospect{background:rgba(245,158,11,.1);color:#fcd34d;border-color:rgba(245,158,11,.2)}.pp-b-loss{background:rgba(239,68,68,.1);color:#fca5a5;border-color:rgba(239,68,68,.2)}.pp-b-province{background:rgba(255,255,255,.04);color:var(--text-3);border-color:var(--carbon-6)}.pp-b-order{background:rgba(255,255,255,.03);color:var(--text-3);border-color:var(--carbon-6)}.pp-vol{text-align:right}.pp-vol-num{font-family:'DM Mono',monospace;font-size:20px;font-weight:600;color:#fff}.pp-vol-lbl{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:1px}.pp-card-body{display:none;border-top:1px solid var(--carbon-6);padding:0 20px 18px;animation:ppFadeIn .2s ease}@keyframes ppFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.pp-card.expanded .pp-card-body{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:0}.pp-detail-grp{padding:16px 12px 0 0}.pp-grp-lbl{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--carbon-6)}.pp-field{display:flex;flex-direction:column;gap:2px;margin-bottom:9px}.pp-field-k{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px}.pp-field-v{font-size:12px;color:var(--text-1);line-height:1.4}.pp-field-v.mono{font-family:'DM Mono',monospace;font-size:11px;color:var(--crimson-pale)}.pp-remark{grid-column:1/-1;margin-top:4px;padding:10px 14px;background:rgba(183,28,28,.06);border:1px solid rgba(183,28,28,.15);border-radius:8px}.pp-remark-lbl{font-size:9px;color:var(--crimson-pale);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.pp-remark-txt{font-size:12px;color:var(--text-2);line-height:1.6}.pp-expand-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;background:0 0;border:none;border-top:1px solid var(--carbon-6);color:var(--text-3);font-size:10px;font-family:Sarabun,sans-serif;cursor:pointer;width:100%;text-transform:uppercase;letter-spacing:1px;transition:color .2s,background .2s}.pp-expand-btn:hover{color:var(--crimson-pale);background:rgba(183,28,28,.05)}.pp-card.expanded .pp-expand-btn{color:var(--crimson-pale)}.pp-expand-arrow{transition:transform .2s;font-size:9px}.pp-card.expanded .pp-expand-arrow{transform:rotate(180deg)}.pp-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:9000;align-items:center;justify-content:center}.pp-modal-overlay.open{display:flex}.pp-modal{background:var(--carbon-3);border:1px solid var(--carbon-7);border-radius:16px;width:90%;max-width:820px;max-height:90vh;overflow-y:auto;padding:28px}.pp-modal-title{font-size:18px;font-weight:700;color:#fff;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--carbon-6)}.pp-modal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}.pp-form-col{display:flex;flex-direction:column;gap:6px}.pp-form-col label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px}.pp-form-col input,.pp-form-col select,.pp-form-col textarea{background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:8px;color:var(--text-1);padding:8px 12px;font-family:Sarabun,sans-serif;font-size:13px;outline:0;transition:border-color .2s}.pp-form-col input:focus,.pp-form-col select:focus,.pp-form-col textarea:focus{border-color:var(--crimson)}.pp-form-col textarea{resize:vertical;min-height:70px}.pp-form-col.full{grid-column:1/-1}.pp-modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--carbon-6)}.pp-empty{text-align:center;padding:60px;color:var(--text-3);font-size:14px}.pp-remarks-section{grid-column:1/-1;margin-top:4px}.pp-remarks-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.pp-remarks-lbl{font-size:9px;color:var(--crimson-pale);text-transform:uppercase;letter-spacing:1px}.pp-add-remark-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;background:rgba(183,28,28,.12);border:1px solid rgba(183,28,28,.3);border-radius:6px;color:var(--crimson-pale);font-size:11px;font-family:Sarabun,sans-serif;cursor:pointer;transition:all .2s}.pp-add-remark-btn:hover{background:rgba(183,28,28,.2)}.pp-remarks-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.pp-remark-item{display:flex;gap:10px;align-items:flex-start;padding:8px 12px;background:rgba(255,255,255,.03);border:1px solid var(--carbon-6);border-radius:8px;position:relative}.pp-remark-item:last-child::before{display:none}.pp-remark-dot{width:6px;height:6px;border-radius:50%;background:var(--crimson);flex-shrink:0;margin-top:5px}.pp-remark-date{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-3);white-space:nowrap;min-width:75px}.pp-remark-text{font-size:12px;color:var(--text-2);line-height:1.5;flex:1}.pp-remark-del{background:0 0;border:none;color:var(--text-3);cursor:pointer;font-size:11px;padding:0 2px;opacity:0;transition:opacity .2s}.pp-remark-item:hover .pp-remark-del{opacity:1}.pp-remark-del:hover{color:#ef9a9a}.pp-add-remark-row{display:none;gap:8px;align-items:flex-start;margin-top:6px}.pp-add-remark-row.open{display:flex}.pp-add-remark-row input[type=date]{background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:7px;color:var(--text-1);padding:6px 10px;font-family:'DM Mono',monospace;font-size:12px;outline:0;flex-shrink:0}.pp-add-remark-row textarea{flex:1;background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:7px;color:var(--text-1);padding:7px 10px;font-family:Sarabun,sans-serif;font-size:12px;outline:0;resize:none;height:60px;transition:border-color .2s}.pp-add-remark-row textarea:focus{border-color:var(--crimson)}.pp-add-remark-row input[type=date]:focus{border-color:var(--crimson)}.pp-remark-save-btn{padding:6px 14px;background:var(--crimson);border:none;border-radius:7px;color:#fff;font-size:12px;font-family:Sarabun,sans-serif;cursor:pointer;white-space:nowrap;align-self:flex-end}.pp-remark-save-btn:hover{background:var(--crimson-bright)}.pp-excel-zone{grid-column:1/-1;border:2px dashed var(--carbon-7);border-radius:10px;padding:18px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:rgba(255,255,255,.02);margin-bottom:4px}.pp-excel-zone.drag,.pp-excel-zone:hover{border-color:var(--crimson);background:rgba(183,28,28,.05)}.pp-excel-zone-icon{font-size:28px;margin-bottom:6px}.pp-excel-zone-text{font-size:13px;color:var(--text-2)}.pp-excel-zone-hint{font-size:11px;color:var(--text-3);margin-top:4px}.pp-excel-parsed{display:none;grid-column:1/-1;padding:10px 14px;background:rgba(34,197,94,.06);border:1px solid rgba(34,197,94,.2);border-radius:8px;margin-bottom:4px}.pp-excel-parsed-lbl{font-size:10px;color:#86efac;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.pp-excel-row-btns{display:flex;flex-wrap:wrap;gap:6px}.pp-excel-row-btn{padding:4px 12px;background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:6px;color:var(--text-2);font-size:11px;font-family:Sarabun,sans-serif;cursor:pointer;transition:all .2s;text-align:left;white-space:nowrap}.pp-excel-row-btn:hover{border-color:var(--crimson);color:var(--crimson-pale)}.quote-upload-zone{border:2px dashed var(--carbon-7);border-radius:10px;padding:22px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:rgba(255,255,255,.02);margin-bottom:16px}.quote-upload-zone.drag,.quote-upload-zone:hover{border-color:var(--crimson);background:rgba(183,28,28,.05)}.quote-upload-icon{font-size:30px;margin-bottom:8px}.quote-upload-text{font-size:14px;color:var(--text-2);font-weight:700}.quote-upload-hint{font-size:12px;color:var(--text-3);margin-top:5px}.quote-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;margin-bottom:18px}.quote-section-title{grid-column:1/-1;font-size:11px;color:var(--crimson-pale);text-transform:uppercase;letter-spacing:1px;padding:6px 0 8px;border-bottom:1px solid var(--carbon-6);margin-top:4px}.quote-field{display:flex;flex-direction:column;gap:6px}.quote-field label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px}.quote-field input,.quote-field select{background:var(--carbon-5);border:1px solid var(--carbon-7);border-radius:8px;color:var(--text-1);padding:8px 12px;font-family:Sarabun,sans-serif;font-size:13px;outline:0}.quote-field input:focus,.quote-field select:focus{border-color:var(--crimson)}.quote-field.full{grid-column:1/-1}.quote-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:14px}.quote-products-wrap{overflow-x:auto;margin-top:10px}.quote-products{min-width:940px}.quote-products input{width:100%;background:0 0;border:1px solid transparent;color:var(--text-1);font-family:Sarabun,sans-serif;font-size:12px;padding:5px 6px;outline:0}.quote-products input:focus{border-color:var(--crimson);background:rgba(255,255,255,.04);border-radius:4px}#quotePrintArea{display:none}@media print{body{background:#fff!important;color:#000!important}#app,#loginScreen,.toast,body::before{display:none!important}#quotePrintArea{display:block!important}@page{size:A4 portrait;margin:0}}.excel100-wrap{display:flex;flex-direction:column;gap:14px}.excel100-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:12px;padding:16px 18px}.excel100-title{font-size:20px;font-weight:800;color:#fff}.excel100-sub{font-size:12px;color:var(--text-3);margin-top:4px}.excel100-actions{display:flex;gap:8px;flex-wrap:wrap}.excel100-kpis{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:12px}.excel100-kpi{background:var(--carbon-3);border:1px solid var(--carbon-6);border-top:2px solid var(--crimson);border-radius:10px;padding:14px}.excel100-kpi .label{font-size:10px;color:var(--crimson-pale);text-transform:uppercase;letter-spacing:1.2px}.excel100-kpi .value{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:800;color:#fff;margin-top:6px}.excel100-kpi .sub{font-size:11px;color:var(--text-3)}.excel100-note{background:rgba(183,28,28,.08);border:1px solid rgba(183,28,28,.25);border-radius:10px;padding:10px 14px;color:var(--text-2);font-size:12px;line-height:1.6}.excel100-sheet{display:flex;flex-direction:column;gap:14px}.xfs-section{background:var(--carbon-3);border:1px solid var(--carbon-6);border-radius:12px;overflow:hidden}.xfs-section-title{background:linear-gradient(90deg,rgba(183,28,28,.22),rgba(255,255,255,.03));border-bottom:1px solid var(--carbon-6);padding:11px 14px;font-weight:800;color:#fff;display:flex;justify-content:space-between;gap:10px}.xfs-section-title span{font-size:11px;color:var(--text-3);font-weight:600}.xfs-table-wrap{overflow:auto}.xfs-table{width:100%;border-collapse:collapse;min-width:780px;font-size:12px}.xfs-table th{position:sticky;top:0;background:#202020;color:#fff;text-align:left;padding:8px;border-bottom:1px solid var(--carbon-6);border-right:1px solid rgba(255,255,255,.04);white-space:nowrap}.xfs-table td{padding:5px 7px;border-bottom:1px solid rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.035);vertical-align:middle}.xfs-table tr:hover td{background:rgba(255,255,255,.025)}.xfs-row-total td{background:rgba(183,28,28,.09)!important;font-weight:800}.xfs-input,.xfs-select{width:100%;min-width:80px;background:#2a1111;border:1px solid rgba(229,57,53,.35);border-radius:6px;color:#fff;padding:7px 8px;font-size:12px;font-family:Sarabun,sans-serif;outline:0}.xfs-input:focus,.xfs-select:focus{border-color:var(--crimson-glow);box-shadow:0 0 0 2px rgba(229,57,53,.14)}.xfs-locked{display:block;width:100%;min-height:31px;background:#1b1b1b;border:1px solid rgba(255,255,255,.07);border-radius:6px;color:#e0e0e0;padding:7px 8px;font-family:'DM Mono',monospace;font-size:12px;text-align:right}.xfs-locked.left{text-align:left;font-family:Sarabun,sans-serif}.xfs-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.xfs-muted{color:var(--text-3);font-size:11px}.xfs-good{color:#a5d6a7}.xfs-bad{color:#ef9a9a}@media(max-width:1400px){.excel100-kpis{grid-template-columns:repeat(4,1fr)}}@media(max-width:1100px){.excel100-kpis{grid-template-columns:repeat(2,1fr)}.xfs-grid2{grid-template-columns:1fr}}@media(max-width:640px){.excel100-head{flex-direction:column}.excel100-kpis{grid-template-columns:1fr}.xfs-table{min-width:760px}.excel100-actions{width:100%}.excel100-actions .btn-primary-sm,.excel100-actions .btn-sm{flex:1;justify-content:center}}.excel100-kpi .value.kpi-positive{color:#a5d6a7!important;text-shadow:0 0 16px rgba(165,214,167,.16)}.excel100-kpi .value.kpi-negative{color:#ef9a9a!important;text-shadow:0 0 16px rgba(239,154,154,.14)}.excel100-kpi .value.kpi-neutral{color:#fff!important}.pc-mix-table td:first-child,.pc-mix-table th:first-child{min-width:150px!important;width:150px!important;text-align:left!important;position:sticky!important;left:0!important;background:var(--carbon-4)!important;z-index:4!important}.pc-mix-table td:nth-child(2),.pc-mix-table th:nth-child(2){min-width:130px!important;width:130px!important;position:sticky!important;left:150px!important;background:var(--carbon-4)!important;z-index:4!important;box-shadow:8px 0 14px rgba(0,0,0,.22)!important}.pc-mix-table th:first-child,.pc-mix-table th:nth-child(2){background:rgba(183,28,28,.92)!important;z-index:6!important}.pc-mix-table tfoot td:first-child,.pc-mix-table tfoot td:nth-child(2){background:var(--carbon-5)!important;z-index:5!important;font-weight:900!important}
.project-mini-kpis-result{grid-template-columns:repeat(3,1fr)!important}@media(max-width:1100px){.project-mini-kpis-result{grid-template-columns:repeat(2,1fr)!important}}@media(max-width:640px){.project-mini-kpis-result{grid-template-columns:1fr!important}}.pc-positive,.pc-positive .label,.pc-positive .value{color:#a5d6a7!important}.pc-negative,.pc-negative .label,.pc-negative .value{color:#ef9a9a!important}.pc-mix-table input.pc-positive,.pc-mix-table td.pc-positive,.pc-mix-table th.pc-positive{color:#a5d6a7!important;font-weight:900!important}.pc-mix-table input.pc-negative,.pc-mix-table td.pc-negative,.pc-mix-table th.pc-negative{color:#ef9a9a!important;font-weight:900!important}
.meaning-col,[data-col=meaning],[id*=meaning],[name*=meaning]{display:none!important}
.pc-material-cost-title{margin-top:14px!important;display:flex;align-items:center;gap:8px}.pc-cost-breakdown-table{min-width:980px;width:100%;border-collapse:collapse;font-size:12px}.pc-cost-breakdown-table td,.pc-cost-breakdown-table th{padding:8px 9px;border-bottom:1px solid rgba(255,255,255,.06);border-right:1px solid rgba(255,255,255,.05);text-align:right;white-space:nowrap}.pc-cost-breakdown-table th{background:rgba(198,40,40,.42);color:#fff;font-size:10px;text-transform:uppercase;letter-spacing:.8px}.pc-cost-breakdown-table td:first-child,.pc-cost-breakdown-table th:first-child{text-align:left}.pc-cost-breakdown-table input{min-width:86px}@media print{.pc-cost-breakdown-table{min-width:0!important;table-layout:fixed!important;font-size:8px!important}.pc-cost-breakdown-table td,.pc-cost-breakdown-table th{white-space:normal!important;padding:3px 4px!important;font-size:8px!important;color:#000!important;background:#fff!important}.pc-cost-breakdown-table th{background:#b00000!important;color:#fff!important}}
.pc-material-cost-title{margin-top:14px!important;display:flex;align-items:center;gap:8px}.pc-mix-table.v9-mix-only{min-width:1120px!important}.pc-cost-breakdown-table{min-width:1500px;width:100%;border-collapse:collapse;font-size:12px}.pc-cost-breakdown-table td,.pc-cost-breakdown-table th{padding:8px 9px;border-bottom:1px solid rgba(255,255,255,.06);border-right:1px solid rgba(255,255,255,.05);text-align:right;white-space:nowrap}.pc-cost-breakdown-table th{background:rgba(198,40,40,.42);color:#fff;font-size:10px;text-transform:uppercase;letter-spacing:.8px}.pc-cost-breakdown-table td:first-child,.pc-cost-breakdown-table th:first-child{text-align:left}.pc-cost-breakdown-table input{min-width:86px}@media print{.pc-cost-breakdown-table,.pc-mix-table.v9-mix-only{min-width:0!important;table-layout:fixed!important;font-size:7.5px!important}.pc-cost-breakdown-table td,.pc-cost-breakdown-table th,.pc-mix-table.v9-mix-only td,.pc-mix-table.v9-mix-only th{white-space:normal!important;padding:3px 3px!important;font-size:7.5px!important;color:#000!important;background:#fff!important}.pc-cost-breakdown-table th,.pc-mix-table.v9-mix-only th{background:#b00000!important;color:#fff!important}}
.pc-material-cost-title{margin-top:14px!important;display:flex;align-items:center;gap:8px}.pc-mix-table.v10-mix-only{min-width:1120px!important}.pc-cost-breakdown-table{min-width:1500px;width:100%;border-collapse:collapse;font-size:12px}.pc-cost-breakdown-table td,.pc-cost-breakdown-table th{padding:8px 9px;border-bottom:1px solid rgba(255,255,255,.06);border-right:1px solid rgba(255,255,255,.05);text-align:right;white-space:nowrap}.pc-cost-breakdown-table th{background:rgba(198,40,40,.42);color:#fff;font-size:10px;text-transform:uppercase;letter-spacing:.8px}.pc-cost-breakdown-table td:first-child,.pc-cost-breakdown-table th:first-child{text-align:left}.pc-cost-breakdown-table input{min-width:86px}.pc-locked-cell{display:block;min-width:86px;padding:8px 9px;border:1px solid rgba(255,255,255,.08);border-radius:8px;background:rgba(255,255,255,.045);color:#dcdcdc;font-family:'DM Mono',monospace;font-weight:700;text-align:right}.pc-locked-cell.code{text-align:left}.pc-nav-focus{outline:2px solid rgba(255,213,79,.65)!important;box-shadow:0 0 0 3px rgba(255,213,79,.12)!important}@media print{.pc-cost-breakdown-table,.pc-mix-table.v10-mix-only{min-width:0!important;table-layout:fixed!important;font-size:7.5px!important}.pc-cost-breakdown-table td,.pc-cost-breakdown-table th,.pc-mix-table.v10-mix-only td,.pc-mix-table.v10-mix-only th{white-space:normal!important;padding:3px 3px!important;font-size:7.5px!important;color:#000!important;background:#fff!important}.pc-cost-breakdown-table th,.pc-mix-table.v10-mix-only th{background:#b00000!important;color:#fff!important}.pc-locked-cell{border:none!important;background:0 0!important;color:#000!important;min-width:0!important;padding:0!important;font-size:7.5px!important}}
.pc-cost-breakdown-table th:first-child,.pc-cost-breakdown-table th:nth-child(2){background:rgba(183,28,28,.85)!important;color:#fff!important;font-size:10px!important;text-transform:uppercase!important;letter-spacing:.8px!important}.pc-cost-breakdown-table th:first-child{text-align:left!important}.pc-cost-breakdown-table th:nth-child(2){text-align:right!important}
#costSubProject .pc-mix-table .pc-total-row td,#costSubProject .pc-mix-table tfoot td,#costSubProject .pc-mix-table tfoot tr{background:rgba(255,255,255,.04)!important;color:#fff!important}#costSubProject .pc-mix-table tfoot td:first-child{background:rgba(255,255,255,.06)!important;color:#fff!important}@media print{#costSubProject .pc-mix-table .pc-total-row td,#costSubProject .pc-mix-table tfoot td,#costSubProject .pc-mix-table tfoot tr{background:#f2f2f2!important;color:#000!important}}
#costSubProject table.pc-mix-table tfoot,#costSubProject table.pc-mix-table tfoot td,#costSubProject table.pc-mix-table tfoot tr,#costSubProject table.pc-mix-table tr.pc-light-total-row,#costSubProject table.pc-mix-table tr.pc-light-total-row td,#costSubProject table.pc-mix-table tr.pc-total-row,#costSubProject table.pc-mix-table tr.pc-total-row td,.pc-print-report table.pc-mix-table tfoot,.pc-print-report table.pc-mix-table tfoot td,.pc-print-report table.pc-mix-table tfoot tr,.pc-print-report table.pc-mix-table tr.pc-total-row,.pc-print-report table.pc-mix-table tr.pc-total-row td,.print-report table.pc-mix-table tfoot,.print-report table.pc-mix-table tfoot td,.print-report table.pc-mix-table tfoot tr,.print-report table.pc-mix-table tr.pc-total-row,.print-report table.pc-mix-table tr.pc-total-row td{background:rgba(183,28,28,.12)!important;background-color:rgba(183,28,28,.12)!important;color:#fff!important;border-color:rgba(255,255,255,.08)!important;font-weight:900!important}#costSubProject table.pc-mix-table tfoot td:first-child,#costSubProject table.pc-mix-table tr.pc-total-row td:first-child,.pc-print-report table.pc-mix-table tfoot td:first-child,.pc-print-report table.pc-mix-table tr.pc-total-row td:first-child,.print-report table.pc-mix-table tfoot td:first-child,.print-report table.pc-mix-table tr.pc-total-row td:first-child{background:rgba(183,28,28,.18)!important;background-color:rgba(183,28,28,.18)!important;color:#fff!important}#costSubProject table.pc-mix-table tfoot td *,#costSubProject table.pc-mix-table tr.pc-total-row td *,.pc-print-report table.pc-mix-table tfoot td *,.pc-print-report table.pc-mix-table tr.pc-total-row td *,.print-report table.pc-mix-table tfoot td *,.print-report table.pc-mix-table tr.pc-total-row td *{background:0 0!important;background-color:transparent!important;color:#fff!important;font-weight:900!important}@media print{#costSubProject table.pc-mix-table tfoot,#costSubProject table.pc-mix-table tfoot td,#costSubProject table.pc-mix-table tfoot tr,#costSubProject table.pc-mix-table tr.pc-total-row,#costSubProject table.pc-mix-table tr.pc-total-row td,.pc-print-report table.pc-mix-table tfoot,.pc-print-report table.pc-mix-table tfoot td,.pc-print-report table.pc-mix-table tfoot tr,.pc-print-report table.pc-mix-table tr.pc-total-row,.pc-print-report table.pc-mix-table tr.pc-total-row td,.print-report table.pc-mix-table tfoot,.print-report table.pc-mix-table tfoot td,.print-report table.pc-mix-table tfoot tr,.print-report table.pc-mix-table tr.pc-total-row,.print-report table.pc-mix-table tr.pc-total-row td{background:#f2f2f2!important;background-color:#f2f2f2!important;color:#000!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}
tr.pc-light-total-row td:first-child{font-weight:800!important}
table th{text-align:center!important;vertical-align:middle!important}table td{vertical-align:middle!important}table td input,table td span,table td:not(:first-child){text-align:center!important}table td:first-child input{text-align:center!important}@media print{table td,table td input,table td span,table th{text-align:center!important;vertical-align:middle!important}}
#costSubFinancial .cost-field,#costSubFinancial .cost-field input[type=text],#costSubFinancial .cost-field label,#costSubFinancial .cost-field select,#costSubFinancial .cost-note,#costSubFinancial .fin-label,#costSubFinancial .fin-name,#costSubFinancial .fin-note,#costSubFinancial .fin-section-title,#costSubFinancial .project-cost-title,#costSubFinancial td:first-child{text-align:left!important}#costSubFinancial table th{text-align:center!important;vertical-align:middle!important}#costSubFinancial .fin-input[type=number],#costSubFinancial input[type=number],#costSubFinancial table td:not(:first-child){text-align:center!important}#costSubFinancial input:not([type=number]),#costSubFinancial textarea{text-align:left!important}@media print{#costSubFinancial .cost-note,#costSubFinancial .fin-label,#costSubFinancial .fin-name,#costSubFinancial .fin-note,#costSubFinancial .fin-section-title,#costSubFinancial .project-cost-title,#costSubFinancial td:first-child{text-align:left!important}#costSubFinancial input[type=number],#costSubFinancial table td:not(:first-child),#costSubFinancial table th{text-align:center!important;vertical-align:middle!important}}
@media print{#costSubFinancial .cost-field,#costSubFinancial .cost-field label,#costSubFinancial .cost-note,#costSubFinancial .fin-label,#costSubFinancial .fin-name,#costSubFinancial .fin-note,#costSubFinancial .fin-row-grid.six>div:first-child,#costSubFinancial .fin-row-grid>div:first-child,#costSubFinancial .fin-section-title,#costSubFinancial .label,#costSubFinancial .project-cost-title,#costSubFinancial .sub,#costSubFinancial label,#costSubFinancial table td:first-child,body.print-mode #costSubFinancial .cost-field,body.print-mode #costSubFinancial .cost-field label,body.print-mode #costSubFinancial .cost-note,body.print-mode #costSubFinancial .fin-label,body.print-mode #costSubFinancial .fin-name,body.print-mode #costSubFinancial .fin-note,body.print-mode #costSubFinancial .fin-row-grid.six>div:first-child,body.print-mode #costSubFinancial .fin-row-grid>div:first-child,body.print-mode #costSubFinancial .fin-section-title,body.print-mode #costSubFinancial .label,body.print-mode #costSubFinancial .project-cost-title,body.print-mode #costSubFinancial .sub,body.print-mode #costSubFinancial label,body.print-mode #costSubFinancial table td:first-child{text-align:left!important}.pc-print-report .cost-field,.pc-print-report .cost-field label,.pc-print-report .cost-note,.pc-print-report .fin-label,.pc-print-report .fin-name,.pc-print-report .fin-note,.pc-print-report .fin-row-grid.six>div:first-child,.pc-print-report .fin-row-grid>div:first-child,.pc-print-report .fin-section-title,.pc-print-report .label,.pc-print-report .project-cost-title,.pc-print-report .sub,.pc-print-report label,.pc-print-report table td:first-child,.print-report .cost-field,.print-report .cost-field label,.print-report .cost-note,.print-report .fin-label,.print-report .fin-name,.print-report .fin-note,.print-report .fin-row-grid.six>div:first-child,.print-report .fin-row-grid>div:first-child,.print-report .fin-section-title,.print-report .label,.print-report .project-cost-title,.print-report .sub,.print-report label,.print-report table td:first-child{text-align:left!important}#costSubFinancial table th,.pc-print-report table th,.print-report table th,body.print-mode #costSubFinancial table th{text-align:center!important}#costSubFinancial input[type=number],#costSubFinancial table td:not(:first-child),.pc-print-report input[type=number],.pc-print-report table td:not(:first-child),.print-report input[type=number],.print-report table td:not(:first-child),body.print-mode #costSubFinancial input[type=number],body.print-mode #costSubFinancial table td:not(:first-child){text-align:center!important}}
#costSubFinancial .fin-table td:first-child,#costSubFinancial .fin-table td:first-child *,#costSubFinancial .fin-table td:last-child,#costSubFinancial .fin-table td:last-child *,#costSubFinancial [data-col=meaning],#costSubFinancial [data-col=meaning] *,#costSubFinancial table td:first-child,#costSubFinancial table td:first-child *,#costSubFinancial table td:last-child,#costSubFinancial table td:last-child *,#costSubFinancial td.meaning,#costSubFinancial td.meaning *{text-align:left!important}#costSubFinancial .fin-table th,#costSubFinancial table th{text-align:center!important}#costSubFinancial input[type=number],#costSubFinancial table td:not(:first-child):not(:last-child),#costSubFinancial table td:not(:first-child):not(:last-child) *{text-align:center!important}@media print{#costSubFinancial .fin-table td:first-child,#costSubFinancial .fin-table td:first-child *,#costSubFinancial .fin-table td:last-child,#costSubFinancial .fin-table td:last-child *,#costSubFinancial table td:first-child,#costSubFinancial table td:first-child *,#costSubFinancial table td:last-child,#costSubFinancial table td:last-child *,.pc-print-report table td:first-child,.pc-print-report table td:first-child *,.pc-print-report table td:last-child,.pc-print-report table td:last-child *,.print-report table td:first-child,.print-report table td:first-child *,.print-report table td:last-child,.print-report table td:last-child *,body.print-mode #costSubFinancial table td:first-child,body.print-mode #costSubFinancial table td:first-child *,body.print-mode #costSubFinancial table td:last-child,body.print-mode #costSubFinancial table td:last-child *{text-align:left!important}#costSubFinancial table th,.pc-print-report table th,.print-report table th,body.print-mode #costSubFinancial table th{text-align:center!important}#costSubFinancial table td:not(:first-child):not(:last-child),.pc-print-report table td:not(:first-child):not(:last-child),.print-report table td:not(:first-child):not(:last-child),body.print-mode #costSubFinancial table td:not(:first-child):not(:last-child){text-align:center!important}}
#costSubFinancial .fin-text-left,#costSubFinancial .fin-text-left *,.pc-print-report .fin-text-left,.pc-print-report .fin-text-left *,.print-report .fin-text-left,.print-report .fin-text-left *,body.print-mode #costSubFinancial .fin-text-left,body.print-mode #costSubFinancial .fin-text-left *{text-align:left!important}#costSubFinancial table td:first-child,#costSubFinancial table td:first-child *,.pc-print-report table td:first-child,.pc-print-report table td:first-child *,.print-report table td:first-child,.print-report table td:first-child *,body.print-mode #costSubFinancial table td:first-child,body.print-mode #costSubFinancial table td:first-child *{text-align:left!important}#costSubFinancial table th,.pc-print-report table th,.print-report table th,body.print-mode #costSubFinancial table th{text-align:center!important;vertical-align:middle!important}#costSubFinancial table td:not(.fin-text-left):not(:first-child),#costSubFinancial table td:not(.fin-text-left):not(:first-child) *,.pc-print-report table td:not(.fin-text-left):not(:first-child),.pc-print-report table td:not(.fin-text-left):not(:first-child) *,.print-report table td:not(.fin-text-left):not(:first-child),.print-report table td:not(.fin-text-left):not(:first-child) *,body.print-mode #costSubFinancial table td:not(.fin-text-left):not(:first-child),body.print-mode #costSubFinancial table td:not(.fin-text-left):not(:first-child) *{text-align:center!important}@media print{.fin-text-left,.fin-text-left *,table td.fin-text-left,table td.fin-text-left *{text-align:left!important}}
.xfs-input{pointer-events:auto!important;user-select:text!important}.xfs-input:focus{outline:2px solid rgba(229,57,53,.45)!important;background:#2b0d0d!important}
.xfs-table{font-size:11.5px!important;min-width:980px!important}.xfs-table td{padding:4px 5px!important}.xfs-input,.xfs-select{max-width:118px!important;min-width:74px!important;width:118px!important;padding:5px 6px!important;font-size:11px!important}.xfs-input.code{max-width:105px!important;width:105px!important;font-family:'DM Mono',monospace}.xfs-input.wide{max-width:180px!important;width:180px!important}.xfs-input.small{max-width:82px!important;width:82px!important}.xfs-locked{min-height:27px!important;padding:5px 6px!important;font-size:11px!important}.xfs-locked.left{text-align:left!important}.xfs-chip{display:inline-flex;align-items:center;border:1px solid rgba(229,57,53,.28);background:rgba(183,28,28,.12);border-radius:999px;padding:2px 8px;color:#ffcdd2;font-size:10px}.xfs-table .desc{min-width:180px;color:var(--text-3);font-size:10.5px;line-height:1.45}.xfs-mini-title{font-size:12px;font-weight:800;color:#fff;margin:8px 0 6px}.xfs-grid-stack{display:grid;grid-template-columns:1fr;gap:14px}.xfs-formula-cell{background:#1b1b1b!important;color:#ddd!important}.xfs-user-cell input{background:#2a1111!important}.xfs-section-title b{color:#ffd54f}.xfs-table-wrap{max-height:none}.xfs-product-tools{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:10px 12px;border-bottom:1px solid var(--carbon-6);background:rgba(255,255,255,.025)}@media(max-width:640px){.xfs-input,.xfs-select{width:105px!important;max-width:105px!important}.xfs-table{min-width:1100px!important}}
#pcSavePanel{margin:16px 0 18px;padding:14px 16px;border:1px solid rgba(198,40,40,.28);border-radius:12px;background:rgba(198,40,40,.07)}#pcSavePanel .pc-save-grid{display:grid;grid-template-columns:minmax(220px,1fr) minmax(260px,1.4fr) auto auto;gap:10px;align-items:end}#pcSavePanel .pc-save-label{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);font-weight:800;margin-bottom:5px}#pcSavePanel .pc-save-note{font-size:11px;color:var(--text-3);margin-top:8px}@media(max-width:900px){#pcSavePanel .pc-save-grid{grid-template-columns:1fr}}
#fsSavePanel{display:none!important}#fsCompactSavePanel,#pcSavePanel{margin:10px 0 12px!important;padding:10px 12px!important;border:1px solid rgba(198,40,40,.3)!important;border-radius:10px!important;background:rgba(198,40,40,.055)!important}#fsCompactSavePanel .save-grid,#pcSavePanel .pc-save-grid{display:grid!important;grid-template-columns:220px minmax(280px,1fr) auto auto auto!important;gap:8px!important;align-items:end!important}#fsCompactSavePanel .save-label,#pcSavePanel .pc-save-label{font-size:9px!important;letter-spacing:.08em!important;text-transform:uppercase!important;color:var(--text-3)!important;font-weight:800!important;margin-bottom:4px!important;line-height:1.1!important}#fsCompactSavePanel input,#fsCompactSavePanel select,#pcSavePanel input,#pcSavePanel select{height:38px!important;min-height:38px!important;padding:7px 10px!important;font-size:12px!important;border-radius:8px!important}#fsCompactSavePanel button,#pcSavePanel button{height:38px!important;min-height:38px!important;padding:0 14px!important;white-space:nowrap!important;justify-content:center!important;font-size:12px!important}#fsCompactSavePanel .save-note,#pcSavePanel .pc-save-note{font-size:10.5px!important;color:var(--text-3)!important;margin-top:6px!important;line-height:1.3!important}@media(max-width:1100px){#fsCompactSavePanel .save-grid,#pcSavePanel .pc-save-grid{grid-template-columns:1fr 1fr auto auto auto!important}}@media(max-width:760px){#fsCompactSavePanel .save-grid,#pcSavePanel .pc-save-grid{grid-template-columns:1fr!important}}
#costSubFinancial .cost-status-warn,#costSubFinancial .formula-badge,#costSubFinancial .xfs-section-title b,#costSubFinancial [style*="#ffd54f"],#costSubFinancial [style*="255,213,79"]{color:#fff!important}
.clear-sheet-btn{border:1px solid rgba(239,83,80,.55)!important;color:#ffcdd2!important;background:rgba(183,28,28,.1)!important}.clear-sheet-btn:hover{background:rgba(183,28,28,.22)!important;color:#fff!important;border-color:#ef5350!important}.clear-sheet-note{display:inline-flex;align-items:center;padding:4px 9px;border:1px solid rgba(255,255,255,.1);border-radius:999px;color:var(--text-3);font-size:11px;background:rgba(255,255,255,.03)}
#pcSavePanel{overflow:visible!important;max-width:100%!important}#pcSavePanel .pc-save-grid{display:grid!important;grid-template-columns:minmax(160px,1fr) minmax(230px,1.5fr) 120px 132px 88px!important;gap:10px!important;align-items:end!important;width:100%!important;max-width:100%!important}#pcSavePanel .pc-save-grid input,#pcSavePanel .pc-save-grid select,#pcSavePanel .pc-save-grid>div{min-width:0!important;max-width:100%!important}#pcSavePanel .pc-save-grid button{width:100%!important;justify-content:center!important;white-space:nowrap!important;padding-left:10px!important;padding-right:10px!important}#pcSavePanel .pc-save-grid button[onclick*=pcDeleteSavedProject]{display:inline-flex!important;visibility:visible!important}@media(max-width:1180px){#pcSavePanel .pc-save-grid{grid-template-columns:1fr 1.2fr 112px 124px 84px!important;gap:8px!important}#pcSavePanel .pc-save-grid button{font-size:11px!important;padding-left:8px!important;padding-right:8px!important}}@media(max-width:900px){#pcSavePanel .pc-save-grid{grid-template-columns:1fr 1fr!important}#pcSavePanel .pc-save-grid button{width:100%!important}}@media(max-width:560px){#pcSavePanel .pc-save-grid{grid-template-columns:1fr!important}}
#pcSavePanel{overflow:hidden!important;max-width:100%!important;width:100%!important;box-sizing:border-box!important}#pcSavePanel .pc-save-grid{display:flex!important;flex-wrap:wrap!important;gap:10px!important;align-items:flex-end!important;width:100%!important;max-width:100%!important;box-sizing:border-box!important;grid-template-columns:none!important}#pcSavePanel .pc-save-grid>div:first-child{flex:1 1 220px!important;min-width:180px!important;max-width:100%!important}#pcSavePanel .pc-save-grid>div:nth-child(2){flex:2 1 340px!important;min-width:240px!important;max-width:100%!important}#pcSavePanel .pc-save-grid input,#pcSavePanel .pc-save-grid select{width:100%!important;min-width:0!important;max-width:100%!important;box-sizing:border-box!important}#pcSavePanel .pc-save-grid button{flex:0 1 132px!important;min-width:108px!important;max-width:160px!important;width:auto!important;justify-content:center!important;white-space:nowrap!important;box-sizing:border-box!important}#pcSavePanel .pc-save-grid button[onclick*=pcDeleteSavedProject]{display:inline-flex!important;visibility:visible!important;flex-basis:88px!important;min-width:82px!important;max-width:100px!important}#pcSavePanel .pc-save-note{max-width:100%!important;overflow-wrap:anywhere!important}@media(max-width:900px){#pcSavePanel .pc-save-grid>div:first-child,#pcSavePanel .pc-save-grid>div:nth-child(2){flex:1 1 100%!important;min-width:0!important}#pcSavePanel .pc-save-grid button{flex:1 1 140px!important;max-width:none!important}}@media(max-width:520px){#pcSavePanel .pc-save-grid{gap:8px!important}#pcSavePanel .pc-save-grid button{flex:1 1 100%!important;width:100%!important}}
#fsCompactSavePanel .save-grid .clear-sheet-btn,#pcSavePanel .pc-save-grid .clear-sheet-btn{display:inline-flex!important;visibility:visible!important;justify-content:center!important;white-space:nowrap!important;border-color:rgba(239,68,68,.45)!important;color:#ffcdd2!important;background:rgba(183,28,28,.08)!important}#fsCompactSavePanel .save-grid .clear-sheet-note,#pcSavePanel .pc-save-grid .clear-sheet-note{display:none!important}#fsCompactSavePanel .save-grid button,#pcSavePanel .pc-save-grid button{min-height:48px}@media(max-width:900px){#fsCompactSavePanel .save-grid .clear-sheet-btn,#pcSavePanel .pc-save-grid .clear-sheet-btn{flex:1 1 150px!important;max-width:none!important}}
#fsCompactSavePanel .save-grid,#pcSavePanel .pc-save-grid{display:grid!important;grid-template-columns:minmax(220px,1fr) minmax(280px,2fr) repeat(4,minmax(130px,auto))!important;gap:10px!important;align-items:end!important;max-width:100%!important;overflow:hidden!important}#fsCompactSavePanel .save-grid button,#pcSavePanel .pc-save-grid button{width:100%;min-height:46px;white-space:nowrap}@media(max-width:1200px){#fsCompactSavePanel .save-grid,#pcSavePanel .pc-save-grid{grid-template-columns:1fr 1fr!important}}@media(max-width:700px){#fsCompactSavePanel .save-grid,#pcSavePanel .pc-save-grid{grid-template-columns:1fr!important}}

#costSubProject #pcSavePanel .pc-save-grid{
  display:grid!important;
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
  gap:10px!important;
  align-items:end!important;
  overflow:visible!important;
}
#costSubProject #pcSavePanel .pc-save-grid>div:nth-child(1){grid-column:1 / span 2!important;grid-row:1!important;min-width:0!important;}
#costSubProject #pcSavePanel .pc-save-grid>div:nth-child(2){grid-column:3 / -1!important;grid-row:1!important;min-width:0!important;}
#costSubProject #pcSavePanel .pc-save-grid>button{grid-row:2!important;width:100%!important;min-height:38px!important;justify-content:center!important;white-space:nowrap!important;margin-top:2px!important;}
#costSubProject #pcSavePanel .pc-save-grid>button:nth-of-type(1){grid-column:1!important;}
#costSubProject #pcSavePanel .pc-save-grid>button:nth-of-type(2){grid-column:3!important;}
#costSubProject #pcSavePanel .pc-save-grid>button:nth-of-type(3){grid-column:2!important;}
#costSubProject #pcSavePanel .pc-save-grid>button:nth-of-type(4){grid-column:4!important;}
#costSubProject .pc-table-scroll-controls{display:flex;gap:8px;justify-content:flex-end;align-items:center;margin:6px 0 8px;}
#costSubProject .pc-scroll-btn{width:34px;height:30px;border-radius:8px;border:1px solid var(--carbon-7);background:var(--carbon-4);color:var(--text-2);font-size:18px;font-weight:900;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;}
#costSubProject .pc-scroll-btn:hover{border-color:var(--crimson);color:#fff;background:rgba(183,28,28,.16);}
@media(max-width:900px){
  #costSubProject #pcSavePanel .pc-save-grid{grid-template-columns:1fr 1fr!important;}
  #costSubProject #pcSavePanel .pc-save-grid>div:nth-child(1),
  #costSubProject #pcSavePanel .pc-save-grid>div:nth-child(2){grid-column:1 / -1!important;}
  #costSubProject #pcSavePanel .pc-save-grid>button{grid-row:auto!important;grid-column:auto!important;}
}
:root{
  --pc-at-bg:#c62828;
  --pc-at-left:#b71c1c;
  --pc-at-border:#8e0000;
  --pc-at-text:#ffffff;
}
#costSubProject tr.pc-total-row>td,
#costSubProject tr.pc-light-total-row>td,
#costSubProject .pc-mix-table tfoot tr>td,
#costSubProject .pc-cost-breakdown-table tfoot tr>td{
  background:var(--pc-at-bg)!important;
  background-color:var(--pc-at-bg)!important;
  color:var(--pc-at-text)!important;
  border-color:var(--pc-at-border)!important;
  font-weight:900!important;
  text-shadow:none!important;
  box-shadow:none!important;
  -webkit-print-color-adjust:exact!important;
  print-color-adjust:exact!important;
}
#costSubProject tr.pc-total-row>td:first-child,
#costSubProject tr.pc-light-total-row>td:first-child,
#costSubProject .pc-mix-table tfoot tr>td:first-child,
#costSubProject .pc-cost-breakdown-table tfoot tr>td:first-child{
  background:var(--pc-at-left)!important;
  background-color:var(--pc-at-left)!important;
  color:var(--pc-at-text)!important;
  border-color:var(--pc-at-border)!important;
  text-align:left!important;
}
#costSubProject tr.pc-total-row input,
#costSubProject tr.pc-light-total-row input,
#costSubProject .pc-mix-table tfoot input,
#costSubProject .pc-cost-breakdown-table tfoot input{
  background:transparent!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:none!important;
}

.xfs-table th:last-child,.xfs-table td.desc,.xfs-table td:last-child{ text-align:left !important; justify-content:flex-start !important; white-space:normal !important; }
.xfs-table td.desc{ color:#333 !important; font-weight:700 !important; line-height:1.35 !important; }
@media print{ .xfs-table td.desc,.xfs-table td:last-child{ text-align:left !important; } }

.security-note{display:none!important;}
th.remark,th.remark-col,td.remark,td.desc,td.pc-remark-cell,.remark,.desc,.pc-remark-cell{
  text-align:left!important; justify-content:flex-start!important; align-items:flex-start!important; color:#e8e8e8!important; opacity:1!important;
}
th.remark *,th.remark-col *,td.remark *,td.desc *,td.pc-remark-cell *,.remark *,.desc *,.pc-remark-cell *{
  text-align:left!important; color:inherit!important; opacity:1!important;
}
@media print{
  th.remark,th.remark-col,td.remark,td.desc,td.pc-remark-cell,.remark,.desc,.pc-remark-cell{
    text-align:left!important; color:#111!important; opacity:1!important; white-space:normal!important;
  }
}

\n    @page{size:A4;margin:0}\n    body{margin:0!important;background:#fff!important}\n    #quotePrintArea{font-family:'Sarabun',Tahoma,sans-serif;color:#000;background:#fff;width:210mm;min-height:297mm;margin:0 auto;padding:6mm 5mm;font-size:10px;box-sizing:border-box}\n    .q-sheet{min-height:285mm;width:100%;box-sizing:border-box;overflow:hidden}\n    .q-top{height:17mm;border-bottom:1px solid #777;position:relative}.q-logo{position:absolute;left:8mm;top:2mm;width:48mm;height:12mm;object-fit:contain;object-position:left center}.q-logo-text{position:absolute;left:18mm;top:2mm;color:red;font-size:28px;font-weight:900}.q-logo-text small{display:block;color:#777;font-size:7px;margin-left:18mm;margin-top:-7px}.q-no{position:absolute;right:12mm;top:7mm;font-weight:700}.q-title{text-align:center;font-size:18px;font-weight:900;margin:12mm 0 6mm}\n    .q-info{display:grid;grid-template-columns:minmax(0,1fr) 64mm;gap:5mm;padding:0 2mm;font-weight:700;box-sizing:border-box}.q-line{display:grid;grid-template-columns:17mm minmax(0,1fr);min-height:5.8mm;align-items:end}.q-line.three{grid-template-columns:17mm 40mm minmax(0,1fr)}.q-date-line{grid-template-columns:24mm minmax(0,1fr)}.q-pay{display:grid;grid-template-columns:1fr 20mm 20mm 16mm 8mm;gap:2mm;align-items:center;white-space:nowrap;min-height:5.8mm}.q-under{border-bottom:2px solid #000;padding-left:2mm;min-height:4.5mm;min-width:0;overflow:hidden}.q-box{display:inline-block;width:4mm;height:4mm;border:2px solid #000;margin:0 1.5mm;vertical-align:-1mm}.q-checked:after{content:'✓';font-size:13px;line-height:3mm}\n    .q-contact{display:grid;grid-template-columns:17mm 36mm 24mm 38mm 18mm 1fr;border-top:2px solid #000;padding:1mm;align-items:end;font-weight:700}\n    .q-round{display:grid;grid-template-columns:17mm 1fr 31mm;border-top:2px solid #000;min-height:26mm}.q-round-list{padding:2mm 0;display:grid;grid-template-columns:repeat(4,1fr);row-gap:2mm}.q-pl{background:#ff0;display:flex;flex-direction:column;justify-content:center;align-items:center;font-weight:900;border-left:1px solid #000}.q-pl b{font-size:20px;margin-bottom:6mm}\n    .q-service,.q-values{display:grid;grid-template-columns:43% 22% 35%;text-align:center;font-weight:800}.q-service{border-top:2px solid #000;border-bottom:2px solid #000}.q-service div,.q-values div{border-right:2px solid #000;padding:1.2mm}.q-service div:last-child,.q-values div:last-child{border-right:0}.q-values{border-bottom:2px solid #000}.q-values div{min-height:14mm}.q-values .disc{background:#ff0;font-size:20px;display:flex;align-items:center;justify-content:center}\n    .q-table{width:100%;border-collapse:collapse;table-layout:fixed;font-weight:700}.q-table th,.q-table td{border:1.4px solid #000;padding:1mm;text-align:center;height:5mm;overflow:hidden}.q-table .left{text-align:left}.q-table .right{text-align:right}\n    .q-notes{display:grid;grid-template-columns:16mm 1fr;font-weight:700;padding-top:1mm}.q-notes p{margin:0 0 1.2mm}.q-staff{border-top:2px solid #000;padding:2mm 16mm;font-weight:700}.q-sign-title{text-align:right;padding:8mm 27mm 12mm 0;font-weight:700}.q-sign{display:grid;grid-template-columns:1fr 1fr;gap:24mm;padding:0 16mm;font-weight:700}.q-dot{display:inline-block;border-bottom:1px dotted #000;width:56mm;height:4mm}\n

#costSubFinancial .fin-input,#costSubFinancial .formula-badge,#costSubFinancial .xfs-input,#costSubFinancial .xfs-locked,#costSubFinancial .xfs-select,#costSubFinancial .xfs-table,#costSubFinancial .xfs-table td,#costSubFinancial .xfs-table th,#costSubProject .cost-table,#costSubProject .cost-table td,#costSubProject .cost-table th,#costSubProject .fin-input,#costSubProject .pc-mix-table,#costSubProject .pc-mix-table td,#costSubProject .pc-mix-table th{font-family:Tahoma,Arial,Sarabun,sans-serif!important;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"zero" 0}#costSubFinancial .fin-input,#costSubFinancial .formula-badge,#costSubFinancial .xfs-input,#costSubFinancial .xfs-locked,#costSubFinancial .xfs-select,#costSubFinancial .xfs-table td,#costSubProject .cost-table td,#costSubProject .fin-input,#costSubProject .pc-mix-table td{font-size:12px!important;line-height:1.35!important}#costSubFinancial .xfs-input,#costSubFinancial .xfs-locked,#costSubFinancial .xfs-select,#costSubProject .fin-input{min-height:30px!important;padding-top:6px!important;padding-bottom:6px!important}#costSubFinancial .xfs-locked{display:inline-flex!important;align-items:center!important;justify-content:flex-end!important}#costSubFinancial .xfs-locked.left{justify-content:flex-start!important}

.xfs-table th:last-child,
.xfs-table td:last-child,
.fin-table th:last-child,
.fin-table td:last-child,
.pdf-report table th:last-child,
.pdf-report table td:last-child,
#pdfPreviewArea table th:last-child,
#pdfPreviewArea table td:last-child,
#xfsPrintArea table th:last-child,
#xfsPrintArea table td:last-child,
td.remark, th.remark-col, td.desc, .desc {
  text-align: left !important;
  justify-content: flex-start !important;
}
.xfs-table td.desc,
.fin-table td.desc,
.pdf-report td.desc,
#pdfPreviewArea td.desc,
#xfsPrintArea td.desc {
  text-align: left !important;
  white-space: normal !important;
  line-height: 1.35 !important;
}
.admin-only-hidden{display:none!important;}

#costSubProject .pc-remark-panel{background:rgba(255,255,255,.035);border:1px solid rgba(183,28,28,.22);border-radius:12px;margin:12px 0 16px;padding:14px;overflow-x:auto;}
#costSubProject .pc-remark-title{font-weight:900;color:#fff;margin-bottom:10px;font-size:13px;letter-spacing:.3px;}
#costSubProject .pc-remark-table{width:100%;border-collapse:collapse;font-size:12px;min-width:720px;}
#costSubProject .pc-remark-table th{background:rgba(183,28,28,.78)!important;color:#fff!important;padding:8px 10px;border:1px solid rgba(255,255,255,.12);font-weight:900;text-align:left!important;}
#costSubProject .pc-remark-table td{background:rgba(255,255,255,.03);color:#e8e8e8;padding:8px 10px;border:1px solid rgba(255,255,255,.08);font-weight:700;text-align:left!important;vertical-align:top;line-height:1.45;}
#costSubProject .pc-remark-table td:first-child{color:#ffd54f;font-family:'DM Mono',Sarabun,sans-serif;white-space:nowrap;width:190px;}
#costSubProject .pc-remark-hint{font-size:10px;color:#b8b8b8;line-height:1.35;margin-top:5px;text-align:left!important;font-weight:600;}
#costSubProject th.pc-remark-col,#costSubProject td.pc-remark-cell{ text-align:left!important; }
#costSubProject td.pc-remark-cell{font-size:12px;line-height:1.45;color:#e8e8e8;white-space:normal!important;min-width:260px;}
#costSubProject .pc-remark-cell *{text-align:left!important;}
#pdfOverlayV58 .v58-report .pc-remark-panel{background:#fff!important;border:0!important;border-radius:0!important;margin:8px 0 10px!important;padding:0!important;overflow:visible!important;}
#pdfOverlayV58 .v58-report .pc-remark-title{background:#eee!important;border-left:4px solid #b00000!important;color:#000!important;padding:5px 8px!important;margin:8px 0 0!important;font-size:10px!important;font-weight:900!important;}
#pdfOverlayV58 .v58-report .pc-remark-table{width:100%!important;border-collapse:collapse!important;min-width:0!important;font-size:8.5px!important;margin:0 0 8px!important;}
#pdfOverlayV58 .v58-report .pc-remark-table th{background:#c00000!important;color:#fff!important;border:1px solid #777!important;text-align:left!important;padding:4px 5px!important;font-size:8px!important;}
#pdfOverlayV58 .v58-report .pc-remark-table td{background:#fff!important;color:#000!important;border:1px solid #777!important;text-align:left!important;padding:4px 5px!important;font-size:8.5px!important;font-weight:700!important;line-height:1.25!important;}
#pdfOverlayV58 .v58-report .pc-remark-table td:first-child{color:#000!important;font-family:Arial,Sarabun,sans-serif!important;width:140px!important;}
#pdfOverlayV58 .v58-report .pc-remark-hint{display:block!important;color:#000!important;font-size:8px!important;margin-top:2px!important;text-align:left!important;}
#pdfOverlayV58 .v58-report th.pc-remark-col,#pdfOverlayV58 .v58-report td.pc-remark-cell{ text-align:left!important; }
@media print{#costSubProject .pc-remark-panel{break-inside:avoid!important;page-break-inside:avoid!important;}}

#costSubProject .xfs-section .xfs-table th,
#costSubProject .xfs-section .xfs-table td{font-size:12px;line-height:1.35;}
#costSubProject .xfs-section .xfs-table td.pc-summary-remark,
#costSubProject .xfs-section .xfs-table th.pc-summary-remark{text-align:left!important;}
#costSubProject .xfs-section .xfs-table td.pc-summary-value{text-align:right!important;font-variant-numeric:tabular-nums;}
#costSubProject .xfs-section .xfs-table td.pc-summary-status{text-align:center!important;font-weight:900;}

td.desc, th.desc,
td.remark, th.remark,
td.remark-cell, th.remark-cell,
td.pc-remark-cell, th.pc-remark-col,
.remark, .remark-cell, .pc-remark-cell,
.pc-remark-table td:nth-child(2), .pc-remark-table th:nth-child(2),
[class*="remark"], [class*="Remark"] {
  text-align: left !important;
  justify-content: flex-start !important;
  align-items: flex-start !important;
}


#app td.desc,
#app td.remark,
#app td.remark-cell,
#app td.pc-remark-cell,
#app .remark,
#app .remark-cell,
#app .pc-remark-cell,
#app .pc-remark-table td:nth-child(2),
#app [class*="remark"],
#app [class*="Remark"] {
  color: #f2f2f2 !important;
  opacity: 1 !important;
  font-weight: 700 !important;
  line-height: 1.45 !important;
}


td.desc *,
td.remark *,
td.remark-cell *,
td.pc-remark-cell *,
.remark *,
.remark-cell *,
.pc-remark-cell *,
.pc-remark-table td:nth-child(2) * {
  text-align: left !important;
  color: inherit !important;
  opacity: 1 !important;
}


#pdfOverlayV58 .v58-report td.desc,
#pdfOverlayV58 .v58-report td.remark,
#pdfOverlayV58 .v58-report td.remark-cell,
#pdfOverlayV58 .v58-report td.pc-remark-cell,
#pdfOverlayV58 .v58-report .remark,
#pdfOverlayV58 .v58-report .remark-cell,
#pdfOverlayV58 .v58-report .pc-remark-cell,
#pdfOverlayV58 .v58-report .pc-remark-table td:nth-child(2),
#pdfOverlayV58 .v58-report [class*="remark"],
#pdfOverlayV58 .v58-report [class*="Remark"] {
  text-align: left !important;
  color: #000 !important;
  opacity: 1 !important;
  font-weight: 700 !important;
}

@media print {
  td.desc, td.remark, td.remark-cell, td.pc-remark-cell,
  .remark, .remark-cell, .pc-remark-cell,
  .pc-remark-table td:nth-child(2),
  [class*="remark"], [class*="Remark"] {
    text-align: left !important;
    color: #000 !important;
    opacity: 1 !important;
    font-weight: 700 !important;
  }
}

#costSubProject #pcSavePanel .pc-saved-control-row{display:flex!important;align-items:center!important;gap:8px!important;width:100%!important;min-width:0!important;}
  #costSubProject #pcSavePanel .pc-saved-control-row #pcSavedList{flex:1 1 auto!important;min-width:0!important;width:auto!important;}
  #pcDeleteAfterProjectBtn{flex:0 0 auto!important;width:auto!important;min-width:78px!important;height:38px!important;padding:0 10px!important;white-space:nowrap!important;}
  .v80-hidden-delete{display:none!important;}

#pcSummaryBody td:nth-child(3),
#pcSummaryBody th:nth-child(3){display:none!important;}
#pcSummaryBody td:nth-child(1){text-align:left!important;}
#pcSummaryBody td:nth-child(2){text-align:right!important;white-space:nowrap!important;}

.kam-access-pill{display:inline-flex;align-items:center;gap:5px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.045);border-radius:999px;padding:3px 8px;font-size:11px;color:#d0d0d0;margin:2px 4px 2px 0;white-space:nowrap}
  .kam-access-pill.all{border-color:rgba(76,175,80,.35);background:rgba(76,175,80,.08);color:#a5d6a7}
  .kam-access-pill.kam{border-color:rgba(255,213,79,.3);background:rgba(255,213,79,.08);color:#ffe082}
  .kam-access-help{font-size:11px;color:var(--text-3);line-height:1.65;margin-top:6px}
  .kam-plant-box{max-height:260px;overflow:auto;border:1px solid var(--carbon-6);background:var(--carbon-5);border-radius:9px;padding:10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:7px}
  .kam-plant-item{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:var(--text-2);line-height:1.35;padding:6px 7px;border:1px solid rgba(255,255,255,.055);border-radius:7px;background:rgba(255,255,255,.025)}
  .kam-plant-item input{margin-top:2px;accent-color:#c62828}
  #kamAccessModal .modal-box{width:820px;max-width:96vw}
  .kam-access-top-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
  @media(max-width:700px){.kam-access-top-grid{grid-template-columns:1fr}.kam-plant-box{grid-template-columns:1fr}}

.topbar{z-index:2147483000!important;pointer-events:auto!important;position:sticky!important;top:0!important;}
  .topbar *,.nav-tabs,.nav-tab,.topbar-right,.plant-selector,.user-pill{pointer-events:auto!important;}
  .nav-tab{cursor:pointer!important;user-select:none!important;}
  .page{display:none;}
  .page.active{display:block;}

'+
      'body{margin:0;background:#fff;color:#111;font-family:Sarabun,Arial,sans-serif;font-size:12px;}'+
      '.preview-bar{position:sticky;top:0;z-index:999;background:#111;color:#fff;padding:12px 16px;display:flex;gap:10px;align-items:center;justify-content:space-between;}'+
      '.preview-bar button{background:#c62828;color:#fff;border:0;border-radius:8px;padding:9px 14px;font-weight:700;cursor:pointer;}'+
      '.preview-wrap{padding:18px;} h1{font-size:20px;margin:0 0 14px;}'+
      '.cost-panel,.xfs-section,.chart-card,.fin-kpi-grid,.project-mini-kpis{break-inside:avoid;margin-bottom:14px;border:1px solid #ddd;border-radius:8px;padding:12px;background:#fff;color:#111;}'+
      'table{width:100%;border-collapse:collapse;color:#111;} th,td{border:1px solid #ddd;padding:6px 8px;color:#111!important;background:#fff!important;} th{background:#f1f1f1!important;font-weight:800;}'+
      '.print-value{display:inline-block;min-width:70px;border:1px solid #ccc;border-radius:5px;padding:4px 7px;background:#fafafa;color:#111;font-weight:700;}'+
      '*{box-shadow:none!important;text-shadow:none!important;} canvas{max-width:100%;}'+
      '@media print{.preview-bar{display:none}.preview-wrap{padding:0} @page{size:A4 landscape;margin:10mm}}'+
      '

' +
      '@page{size:A4 landscape;margin:7mm}' +
      '*{box-sizing:border-box} body{margin:0;background:#fff;color:#111;font-family:Sarabun,Tahoma,Arial,sans-serif;font-size:10px;line-height:1.3}' +
      '.printbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;background:#111;color:#fff;font-size:13px}' +
      '.printbar button{border:0;background:#b00000;color:#fff;padding:8px 14px;border-radius:6px;font-weight:800;cursor:pointer}' +
      '.report{max-width:297mm;margin:0 auto;padding:5mm;background:#fff}' +
      '.report-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:3mm}' +
      '.report-head h1{margin:0;font-size:20px;line-height:1.05;font-weight:900;letter-spacing:0;color:#111}' +
      '.report-sub{font-size:10px;color:#333;margin-top:2px}.report-meta{text-align:right;color:#333;font-size:9px;line-height:1.35}' +
      '.report-rule{height:3px;background:#b00000;margin:3mm 0 4mm}' +
      '.report-band{background:#f2f2f2;border-left:5px solid #b00000;padding:8px 11px;margin:0 0 4mm}' +
      '.report-band b{display:block;color:#b00000;font-size:14px}.report-band span{display:block;color:#333;font-size:10px;margin-top:1px}' +
      '.report-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2.5mm;margin:0 0 4mm}' +
      '.report-kpi{border:1px solid #777;border-top:3px solid #b00000;background:#f7f7f7;padding:7px 8px;min-height:16mm;break-inside:avoid;page-break-inside:avoid}' +
      '.report-kpi .label{font-size:8px;text-transform:uppercase;letter-spacing:.6px;color:#333;font-weight:900;margin-bottom:4px}' +
      '.report-kpi .value{font-size:18px;line-height:1.05;color:#111;font-weight:900;word-break:break-word}' +
      '.report-kpi .sub{font-size:8.5px;color:#555;font-weight:800;margin-top:4px;word-break:break-word}' +
      '.info-box{border:1px solid #cfcfcf;padding:8px 10px;margin-bottom:4mm;background:#fff}.info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px 18px}' +
      '.info-item .label{color:#333;font-size:9px}.info-item .value{font-weight:900;border-bottom:1px solid #777;min-height:15px;padding-top:1px}' +
      '.saved-note{margin-top:5px;color:#111;font-weight:800}.firebase-note{color:#b6d9c4;font-size:9px;margin-top:2px}' +
      '.report-section{border:1px solid #d3d3d3;margin:0 0 4mm;padding:2mm;background:#fff;break-inside:avoid;page-break-inside:avoid}' +
      '.report-section-title{display:flex;align-items:center;gap:3px;background:#f4f4f4;border-left:4px solid #b00000;padding:6px 8px;margin:0 0 2mm;font-weight:900;color:#111;font-size:12px}' +
      '.report-section-title span{font-weight:800;color:#111}.report-table,.xfs-table,.fin-table,.cost-table,.pc-mix-table{width:100%;border-collapse:collapse;table-layout:fixed;color:#111;background:#fff}' +
      '.report-table th,.xfs-table th,.fin-table th,.cost-table th,.pc-mix-table th{background:#b00000!important;color:#fff!important;border:1px solid #777!important;padding:4px 5px!important;text-align:center!important;font-size:8px!important;font-weight:900!important;white-space:normal!important}' +
      '.report-table td,.xfs-table td,.fin-table td,.cost-table td,.pc-mix-table td{border:1px solid #777!important;padding:4px 5px!important;background:#fff!important;color:#111!important;font-size:8.5px!important;font-weight:700!important;vertical-align:top!important;white-space:normal!important;word-break:break-word}' +
      '.report-table td.left,.xfs-table td:first-child,.fin-table td:first-child,.cost-table td:first-child,.pc-mix-table td:first-child{text-align:left!important}' +
      '.report-table .total-row td,.xfs-row-total td,tfoot td,.pc-light-total-row td{background:#e6e6e6!important;font-weight:900!important;color:#111!important}' +
      '.entry,.xfs-locked,.formula-badge{display:inline-block;color:#111!important;background:transparent!important;border:0!important;border-bottom:1px solid #999!important;border-radius:0!important;min-width:26px;padding:0 2px;font-weight:800!important;text-align:left!important}' +
      '.xfs-section,.cost-panel,.chart-card{border:1px solid #d3d3d3!important;border-radius:0!important;margin:0 0 4mm!important;padding:2mm!important;background:#fff!important;color:#111!important;break-inside:avoid}' +
      '.xfs-section-title,.project-cost-title,.chart-title{display:flex!important;gap:3px!important;background:#f4f4f4!important;border-left:4px solid #b00000!important;color:#111!important;padding:6px 8px!important;margin:0 0 2mm!important;font-size:12px!important;font-weight:900!important}' +
      '.xfs-revenue-zonebar{background:#fff!important;border:1px solid #cfcfcf!important;border-radius:0!important;color:#111!important;padding:5px 7px!important;margin:0 0 2mm!important}.xfs-revenue-zonebar label,.xfs-revenue-zonebar span{color:#111!important}' +
      '.chart-dot{display:none!important}.xfs-section-title span{display:inline!important;color:#111!important;font-weight:800!important}.xfs-table-wrap,.fin-table-wrap,.tbl-wrap,.pc-table-wrap{overflow:visible!important}.desc,.remark,.pc-summary-remark{text-align:left!important;color:#111!important}' +
      '.project-extra{display:grid;grid-template-columns:1fr 1fr;gap:4mm}.project-extra .report-section{margin-bottom:0}.small-note{font-size:9px;color:#444;margin-top:3px}' +
      '@media print{.printbar{display:none!important}.report{padding:0;max-width:none}.report-section{break-inside:avoid;page-break-inside:avoid}}' +
    '

.printbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#111;color:#fff;font-family:Sarabun,Tahoma,Arial,sans-serif;font-size:13px}.printbar button{border:0;background:#b00000;color:#fff;padding:8px 14px;border-radius:6px;font-weight:800;cursor:pointer}@media print{.printbar{display:none!important}}

@page{size:A4 portrait;margin:10mm}body{background:#fff;color:#111;font-family:Sarabun,Tahoma,Arial,sans-serif}.page-hdr-right,.chart-hdr button{display:none!important}

/* ===== INDEX THEME OVERRIDE: ใช้ธีมสว่างแดงจากไฟล์ Index แต่คง Topbar/ไส้ในจาก BB ===== */
:root{
  --crimson:#c0392b;--crimson-bright:#e74c3c;--crimson-glow:#e74c3c;--crimson-pale:#fdecea;--crimson-dark:#96281b;
  --carbon:#fafafa;--carbon-2:#ffffff;--carbon-3:#ffffff;--carbon-4:#f5f5f5;--carbon-5:#eeeeee;--carbon-6:#e0e0e0;--carbon-7:#bdbdbd;
  --steel:#555555;--steel-light:#777777;--steel-dim:#9e9e9e;--gold:#e65100;--gold-dim:#bf360c;--jade:#2e7d32;--ice:#e3f2fd;
  --text-1:#1a1a1a;--text-2:#555555;--text-3:#9e9e9e;
  --card:#ffffff;--card-border:#e0e0e0;--card-border-active:rgba(192,57,43,.35);--glass:rgba(192,57,43,.08);
  --shadow:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
}
html,body{background:#fafafa!important;color:#1a1a1a!important}body::before{display:none!important}.page{color:#1a1a1a}.chart-card,.cost-panel,.exec-card,.exec-table-wrap,.mix-list,.mix-detail,.mix-summary-card,.cost-kpi,.project-mini-kpi,.fin-kpi,.admin-sidebar,.admin-content,.admin-section,.upload-result,.modal-box,.login-card{background:#fff!important;border-color:#e0e0e0!important;box-shadow:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04)!important;color:#1a1a1a!important}.chart-card::after,.cost-panel::after{display:none!important}
.topbar{height:54px!important;background:#c0392b!important;border-bottom:none!important;box-shadow:0 2px 6px rgba(0,0,0,.18)!important;backdrop-filter:none!important;padding:0 16px!important;gap:10px!important}.topbar-icon{background:rgba(255,255,255,.96)!important;border-radius:8px!important;box-shadow:none!important}.topbar-icon svg{height:30px!important;width:auto!important}.topbar-sep{background:rgba(255,255,255,.2)!important}.nav-tab{height:54px!important;border-radius:0!important;color:rgba(255,255,255,.9)!important;background:transparent!important;border-bottom:3px solid transparent!important;padding:0 14px!important}.nav-tab:hover{background:rgba(255,255,255,.12)!important;color:#fff!important}.nav-tab.active{background:rgba(0,0,0,.18)!important;color:#fff!important;border-bottom-color:#fff!important}.nav-dot{display:none!important}.topbar-right{gap:8px!important}.firebase-status-chip,.plant-selector,.user-pill,.btn-sm{background:rgba(255,255,255,.12)!important;border-color:rgba(255,255,255,.25)!important;color:#fff!important}.plant-selector option{background:#c0392b;color:#fff}.user-avatar{background:rgba(255,255,255,.22)!important;border:1px solid rgba(255,255,255,.45)!important;color:#fff!important}.btn-sm:hover{background:rgba(255,255,255,.18)!important;color:#fff!important;border-color:rgba(255,255,255,.45)!important}.btn-primary-sm,.month-btn.active,.mix-tab.active,.cost-subtab.active{background:#c0392b!important;border-color:#c0392b!important;color:#fff!important;box-shadow:none!important}
#loginScreen{background:linear-gradient(150deg,#7f0000 0%,#c0392b 45%,#922b21 100%)!important}.login-card{border-radius:16px!important;padding:40px!important}.login-logo-icon{background:#fff!important;box-shadow:0 4px 12px rgba(0,0,0,.18)!important}.login-logo-icon svg{height:34px!important;width:auto!important}.login-logo-text h1,.login-title,.form-field input{color:#1a1a1a!important}.form-field input{background:#fff!important;border-color:#bdbdbd!important}.form-field label,.chart-dot,.kpi-card-label,.form-col label{color:#c0392b!important}.btn-login{background:#c0392b!important;box-shadow:none!important}.btn-login:hover{background:#96281b!important;transform:none!important}
.page-hdr-left h2,.admin-section-title,.chart-title,.exec-table-hdr,.mix-list-hdr,.project-cost-title,.fin-section-title,table.data-tbl th{color:#1a1a1a!important}.page-hdr-left p,.exec-sub,.kpi-card-sub,.mix-detail-sub,.mix-info .label,.mix-item-meta,.mix-summary-card .label,.cost-field label,.fin-row-grid .fin-label,.cost-kpi .label,.fin-kpi .label{color:#777!important}.kpi-card-value,.exec-value,.mix-summary-card .value,.mix-detail-title,.cost-kpi .value,.project-mini-kpi .value,.fin-kpi .value{color:#1a1a1a!important}.plant-month-banner{background:#fff!important;border-color:#e0e0e0!important;box-shadow:var(--shadow)!important}.pmb-plant{color:#1a1a1a!important;text-shadow:none!important}.pmb-plant span{color:#c0392b!important}.chart-dot{background:#c0392b!important;box-shadow:none!important}.chart-badge,.cost-pill,.mix-pill{background:#f5f5f5!important;border-color:#e0e0e0!important;color:#555!important}.kpi-card{background:#fff!important;border-color:#e0e0e0!important;border-top:3px solid #c0392b!important;box-shadow:var(--shadow)!important}.kpi-card::before{display:none!important}.kpi-card:hover{transform:none!important;box-shadow:0 4px 6px rgba(0,0,0,.08)!important}.month-btn,.mix-tab,.cost-subtab{background:#fff!important;border-color:#bdbdbd!important;color:#555!important}.month-btn:hover,.mix-tab:hover,.cost-subtab:hover{border-color:#c0392b!important;color:#c0392b!important}.tbl-wrap,.pc-table-wrap,.fin-table-wrap{background:#fff!important;border-color:#e0e0e0!important}table.data-tbl td,.exec-table td,.cost-table td,.fin-table td,.pc-mix-table td{color:#1a1a1a!important;border-color:#e0e0e0!important}table.data-tbl th,.exec-table th,.cost-table th,.fin-table th,.pc-mix-table th{background:#f5f5f5!important;color:#555!important;border-color:#e0e0e0!important}.pc-mix-table th{background:#c0392b!important;color:#fff!important}.pc-mix-table td:first-child{background:#fff!important}.pc-total-row td,.fin-total-row td,.xfs-row-total td{background:#fdecea!important;color:#1a1a1a!important}.admin-sidebar-btn,.admin-sidebar-btn.active{color:#555!important}.admin-sidebar-btn:hover,.admin-sidebar-btn.active{background:#fdecea!important;color:#c0392b!important}.upload-zone{background:#f5f5f5!important;border-color:#bdbdbd!important}.upload-zone:hover,.upload-zone.drag{background:#fdecea!important;border-color:#c0392b!important}.form-col input,.form-col select,.edit-controls input,.edit-controls select,.filter-bar input,.filter-bar select,.mix-toolbar input,.mix-toolbar select,.cost-field input,.cost-field select,.fin-input{background:#fff!important;border-color:#bdbdbd!important;color:#1a1a1a!important}.modal-bg{background:rgba(0,0,0,.35)!important}.toast{background:#c0392b!important;box-shadow:0 8px 24px rgba(192,57,43,.25)!important}.security-note,.fin-note,.cost-note{background:#fff3e0!important;border-color:#ffe0b2!important;color:#e65100!important}.firebase-status-chip.online{background:rgba(46,125,50,.16)!important;color:#fff!important}.firebase-status-chip.offline{background:rgba(230,81,0,.18)!important;color:#fff!important}
/* Print safety: ซ่อน topbar เฉพาะตอนพิมพ์ ไม่แตะสูตร/ข้อมูลตาราง */
@media print{.topbar,#loginScreen,.modal-bg,.toast{display:none!important}body{background:#fff!important;color:#111!important}.page{max-width:none!important}.chart-card,.cost-panel,.kpi-card,.exec-card,.mix-detail,.mix-list{box-shadow:none!important}}

:root{
  --crimson:#c0392b!important;--crimson-dark:#96281b!important;--crimson-bright:#e74c3c!important;--crimson-glow:#c0392b!important;--crimson-pale:#fdecea!important;
  --carbon:#fafafa!important;--carbon-2:#fafafa!important;--carbon-3:#ffffff!important;--carbon-4:#ffffff!important;--carbon-5:#f5f5f5!important;--carbon-6:#e0e0e0!important;--carbon-7:#bdbdbd!important;
  --steel:#9e9e9e!important;--steel-light:#bdbdbd!important;--steel-dim:#757575!important;--gold:#f39c12!important;--jade:#27ae60!important;--ice:#e3f2fd!important;
  --text-1:#1a1a1a!important;--text-2:#555555!important;--text-3:#9e9e9e!important;--card:#ffffff!important;--card-border:#e0e0e0!important;--card-border-active:#c0392b!important;--glass:rgba(192,57,43,.08)!important;
}
html,body{background:#fafafa!important;color:#1a1a1a!important;font-family:Sarabun,'Noto Sans Thai',system-ui,sans-serif!important;font-size:14px!important;letter-spacing:0!important}body::before{display:none!important}
#app{background:#fafafa!important;min-height:100vh!important}.page{background:#fafafa!important;max-width:1600px!important;padding:20px!important}.page.active{display:block!important}
/* Topbar exactly like BB reference */
.topbar{height:54px!important;min-height:54px!important;background:#c0392b!important;border-bottom:none!important;box-shadow:0 2px 6px rgba(0,0,0,.18)!important;backdrop-filter:none!important;padding:0!important;gap:0!important;position:sticky!important;top:0!important;z-index:200!important;display:flex!important;align-items:center!important}
.topbar-brand{height:54px!important;min-width:194px!important;padding:0 20px!important;background:rgba(0,0,0,.15)!important;border-right:1px solid rgba(255,255,255,.12)!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:0!important}.topbar-icon{width:auto!important;height:auto!important;background:transparent!important;box-shadow:none!important;border-radius:0!important}.topbar-icon svg{width:118px!important;height:auto!important;display:block!important}.topbar-name,.topbar-sep{display:none!important}
.nav-tabs{height:54px!important;display:flex!important;gap:0!important;flex:1!important;overflow-x:auto!important;padding-left:6px!important;background:transparent!important}.nav-tab{height:54px!important;padding:0 16px!important;border:0!important;border-bottom:3px solid transparent!important;border-radius:0!important;background:transparent!important;color:rgba(255,255,255,.9)!important;font-size:12px!important;font-family:Sarabun,sans-serif!important;font-weight:600!important;letter-spacing:.2px!important;display:flex!important;align-items:center!important;white-space:nowrap!important;box-shadow:none!important}.nav-tab span,.nav-dot{display:none!important}.nav-tab:hover{background:rgba(255,255,255,.12)!important;color:#fff!important}.nav-tab.active{background:rgba(0,0,0,.18)!important;color:#fff!important;font-weight:800!important;border-bottom-color:#fff!important}
.topbar-right{height:54px!important;margin-left:auto!important;padding:0 16px!important;gap:6px!important;border-left:1px solid rgba(255,255,255,.12)!important;display:flex!important;align-items:center!important;background:transparent!important}.firebase-status-chip,.plant-selector,.user-pill,.topbar-right .btn-sm{height:30px!important;background:rgba(255,255,255,.12)!important;border:1px solid rgba(255,255,255,.25)!important;border-radius:6px!important;color:#fff!important;font-size:12px!important;box-shadow:none!important}.firebase-status-chip{padding:3px 10px!important;border-radius:20px!important}.plant-selector{padding:4px 10px!important;min-width:128px!important}.plant-selector option{background:#c0392b!important;color:#fff!important}.user-pill{width:30px!important;padding:0!important;border-radius:50%!important;justify-content:center!important}.user-pill span{display:none!important}.user-avatar{width:30px!important;height:30px!important;border-radius:50%!important;background:rgba(255,255,255,.2)!important;border:1.5px solid rgba(255,255,255,.5)!important;color:#fff!important}.topbar-right .btn-sm{padding:5px 12px!important;width:auto!important;border-radius:6px!important;color:rgba(255,255,255,.9)!important}
/* Page headers */
.page-hdr{display:flex!important;align-items:flex-start!important;justify-content:space-between!important;margin:0 0 14px!important}.page-hdr-left h2{font-size:22px!important;font-weight:900!important;color:#1a1a1a!important;letter-spacing:-.3px!important;line-height:1.2!important}.page-hdr-left p{font-size:12px!important;color:#9e9e9e!important;margin-top:4px!important;letter-spacing:0!important}.page-hdr-right{gap:8px!important}.plant-month-banner{display:none!important}
/* Buttons */
.btn-primary-sm,.month-btn.active,.mix-tab.active,.cost-subtab.active{background:#c0392b!important;border-color:#c0392b!important;color:#fff!important;box-shadow:none!important}.btn-sm{background:#fff!important;border:1px solid #bdbdbd!important;color:#555!important;border-radius:6px!important;box-shadow:none!important}.btn-sm:hover{border-color:#c0392b!important;color:#c0392b!important;background:#fdecea!important}
/* Cards and KPI */
.kpi-strip,.exec-grid{gap:12px!important;margin-bottom:12px!important}.kpi-card,.exec-card,.chart-card,.exec-table-wrap,.mix-summary-card,.mix-list,.mix-detail,.cost-panel,.cost-kpi,.project-mini-kpi,.fin-kpi{background:#fff!important;border:1px solid #e0e0e0!important;border-radius:10px!important;box-shadow:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04)!important;color:#1a1a1a!important}.kpi-card,.exec-card{padding:20px!important;min-height:108px!important;border-top:3px solid #c0392b!important}.kpi-card:first-child{border-top-color:#234db6!important}.kpi-card:hover{transform:none!important;box-shadow:0 4px 6px -1px rgba(0,0,0,.09),0 2px 4px -2px rgba(0,0,0,.06)!important}.kpi-card::before,.chart-card::after,.cost-panel::after{display:none!important}.kpi-card-icon{display:none!important}.kpi-card-label,.exec-label{font-size:10px!important;font-weight:800!important;color:#9e9e9e!important;text-transform:uppercase!important;letter-spacing:.08em!important;margin-bottom:8px!important}.kpi-card-value,.exec-value{font-size:30px!important;font-weight:900!important;color:#1a1a1a!important;line-height:1!important;letter-spacing:-.5px!important}.kpi-card:first-child .kpi-card-value{color:#234db6!important}.kpi-card:nth-child(4) .kpi-card-value,.exec-card:nth-child(3) .exec-value{color:#c0392b!important}.kpi-card-unit,.kpi-card-sub,.exec-sub,.kpi-tag{color:#9e9e9e!important;font-size:12px!important;letter-spacing:0!important;opacity:1!important}
/* Chart cards */
.chart-grid-2,.chart-grid-half,.exec-layout{gap:14px!important;margin-bottom:14px!important}.chart-card{padding:18px!important;overflow:hidden!important}.chart-hdr{margin-bottom:14px!important}.chart-title{font-size:12px!important;font-weight:900!important;color:#555!important;text-transform:uppercase!important;letter-spacing:.08em!important}.chart-dot{display:none!important}.chart-badge{background:#f0f0f0!important;color:#9e9e9e!important;border:0!important;border-radius:4px!important;font-size:10px!important;font-weight:800!important;letter-spacing:.08em!important;padding:2px 8px!important}canvas{max-height:310px!important}.chart-grid-2 canvas{max-height:330px!important}
/* Tables */
.tbl-wrap{background:#fff!important;border-radius:8px!important;overflow:auto!important}table.data-tbl,.exec-table,.cost-table,.fin-table,.pc-mix-table{font-size:12px!important;color:#1a1a1a!important;background:#fff!important}table.data-tbl th,.exec-table th,.cost-table th,.fin-table th,.pc-mix-table th{background:#f5f5f5!important;color:#555!important;border-bottom:1px solid #e0e0e0!important;font-size:10px!important;font-weight:900!important;letter-spacing:.08em!important;text-transform:uppercase!important}table.data-tbl td,.exec-table td,.cost-table td,.fin-table td,.pc-mix-table td{color:#1a1a1a!important;border-bottom:1px solid #e0e0e0!important;background:#fff!important}table.data-tbl tr:hover td,.exec-table tr:hover td{background:#f5f5f5!important}.exec-table-hdr,.mix-list-hdr{color:#555!important;background:#fff!important;border-bottom:1px solid #e0e0e0!important;font-size:12px!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.08em!important}.rank-chip{border-radius:6px!important;font-weight:900!important}.r1{background:#fbbf24!important;color:#000!important}.r2{background:#94a3b8!important;color:#fff!important}.r3{background:#c2410c!important;color:#fff!important}.rN{background:#eeeeee!important;color:#555!important}.str-badge,.mix-pill,.cost-pill,.formula-badge{background:#eeeeee!important;color:#555!important;border:0!important}
/* Inputs and forms */
input,select,textarea,.fin-input,.cost-field input,.cost-field select,.form-col input,.form-col select{background:#fff!important;border:1px solid #bdbdbd!important;color:#1a1a1a!important;border-radius:6px!important;box-shadow:none!important}input:focus,select:focus,textarea:focus{border-color:#c0392b!important;box-shadow:0 0 0 3px rgba(192,57,43,.12)!important}.cost-field label,.fin-label,.fin-name,.fin-section-title,.project-cost-title{color:#555!important}.cost-note,.fin-note{background:#fdecea!important;border-left-color:#c0392b!important;color:#555!important}
/* Login follows same theme */
#loginScreen{background:linear-gradient(150deg,#7f0000 0%,#c0392b 45%,#922b21 100%)!important}.login-card{background:#fff!important;border:0!important;border-radius:16px!important;box-shadow:0 20px 60px rgba(0,0,0,.25)!important}.login-logo-text h1{color:#1a1a1a!important}.login-logo-text p,.login-title{color:#9e9e9e!important}.login-logo-icon{background:#c0392b!important}.form-field label{color:#555!important}.btn-login{background:#c0392b!important;box-shadow:none!important;border-radius:6px!important}.security-note,.demo-accounts{background:#f5f5f5!important;border-color:#e0e0e0!important;color:#555!important}
/* iPad */
@media(max-width:768px){.topbar{height:auto!important;min-height:54px!important;flex-wrap:wrap!important}.topbar-brand{height:54px!important;min-width:170px!important}.nav-tabs{order:3!important;flex:0 0 100%!important;background:#c0392b!important;padding-left:0!important}.topbar-right{height:54px!important;margin-left:auto!important}.page{padding:16px 12px!important}.kpi-strip,.exec-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.chart-grid-2,.chart-grid-half,.exec-layout{grid-template-columns:1fr!important}.plant-selector{min-width:120px!important;max-width:160px!important}.user-pill{display:flex!important}}
@media(max-width:520px){.kpi-strip,.exec-grid{grid-template-columns:1fr!important}.topbar-brand{min-width:150px!important}.topbar-icon svg{width:105px!important}.topbar-right{padding:0 8px!important}.firebase-status-chip{display:none!important}}
/* Print safety */
@media print{.topbar,#loginScreen,.modal-bg,.toast,.page-hdr-right,.filter-bar,.mix-toolbar,.edit-controls,.cost-actions,.pc-mix-actions{display:none!important}html,body,#app,.page{background:#fff!important;color:#111!important}.page{max-width:none!important;padding:0!important}.chart-card,.exec-card,.kpi-card,.exec-table-wrap,.cost-panel,.mix-detail,.mix-list{box-shadow:none!important;border-color:#d3d3d3!important;break-inside:avoid!important;page-break-inside:avoid!important}table th{background:#f2f2f2!important;color:#111!important}table td{color:#111!important}.pc-print-page,.print-page{page-break-after:always!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}

.topbar-brand{min-width:220px;background:#fff!important;align-self:stretch;margin:-1px 0 -1px -16px;padding:8px 18px;display:flex!important;align-items:center!important;justify-content:center!important;border-right:1px solid rgba(0,0,0,.08)}
.topbar-brand .topbar-icon{width:190px!important;height:50px!important;background:#fff!important;box-shadow:none!important;border-radius:0!important;padding:0!important;overflow:visible!important;display:flex!important;align-items:center!important;justify-content:center!important}
.insee-logo-img{display:block!important;width:100%!important;height:100%!important;object-fit:contain!important}
.dashboard-month-selector-patch{display:flex!important;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;margin:0 0 18px 0;padding:10px 0;background:transparent!important;color:#444!important;clear:both;position:relative;z-index:20}
.dashboard-month-selector-patch .dm-label{font-size:13px;font-weight:800;color:#555;margin-right:8px;white-space:nowrap}
.dashboard-month-selector-patch .dm-btn{height:34px;min-width:48px;border:1px solid #d7dce2;background:#fff;color:#5a6068;border-radius:999px;padding:0 13px;font-family:Sarabun,sans-serif;font-size:12px;font-weight:800;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.05);transition:.15s}
.dashboard-month-selector-patch .dm-btn:hover{border-color:#c62828;color:#c62828}
.dashboard-month-selector-patch .dm-btn.active{background:#c62828!important;border-color:#c62828!important;color:#fff!important;box-shadow:0 4px 12px rgba(198,40,40,.25)}
.dashboard-month-selector-patch .dm-year{height:34px;border:1px solid #d7dce2;background:#fff;color:#333;border-radius:999px;padding:0 12px;font-family:Sarabun,sans-serif;font-size:12px;font-weight:800;outline:none}
#page-dashboard .plant-month-banner{display:none!important}
@media(max-width:768px){.topbar-brand{min-width:170px;margin:0;padding:6px 10px;border-radius:8px;height:48px;align-self:center}.topbar-brand .topbar-icon{width:155px!important;height:42px!important}.dashboard-month-selector-patch{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:12px}.dashboard-month-selector-patch .dm-label{flex:0 0 auto}.dashboard-month-selector-patch .dm-btn,.dashboard-month-selector-patch .dm-year{flex:0 0 auto}}

:root{
  --bb-red:#c0392b;--bb-red-2:#b7332a;--bb-red-dark:#9f2b25;--bb-active:#a92c25;
  --bb-bg:#f3f4f6;--bb-panel:#ffffff;--bb-panel-2:#fbfbfc;--bb-line:#e4e7eb;
  --bb-text:#1f2933;--bb-muted:#667085;--bb-soft:#8a94a3;
  --bb-good:#2e7d32;--bb-warn:#f39c12;--bb-blue:#2f80ed;--bb-purple:#8e44ad;
  --carbon:var(--bb-bg)!important;--carbon-2:#eef0f3!important;--carbon-3:var(--bb-panel)!important;--carbon-4:var(--bb-panel)!important;--carbon-5:#f7f8fa!important;--carbon-6:var(--bb-line)!important;--carbon-7:#d2d7de!important;
  --text-1:var(--bb-text)!important;--text-2:#3f4a59!important;--text-3:var(--bb-muted)!important;
  --card:var(--bb-panel)!important;--card-border:var(--bb-line)!important;--glass:rgba(192,57,43,.08)!important;
  --crimson:var(--bb-red)!important;--crimson-bright:#d54940!important;--crimson-glow:#c0392b!important;--crimson-dark:var(--bb-red-dark)!important;--crimson-pale:#fae2df!important;
}
html,body{background:var(--bb-bg)!important;color:var(--bb-text)!important;font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;font-weight:500!important;letter-spacing:0!important;}
body::before{display:none!important}#app{background:var(--bb-bg)!important}.page{max-width:1840px!important;padding:18px 22px 26px!important;}
/* BB-like topbar */
.topbar{height:52px!important;min-height:52px!important;background:var(--bb-red)!important;border:0!important;border-bottom:1px solid rgba(0,0,0,.14)!important;box-shadow:0 1px 4px rgba(16,24,40,.20)!important;padding:0!important;gap:0!important;backdrop-filter:none!important;display:flex!important;align-items:center!important;}
.topbar-brand{height:52px!important;width:174px!important;min-width:174px!important;max-width:174px!important;background:rgba(0,0,0,.13)!important;border-right:1px solid rgba(255,255,255,.15)!important;margin:0!important;padding:0 18px!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:0!important;}
.topbar-icon{width:124px!important;height:38px!important;background:transparent!important;border-radius:0!important;box-shadow:none!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;font-size:0!important;overflow:visible!important;}
.topbar-icon svg{width:116px!important;height:auto!important;display:block!important}.topbar-icon svg g,.topbar-icon svg path,.topbar-icon svg text{fill:#fff!important}.topbar-name,.topbar-sep{display:none!important;}
.nav-tabs{height:52px!important;display:flex!important;align-items:center!important;gap:0!important;flex:1 1 auto!important;background:transparent!important;overflow-x:auto!important;overflow-y:hidden!important;padding:0 0 0 4px!important;scrollbar-width:none!important;}
.nav-tabs::-webkit-scrollbar{display:none!important}.nav-dot,.nav-tab span,.kpi-card-icon,.chart-dot,.upload-icon{display:none!important;}
.nav-tab{height:52px!important;min-height:52px!important;padding:0 15px!important;background:transparent!important;color:rgba(255,255,255,.90)!important;border:0!important;border-radius:0!important;border-bottom:3px solid transparent!important;box-shadow:none!important;font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;font-size:12px!important;font-weight:650!important;letter-spacing:.1px!important;line-height:52px!important;white-space:nowrap!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:0!important;}
.nav-tab:hover{background:rgba(0,0,0,.10)!important;color:#fff!important}.nav-tab.active{background:rgba(0,0,0,.19)!important;color:#fff!important;font-weight:800!important;border-bottom-color:#fff!important;}
.topbar-right{height:52px!important;display:flex!important;align-items:center!important;gap:7px!important;margin-left:auto!important;padding:0 14px!important;border-left:1px solid rgba(255,255,255,.14)!important;background:transparent!important;}
.firebase-status-chip,.plant-selector,.topbar-right .btn-sm{height:30px!important;min-height:30px!important;background:rgba(255,255,255,.14)!important;border:1px solid rgba(255,255,255,.26)!important;color:#fff!important;border-radius:5px!important;box-shadow:none!important;font-size:12px!important;font-weight:650!important;letter-spacing:0!important;line-height:18px!important;}
.firebase-status-chip{border-radius:16px!important;padding:3px 10px!important}.plant-selector{min-width:126px!important;max-width:150px!important;padding:4px 9px!important;outline:0!important}.plant-selector option{background:#fff!important;color:#222!important}.user-pill{width:30px!important;height:30px!important;padding:0!important;border-radius:50%!important;background:rgba(255,255,255,.22)!important;border:1.5px solid rgba(255,255,255,.50)!important;display:flex!important;align-items:center!important;justify-content:center!important;box-shadow:none!important;}.user-pill span{display:none!important}.user-avatar{width:28px!important;height:28px!important;background:transparent!important;border:0!important;color:#fff!important;font-size:12px!important;font-weight:800!important}.topbar-right .btn-sm{padding:5px 12px!important;width:auto!important;color:#fff!important}.topbar-right .btn-sm:hover{background:rgba(255,255,255,.20)!important;border-color:rgba(255,255,255,.50)!important;}
/* Layout/cards: clean BB report style */
.page-hdr{margin-bottom:14px!important}.page-hdr-left h2{font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;color:var(--bb-text)!important;font-size:22px!important;font-weight:800!important;letter-spacing:0!important}.page-hdr-left p{color:var(--bb-muted)!important;font-size:12px!important}.plant-month-banner{background:#fff!important;border:1px solid var(--bb-line)!important;border-left:5px solid var(--bb-red)!important;border-radius:8px!important;box-shadow:0 1px 3px rgba(16,24,40,.08)!important;padding:15px 18px!important;margin-bottom:16px!important;}.plant-month-banner::before{display:none!important}.pmb-plant{font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;font-size:24px!important;font-weight:800!important;letter-spacing:0!important;color:var(--bb-text)!important;text-shadow:none!important}.pmb-plant span{color:var(--bb-red)!important}.pmb-sub{color:var(--bb-muted)!important;font-size:11px!important;letter-spacing:.6px!important;text-transform:none!important}.month-btn,.month-select-wrap select{background:#fff!important;border:1px solid #d6dae0!important;color:var(--bb-text)!important;border-radius:6px!important;box-shadow:none!important;font-size:12px!important}.month-btn.active{background:var(--bb-red)!important;border-color:var(--bb-red)!important;color:#fff!important;box-shadow:none!important;}
.kpi-strip{gap:12px!important;margin-bottom:16px!important}.kpi-card,.exec-card,.mix-summary-card,.cost-kpi,.fin-kpi,.project-mini-kpi{background:#fff!important;border:1px solid var(--bb-line)!important;border-top:3px solid var(--bb-red)!important;border-radius:8px!important;box-shadow:0 1px 3px rgba(16,24,40,.08)!important;color:var(--bb-text)!important;}.kpi-card{padding:15px 16px!important}.kpi-card::before,.kpi-card::after,.chart-card::after,.cost-panel::after{display:none!important}.kpi-card:hover{transform:none!important;box-shadow:0 2px 8px rgba(16,24,40,.10)!important}.kpi-card-label,.exec-label,.cost-kpi .label,.fin-kpi .label,.mix-summary-card .label,.project-mini-kpi .label{color:var(--bb-muted)!important;font-size:10px!important;letter-spacing:.5px!important;text-transform:uppercase!important;font-weight:800!important}.kpi-card-value,.exec-value,.cost-kpi .value,.fin-kpi .value,.mix-summary-card .value,.project-mini-kpi .value{font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;color:var(--bb-text)!important;font-weight:900!important;letter-spacing:-.2px!important}.kpi-card-value{font-size:30px!important}.exec-value,.cost-kpi .value,.fin-kpi .value{font-size:26px!important}.kpi-card-sub,.exec-sub,.cost-kpi .sub,.fin-kpi .sub{color:var(--bb-muted)!important;font-size:11px!important}.kpi-tag{color:#7a8491!important;opacity:1!important;font-weight:700!important;}
.chart-card,.cost-panel,.mix-detail,.mix-list,.exec-table-wrap,.upload-zone,.upload-result,.pp-card,.pp-filters,.pp-stat,.admin-sidebar,.modal-box{background:#fff!important;border:1px solid var(--bb-line)!important;border-radius:8px!important;box-shadow:0 1px 3px rgba(16,24,40,.08)!important;color:var(--bb-text)!important;}.chart-card{padding:18px 18px!important}.chart-hdr{margin-bottom:14px!important}.chart-title,.exec-table-hdr,.mix-list-hdr,.admin-section-title,.modal-title,.fin-section-title,.project-cost-title{font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;color:var(--bb-text)!important;font-size:13px!important;font-weight:900!important;letter-spacing:.1px!important;text-transform:none!important}.chart-badge{background:#f5f6f8!important;border:1px solid var(--bb-line)!important;color:var(--bb-muted)!important;border-radius:12px!important;font-size:10px!important;font-weight:800!important;letter-spacing:.3px!important;}
table.data-tbl,table.exec-table,.cost-table,.fin-table,.pc-mix-table{color:var(--bb-text)!important}table.data-tbl th,.exec-table th,.cost-table th,.fin-table th,.pc-mix-table th{background:#f2f4f7!important;color:#475467!important;border-bottom:1px solid var(--bb-line)!important;font-weight:900!important;font-size:10px!important;letter-spacing:.4px!important}table.data-tbl td,.exec-table td,.cost-table td,.fin-table td,.pc-mix-table td{color:var(--bb-text)!important;border-bottom:1px solid #eef0f2!important}table.data-tbl tr:hover td{background:#fafafa!important}.pc-total-row td,.fin-total-row td{background:#fae9e7!important;color:#111827!important}.rank-chip{box-shadow:none!important}.r1{background:#f9d65c!important;color:#3b2f00!important}.r2{background:#d7dde4!important;color:#27323f!important}.r3{background:#f0a46b!important;color:#fff!important}.rN{background:#eef0f3!important;color:#5d6673!important}
.btn-sm,.btn-primary-sm,.cost-subtab,.mix-tab,.pp-filter-btn{border-radius:6px!important;font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;font-weight:800!important;box-shadow:none!important}.btn-primary-sm{background:var(--bb-red)!important;border:1px solid var(--bb-red)!important;color:#fff!important}.btn-sm{background:#fff!important;border:1px solid #d6dae0!important;color:#344054!important}.btn-sm:hover{border-color:var(--bb-red)!important;color:var(--bb-red)!important}.btn-primary-sm:hover{background:var(--bb-red-dark)!important;transform:none!important}.filter-bar input,.filter-bar select,.edit-controls input,.edit-controls select,.mix-toolbar input,.mix-toolbar select,.cost-field input,.cost-field select,.fin-input,.form-col input,.form-col select,.pp-form-col input,.pp-form-col select,.pp-form-col textarea{background:#fff!important;border:1px solid #d6dae0!important;color:var(--bb-text)!important;border-radius:6px!important;box-shadow:none!important}.filter-bar input:focus,.filter-bar select:focus,.edit-controls input:focus,.edit-controls select:focus,.mix-toolbar input:focus,.mix-toolbar select:focus,.cost-field input:focus,.cost-field select:focus,.fin-input:focus{border-color:var(--bb-red)!important;box-shadow:0 0 0 3px rgba(192,57,43,.10)!important}.admin-grid{background:var(--bb-bg)!important}.admin-sidebar{border-radius:0!important;border-top:0!important;border-left:0!important;border-bottom:0!important}.admin-sidebar-btn{color:#344054!important;border-radius:6px!important}.admin-sidebar-btn:hover,.admin-sidebar-btn.active{background:#fae9e7!important;color:var(--bb-red)!important;box-shadow:none!important}.toast{background:var(--bb-red)!important;color:#fff!important;border-radius:8px!important;font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;box-shadow:0 8px 20px rgba(16,24,40,.22)!important}
.login-card{background:#fff!important;color:var(--bb-text)!important;border:1px solid var(--bb-line)!important;border-radius:14px!important;box-shadow:0 16px 50px rgba(16,24,40,.18)!important}.login-title,.login-logo-text p,.demo-accounts p,.demo-row{color:var(--bb-muted)!important}.login-logo-text h1{color:var(--bb-text)!important}.form-field input{background:#fff!important;border:1px solid #d6dae0!important;color:var(--bb-text)!important}.login-logo-icon,.btn-login{background:var(--bb-red)!important;box-shadow:none!important}.demo-accounts{background:#f9fafb!important;border:1px solid var(--bb-line)!important}.demo-row span:last-child{color:var(--bb-red)!important}
/* Hide modules the reference topbar does not show. Core pages still exist. */
.nav-tab[onclick*="strength"],.nav-tab[onclick*="cost"],.nav-tab[onclick*="quotation"]{display:none!important;}
@media(max-width:900px){.topbar{height:auto!important;min-height:52px!important;flex-wrap:wrap!important}.topbar-brand{width:154px!important;min-width:154px!important}.topbar-icon svg{width:104px!important}.nav-tabs{order:3!important;flex:0 0 100%!important;background:var(--bb-red)!important;padding-left:0!important}.topbar-right{height:52px!important}.kpi-strip,.exec-grid{grid-template-columns:repeat(2,1fr)!important}.page{padding:14px 12px 22px!important}}
@media(max-width:520px){.kpi-strip,.exec-grid{grid-template-columns:1fr!important}.topbar-brand{width:145px!important;min-width:145px!important}.firebase-status-chip{display:none!important}.plant-selector{max-width:132px!important}.topbar-right{padding:0 8px!important}.nav-tab{padding:0 12px!important;font-size:11px!important}}
@media print{.topbar,#loginScreen,.modal-bg,.toast,.page-hdr-right,.filter-bar,.mix-toolbar,.edit-controls,.cost-actions,.pc-mix-actions{display:none!important}html,body,#app,.page{background:#fff!important;color:#111!important}.chart-card,.exec-card,.kpi-card,.exec-table-wrap,.cost-panel,.mix-detail,.mix-list{box-shadow:none!important;border-color:#d3d3d3!important;break-inside:avoid!important;page-break-inside:avoid!important}table th{background:#f2f2f2!important;color:#111!important}table td{color:#111!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}

/* Final reference polish: visual theme only. Keeps formulas, print, data checks and page logic intact. */
:root{
  --bb-red:#b74235;
  --bb-red-dark:#983126;
  --bb-red-active:#8f3027;
  --bb-orange:#df8439;
  --bb-green:#59ad6a;
  --bb-blue:#4887bd;
  --bb-purple:#894cad;
  --bb-teal:#4aa68c;
  --bb-ink:#1f2329;
  --bb-text:#2b2f36;
  --bb-soft-text:#5e6670;
  --bb-muted:#9da3aa;
  --bb-axis:#a9b4c5;
  --bb-line:#e2e4e7;
  --bb-line-soft:#eef0f2;
  --bb-bg:#fafafa;
  --bb-card:#ffffff;
}
html,body,#app,.page,.admin-grid,.admin-content{
  background:var(--bb-bg)!important;
  color:var(--bb-text)!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important;
  font-weight:500!important;
  letter-spacing:0!important;
}
body::before,.chart-card::after,.cost-panel::after,.kpi-card::before,.kpi-card::after,.plant-month-banner::before{display:none!important}
.topbar{
  height:54px!important;
  min-height:54px!important;
  background:var(--bb-red)!important;
  border:0!important;
  border-bottom:1px solid rgba(0,0,0,.14)!important;
  box-shadow:0 1px 4px rgba(16,24,40,.18)!important;
}
.topbar-brand{
  height:54px!important;
  width:176px!important;
  min-width:176px!important;
  max-width:176px!important;
  background:rgba(0,0,0,.14)!important;
  border-right:1px solid rgba(255,255,255,.14)!important;
}
.topbar-icon{background:transparent!important;box-shadow:none!important;border-radius:0!important}
.topbar-icon svg{width:118px!important;max-height:40px!important}
.topbar-name,.topbar-sep,.nav-dot,.nav-tab span,.kpi-card-icon,.chart-dot,.upload-icon{display:none!important}
.nav-tabs{height:54px!important;padding-left:8px!important;gap:0!important}
.nav-tab{
  height:54px!important;
  min-height:54px!important;
  padding:0 17px!important;
  border-radius:0!important;
  border:0!important;
  border-bottom:3px solid transparent!important;
  background:transparent!important;
  color:rgba(255,255,255,.9)!important;
  font-size:12px!important;
  font-weight:700!important;
  letter-spacing:0!important;
  line-height:54px!important;
}
.nav-tab:hover{background:rgba(0,0,0,.10)!important;color:#fff!important}
.nav-tab.active{background:rgba(0,0,0,.20)!important;color:#fff!important;border-bottom-color:#fff!important;font-weight:800!important}
.topbar-right{height:54px!important;gap:8px!important;padding:0 18px!important;border-left:1px solid rgba(255,255,255,.13)!important}
.firebase-status-chip,.plant-selector,.topbar-right .btn-sm{
  height:30px!important;
  min-height:30px!important;
  background:rgba(255,255,255,.14)!important;
  border:1px solid rgba(255,255,255,.27)!important;
  color:#fff!important;
  border-radius:6px!important;
  box-shadow:none!important;
  font-size:12px!important;
  font-weight:700!important;
}
.firebase-status-chip{border-radius:999px!important;padding:3px 11px!important}
.plant-selector{min-width:132px!important;max-width:152px!important;padding:4px 10px!important}
.plant-selector option{background:#fff!important;color:var(--bb-text)!important}
.user-pill{
  width:31px!important;
  height:31px!important;
  padding:0!important;
  border-radius:50%!important;
  background:rgba(255,255,255,.20)!important;
  border:1.5px solid rgba(255,255,255,.58)!important;
  box-shadow:none!important;
}
.user-pill span{display:none!important}
.user-avatar{background:transparent!important;color:#fff!important;border:0!important;font-weight:900!important}
.page{max-width:none!important;width:100%!important;padding:22px 28px 34px!important}
.page-hdr{margin:0 0 16px!important}
.page-hdr-left h2{
  color:#202124!important;
  font-size:24px!important;
  font-weight:900!important;
  line-height:1.18!important;
  letter-spacing:0!important;
}
.page-hdr-left p{color:#9da0a4!important;font-size:13px!important;font-weight:600!important;margin-top:4px!important}
.page-hdr-right{gap:9px!important}
.plant-month-banner{
  background:#fff!important;
  border:1px solid var(--bb-line)!important;
  border-left:4px solid var(--bb-red)!important;
  border-radius:8px!important;
  box-shadow:0 1px 3px rgba(16,24,40,.08)!important;
  padding:15px 18px!important;
  margin-bottom:16px!important;
}
.pmb-plant{color:var(--bb-text)!important;text-shadow:none!important;font-size:24px!important;font-weight:900!important;letter-spacing:0!important}
.pmb-plant span{color:var(--bb-red)!important}
.pmb-sub{color:var(--bb-muted)!important;font-size:11px!important;letter-spacing:0!important;text-transform:none!important}
.kpi-strip,.exec-grid{gap:14px!important;margin-bottom:16px!important}
.chart-grid-2,.chart-grid-half,.exec-layout{gap:14px!important;margin-bottom:14px!important}
.chart-grid-2{grid-template-columns:1fr 1fr!important}
.kpi-card,.exec-card,.mix-summary-card,.cost-kpi,.fin-kpi,.project-mini-kpi,
.chart-card,.cost-panel,.mix-detail,.mix-list,.exec-table-wrap,.upload-zone,.upload-result,.pp-card,.pp-filters,.pp-stat,.modal-box{
  background:#fff!important;
  border:1px solid var(--bb-line)!important;
  border-radius:8px!important;
  box-shadow:0 1px 3px rgba(16,24,40,.08)!important;
  color:var(--bb-text)!important;
}
.kpi-card,.exec-card,.mix-summary-card,.cost-kpi,.fin-kpi,.project-mini-kpi{border-top:3px solid var(--bb-red)!important}
.kpi-card:first-child{border-top-color:#2849b9!important}
.exec-card:nth-child(3),.kpi-card:nth-child(5){border-top-color:#2f7668!important}
.exec-card:nth-child(4),.kpi-card:nth-child(4){border-top-color:#e05a2a!important}
.kpi-card:hover,.exec-card:hover{transform:none!important;box-shadow:0 2px 8px rgba(16,24,40,.10)!important}
.kpi-card{padding:16px 18px!important;min-height:112px!important}
.exec-card{padding:18px 20px!important;min-height:108px!important}
.chart-card{padding:18px 20px!important}
.kpi-card-label,.exec-label,.cost-kpi .label,.fin-kpi .label,.mix-summary-card .label,.project-mini-kpi .label{
  color:var(--bb-muted)!important;
  font-size:10px!important;
  font-weight:900!important;
  letter-spacing:.06em!important;
  text-transform:uppercase!important;
}
.kpi-card-value,.exec-value,.cost-kpi .value,.fin-kpi .value,.mix-summary-card .value,.project-mini-kpi .value{
  color:#202124!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-weight:900!important;
  letter-spacing:0!important;
}
.kpi-card-value{font-size:31px!important}
.exec-value,.cost-kpi .value,.fin-kpi .value{font-size:27px!important}
.kpi-card:first-child .kpi-card-value{color:#2849b9!important}
.kpi-card:nth-child(4) .kpi-card-value,.exec-card:nth-child(3) .exec-value,.data-tbl td:nth-child(4),.exec-table td:last-child{color:#df5a27!important}
.kpi-card-sub,.exec-sub,.cost-kpi .sub,.fin-kpi .sub,.kpi-card-unit{color:var(--bb-muted)!important;font-weight:600!important}
.chart-hdr{margin-bottom:14px!important}
.chart-title,.exec-table-hdr,.mix-list-hdr,.admin-section-title,.modal-title,.fin-section-title,.project-cost-title{
  color:#4f5358!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-size:13px!important;
  font-weight:900!important;
  letter-spacing:.03em!important;
  text-transform:none!important;
}
.chart-badge{
  background:#f1f2f4!important;
  border:0!important;
  color:#a1a3a6!important;
  border-radius:5px!important;
  font-size:10px!important;
  font-weight:900!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
}
canvas{max-height:320px!important}
.chart-grid-2 canvas{max-height:340px!important}
.exec-layout canvas{max-height:300px!important}
.tbl-wrap{background:#fff!important;border-radius:8px!important}
table.data-tbl,table.exec-table,.cost-table,.fin-table,.pc-mix-table{
  background:#fff!important;
  color:var(--bb-text)!important;
  border-collapse:collapse!important;
  font-size:13px!important;
}
table.data-tbl th,.exec-table th,.cost-table th,.fin-table th,.pc-mix-table th{
  background:#f2f2f2!important;
  color:#55585d!important;
  border-bottom:1px solid var(--bb-line)!important;
  padding:10px 12px!important;
  font-size:10px!important;
  font-weight:900!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
}
table.data-tbl td,.exec-table td,.cost-table td,.fin-table td,.pc-mix-table td{
  background:#fff!important;
  color:var(--bb-text)!important;
  border-bottom:1px solid var(--bb-line-soft)!important;
  padding:10px 12px!important;
}
table.data-tbl tr:hover td,.exec-table tr:hover td{background:#fafafa!important}
.rank-chip{width:28px!important;height:28px!important;border-radius:7px!important;font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;font-weight:900!important}
.r1{background:#f7c542!important;color:#1f2329!important}
.r2{background:#a7b2c2!important;color:#fff!important}
.r3{background:#bf4d27!important;color:#fff!important}
.rN{background:#eceef0!important;color:#5f6368!important}
.mini-bar{height:5px!important;background:var(--bb-red)!important;border-radius:4px!important}
.str-badge,.mix-pill,.cost-pill,.formula-badge,.xfs-chip{
  background:#eeeeee!important;
  color:#55585d!important;
  border:0!important;
  border-radius:7px!important;
  box-shadow:none!important;
}
.btn-sm,.btn-primary-sm,.month-btn,.cost-subtab,.mix-tab,.pp-filter-btn,.clear-sheet-btn{
  border-radius:6px!important;
  box-shadow:none!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-weight:800!important;
  letter-spacing:0!important;
}
.btn-primary-sm,.month-btn.active{background:var(--bb-red)!important;border:1px solid var(--bb-red)!important;color:#fff!important}
.btn-primary-sm:hover{background:var(--bb-red-dark)!important;transform:none!important}
.btn-sm,.month-btn{
  background:#fff!important;
  border:1px solid #d2d6dc!important;
  color:#444b55!important;
}
.btn-sm:hover,.month-btn:hover,.cost-subtab:hover,.mix-tab:hover{
  border-color:var(--bb-red)!important;
  color:var(--bb-red)!important;
  background:#fff!important;
}
input,select,textarea,.filter-bar input,.filter-bar select,.edit-controls input,.edit-controls select,
.mix-toolbar input,.mix-toolbar select,.cost-field input,.cost-field select,.fin-input,
.form-col input,.form-col select,.pp-form-col input,.pp-form-col select,.pp-form-col textarea,
.xfs-input,.xfs-select,.pc-mix-input,.pc-nav-input{
  background:#fff!important;
  border:1px solid #d2d6dc!important;
  color:var(--bb-text)!important;
  border-radius:6px!important;
  box-shadow:none!important;
}
input:focus,select:focus,textarea:focus,.fin-input:focus,.xfs-input:focus,.xfs-select:focus{
  border-color:var(--bb-red)!important;
  outline:none!important;
  box-shadow:0 0 0 3px rgba(183,66,53,.11)!important;
  background:#fff!important;
}
.xfs-locked,.xfs-formula-cell,.xfs-user-cell input{
  background:#f7f8fa!important;
  color:var(--bb-text)!important;
  border-color:#d2d6dc!important;
}
.xfs-mini-title,.xfs-section-title b,#costSubFinancial .formula-badge,#costSubFinancial .cost-status-warn,#costSubFinancial [style*="#ffd54f"],#costSubFinancial [style*="255,213,79"]{
  color:var(--bb-text)!important;
}
.cost-note,.fin-note,.security-note{
  background:#fff4f2!important;
  color:#5f6368!important;
  border-color:#f2c8c2!important;
  border-left-color:var(--bb-red)!important;
}
.admin-sidebar{border-radius:0!important;border-top:0!important;border-left:0!important;border-bottom:0!important}
.admin-sidebar-btn{color:#3f4650!important;border-radius:6px!important;font-weight:800!important}
.admin-sidebar-btn:hover,.admin-sidebar-btn.active{background:#fae9e7!important;color:var(--bb-red)!important;box-shadow:none!important}
.login-card{background:#fff!important;color:var(--bb-text)!important;border:1px solid var(--bb-line)!important;border-radius:14px!important}
.login-logo-text h1{color:var(--bb-text)!important}
.login-title,.login-logo-text p,.demo-accounts p,.demo-row{color:var(--bb-muted)!important}
.login-logo-icon,.btn-login{background:var(--bb-red)!important;box-shadow:none!important}
@media(max-width:900px){
  .topbar{height:auto!important;min-height:54px!important;flex-wrap:wrap!important}
  .topbar-brand{width:154px!important;min-width:154px!important;max-width:154px!important}
  .nav-tabs{order:3!important;flex:0 0 100%!important;height:54px!important;background:var(--bb-red)!important;padding-left:0!important}
  .topbar-right{height:54px!important;padding:0 10px!important}
  .chart-grid-2,.chart-grid-half,.exec-layout{grid-template-columns:1fr!important}
  .kpi-strip,.exec-grid{grid-template-columns:repeat(2,1fr)!important}
  .page{padding:16px 12px 24px!important}
}
@media(max-width:520px){
  .kpi-strip,.exec-grid{grid-template-columns:1fr!important}
  .topbar-brand{width:144px!important;min-width:144px!important;max-width:144px!important}
  .topbar-icon svg{width:104px!important}
  .firebase-status-chip{display:none!important}
  .plant-selector{max-width:132px!important}
  .nav-tab{padding:0 12px!important;font-size:11px!important}
}
@media print{
  .topbar,#loginScreen,.modal-bg,.toast,.page-hdr-right,.filter-bar,.mix-toolbar,.edit-controls,.cost-actions,.pc-mix-actions{display:none!important}
  html,body,#app,.page{background:#fff!important;color:#111!important}
  .chart-card,.exec-card,.kpi-card,.exec-table-wrap,.cost-panel,.mix-detail,.mix-list{box-shadow:none!important;border-color:#d3d3d3!important;break-inside:avoid!important;page-break-inside:avoid!important}
  table th{background:#f2f2f2!important;color:#111!important}
  table td{color:#111!important}
  *{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}
}

:root{
  --bb-red:#b74235;
  --bb-red-dark:#9f352b;
  --bb-red-soft:#d95b43;
  --bb-orange:#df8439;
  --bb-green:#4f875e;
  --bb-blue:#4a84b7;
  --bb-ink:#1f2024;
  --bb-muted:#9a9a9a;
  --bb-line:#dedede;
  --bb-page:#f6f6f6;
}
.nav-tabs{flex:1 1 auto!important;min-width:0!important;overflow-x:auto!important;overflow-y:hidden!important;}
.nav-tab{padding:0 14px!important;min-width:max-content!important;}
.nav-tab[onclick*="cost"],.nav-tab[onclick*="quotation"]{display:flex!important;}
.nav-tab[onclick*="cost"] span,.nav-tab[onclick*="quotation"] span{display:none!important;}
#page-cost .page-hdr,#page-quotation .page-hdr{align-items:flex-start!important;gap:14px!important;}
#page-cost .page-hdr-left h2,#page-quotation .page-hdr-left h2{color:var(--bb-ink)!important;font-size:28px!important;font-weight:900!important;letter-spacing:0!important;}
#page-cost .page-hdr-left p,#page-quotation .page-hdr-left p{color:var(--bb-muted)!important;font-weight:700!important;}
#page-cost .page-hdr .btn-primary-sm,#page-cost .page-hdr .btn-sm,#page-quotation .page-hdr .btn-primary-sm,#page-quotation .page-hdr .btn-sm{
  height:38px!important;border-radius:7px!important;border:1px solid rgba(183,66,53,.22)!important;
  background:#fff!important;color:#55585d!important;box-shadow:none!important;font-weight:900!important;
}
#page-cost .page-hdr .btn-primary-sm,#page-quotation .page-hdr .btn-primary-sm{
  background:var(--bb-red)!important;border-color:var(--bb-red)!important;color:#fff!important;
}
#page-cost .cost-subtabs{display:flex!important;gap:8px!important;flex-wrap:wrap!important;margin:0 0 16px!important;}
#page-cost .cost-subtab{
  height:38px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;
  border-radius:7px!important;border:1px solid #d4d7dc!important;background:#fff!important;color:#4f5358!important;
  padding:0 16px!important;font-weight:900!important;letter-spacing:.01em!important;box-shadow:none!important;
}
#page-cost .cost-subtab.active{background:var(--bb-red)!important;border-color:var(--bb-red)!important;color:#fff!important;}
#page-cost .cost-subpage.active{display:block!important;}
#page-cost .chart-card,#page-cost .cost-panel,#page-cost .excel100-wrap,#page-cost .xfs-section,#page-cost .project-cost-card,#page-quotation .chart-card,#page-quotation .quote-card,#page-quotation .quotation-card{
  background:#fff!important;border:1px solid var(--bb-line)!important;border-radius:8px!important;
  box-shadow:0 1px 4px rgba(16,24,40,.12)!important;color:var(--bb-ink)!important;overflow:hidden!important;
}
#page-cost .chart-card::after,#page-quotation .chart-card::after,#page-cost .cost-panel::after{display:none!important;}
#page-cost .chart-hdr,#page-quotation .chart-hdr,#page-cost .excel100-head,#page-cost .cost-panel-hdr,#page-cost .project-cost-head{
  border-bottom:1px solid #ececec!important;margin-bottom:16px!important;padding-bottom:12px!important;
}
#page-cost .chart-title,#page-cost .excel100-title,#page-cost .project-cost-title,#page-cost .fin-section-title,#page-cost .xfs-section-title b,#page-quotation .chart-title,#page-quotation .quote-section-title{
  color:#55585d!important;font-size:14px!important;font-weight:900!important;text-transform:none!important;letter-spacing:.04em!important;
}
#page-cost .chart-badge,#page-quotation .chart-badge,#page-cost .excel100-note,#page-cost .xfs-section-title span{
  background:#eeeeee!important;border:0!important;border-radius:5px!important;color:#a0a0a0!important;
  font-size:11px!important;font-weight:900!important;letter-spacing:.08em!important;padding:4px 10px!important;
}
#page-cost .excel100-kpis,#page-cost .project-mini-kpis,#page-cost .fin-kpi-grid,#page-cost .cost-kpi-grid{
  display:grid!important;grid-template-columns:repeat(auto-fit,minmax(170px,1fr))!important;gap:12px!important;margin:12px 0 16px!important;
}
#page-cost .excel100-kpi,#page-cost .project-mini-kpi,#page-cost .fin-kpi,#page-cost .cost-kpi{
  background:#fff!important;border:1px solid var(--bb-line)!important;border-top:3px solid var(--bb-red)!important;
  border-radius:8px!important;box-shadow:0 1px 3px rgba(16,24,40,.08)!important;color:var(--bb-ink)!important;
  padding:14px 16px!important;
}
#page-cost .excel100-kpi:nth-child(2n),#page-cost .project-mini-kpi:nth-child(2n),#page-cost .fin-kpi:nth-child(2n),#page-cost .cost-kpi:nth-child(2n){border-top-color:var(--bb-orange)!important;}
#page-cost .excel100-kpi:nth-child(3n),#page-cost .project-mini-kpi:nth-child(3n),#page-cost .fin-kpi:nth-child(3n),#page-cost .cost-kpi:nth-child(3n){border-top-color:var(--bb-green)!important;}
#page-cost .excel100-kpi .label,#page-cost .project-mini-kpi .label,#page-cost .fin-kpi .label,#page-cost .cost-kpi .label{
  color:#9a9a9a!important;font-weight:900!important;letter-spacing:.04em!important;text-transform:uppercase!important;
}
#page-cost .excel100-kpi .value,#page-cost .project-mini-kpi .value,#page-cost .fin-kpi .value,#page-cost .cost-kpi .value{
  color:var(--bb-ink)!important;font-weight:900!important;
}
#page-cost input,#page-cost select,#page-cost textarea,#page-quotation input,#page-quotation select,#page-quotation textarea{
  background:#fff!important;border:1px solid #d4d7dc!important;border-radius:7px!important;color:var(--bb-ink)!important;
  min-height:36px!important;box-shadow:none!important;font-weight:700!important;
}
#page-cost input:focus,#page-cost select:focus,#page-cost textarea:focus,#page-quotation input:focus,#page-quotation select:focus,#page-quotation textarea:focus{
  outline:0!important;border-color:var(--bb-red)!important;box-shadow:0 0 0 3px rgba(183,66,53,.12)!important;
}
#page-cost label,#page-quotation label{color:#6a6e75!important;font-weight:900!important;letter-spacing:.02em!important;}
#page-cost .xfs-table-wrap,#page-cost .pc-table-wrap,#page-cost .cost-table-wrap,#page-cost .excel100-sheet,#page-quotation .tbl-wrap,#page-quotation .quote-products-wrap{
  background:#fff!important;border:1px solid var(--bb-line)!important;border-radius:8px!important;overflow:auto!important;
}
#page-cost table,#page-quotation table{background:#fff!important;color:var(--bb-ink)!important;}
#page-cost th,#page-quotation th,#page-cost .xfs-table th,#page-cost .pc-mix-table th,#page-cost .cost-table th,#page-cost .fin-table th,#page-quotation .quote-products th,#page-quotation table.data-tbl th{
  background:#f1f1f1!important;color:#55585d!important;border-bottom:1px solid #dedede!important;
  font-weight:900!important;letter-spacing:.06em!important;text-transform:uppercase!important;
}
#page-cost td,#page-quotation td,#page-cost .xfs-table td,#page-cost .pc-mix-table td,#page-cost .cost-table td,#page-cost .fin-table td,#page-quotation .quote-products td,#page-quotation table.data-tbl td{
  background:#fff!important;color:var(--bb-ink)!important;border-bottom:1px solid #e5e5e5!important;
}
#page-cost tr:hover td,#page-quotation tr:hover td{background:#fafafa!important;}
#page-cost .pc-total-row td,#page-cost .xfs-row-total td,#page-cost .cost-total-row td,#page-quotation .quote-total-row td{
  background:#fae9e7!important;color:#111827!important;font-weight:900!important;
}
#page-cost .kpi-positive,#page-cost .xfs-good,#page-quotation .kpi-positive{color:#3f7d56!important;font-weight:900!important;}
#page-cost .kpi-negative,#page-cost .xfs-bad,#page-quotation .kpi-negative{color:var(--bb-red)!important;font-weight:900!important;}
#page-cost .cost-actions,#page-cost .pc-mix-actions,#page-cost .xfs-product-tools,#page-quotation .quote-actions{
  display:flex!important;gap:8px!important;align-items:center!important;justify-content:flex-end!important;flex-wrap:wrap!important;margin-top:12px!important;
}
#page-cost .cost-actions button,#page-cost .pc-mix-actions button,#page-cost .xfs-product-tools button,#page-quotation .quote-actions button,#page-quotation button{
  border-radius:7px!important;font-weight:900!important;box-shadow:none!important;
}
#page-cost .btn-primary-sm,#page-cost .cost-actions .btn-primary-sm,#page-quotation .btn-primary-sm{
  background:var(--bb-red)!important;border:1px solid var(--bb-red)!important;color:#fff!important;
}
#page-cost .btn-sm,#page-cost .cost-actions .btn-sm,#page-quotation .btn-sm{
  background:#fff!important;border:1px solid #d4d7dc!important;color:#55585d!important;
}
#page-quotation .quote-form-grid{
  display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:12px!important;align-items:end!important;
}
#page-quotation .quote-section-title{
  grid-column:1/-1!important;background:#f7f8fa!important;border-left:4px solid var(--bb-red)!important;
  border-radius:6px!important;padding:8px 10px!important;margin-top:4px!important;
}
#page-quotation .quote-field{display:flex!important;flex-direction:column!important;gap:6px!important;min-width:0!important;}
#page-quotation .quote-field.full{grid-column:span 2!important;}
#page-quotation .quote-field label{font-size:12px!important;color:#6a6e75!important;}
#page-quotation .quote-products{min-width:980px!important;}
#page-quotation .quote-products input,#page-quotation .quote-products select{min-width:90px!important;}
#page-quotation .quote-products .desc,#page-quotation .quote-products [class*="desc"]{min-width:180px!important;}
#page-quotation .quote-summary,#page-quotation .quote-total-box,#page-quotation .quote-note,#quotePrintArea{
  background:#fff!important;color:#111827!important;border-color:var(--bb-line)!important;
}
@media(max-width:1100px){
  .nav-tab{padding:0 12px!important;font-size:13px!important;}
  #page-quotation .quote-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
}
@media(max-width:640px){
  #page-cost .page-hdr,#page-quotation .page-hdr{flex-direction:column!important;}
  #page-quotation .quote-form-grid{grid-template-columns:1fr!important;}
  #page-quotation .quote-field.full{grid-column:1/-1!important;}
}
@media print{
  #page-cost,#page-quotation,#quotePrintArea{background:#fff!important;color:#111!important;}
  #page-cost .chart-card,#page-cost .cost-panel,#page-cost .excel100-wrap,#page-cost .xfs-section,#page-quotation .chart-card{box-shadow:none!important;}
}

:root{
  --bb-logo-url:url("insee-concrete-logo-crop.png");
  --bb-red:#b74235;
  --bb-red-dark:#983126;
  --bb-red-soft:#fff1ef;
  --bb-orange:#df8439;
  --bb-orange-soft:#fff4e8;
  --bb-green:#4f875e;
  --bb-green-soft:#edf7f0;
  --bb-blue:#4a84b7;
  --bb-blue-soft:#eef6fc;
  --bb-text:#24272d;
  --bb-muted:#667085;
  --bb-line:#dfe3e8;
  --bb-soft:#f7f8fa;
}
.topbar-brand{
  width:224px!important;
  min-width:224px!important;
  max-width:224px!important;
  background:#fff!important;
  border-right:1px solid rgba(0,0,0,.12)!important;
  padding:0 16px!important;
}
.topbar-icon{
  width:190px!important;
  height:42px!important;
  background-image:none!important;
  background-color:#fff!important;
  background-repeat:no-repeat!important;
  background-position:center!important;
  background-size:contain!important;
  border-radius:0!important;
  box-shadow:none!important;
}
.topbar-icon svg,.topbar-name{display:none!important}
.topbar-icon .bb-topbar-logo-img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
}
.login-card{width:440px!important;padding-top:34px!important}
.login-logo{
  display:block!important;
  margin:0 0 24px!important;
  text-align:center!important;
}
.login-logo-icon{
  width:100%!important;
  height:112px!important;
  background-image:none!important;
  background-color:#fff!important;
  background-repeat:no-repeat!important;
  background-position:center!important;
  background-size:contain!important;
  border-radius:0!important;
  box-shadow:none!important;
  padding:0!important;
  margin:0 auto 8px!important;
}
.login-logo-icon svg,.login-logo-text{display:none!important}
.login-logo-icon .bb-login-logo-img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
}
.login-title{text-align:center!important;color:#606873!important;font-weight:700!important}
#page-pipeline .page-hdr-left h2{
  color:#202124!important;
  font-size:26px!important;
  font-weight:900!important;
}
#page-pipeline .page-hdr-left p{
  color:#606873!important;
  font-size:13px!important;
  font-weight:700!important;
}
#page-pipeline .pp-stats{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr))!important;
  gap:12px!important;
  margin:0 0 14px!important;
}
#page-pipeline .pp-stat{
  background:#fff!important;
  border:1px solid var(--bb-line)!important;
  border-top:3px solid var(--bb-red)!important;
  border-radius:8px!important;
  box-shadow:0 1px 3px rgba(16,24,40,.08)!important;
  padding:13px 15px!important;
}
#page-pipeline .pp-stat:nth-child(2){border-top-color:var(--bb-orange)!important}
#page-pipeline .pp-stat:nth-child(3),#page-pipeline .pp-stat:nth-child(6){border-top-color:var(--bb-green)!important}
#page-pipeline .ps-num{
  color:#202124!important;
  font-size:25px!important;
  font-weight:900!important;
  letter-spacing:0!important;
}
#page-pipeline .ps-lbl{
  color:#606873!important;
  font-size:11px!important;
  font-weight:900!important;
  letter-spacing:.04em!important;
  text-transform:uppercase!important;
}
#page-pipeline .pp-filters{
  background:#fff!important;
  border:1px solid var(--bb-line)!important;
  border-radius:8px!important;
  box-shadow:0 1px 3px rgba(16,24,40,.08)!important;
  padding:12px!important;
  gap:8px!important;
}
#page-pipeline .pp-filter-lbl{
  color:#4f5358!important;
  font-weight:900!important;
  letter-spacing:.03em!important;
}
#page-pipeline .pp-sep{
  background:var(--bb-line)!important;
  opacity:1!important;
}
#page-pipeline .pp-search{
  background:#fff!important;
  border:1px solid #d2d6dc!important;
  color:#202124!important;
  border-radius:6px!important;
  min-height:34px!important;
  font-weight:800!important;
}
#page-pipeline .pp-filter-btn{
  background:#fff!important;
  border:1px solid #d2d6dc!important;
  color:#4f5358!important;
  border-radius:6px!important;
  min-height:34px!important;
  font-weight:900!important;
}
#page-pipeline .pp-filter-btn:hover{
  border-color:var(--bb-red)!important;
  color:var(--bb-red)!important;
}
#page-pipeline .pp-filter-btn.active{
  background:var(--bb-red)!important;
  border-color:var(--bb-red)!important;
  color:#fff!important;
}
#page-pipeline .pp-grid{
  display:grid!important;
  gap:12px!important;
}
#page-pipeline .pp-card{
  background:#fff!important;
  border:1px solid var(--bb-line)!important;
  border-radius:8px!important;
  box-shadow:0 1px 4px rgba(16,24,40,.10)!important;
  color:#202124!important;
  overflow:hidden!important;
}
#page-pipeline .pp-card-hdr{
  background:#fff!important;
  color:#202124!important;
  border-bottom:1px solid #edf0f2!important;
  padding:14px 16px!important;
}
#page-pipeline .pp-card.expanded .pp-card-hdr{
  background:#fff8f7!important;
  border-bottom-color:#f1c8c2!important;
}
#page-pipeline .pp-no{
  background:var(--bb-red)!important;
  color:#fff!important;
  border-radius:7px!important;
  font-weight:900!important;
  box-shadow:none!important;
}
#page-pipeline .pp-name{
  color:#202124!important;
  font-size:16px!important;
  font-weight:900!important;
  line-height:1.35!important;
}
#page-pipeline .pp-vol-num{
  color:var(--bb-red)!important;
  font-weight:900!important;
}
#page-pipeline .pp-vol-lbl{
  color:#606873!important;
  font-weight:800!important;
}
#page-pipeline .pp-card-body{
  background:#fff!important;
  color:#202124!important;
  padding:14px 16px!important;
}
#page-pipeline .pp-detail-grp{
  background:#fff!important;
  border:1px solid var(--bb-line)!important;
  border-left:4px solid var(--bb-red)!important;
  border-radius:8px!important;
  padding:12px!important;
  color:#202124!important;
}
#page-pipeline .pp-detail-grp:nth-child(2){border-left-color:var(--bb-orange)!important}
#page-pipeline .pp-detail-grp:nth-child(3){border-left-color:var(--bb-green)!important}
#page-pipeline .pp-grp-lbl{
  color:#4f5358!important;
  background:#f4f5f6!important;
  border-radius:5px!important;
  padding:6px 8px!important;
  font-size:12px!important;
  font-weight:900!important;
  letter-spacing:.04em!important;
  text-transform:none!important;
}
#page-pipeline .pp-field{
  background:#fff!important;
  border-bottom:1px solid #edf0f2!important;
  padding:8px 0!important;
}
#page-pipeline .pp-field-k{
  color:#5b626d!important;
  font-size:12px!important;
  font-weight:900!important;
}
#page-pipeline .pp-field-v{
  color:#202124!important;
  font-size:13px!important;
  font-weight:800!important;
  line-height:1.45!important;
  word-break:break-word!important;
}
#page-pipeline .mono{
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  letter-spacing:0!important;
}
#page-pipeline .pp-badge{
  background:#f1f2f4!important;
  border:1px solid #d9dee4!important;
  color:#4f5358!important;
  border-radius:999px!important;
  font-size:11px!important;
  font-weight:900!important;
  box-shadow:none!important;
}
#page-pipeline .pp-b-working,#page-pipeline .pp-b-construction{
  background:var(--bb-green-soft)!important;
  border-color:#bddbc5!important;
  color:#336d43!important;
}
#page-pipeline .pp-b-bidding,#page-pipeline .pp-b-commercial{
  background:var(--bb-orange-soft)!important;
  border-color:#f1c99d!important;
  color:#a95d18!important;
}
#page-pipeline .pp-b-predev,#page-pipeline .pp-b-prospect,#page-pipeline .pp-b-residential{
  background:var(--bb-red-soft)!important;
  border-color:#e7bbb5!important;
  color:var(--bb-red-dark)!important;
}
#page-pipeline .pp-b-infrastructure,#page-pipeline .pp-b-education,#page-pipeline .pp-b-province{
  background:var(--bb-blue-soft)!important;
  border-color:#bdd6ea!important;
  color:#356d9b!important;
}
#page-pipeline .pp-b-backlog,#page-pipeline .pp-b-default,#page-pipeline .pp-b-order{
  background:#f2f4f7!important;
  border-color:#d7dce2!important;
  color:#4f5358!important;
}
#page-pipeline .pp-b-loss{
  background:#f8eeee!important;
  border-color:#e2b9b9!important;
  color:#9f352b!important;
}
#page-pipeline .pp-remarks-section{
  background:#fff!important;
  border:1px solid var(--bb-line)!important;
  border-radius:8px!important;
  color:#202124!important;
}
#page-pipeline .pp-remarks-hdr{
  background:#f7f8fa!important;
  border-bottom:1px solid var(--bb-line)!important;
}
#page-pipeline .pp-remarks-lbl{
  color:#4f5358!important;
  font-weight:900!important;
}
#page-pipeline .pp-remark-item{
  background:#fff!important;
  border-bottom:1px solid #edf0f2!important;
  color:#202124!important;
}
#page-pipeline .pp-remark-dot{
  background:var(--bb-red)!important;
  box-shadow:none!important;
}
#page-pipeline .pp-remark-date{
  color:#606873!important;
  font-weight:900!important;
}
#page-pipeline .pp-remark-text,#page-pipeline .pp-remark-txt{
  color:#202124!important;
  font-weight:800!important;
}
#page-pipeline .pp-add-remark-row{
  background:#fff!important;
  border-top:1px solid var(--bb-line)!important;
}
#page-pipeline .pp-add-remark-row input,#page-pipeline .pp-add-remark-row textarea{
  background:#fff!important;
  border:1px solid #d2d6dc!important;
  color:#202124!important;
  font-weight:800!important;
  border-radius:6px!important;
}
#page-pipeline .pp-add-remark-btn,#page-pipeline .pp-remark-save-btn{
  background:var(--bb-red)!important;
  border:1px solid var(--bb-red)!important;
  color:#fff!important;
  border-radius:6px!important;
  font-weight:900!important;
}
#page-pipeline .pp-remark-del{
  background:#fff!important;
  border:1px solid #e0b4ae!important;
  color:var(--bb-red)!important;
  border-radius:6px!important;
}
#page-pipeline .pp-expand-btn{
  background:#fff!important;
  color:#4f5358!important;
  border-top:1px solid var(--bb-line)!important;
  font-weight:900!important;
}
#page-pipeline .pp-card.expanded .pp-expand-btn{
  color:var(--bb-red)!important;
}
#page-pipeline .pp-expand-arrow{display:none!important}
#page-pipeline .btn-sm{
  background:#fff!important;
  border:1px solid #d2d6dc!important;
  color:#4f5358!important;
}
#page-pipeline .btn-primary-sm{
  background:var(--bb-red)!important;
  border-color:var(--bb-red)!important;
  color:#fff!important;
}
#page-pipeline .pp-empty{
  background:#fff!important;
  border:1px dashed #cfd5dc!important;
  color:#606873!important;
  border-radius:8px!important;
  font-weight:800!important;
}
.pp-modal,.pp-modal-overlay .pp-modal{
  background:#fff!important;
  color:#202124!important;
  border:1px solid var(--bb-line)!important;
  border-radius:10px!important;
}
.pp-modal-title{
  color:#202124!important;
  font-weight:900!important;
}
.pp-form-col label{
  color:#4f5358!important;
  font-weight:900!important;
}
.pp-form-col input,.pp-form-col select,.pp-form-col textarea{
  background:#fff!important;
  color:#202124!important;
  border:1px solid #d2d6dc!important;
  border-radius:6px!important;
  font-weight:800!important;
}
@media(max-width:900px){
  .topbar-brand{width:190px!important;min-width:190px!important;max-width:190px!important}
  .topbar-icon{width:160px!important}
}
@media(max-width:520px){
  .topbar-brand{width:152px!important;min-width:152px!important;max-width:152px!important;padding:0 10px!important}
  .topbar-icon{width:132px!important;height:38px!important}
  .login-logo-icon{height:88px!important}
}

.topbar select.plant-selector,#plantFilter.plant-selector{
  -webkit-appearance:none!important;
  appearance:none!important;
  min-width:218px!important;
  max-width:260px!important;
  height:34px!important;
  padding:5px 34px 5px 14px!important;
  background-color:rgba(255,255,255,.14)!important;
  background-image:linear-gradient(45deg,transparent 50%,#fff 50%),linear-gradient(135deg,#fff 50%,transparent 50%)!important;
  background-position:calc(100% - 18px) 14px,calc(100% - 12px) 14px!important;
  background-size:6px 6px,6px 6px!important;
  background-repeat:no-repeat!important;
  border:1px solid rgba(255,255,255,.34)!important;
  border-radius:8px!important;
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-size:13px!important;
  font-weight:800!important;
  line-height:22px!important;
  opacity:1!important;
  box-shadow:none!important;
}
.topbar select.plant-selector:focus,#plantFilter.plant-selector:focus{
  border-color:rgba(255,255,255,.72)!important;
  box-shadow:0 0 0 3px rgba(255,255,255,.14)!important;
  outline:0!important;
}
.topbar select.plant-selector option,#plantFilter.plant-selector option{
  background:#fff!important;
  color:#24272d!important;
  -webkit-text-fill-color:#24272d!important;
  font-weight:800!important;
}
#page-dashboard .kpi-tag,#page-dashboard .kpi-card-icon{display:none!important}
#page-dashboard .kpi-card{min-height:104px!important}
#page-admin{
  background:#f7f8fa!important;
  color:#24272d!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
}
#page-admin .admin-grid{
  background:#f7f8fa!important;
  grid-template-columns:260px minmax(0,1fr)!important;
  min-height:calc(100vh - 54px)!important;
}
#page-admin .admin-sidebar{
  background:#fff!important;
  border-right:1px solid #dfe3e8!important;
  box-shadow:none!important;
  padding:26px 20px!important;
}
#page-admin .admin-sidebar-title{
  color:#77808d!important;
  font-size:12px!important;
  letter-spacing:.08em!important;
  text-transform:none!important;
  font-weight:900!important;
  padding:0 10px!important;
  margin:14px 0 10px!important;
}
#page-admin .admin-sidebar-btn{
  background:transparent!important;
  color:#3f4650!important;
  border:1px solid transparent!important;
  border-radius:8px!important;
  font-size:15px!important;
  font-weight:900!important;
  letter-spacing:0!important;
  padding:12px 14px!important;
  margin:4px 0!important;
  box-shadow:none!important;
  gap:0!important;
}
#page-admin .admin-sidebar-btn:hover{
  background:#fff1ef!important;
  color:#b74235!important;
  border-color:#efd0cb!important;
}
#page-admin .admin-sidebar-btn.active{
  background:#fae9e7!important;
  color:#b74235!important;
  border-color:#e8c4bd!important;
  border-left:4px solid #b74235!important;
  padding-left:10px!important;
  box-shadow:none!important;
}
#page-admin .admin-content{
  background:#f7f8fa!important;
  padding:34px 34px!important;
}
#page-admin .admin-section-hdr{
  background:#fff!important;
  border:1px solid #dfe3e8!important;
  border-radius:8px 8px 0 0!important;
  padding:18px 20px!important;
  margin:0!important;
  box-shadow:0 1px 3px rgba(16,24,40,.06)!important;
}
#page-admin .admin-section-title{
  color:#24272d!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-size:18px!important;
  font-weight:900!important;
  letter-spacing:0!important;
  text-transform:none!important;
}
#page-admin .admin-section-hdr p,#page-admin .ckpa-sub{
  color:#667085!important;
  font-size:13px!important;
  font-weight:700!important;
  line-height:1.55!important;
}
#page-admin .admin-section.active>table,#page-admin .tbl-wrap,#page-admin .ckpa-card,#page-admin .upload-zone,#page-admin .upload-result,#page-admin .modal-box,#page-admin .ckpa-table-wrap{
  background:#fff!important;
  border:1px solid #dfe3e8!important;
  border-radius:8px!important;
  box-shadow:0 1px 3px rgba(16,24,40,.06)!important;
  color:#24272d!important;
}
#page-admin .ckpa-card{padding:18px!important}
#page-admin .ckpa-title{
  color:#24272d!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-size:22px!important;
  font-weight:900!important;
}
#page-admin table.data-tbl,#page-admin .ckpa-table,#page-admin #userTable{
  background:#fff!important;
  color:#24272d!important;
  border-collapse:collapse!important;
}
#page-admin table.data-tbl th,#page-admin .ckpa-table th,#page-admin #userTable th{
  background:#f1f2f4!important;
  color:#4f5358!important;
  border-bottom:1px solid #dfe3e8!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-size:12px!important;
  font-weight:900!important;
  letter-spacing:.06em!important;
}
#page-admin table.data-tbl td,#page-admin .ckpa-table td,#page-admin #userTable td{
  background:#fff!important;
  color:#24272d!important;
  border-bottom:1px solid #e7eaee!important;
  font-size:14px!important;
  font-weight:800!important;
}
#page-admin table.data-tbl tr:hover td,#page-admin .ckpa-table tr:hover td,#page-admin #userTable tr:hover td{
  background:#fff8f7!important;
}
#page-admin input,#page-admin select,#page-admin textarea,#page-admin .ckpa-input,#page-admin .ckpa-select,#page-admin .ckpa-row-input{
  background:#fff!important;
  border:1px solid #d2d6dc!important;
  color:#24272d!important;
  -webkit-text-fill-color:#24272d!important;
  border-radius:7px!important;
  box-shadow:none!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-weight:800!important;
}
#page-admin input:focus,#page-admin select:focus,#page-admin textarea:focus,#page-admin .ckpa-input:focus,#page-admin .ckpa-select:focus,#page-admin .ckpa-row-input:focus{
  border-color:#b74235!important;
  box-shadow:0 0 0 3px rgba(183,66,53,.12)!important;
  outline:0!important;
}
#page-admin button,#page-admin .btn-sm,#page-admin .btn-primary-sm,#page-admin .ckpa-btn,#page-admin .ckpa-link{
  border-radius:7px!important;
  box-shadow:none!important;
  font-family:Sarabun,'IBM Plex Sans Thai',system-ui,sans-serif!important;
  font-weight:900!important;
  letter-spacing:0!important;
  text-decoration:none!important;
}
#page-admin .btn-primary-sm,#page-admin .ckpa-btn,#page-admin button[onclick*="add"],#page-admin button[onclick*="save"],#page-admin button[id*="Save"],#page-admin #ckpaSaveBtn{
  background:#b74235!important;
  border:1px solid #b74235!important;
  color:#fff!important;
}
#page-admin .btn-sm,#page-admin .ckpa-link,#page-admin .ckpa-btn.secondary,#page-admin button[onclick*="openKamAccessModal"],#page-admin button[onclick*="resetPass"],#page-admin button[onclick*="toggleUser"],#page-admin button[id*="Refresh"]{
  background:#fff!important;
  border:1px solid #d2d6dc!important;
  color:#3f4650!important;
}
#page-admin button[onclick*="removeUser"],#page-admin .ckpa-btn.danger{
  background:#fff1ef!important;
  border:1px solid #e4bbb5!important;
  color:#b74235!important;
}
#page-admin .ckpa-code,#page-admin .ckpa-row-input.code{
  color:#b74235!important;
  -webkit-text-fill-color:#b74235!important;
}
#page-admin .upload-icon,#page-admin .chart-dot,#page-admin .kpi-card-icon{display:none!important}
#page-admin .str-badge,#page-admin [style*="255,213,79"],#page-admin [style*="33,150,243"]{
  color:#3f4650!important;
}
@media(max-width:900px){
  #page-admin .admin-grid{grid-template-columns:1fr!important}
  #page-admin .admin-sidebar{border-right:0!important;border-bottom:1px solid #dfe3e8!important}
  .topbar select.plant-selector,#plantFilter.plant-selector{min-width:168px!important;max-width:190px!important}
}

.topbar .topbar-brand{width:236px!important;min-width:236px!important;max-width:236px!important;background:#fff!important;padding:0 14px!important}
  .topbar .topbar-icon{width:206px!important;height:48px!important;background:#fff!important;border-radius:6px!important;padding:4px 8px!important;box-shadow:none!important;overflow:hidden!important}
  .topbar .topbar-icon img,.login-logo-icon img{display:block!important;width:100%!important;height:100%!important;object-fit:contain!important;object-position:center!important}
  #loginScreen .login-logo-icon{width:310px!important;height:96px!important;background:#fff!important;border-radius:12px!important;padding:8px 14px!important;box-shadow:0 10px 28px rgba(0,0,0,.18)!important}
  @media(max-width:768px){.topbar .topbar-brand{width:186px!important;min-width:186px!important;max-width:186px!important}.topbar .topbar-icon{width:162px!important;height:42px!important}#loginScreen .login-logo-icon{width:260px!important;height:82px!important}}

.topbar .topbar-icon img.insee-logo-img,
  #loginScreen .login-logo-icon img.insee-logo-img{display:block!important;width:100%!important;height:100%!important;object-fit:contain!important;object-position:center!important;}
  .topbar .topbar-icon svg,
  #loginScreen .login-logo-icon svg{display:none!important;}

/* Final repair: keep the latest topbar/dashboard behavior and remove confusing status UI. */
.firebase-status-chip,#firebaseStatusChip{display:none!important;visibility:hidden!important;width:0!important;min-width:0!important;padding:0!important;margin:0!important;border:0!important;overflow:hidden!important}
.topbar-right{gap:10px!important;padding-left:14px!important}
.topbar .plant-selector,#plantFilter.plant-selector{min-width:190px!important;max-width:260px!important;height:34px!important;padding:5px 34px 5px 12px!important;text-overflow:ellipsis!important;white-space:nowrap!important;overflow:hidden!important}
.nav-tab[onclick*="strength"],.nav-tab[data-page="strength"],.nav-tab[onclick*="cost"],.nav-tab[onclick*="quotation"]{display:flex!important;align-items:center!important;justify-content:center!important;min-width:max-content!important}
#page-strength .page-hdr-left h2{color:var(--bb-ink,#1f2024)!important;font-size:28px!important;font-weight:900!important}
#page-strength .page-hdr-left p{color:var(--bb-muted,#8a8f98)!important;font-weight:700!important}
#page-strength .mix-summary{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:12px!important;margin-bottom:16px!important}
#page-strength .mix-summary-card,#page-strength .mix-list,#page-strength .mix-detail{background:#fff!important;border:1px solid var(--bb-line,#dedede)!important;border-radius:8px!important;box-shadow:0 1px 4px rgba(16,24,40,.10)!important;color:var(--bb-ink,#1f2024)!important}
#page-strength .mix-summary-card{border-top:3px solid var(--bb-red,#b74235)!important;padding:16px 18px!important}
#page-strength .mix-toolbar{display:flex!important;gap:10px!important;flex-wrap:wrap!important;margin:0 0 14px!important}
#page-strength .mix-toolbar select,#page-strength .mix-toolbar input{height:38px!important;background:#fff!important;border:1px solid #d4d7dc!important;border-radius:7px!important;color:#24272c!important;font-weight:800!important;box-shadow:none!important}
#page-strength .mix-category-tabs{display:flex!important;gap:8px!important;flex-wrap:wrap!important;margin-bottom:14px!important}
#page-strength .mix-tab{height:34px!important;border-radius:7px!important;border:1px solid #d4d7dc!important;background:#fff!important;color:#4f5358!important;padding:0 12px!important;font-weight:900!important}
#page-strength .mix-tab.active{background:var(--bb-red,#b74235)!important;border-color:var(--bb-red,#b74235)!important;color:#fff!important}
#page-strength .mix-layout{display:grid!important;grid-template-columns:minmax(280px,360px) 1fr!important;gap:14px!important;align-items:start!important}
#page-strength .mix-list-hdr{border-bottom:1px solid var(--bb-line,#dedede)!important;padding:12px 14px!important;color:#202124!important;font-weight:900!important}
#page-strength .mix-list-body{max-height:620px!important;overflow:auto!important;padding:10px!important}
#page-strength .mix-item{width:100%!important;background:#fff!important;border:1px solid #e2e5e9!important;border-radius:7px!important;color:#202124!important;padding:11px 12px!important;margin-bottom:8px!important;text-align:left!important;box-shadow:none!important}
#page-strength .mix-item.active{border-color:var(--bb-red,#b74235)!important;background:#fff7f5!important;box-shadow:inset 4px 0 0 var(--bb-red,#b74235)!important}
#page-strength .mix-item-code{font-size:15px!important;font-weight:900!important;color:#b74235!important}
#page-strength .mix-item-meta{font-size:12px!important;color:#6f7782!important;line-height:1.45!important;margin-top:4px!important}
#page-strength .mix-detail{padding:18px!important;min-height:420px!important}
#page-strength .mix-detail-title{font-size:28px!important;color:#202124!important;font-weight:900!important}
#page-strength .mix-detail-sub{color:#6f7782!important;font-weight:700!important}
#page-strength .mix-pill{display:inline-flex!important;align-items:center!important;height:26px!important;border-radius:999px!important;background:#f3f4f6!important;border:1px solid #e1e4e8!important;color:#555b63!important;padding:0 10px!important;font-size:12px!important;font-weight:800!important}
#page-strength .mix-info{background:#fafafa!important;border:1px solid #e6e8ec!important;border-radius:7px!important;padding:11px 12px!important}
#page-strength .mix-info .label{color:#8a8f98!important;font-size:10px!important;font-weight:900!important;text-transform:uppercase!important}
#page-strength .mix-info .value{color:#202124!important;font-weight:900!important}
#page-strength .mix-material{background:#fff!important;border:1px solid #e6e8ec!important;border-radius:7px!important;padding:10px 12px!important}
#page-strength .mix-bar-track{height:7px!important;background:#eef0f3!important;border-radius:999px!important;overflow:hidden!important;margin-top:8px!important}
#page-strength .mix-bar-fill{height:100%!important;background:linear-gradient(90deg,var(--bb-red,#b74235),var(--bb-orange,#df8439))!important;border-radius:999px!important}
#inseeCostPrintRoot{display:none}
@media(max-width:980px){#page-strength .mix-summary{grid-template-columns:repeat(2,minmax(0,1fr))!important}#page-strength .mix-layout{grid-template-columns:1fr!important}.topbar .plant-selector,#plantFilter.plant-selector{min-width:150px!important;max-width:190px!important}}
@media(max-width:560px){#page-strength .mix-summary{grid-template-columns:1fr!important}.topbar .plant-selector,#plantFilter.plant-selector{min-width:132px!important;max-width:160px!important}}
@media print{body>*:not(#inseeCostPrintRoot){display:none!important}#inseeCostPrintRoot{display:block!important;background:#fff!important;color:#111!important;font-family:Sarabun,Arial,sans-serif!important;padding:0!important}.cost-print-page{page-break-after:always!important;padding:10mm!important}.cost-print-page:last-child{page-break-after:auto!important}.cost-print-title{font-size:18px!important;font-weight:900!important;color:#111!important;border-bottom:3px solid #b74235!important;padding-bottom:6px!important;margin-bottom:10px!important}.cost-print-meta{font-size:10px!important;color:#555!important;margin-bottom:10px!important}.cost-print-page input,.cost-print-page select,.cost-print-page textarea{border:0!important;background:transparent!important;color:#111!important;padding:0!important;box-shadow:none!important}.cost-print-page .btn-sm,.cost-print-page .btn-primary-sm,.cost-print-page .cost-actions,.cost-print-page .pc-mix-actions,.cost-print-page .xfs-product-tools{display:none!important}.cost-print-page .chart-card,.cost-print-page .cost-panel,.cost-print-page .project-cost-card,.cost-print-page .xfs-section,.cost-print-page .excel100-wrap{box-shadow:none!important;border:1px solid #d0d0d0!important;background:#fff!important;color:#111!important;break-inside:avoid!important;page-break-inside:avoid!important}.cost-print-page table{width:100%!important;border-collapse:collapse!important;color:#111!important}.cost-print-page th{background:#eee!important;color:#111!important}.cost-print-page td,.cost-print-page th{border:1px solid #ccc!important;padding:4px 5px!important;font-size:9px!important}.cost-print-page canvas{max-height:180px!important}.cost-print-page img.cost-print-canvas{max-width:100%!important;height:auto!important}}

/* Final topbar cleanup: stop sticky/freeze behavior and prevent logo overlap. */
.topbar{
  position:relative!important;
  top:auto!important;
  z-index:200!important;
  height:56px!important;
  min-height:56px!important;
  padding:0!important;
  gap:0!important;
  display:flex!important;
  align-items:center!important;
  overflow:visible!important;
}
.topbar .topbar-brand{
  position:relative!important;
  flex:0 0 196px!important;
  width:196px!important;
  min-width:196px!important;
  max-width:196px!important;
  height:56px!important;
  min-height:56px!important;
  align-self:stretch!important;
  margin:0!important;
  padding:6px 16px!important;
  background:#fff!important;
  border-radius:0!important;
  border-right:1px solid rgba(0,0,0,.10)!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  transform:none!important;
}
.topbar .topbar-icon{
  width:164px!important;
  height:44px!important;
  max-width:164px!important;
  max-height:44px!important;
  margin:0!important;
  padding:0!important;
  background:transparent!important;
  border-radius:0!important;
  box-shadow:none!important;
  overflow:hidden!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  transform:none!important;
}
.topbar .topbar-icon img,
.topbar .topbar-icon img.insee-logo-img,
.topbar .topbar-icon .bb-topbar-logo-img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:100%!important;
  max-height:100%!important;
  object-fit:contain!important;
  object-position:center!important;
}
.topbar .nav-tabs{
  position:relative!important;
  flex:1 1 auto!important;
  min-width:0!important;
  margin-left:0!important;
  padding-left:8px!important;
  transform:none!important;
}
.topbar .nav-tab:first-child{
  margin-left:0!important;
}
@media(max-width:900px){
  .topbar{
    position:relative!important;
    height:auto!important;
    min-height:56px!important;
    flex-wrap:wrap!important;
  }
  .topbar .topbar-brand{
    flex:0 0 168px!important;
    width:168px!important;
    min-width:168px!important;
    max-width:168px!important;
  }
  .topbar .topbar-icon{
    width:138px!important;
    max-width:138px!important;
  }
  .topbar .nav-tabs{
    order:3!important;
    flex:0 0 100%!important;
    padding-left:0!important;
  }
}
@media(max-width:520px){
  .topbar .topbar-brand{
    flex-basis:146px!important;
    width:146px!important;
    min-width:146px!important;
    max-width:146px!important;
    padding:6px 10px!important;
  }
  .topbar .topbar-icon{
    width:126px!important;
    max-width:126px!important;
  }
}

#page-dashboard .plant-month-banner{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:14px!important;
  background:#fff!important;
  border:1px solid #dfe3e8!important;
  border-left:4px solid #c0392b!important;
  border-radius:8px!important;
  box-shadow:0 1px 3px rgba(16,24,40,.08)!important;
  padding:12px 14px!important;
  margin:0 0 16px!important;
}
#page-dashboard .plant-month-banner::before{display:none!important}
#page-dashboard .pmb-left{display:flex!important;flex-direction:column!important;gap:2px!important;min-width:180px!important}
#page-dashboard .pmb-plant{
  color:#1f2328!important;
  font-size:16px!important;
  font-weight:900!important;
  line-height:1.2!important;
  letter-spacing:0!important;
  text-shadow:none!important;
}
#page-dashboard .pmb-plant span{color:#c0392b!important}
#page-dashboard .pmb-sub{color:#8b949e!important;font-size:11px!important;font-weight:700!important;letter-spacing:0!important;text-transform:none!important}
#page-dashboard .pmb-right{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:8px!important;flex-wrap:wrap!important}
#page-dashboard .month-select-wrap{display:flex!important;align-items:center!important}
#page-dashboard #monthFilter{
  height:34px!important;
  min-width:150px!important;
  background:#fff!important;
  border:1px solid #d0d7de!important;
  border-radius:6px!important;
  color:#24292f!important;
  font-size:12px!important;
  font-weight:800!important;
  padding:4px 10px!important;
  box-shadow:none!important;
}
#page-dashboard #monthQuickBtns{display:none!important}
#page-dashboard #monthQuickBtns .month-btn{
  height:32px!important;
  min-width:46px!important;
  background:#fff!important;
  border:1px solid #d0d7de!important;
  border-radius:999px!important;
  color:#57606a!important;
  font-size:12px!important;
  font-weight:800!important;
  padding:0 12px!important;
  box-shadow:none!important;
}
#page-dashboard #monthQuickBtns .month-btn:hover{border-color:#c0392b!important;color:#c0392b!important;background:#fff5f3!important}
#page-dashboard #monthQuickBtns .month-btn.active{background:#c0392b!important;border-color:#c0392b!important;color:#fff!important}
@media(max-width:760px){
  #page-dashboard .plant-month-banner{align-items:flex-start!important;flex-direction:column!important}
  #page-dashboard .pmb-left,#page-dashboard .pmb-right,#page-dashboard .month-select-wrap,#page-dashboard #monthFilter{width:100%!important}
  #page-dashboard .pmb-right{justify-content:flex-start!important}
  #page-dashboard #monthQuickBtns{display:none!important}
  #page-dashboard #monthQuickBtns .month-btn{flex:0 0 auto!important}
}