.pl-nav{flex:1;padding:10px 0;overflow-y:auto}.pl-nav-item{color:#ffffffbf;cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:11px 16px;font-size:.9rem;text-decoration:none;transition:background .15s,color .15s;display:flex}.pl-nav-item:hover{color:#fff;background:#ffffff14}.pl-nav-item.active{color:#fff;background:#ffffff1f;border-left-color:#d4ac0d;font-weight:600}.pl-nav-item svg{flex-shrink:0;font-size:1rem}.pl-nav-label{flex:1}.pl-nav-soon{opacity:.45;cursor:not-allowed}.pl-nav-soon:hover{color:#ffffffbf;background:0 0}.pl-nav-badge{white-space:nowrap;background:#ffffff26;border-radius:10px;padding:2px 6px;font-size:.65rem}.pl-nav-divider{background:#ffffff1a;height:1px;margin:8px 16px}.pl-layout{min-height:100vh;display:flex}.pl-sidebar{color:#fff;z-index:100;background:#1a1a4e;flex-direction:column;flex-shrink:0;width:240px;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0}.pl-sidebar-logo{border-bottom:1px solid #ffffff1a;align-items:center;gap:10px;padding:18px 16px 14px;display:flex}.pl-sidebar-logo img{object-fit:cover;background:#fff;border-radius:50%;flex-shrink:0;width:38px;height:38px;padding:2px}.pl-sidebar-logo span{font-size:.82rem;font-weight:600;line-height:1.3}.pl-sidebar-footer{border-top:1px solid #ffffff1a;margin-top:auto;padding:14px 16px}.pl-user-name{color:#ffffffb3;white-space:nowrap;text-overflow:ellipsis;margin-bottom:8px;font-size:.82rem;overflow:hidden}.pl-logout-btn{color:#fff;cursor:pointer;width:100%;min-height:unset;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;padding:7px;font-family:Sarabun,sans-serif;font-size:.85rem;transition:background .15s}.pl-logout-btn:hover{background:#fff3}.pl-main{background:#f4f6f9;flex:1;min-height:100vh;margin-left:240px}.app-switcher-wrapper{z-index:1001;color:#fff;background:#2c3e50;border-radius:8px;position:fixed;top:8px;right:8px;box-shadow:0 2px 8px #0000004d}.pl-hamburger{z-index:200;color:#fff;cursor:pointer;width:44px;height:44px;min-height:unset;background:#1a1a4e;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:1.3rem;display:none;position:fixed;top:12px;left:12px}.pl-sidebar-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}@media (max-width:768px){.pl-sidebar{transform:translate(-100%)}.pl-sidebar.open{transform:translate(0)}.pl-sidebar-overlay{display:block}.pl-main{margin-left:0;padding-top:56px}.pl-hamburger{display:flex}}.pl-dash{max-width:1100px;padding:28px}.pl-dash-header{margin-bottom:24px}.pl-dash-header h2{color:#1a1a4e;margin:0 0 4px;font-size:1.5rem}.pl-dash-header p{color:#7f8c8d;margin:0;font-size:.9rem}.pl-dash-cards{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.pl-dash-card{text-align:center;background:#fff;border-top:4px solid #ddd;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:20px;display:flex;box-shadow:0 2px 8px #0000000f}.pl-dash-card.blue{border-top-color:#3498db}.pl-dash-card.green{border-top-color:#27ae60}.pl-dash-card.orange{border-top-color:#f39c12}.pl-dash-card.teal{border-top-color:#16a085}.pl-dash-card-icon{color:#bbb;font-size:1.4rem}.pl-dash-card.blue .pl-dash-card-icon{color:#3498db}.pl-dash-card.green .pl-dash-card-icon{color:#27ae60}.pl-dash-card.orange .pl-dash-card-icon{color:#f39c12}.pl-dash-card.teal .pl-dash-card-icon{color:#16a085}.pl-dash-card-val{color:#2c3e50;font-size:2rem;font-weight:700;line-height:1}.pl-dash-card-lbl{color:#7f8c8d;font-size:.82rem}.pl-dash-notice{background:#fff;border-left:4px solid #f39c12;border-radius:12px;align-items:flex-start;gap:16px;padding:24px;display:flex;box-shadow:0 2px 8px #0000000f}.pl-dash-notice-icon{flex-shrink:0;font-size:2rem}.pl-dash-notice strong{color:#2c3e50;margin-bottom:6px;display:block}.pl-dash-notice p{color:#7f8c8d;margin:0;font-size:.88rem;line-height:1.6}.pl-dash-loading{text-align:center;color:#7f8c8d;justify-content:center;align-items:center;gap:10px;padding:60px;font-size:1.1rem;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.pl-dash-year{color:#2980b9;background:#ebf5fb;border-radius:20px;margin-top:6px;padding:3px 12px;font-size:.85rem;display:inline-block}.pl-dash-budget-row{grid-template-columns:1fr 1fr;gap:16px;margin:16px 0;display:grid}.pl-dash-budget-card{background:#fff;border-left:4px solid #3498db;border-radius:12px;align-items:center;gap:16px;padding:18px 20px;display:flex;box-shadow:0 2px 8px #00000012}.pl-dash-budget-card.orange{border-left-color:#e67e22}.pl-dash-budget-icon{color:#3498db;flex-shrink:0;font-size:1.8rem}.pl-dash-budget-card.orange .pl-dash-budget-icon{color:#e67e22}.pl-dash-budget-label{color:#7f8c8d;margin-bottom:4px;font-size:.82rem}.pl-dash-budget-val{color:#2c3e50;font-size:1.2rem;font-weight:700}.pl-dash-status-grid{background:#fff;border-radius:12px;margin-top:16px;padding:20px;box-shadow:0 2px 8px #00000012}.pl-dash-status-grid h3{color:#2c3e50;margin:0 0 16px;font-size:1rem}.pl-dash-status-bars{flex-direction:column;gap:10px;display:flex}.pl-dash-status-bar-row{grid-template-columns:160px 1fr 36px;align-items:center;gap:10px;display:grid}.pl-dash-status-label{color:#2c3e50;font-size:.85rem}.pl-dash-status-bar-bg{background:#f0f0f0;border-radius:6px;height:16px;overflow:hidden}.pl-dash-status-bar-fill{border-radius:6px;min-width:4px;height:100%;transition:width .5s}.pl-dash-status-count{text-align:right;font-size:.85rem;font-weight:700}@media (max-width:768px){.pl-dash{padding:16px}.pl-dash-cards{grid-template-columns:repeat(2,1fr)}.pl-dash-budget-row{grid-template-columns:1fr}.pl-dash-status-bar-row{grid-template-columns:120px 1fr 30px}}@media (max-width:480px){.pl-dash-cards{grid-template-columns:1fr}}.plset-container{max-width:860px;padding:28px;font-family:Sarabun,sans-serif}.plset-header h2{color:#1a1a4e;margin:0 0 20px;font-size:1.4rem}.plset-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.plset-tab{color:#7f8c8d;cursor:pointer;min-height:unset;background:#fff;border:2px solid #ddd;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-family:Sarabun,sans-serif;font-size:.9rem;font-weight:600;transition:all .15s;display:flex}.plset-tab.active{color:#fff;background:#1a1a4e;border-color:#1a1a4e}.plset-body{background:#fff;border-radius:12px;flex-direction:column;gap:24px;padding:24px;display:flex;box-shadow:0 2px 8px #0000000f}.plset-section h3{color:#2c3e50;margin:0 0 4px;font-size:1rem}.plset-hint{color:#7f8c8d;margin:0 0 10px;font-size:.83rem}.plset-input{border:1.5px solid #ddd;border-radius:8px;outline:none;width:100%;max-width:340px;padding:9px 13px;font-family:Sarabun,sans-serif;font-size:.95rem;transition:border-color .15s}.plset-input:focus{border-color:#1a1a4e}.plset-input-sm{max-width:120px}.plset-select{cursor:pointer;background:#fff;border:1.5px solid #ddd;border-radius:8px;outline:none;flex:1;min-width:200px;padding:9px 13px;font-family:Sarabun,sans-serif;font-size:.9rem}.plset-select:focus{border-color:#1a1a4e}.plset-btn-primary{color:#fff;cursor:pointer;min-height:unset;background:#1a1a4e;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-family:Sarabun,sans-serif;font-size:.9rem;font-weight:600;transition:background .15s;display:inline-flex}.plset-btn-primary:hover:not(:disabled){background:#2c2c8e}.plset-btn-primary:disabled{opacity:.65;cursor:not-allowed}.plset-btn-secondary{color:#1a1a4e;cursor:pointer;min-height:unset;background:#fff;border:2px solid #1a1a4e;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-family:Sarabun,sans-serif;font-size:.9rem;font-weight:600;transition:background .15s;display:inline-flex}.plset-btn-secondary:hover:not(:disabled){background:#f0f0f8}.plset-btn-secondary:disabled{opacity:.65;cursor:not-allowed}.plset-btn-sm{color:#fff;cursor:pointer;white-space:nowrap;min-height:unset;background:#1a1a4e;border:none;border-radius:6px;padding:5px 12px;font-family:Sarabun,sans-serif;font-size:.8rem}.plset-btn-danger-sm{color:#fff;cursor:pointer;min-height:unset;background:#e74c3c;border:none;border-radius:6px;flex-shrink:0;padding:8px 10px}.plset-btn-danger-sm:hover{background:#c0392b}.plset-add-row{align-items:center;gap:8px;display:flex}.plset-table{border-collapse:collapse;width:100%;font-size:.9rem}.plset-table thead th{text-align:left;color:#555;background:#f4f6f9;border-bottom:2px solid #e0e0e0;padding:8px 12px;font-weight:600}.plset-table tbody td{border-bottom:1px solid #f0f0f0;padding:10px 12px}.plset-year-label{color:#1a1a4e;font-size:1rem;font-weight:600}.plset-badge{border-radius:12px;align-items:center;gap:4px;padding:3px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.plset-badge.active{color:#196f3d;background:#eafaf1}.plset-badge.inactive{color:#888;background:#f0f0f0}.plset-dept-grid{flex-direction:column;gap:10px;display:flex}.plset-dept-row{align-items:center;gap:12px;display:flex}.plset-dept-label{color:#2c3e50;min-width:160px;font-size:.9rem;font-weight:600}.plset-deputy-row{border-bottom:1px solid #f5f5f5;align-items:center;gap:10px;padding:8px 0;display:flex}.plset-deputy-num{color:#fff;background:#1a1a4e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.plset-deputy-actions{gap:10px;margin-top:8px;display:flex}.plset-line-actions{flex-wrap:wrap;gap:10px;display:flex}.plset-note{color:#555;background:#fef9e7;border:1px solid #f9ca24;border-radius:8px;padding:12px 16px;font-size:.85rem;line-height:1.6}.plset-loading{color:#888;align-items:center;gap:8px;padding:20px 0;display:flex}.plset-empty{color:#aaa;padding:16px 0;font-style:italic}@media (max-width:600px){.plset-container{padding:16px}.plset-dept-row{flex-direction:column;align-items:flex-start}.plset-deputy-row{flex-wrap:wrap}.plset-deputy-actions{flex-direction:column}}.spl-container{max-width:1100px;margin:0 auto;padding:24px}.spl-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.spl-header-left{align-items:center;gap:14px;display:flex}.spl-header-icon{color:#3498db;flex-shrink:0;font-size:2rem}.spl-header h2{color:#2c3e50;margin:0;font-size:1.4rem}.spl-header p{color:#7f8c8d;margin:2px 0 0;font-size:.85rem}.spl-btn-primary{color:#fff;cursor:pointer;background:#3498db;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-family:Sarabun,sans-serif;font-size:.95rem;font-weight:600;transition:background .2s;display:inline-flex}.spl-btn-primary:hover{background:#2980b9}.spl-btn-primary:disabled{cursor:not-allowed;background:#aaa}.spl-btn-secondary{color:#2c3e50;cursor:pointer;background:#ecf0f1;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-family:Sarabun,sans-serif;font-size:.95rem;transition:background .2s;display:inline-flex}.spl-btn-secondary:hover{background:#dee2e6}.spl-btn-outline{color:#3498db;cursor:pointer;background:0 0;border:1.5px solid #3498db;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-family:Sarabun,sans-serif;font-size:.9rem;transition:all .2s;display:inline-flex}.spl-btn-outline:hover{background:#ebf5fb}.spl-btn-icon{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:34px;height:34px;font-size:.9rem;transition:background .2s;display:inline-flex}.spl-btn-icon.edit{color:#2980b9;background:#ebf5fb}.spl-btn-icon.edit:hover{background:#d6eaf8}.spl-btn-icon.del{color:#c0392b;background:#fdedec}.spl-btn-icon.del:hover{background:#fadbd8}.spl-loading{text-align:center;color:#7f8c8d;padding:40px;font-size:1rem}.spl-empty{text-align:center;color:#7f8c8d;padding:60px 20px}.spl-empty-icon{opacity:.3;margin-bottom:12px;font-size:3rem}.spl-empty p{margin:0 0 16px;font-size:1rem}.spl-empty-sm{color:#7f8c8d;margin:0;padding:12px 0;font-size:.9rem}.spl-cards{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;display:grid}.spl-card{background:#fff;border-left:4px solid #dee2e6;border-radius:12px;flex-direction:column;gap:10px;padding:20px;transition:box-shadow .2s;display:flex;box-shadow:0 2px 8px #00000012}.spl-card:hover{box-shadow:0 4px 16px #0000001c}.spl-card.active{border-left-color:#27ae60}.spl-card.draft{border-left-color:#bdc3c7}.spl-card.archived{opacity:.8;border-left-color:#95a5a6}.spl-card-top{justify-content:space-between;align-items:center;display:flex}.spl-card-years{color:#7f8c8d;font-size:.82rem}.spl-card-title{color:#2c3e50;margin:0;font-size:1.05rem;font-weight:700;line-height:1.4}.spl-card-desc{color:#555;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:.88rem;line-height:1.5;display:-webkit-box;overflow:hidden}.spl-card-meta{align-items:center;display:flex}.spl-card-goals-count{color:#7f8c8d;background:#f4f6f9;border-radius:20px;padding:3px 10px;font-size:.82rem}.spl-card-actions{align-items:center;gap:8px;margin-top:4px;display:flex}.spl-badge{border-radius:20px;padding:3px 10px;font-size:.78rem;font-weight:700;display:inline-block}.spl-badge.active{color:#196f3d;background:#eafaf1}.spl-badge.draft{color:#666;background:#f0f0f0}.spl-badge.archived{color:#717d7e;background:#eaecee}.spl-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.spl-modal{background:#fff;border-radius:14px;flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex;overflow-y:auto;box-shadow:0 8px 32px #0000002e}.spl-modal-wide{max-width:860px}.spl-modal-head{border-bottom:1px solid #ecf0f1;justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.spl-modal-head h3{color:#2c3e50;align-items:center;gap:8px;margin:0;font-size:1.1rem;display:flex}.spl-modal-close{cursor:pointer;color:#7f8c8d;background:0 0;border:none;border-radius:4px;padding:4px;font-size:1.1rem}.spl-modal-close:hover{color:#e74c3c}.spl-form{flex-direction:column;gap:14px;padding:18px 22px;display:flex}.spl-form-group{flex-direction:column;gap:5px;display:flex}.spl-form-group label{color:#2c3e50;font-size:.88rem;font-weight:600}.spl-form-group input,.spl-form-group select,.spl-form-group textarea{color:#2c3e50;background:#fff;border:1.5px solid #dee2e6;border-radius:8px;outline:none;padding:9px 12px;font-family:Sarabun,sans-serif;font-size:.95rem;transition:border-color .2s}.spl-form-group input:focus,.spl-form-group select:focus,.spl-form-group textarea:focus{border-color:#3498db}.spl-form-group textarea{resize:vertical;min-height:80px}.spl-form-row{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.spl-modal-footer{border-top:1px solid #ecf0f1;flex-wrap:wrap;align-items:center;gap:10px;padding:14px 22px 18px;display:flex}.spl-goals-list{flex-direction:column;gap:10px;max-height:420px;padding:16px 22px;display:flex;overflow-y:auto}.spl-goal-row{background:#f8f9fa;border-radius:8px;grid-template-columns:24px 70px 130px 1fr 1fr 32px;align-items:center;gap:8px;padding:10px 12px;display:grid}.spl-goal-num{color:#7f8c8d;text-align:center;font-size:.8rem;font-weight:700}.spl-goal-no,.spl-goal-dept,.spl-goal-title,.spl-goal-desc{background:#fff;border:1.5px solid #dee2e6;border-radius:6px;outline:none;padding:7px 10px;font-family:Sarabun,sans-serif;font-size:.88rem}.spl-goal-no:focus,.spl-goal-dept:focus,.spl-goal-title:focus,.spl-goal-desc:focus{border-color:#3498db}.spl-goal-del{color:#c0392b;cursor:pointer;background:#fdedec;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.spl-goal-del:hover{background:#fadbd8}@media (max-width:768px){.spl-container{padding:14px}.spl-header{flex-direction:column;align-items:flex-start}.spl-btn-primary,.spl-btn-secondary,.spl-btn-outline{justify-content:center;width:100%;min-height:44px}.spl-cards,.spl-form-row{grid-template-columns:1fr}.spl-goal-row{grid-template-columns:24px 60px 1fr 1fr 28px}.spl-goal-dept{display:none}.spl-modal-footer{flex-direction:column}}.apl-container{max-width:1100px;margin:0 auto;padding:24px}.apl-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.apl-header-left{align-items:center;gap:14px;display:flex}.apl-header-icon{color:#27ae60;flex-shrink:0;font-size:2rem}.apl-header h2{color:#2c3e50;margin:0;font-size:1.4rem}.apl-header p{color:#7f8c8d;margin:2px 0 0;font-size:.85rem}.apl-filter{background:#fff;border-radius:10px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;display:flex;box-shadow:0 1px 4px #0000000f}.apl-filter label{color:#2c3e50;white-space:nowrap;font-size:.88rem;font-weight:600}.apl-filter select{cursor:pointer;background:#fff;border:1.5px solid #dee2e6;border-radius:7px;outline:none;padding:7px 12px;font-family:Sarabun,sans-serif;font-size:.9rem}.apl-filter select:focus{border-color:#27ae60}.apl-btn-primary{color:#fff;cursor:pointer;background:#27ae60;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-family:Sarabun,sans-serif;font-size:.95rem;font-weight:600;transition:background .2s;display:inline-flex}.apl-btn-primary:hover{background:#219a52}.apl-btn-secondary{color:#2c3e50;cursor:pointer;background:#ecf0f1;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-family:Sarabun,sans-serif;font-size:.95rem;transition:background .2s;display:inline-flex}.apl-btn-secondary:hover{background:#dee2e6}.apl-btn-icon{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.88rem;transition:background .2s;display:inline-flex}.apl-btn-icon.edit{color:#2980b9;background:#ebf5fb}.apl-btn-icon.edit:hover{background:#d6eaf8}.apl-btn-icon.del{color:#c0392b;background:#fdedec}.apl-btn-icon.del:hover{background:#fadbd8}.apl-loading{text-align:center;color:#7f8c8d;padding:40px}.apl-empty{text-align:center;color:#7f8c8d;padding:60px 20px}.apl-empty-icon{opacity:.3;margin-bottom:12px;font-size:3rem}.apl-empty p{margin:0 0 16px}.apl-none{color:#bdc3c7}.apl-table-wrap{background:#fff;border-radius:12px;overflow:auto hidden;box-shadow:0 2px 8px #00000012}.apl-table{border-collapse:collapse;width:100%}.apl-table thead tr{color:#fff;background:#2c3e50}.apl-table th{text-align:left;white-space:nowrap;padding:12px 14px;font-size:.88rem;font-weight:600}.apl-table tbody tr{border-bottom:1px solid #ecf0f1;transition:background .15s}.apl-table tbody tr:hover{background:#f8f9fa}.apl-table td{color:#2c3e50;padding:12px 14px;font-size:.9rem}.apl-td-num{color:#7f8c8d;width:36px;font-size:.82rem}.apl-td-title{font-weight:600}.apl-td-center{text-align:center}.apl-td-link{color:#555;max-width:200px;font-size:.85rem}.apl-td-budget{text-align:right;white-space:nowrap;font-family:monospace;font-size:.88rem}.apl-td-actions{gap:6px;display:flex}.apl-proj-count{color:#2980b9;background:#ebf5fb;border-radius:12px;padding:2px 10px;font-size:.82rem;font-weight:700;display:inline-block}.apl-badge{border-radius:20px;padding:3px 10px;font-size:.78rem;font-weight:700;display:inline-block}.apl-badge.active{color:#196f3d;background:#eafaf1}.apl-badge.draft{color:#666;background:#f0f0f0}.apl-badge.closed{color:#717d7e;background:#eaecee}.apl-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.apl-modal{background:#fff;border-radius:14px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000002e}.apl-modal-head{border-bottom:1px solid #ecf0f1;justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.apl-modal-head h3{color:#2c3e50;margin:0;font-size:1.1rem}.apl-modal-close{cursor:pointer;color:#7f8c8d;background:0 0;border:none;border-radius:4px;padding:4px;font-size:1.1rem}.apl-modal-close:hover{color:#e74c3c}.apl-form{flex-direction:column;gap:14px;padding:18px 22px;display:flex}.apl-form-group{flex-direction:column;gap:5px;display:flex}.apl-form-group label{color:#2c3e50;font-size:.88rem;font-weight:600}.apl-form-group input,.apl-form-group select{color:#2c3e50;background:#fff;border:1.5px solid #dee2e6;border-radius:8px;outline:none;padding:9px 12px;font-family:Sarabun,sans-serif;font-size:.95rem;transition:border-color .2s}.apl-form-group input:focus,.apl-form-group select:focus{border-color:#27ae60}.req{color:#e74c3c}.apl-form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.apl-modal-footer{border-top:1px solid #ecf0f1;flex-wrap:wrap;gap:10px;padding:14px 22px 18px;display:flex}@media (max-width:768px){.apl-container{padding:14px}.apl-header{flex-direction:column;align-items:flex-start}.apl-btn-primary,.apl-btn-secondary{justify-content:center;width:100%;min-height:44px}.apl-filter{flex-direction:column;align-items:flex-start}.apl-filter select{width:100%}.apl-form-row{grid-template-columns:1fr}.apl-modal-footer{flex-direction:column}}.prj-list-page{background:#f4f6f9;min-height:100vh;padding:24px}.prj-list-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.prj-list-title{color:#2c3e50;margin:0 0 4px;font-size:1.5rem;font-weight:700}.prj-list-subtitle{color:#7f8c8d;margin:0;font-size:.875rem}.prj-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;min-height:44px;padding:10px 20px;font-size:.875rem;font-weight:600;text-decoration:none;transition:background .2s,opacity .2s;display:inline-flex}.prj-btn-primary:hover{background:#2980b9}.prj-btn-ghost:hover{background:#ebf5fb}.prj-filter-bar{background:#fff;border-radius:10px;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:20px;padding:16px 20px;display:flex;box-shadow:0 1px 4px #00000014}.prj-filter-group{flex-direction:column;flex:1;gap:4px;min-width:160px;display:flex}.prj-filter-group label{color:#7f8c8d;font-size:.78rem;font-weight:600}.prj-filter-group select{color:#2c3e50;background:#fff;border:1.5px solid #d5d8dc;border-radius:6px;outline:none;min-height:40px;padding:8px 10px;font-size:.875rem;transition:border-color .2s}.prj-filter-group select:focus{border-color:#3498db}.prj-table-wrap{background:#fff;border-radius:10px;margin-bottom:12px;overflow-x:auto;box-shadow:0 1px 4px #00000014}.prj-table{border-collapse:collapse;width:100%;font-size:.875rem}.prj-table thead tr{background:#f4f6f9;border-bottom:2px solid #e5e8eb}.prj-table th{text-align:left;color:#2c3e50;white-space:nowrap;padding:12px 14px;font-weight:700}.prj-table td{vertical-align:middle;color:#2c3e50;border-bottom:1px solid #f0f2f5;padding:12px 14px}.prj-table tbody tr:hover{background:#f8fafc}.prj-table tbody tr:last-child td{border-bottom:none}.prj-th-no,.prj-td-no{text-align:center;width:40px}.prj-th-dept{width:130px}.prj-th-plan{width:180px}.prj-th-budget{text-align:right;width:120px}.prj-th-status{width:160px}.prj-th-submitter{width:120px}.prj-th-actions{text-align:center;width:130px}.prj-td-budget{text-align:right}.prj-title-link{color:#2980b9;cursor:pointer;font-weight:600}.prj-title-link:hover{text-decoration:underline}.prj-td-plan{flex-direction:column;gap:2px;display:flex}.prj-plan-text{color:#2c3e50;white-space:nowrap;text-overflow:ellipsis;max-width:160px;font-size:.8rem;overflow:hidden}.prj-year-badge{color:#2980b9;background:#ebf5fb;border-radius:4px;padding:2px 6px;font-size:.72rem;display:inline-block}.prj-td-actions{text-align:center}.prj-action-btn{cursor:pointer;border:none;border-radius:5px;min-height:30px;margin:2px;padding:5px 10px;font-size:.78rem;font-weight:600;transition:opacity .2s;display:inline-block}.prj-action-btn:hover{opacity:.85}.prj-action-view{color:#2980b9;background:#ebf5fb}.prj-action-edit{color:#1e8449;background:#eafaf1}.prj-action-delete{color:#c0392b;background:#fdedec}.prj-loading,.prj-empty{text-align:center;color:#7f8c8d;padding:48px;font-size:.95rem}.prj-list-summary{text-align:right;color:#7f8c8d;padding:0 4px;font-size:.8rem}@media (max-width:768px){.prj-list-page{padding:16px}.prj-list-header{flex-direction:column;align-items:stretch}.prj-btn{justify-content:center;width:100%}.prj-filter-bar{flex-direction:column;gap:10px}.prj-filter-group{min-width:unset}.prj-th-plan,.prj-td-plan,.prj-th-submitter,.prj-table td:nth-child(7){display:none}.prj-action-btn{min-height:36px;padding:6px 10px}}.prj-btn-print{color:#fff;cursor:pointer;background:#2c3e50;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-family:Sarabun,sans-serif;font-size:.95rem;transition:background .2s;display:inline-flex}.prj-btn-print:hover{background:#1a252f}.prj-form-page{background:#f4f6f9;min-height:100vh;padding:24px 24px 100px}.prj-form-top-bar{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px;display:flex}.prj-back-btn{color:#3498db;cursor:pointer;background:0 0;border:none;min-height:44px;padding:6px 0;font-size:.875rem;font-weight:600}.prj-back-btn:hover{text-decoration:underline}.prj-form-page-title{color:#2c3e50;margin:0;font-size:1.4rem;font-weight:700}.prj-status-panel{background:#fff;border-radius:10px;margin-bottom:16px;padding:16px 20px;box-shadow:0 1px 4px #00000014}.prj-status-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.prj-status-label{color:#2c3e50;font-size:.9rem;font-weight:600}.prj-timeline{border-left:2px solid #e5e8eb;flex-direction:column;gap:10px;margin-top:8px;padding-left:8px;display:flex}.prj-timeline-item{align-items:flex-start;gap:12px;display:flex;position:relative}.prj-timeline-dot{border:2px solid #fff;border-radius:50%;flex-shrink:0;width:12px;height:12px;margin-top:3px;margin-left:-7px;box-shadow:0 0 0 2px}.prj-timeline-content{flex-wrap:wrap;gap:4px 10px;font-size:.82rem;display:flex}.prj-timeline-action{font-weight:700}.prj-timeline-who{color:#2c3e50}.prj-timeline-comment{color:#7f8c8d;width:100%;font-style:italic}.prj-timeline-date{color:#aab7c4;font-size:.76rem}.prj-tabs{flex-wrap:wrap;gap:4px;margin-bottom:16px;display:flex}.prj-tab{color:#7f8c8d;cursor:pointer;background:#fff;border:1.5px solid #e5e8eb;border-radius:8px 8px 0 0;min-height:44px;padding:10px 20px;font-size:.875rem;font-weight:600;transition:background .2s,color .2s,border-color .2s}.prj-tab.active{color:#fff;background:#3498db;border-color:#3498db}.prj-tab:not(.active):hover{color:#2980b9;background:#ebf5fb;border-color:#aed6f1}.prj-tab-content{flex-direction:column;gap:16px;display:flex}.prj-card{background:#fff;border-radius:10px;padding:24px;box-shadow:0 1px 4px #00000014}.prj-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.prj-section-title{color:#2c3e50;margin:0 0 16px;font-size:1rem;font-weight:700}.prj-card-header .prj-section-title{margin-bottom:0}.prj-form-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.prj-form-group{flex-direction:column;gap:6px;display:flex}.prj-form-group-full{grid-column:1/-1}.prj-form-group label{color:#2c3e50;font-size:.82rem;font-weight:600}.prj-form-group input[type=text],.prj-form-group input[type=date],.prj-form-group input[type=number],.prj-form-group select,.prj-form-group textarea{color:#2c3e50;background:#fff;border:1.5px solid #d5d8dc;border-radius:7px;outline:none;min-height:42px;padding:10px 12px;font-family:inherit;font-size:.875rem;transition:border-color .2s}.prj-form-group input:focus,.prj-form-group select:focus,.prj-form-group textarea:focus{border-color:#3498db}.prj-form-group input:disabled,.prj-form-group select:disabled,.prj-form-group textarea:disabled{color:#7f8c8d;cursor:not-allowed;background:#f8f9fa}.prj-form-group textarea{resize:vertical;min-height:80px}.prj-req{color:#e74c3c}.prj-hint{color:#7f8c8d;font-size:.76rem;font-style:italic}.prj-radio-group{flex-wrap:wrap;align-items:center;gap:16px;padding:8px 0;display:flex}.prj-radio-label{color:#2c3e50;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:.875rem;display:flex}.prj-radio-label input[type=radio]{cursor:pointer;width:16px;height:16px}.prj-badge{white-space:nowrap;border-radius:20px;padding:4px 12px;font-size:.78rem;font-weight:700;display:inline-block}.prj-badge.draft{color:#7f8c8d;background:#f0f2f5}.prj-badge.submitted{color:#2980b9;background:#ebf5fb}.prj-badge.head-approved{color:#1a8a70;background:#e8f8f5}.prj-badge.deputy-approved{color:#ca6f1e;background:#fef5e7}.prj-badge.director-approved{color:#1e8449;background:#eafaf1}.prj-badge.rejected{color:#c0392b;background:#fdedec}.prj-activities-table-wrap{margin-top:8px;overflow-x:auto}.prj-activities-table{border-collapse:collapse;width:100%;font-size:.82rem}.prj-activities-table th{text-align:left;color:#2c3e50;white-space:nowrap;background:#f4f6f9;border-bottom:2px solid #e5e8eb;padding:10px 8px;font-weight:700}.prj-activities-table td{vertical-align:middle;border-bottom:1px solid #f0f2f5;padding:6px 4px}.prj-activities-table tfoot td{border-top:2px solid #e5e8eb;border-bottom:none;padding:10px 8px}.prj-budget-total-label{text-align:right;color:#2c3e50;font-size:.875rem;font-weight:700}.prj-budget-total-value{color:#27ae60;white-space:nowrap;font-size:.95rem;font-weight:700}.prj-activity-input{color:#2c3e50;box-sizing:border-box;background:#fff;border:1.5px solid #e5e8eb;border-radius:5px;outline:none;width:100%;min-height:36px;padding:6px 8px;font-family:inherit;font-size:.82rem;transition:border-color .2s}.prj-activity-input:focus{border-color:#3498db}.prj-activity-input:disabled{color:#7f8c8d;cursor:not-allowed;background:#f8f9fa}.prj-activity-no{width:50px}.prj-activity-title{min-width:180px}.prj-activity-quarter{width:100px}.prj-activity-person{min-width:130px}.prj-activity-budget{text-align:right;width:110px}.prj-remove-btn{color:#c0392b;cursor:pointer;background:#fdedec;border:none;border-radius:5px;justify-content:center;align-items:center;width:28px;height:28px;font-size:1rem;transition:background .2s;display:flex}.prj-remove-btn:hover{background:#f5b7b1}.prj-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;min-height:44px;padding:10px 20px;font-size:.875rem;font-weight:600;transition:background .2s,opacity .2s;display:inline-flex}.prj-btn:disabled{opacity:.6;cursor:not-allowed}.prj-btn-primary{color:#fff;background:#3498db}.prj-btn-primary:not(:disabled):hover{background:#2980b9}.prj-btn-ghost{color:#3498db;background:#fff;border:1.5px solid #3498db}.prj-btn-ghost:not(:disabled):hover{background:#ebf5fb}.prj-btn-sm{min-height:36px;padding:6px 14px;font-size:.8rem}.prj-btn-submit{color:#fff;background:#2980b9}.prj-btn-submit:not(:disabled):hover{background:#1a6a9a}.prj-btn-approve{color:#fff;background:#27ae60}.prj-btn-approve:not(:disabled):hover{background:#1e8449}.prj-btn-reject{color:#fff;background:#e74c3c}.prj-btn-reject:not(:disabled):hover{background:#c0392b}.prj-bottom-bar{z-index:100;background:#fff;border-top:1.5px solid #e5e8eb;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 24px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px #00000014}.prj-bottom-bar-actions{flex-wrap:wrap;gap:8px;display:flex}@media (max-width:768px){.prj-form-page{padding:12px 12px 110px}.prj-form-row{grid-template-columns:1fr}.prj-form-group-full{grid-column:1}.prj-tabs{gap:2px}.prj-tab{text-align:center;flex:1;padding:8px 12px;font-size:.8rem}.prj-card{padding:16px}.prj-bottom-bar{padding:10px 16px}.prj-btn{flex:1;min-width:80px}.prj-bottom-bar-actions{flex:1}.prj-activities-table th,.prj-activities-table td{padding:4px 3px}}.pp-page{display:none}@media print{body>*{display:none!important}#project-print-area{display:block!important}.pp-page{display:block}body{color:#000;background:#fff;margin:0;padding:0;font-family:Sarabun,sans-serif;font-size:13pt}*{box-sizing:border-box}.pp-school-header{text-align:center;margin-bottom:16px}.pp-school-name{margin:0;font-size:16pt;font-weight:700}.pp-doc-title{margin:4px 0 0;font-size:14pt;font-weight:700}.pp-info-table{border-collapse:collapse;width:100%;margin-bottom:10px}.pp-info-table td{vertical-align:top;border:1px solid #000;padding:5px 8px}.pp-label{white-space:nowrap;background:#f5f5f5;width:180px;font-weight:700}.pp-title-val{font-size:14pt;font-weight:700}.pp-multiline{white-space:pre-wrap}.pp-section{margin:14px 0}.pp-section-title{border-bottom:2px solid #000;margin-bottom:8px;padding-bottom:4px;font-size:13pt;font-weight:700}.pp-detail-row{gap:8px;margin-bottom:10px;display:flex}.pp-detail-no{min-width:30px;font-weight:700}.pp-detail-content{flex:1}.pp-detail-label{margin-bottom:3px;font-weight:700}.pp-detail-val{white-space:pre-wrap;min-height:20px;padding-left:12px}.pp-eval-table{border-collapse:collapse;width:100%;margin-top:6px}.pp-eval-table th,.pp-eval-table td{border:1px solid #000;padding:4px 8px;font-size:12pt}.pp-eval-table th{background:#f5f5f5;font-weight:700}.pp-budget-total{margin-bottom:8px}.pp-act-table{border-collapse:collapse;width:100%;margin-top:8px;font-size:11pt}.pp-act-table th,.pp-act-table td{border:1px solid #000;padding:4px 6px}.pp-act-table th{text-align:center;background:#f5f5f5;font-weight:700}.pp-td-center{text-align:center}.pp-td-right{text-align:right}.pp-total-row{background:#f5f5f5}.pp-total-row td{font-weight:700}.pp-checkbox{font-size:14pt}.pp-approval{page-break-inside:avoid;margin-top:30px}.pp-sig-row{justify-content:space-around;margin-top:40px;display:flex}.pp-sig-box{text-align:center;width:28%}.pp-sig-line{border-bottom:1px solid #000;height:50px;margin-bottom:8px}.pp-sig-name{margin-bottom:4px}.pp-sig-role{font-weight:700}.pp-sig-date{color:#555;font-size:11pt}@page{size:A4;margin:15mm 15mm 15mm 20mm}}.teacher-picker{position:relative}.picker-input{border:1px solid #ccc;border-radius:5px;width:100%;padding:8px 10px;font-family:inherit;font-size:13px}.picker-dropdown{z-index:100;background:#fff;border:1px solid #ddd;border-radius:5px;max-height:240px;margin:4px 0 0;padding:4px 0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.picker-dropdown li{cursor:pointer;padding:8px 12px;font-size:13px}.picker-dropdown li:hover{background:#f0f0f7}.picker-dropdown li.empty{color:#aaa;cursor:default}.cat-alloc-editor{background:#f8f9fb;border:1px solid #e0e0ea;border-radius:8px;padding:16px}.cat-alloc-editor .empty-hint{color:#888;margin:0 0 12px;font-size:13px;font-style:italic}.cat-alloc-editor .alloc-row{border-bottom:1px solid #eee;align-items:center;gap:10px;padding:8px 0;display:flex}.cat-alloc-editor .alloc-row:last-of-type{border-bottom:none}.cat-alloc-editor .alloc-cat{flex-direction:column;flex:1;display:flex}.cat-alloc-editor .alloc-cat strong{color:#1a1a4e;font-size:14px}.cat-alloc-editor .alloc-cat small{color:#888;font-size:11px}.cat-alloc-editor .alloc-amount{text-align:right;border:1px solid #ccc;border-radius:4px;width:120px;padding:7px;font-family:inherit;font-size:14px}.cat-alloc-editor .alloc-unit{color:#888;font-size:13px}.cat-alloc-editor .alloc-remove{color:#e74c3c;cursor:pointer;background:0 0;border:none;font-size:18px}.cat-alloc-editor .alloc-add{border-top:1px dashed #ccc;align-items:center;gap:10px;margin-top:12px;padding-top:12px;display:flex}.cat-alloc-editor .alloc-add label{color:#555;font-size:13px}.cat-alloc-editor .alloc-add select{border:1px solid #ccc;border-radius:4px;flex:1;padding:7px;font-family:inherit;font-size:13px}.cat-alloc-editor .alloc-total{text-align:right;color:#1a1a4e;border-top:1px solid #ddd;margin-top:12px;padding-top:12px;font-size:14px}.cat-alloc-editor .alloc-total strong{font-size:18px}.import-page{max-width:1200px;margin:0 auto;padding:24px}.import-page h2{color:var(--color-navy,#1a1a4e);margin-top:0}.upload-zone{text-align:center;background:#f8f9fb;border:2px dashed #ccc;border-radius:10px;padding:40px}.upload-zone code{background:#fff;border-radius:4px;padding:4px 8px;font-size:12px}.preview-area{margin-top:20px}.errors-box{background:#fdecea;border-radius:6px;margin:12px 0;padding:12px}.errors-box ul{margin:4px 0 0 20px;padding:0;font-size:13px}.project-preview{background:#fff;border:1px solid #e0e0ea;border-radius:8px;margin-bottom:14px;padding:16px}.proj-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:8px;display:flex}.dept-badge{color:#006064;background:#e0f7fa;border-radius:12px;padding:3px 10px;font-size:12px}.budget-tag{color:#1e6e3a;background:#d4f4dd;border-radius:12px;padding:3px 10px;font-size:12px}.activities-list,.responsibles-list{margin:10px 0;font-size:13px}.activities-list ul{margin:4px 0 0 20px;padding:0}.resp-row{flex-wrap:wrap;align-items:center;gap:8px;margin:4px 0;display:flex}.input-name{color:#555;font-style:italic}.match-tag.good{color:#1e6e3a;background:#d4f4dd;border-radius:6px;padding:3px 10px;font-size:12px}.resp-row.ambig select{border-color:#f39c12}.resp-row.nomatch select{border-color:#e74c3c}.commit-actions{border-top:1px solid #eee;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;display:flex}.commit-actions button{cursor:pointer;background:#fff;border:1px solid #ccc;border-radius:6px;padding:10px 24px;font-family:inherit;font-weight:600}.commit-actions button.primary{color:#fff;background:#1a1a4e;border-color:#1a1a4e}.commit-actions button:disabled{opacity:.6;cursor:wait}.cat-select{border:1px solid #ccc;border-radius:5px;width:100%;padding:7px 10px;font-family:inherit;font-size:13px}.bgt-container{max-width:1200px;padding:28px}.bgt-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.bgt-header-left{align-items:center;gap:14px;display:flex}.bgt-header-icon{color:#e67e22;flex-shrink:0;font-size:2rem}.bgt-header h2{color:#2c3e50;margin:0 0 3px;font-size:1.4rem}.bgt-header p{color:#7f8c8d;margin:0;font-size:.85rem}.bgt-btn-excel{color:#fff;cursor:pointer;white-space:nowrap;background:#27ae60;border:none;border-radius:8px;align-items:center;gap:7px;padding:9px 18px;font-size:.9rem;font-weight:600;transition:background .2s;display:inline-flex}.bgt-btn-excel:hover:not(:disabled){background:#219a52}.bgt-btn-excel:disabled{opacity:.5;cursor:not-allowed}.bgt-filter{background:#fff;border-radius:10px;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:16px 20px;display:flex;box-shadow:0 2px 8px #0000000f}.bgt-filter-group{flex-direction:column;gap:5px;min-width:180px;display:flex}.bgt-filter-group label{color:#7f8c8d;text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.bgt-filter-group select{color:#2c3e50;cursor:pointer;background:#f4f6f9;border:1px solid #dee2e6;border-radius:6px;outline:none;padding:7px 10px;font-size:.9rem;transition:border-color .2s}.bgt-filter-group select:focus{background:#fff;border-color:#3498db}.bgt-summary-cards{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;display:grid}.bgt-card{background:#fff;border-left:4px solid #dee2e6;border-radius:12px;flex-direction:column;gap:6px;padding:18px 20px;display:flex;box-shadow:0 2px 8px #0000000f}.bgt-card.blue{border-left-color:#3498db}.bgt-card.orange{border-left-color:#e67e22}.bgt-card.green{border-left-color:#27ae60}.bgt-card.gray{border-left-color:#7f8c8d}.bgt-card-label{color:#7f8c8d;text-transform:uppercase;letter-spacing:.03em;font-size:.78rem;font-weight:600}.bgt-card-val{color:#2c3e50;word-break:break-all;font-size:1.4rem;font-weight:700;line-height:1.2}.bgt-card.blue .bgt-card-val{color:#2980b9}.bgt-card.orange .bgt-card-val{color:#e67e22}.bgt-card.green .bgt-card-val{color:#219a52}.bgt-card.gray .bgt-card-val{color:#7f8c8d}.bgt-table-wrap{background:#fff;border-radius:12px;overflow-x:auto;box-shadow:0 2px 8px #0000000f}.bgt-table{border-collapse:collapse;width:100%;font-size:.88rem}.bgt-table th{color:#2c3e50;text-align:left;white-space:nowrap;background:#f4f6f9;border-bottom:2px solid #dee2e6;padding:12px 14px;font-weight:700}.bgt-table td{color:#2c3e50;vertical-align:middle;border-bottom:1px solid #ecf0f1;padding:11px 14px}.bgt-table tbody tr:hover{background:#f9fbfc}.bgt-table tbody tr:last-child td{border-bottom:none}.bgt-td-num{text-align:center;color:#7f8c8d;width:40px}.bgt-td-title{font-weight:600}.bgt-td-money{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.bgt-td-pct{min-width:130px}.bgt-bar-wrap{background:#ecf0f1;border-radius:4px;width:100px;height:8px;margin-bottom:3px;overflow:hidden}.bgt-bar{border-radius:4px;min-width:2px;height:100%;transition:width .4s}.bgt-btn-view{color:#3498db;cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid #3498db;border-radius:6px;align-items:center;gap:5px;padding:5px 12px;font-size:.82rem;font-weight:600;transition:all .2s;display:inline-flex}.bgt-btn-view:hover{color:#fff;background:#3498db}.bgt-loading{text-align:center;color:#7f8c8d;padding:40px;font-size:1rem}.bgt-empty{color:#bdc3c7;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.bgt-empty-icon{color:#dee2e6;margin-bottom:14px;font-size:3.5rem}.bgt-empty p{color:#7f8c8d;margin:0;font-size:1rem}.bgt-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:flex-start;padding:20px;display:flex;position:fixed;inset:0;overflow-y:auto}.bgt-modal{background:#fff;border-radius:14px;flex-direction:column;width:100%;max-width:900px;max-height:90vh;margin:auto;display:flex;overflow:hidden;box-shadow:0 8px 40px #0003}.bgt-modal-head{border-bottom:1px solid #ecf0f1;flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.bgt-modal-head h3{color:#2c3e50;align-items:center;gap:9px;margin:0;font-size:1.05rem;display:flex}.bgt-modal-close{color:#7f8c8d;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.2rem;line-height:1;transition:background .2s,color .2s}.bgt-modal-close:hover{color:#2c3e50;background:#ecf0f1}.bgt-modal-body{flex:1;padding:20px 22px;overflow-y:auto}.bgt-add-form{background:#f4f6f9;border:1px solid #dee2e6;border-radius:10px;margin-bottom:20px;padding:16px 18px}.bgt-add-form h4{color:#2c3e50;text-transform:uppercase;letter-spacing:.03em;margin:0 0 14px;font-size:.9rem;font-weight:700}.bgt-add-row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.bgt-fg{flex-direction:column;flex:1;gap:4px;min-width:130px;display:flex}.bgt-fg-wide{flex:2;min-width:200px}.bgt-fg-btn{flex:none;align-self:flex-end}.bgt-fg label{color:#7f8c8d;font-size:.78rem;font-weight:600}.bgt-fg input,.bgt-fg select{color:#2c3e50;box-sizing:border-box;background:#fff;border:1px solid #dee2e6;border-radius:6px;outline:none;width:100%;padding:7px 10px;font-size:.88rem;transition:border-color .2s}.bgt-fg input:focus,.bgt-fg select:focus{border-color:#3498db}.bgt-btn-add{color:#fff;cursor:pointer;white-space:nowrap;background:#3498db;border:none;border-radius:7px;align-items:center;gap:6px;padding:8px 16px;font-size:.88rem;font-weight:600;transition:background .2s;display:inline-flex}.bgt-btn-add:hover:not(:disabled){background:#2980b9}.bgt-btn-add:disabled{opacity:.55;cursor:not-allowed}.bgt-txn-wrap{overflow-x:auto}.bgt-txn-table{border-collapse:collapse;width:100%;font-size:.85rem}.bgt-txn-table th{color:#2c3e50;text-align:left;white-space:nowrap;background:#f4f6f9;border-bottom:2px solid #dee2e6;padding:9px 12px;font-weight:700}.bgt-txn-table td{color:#2c3e50;vertical-align:middle;border-bottom:1px solid #ecf0f1;padding:8px 12px}.bgt-txn-table tbody tr:hover{background:#f9fbfc}.bgt-txn-empty{text-align:center;color:#7f8c8d;padding:24px;font-style:italic}.bgt-txn-total td{background:#fef9ec;border-top:2px solid #dee2e6}.bgt-cat-badge{color:#2980b9;white-space:nowrap;background:#ebf5fb;border-radius:20px;padding:2px 9px;font-size:.78rem;font-weight:600;display:inline-block}.bgt-del-btn{color:#e74c3c;cursor:pointer;background:0 0;border:1.5px solid #e74c3c;border-radius:6px;padding:4px 8px;font-size:.85rem;line-height:1;transition:all .2s}.bgt-del-btn:hover{color:#fff;background:#e74c3c}.bgt-modal-foot{background:#f9fbfc;border-top:1px solid #ecf0f1;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 22px;display:flex}.bgt-budget-summary{color:#7f8c8d;flex-wrap:wrap;gap:20px;font-size:.88rem;display:flex}.bgt-budget-summary strong{color:#2c3e50}.bgt-btn-close{color:#2c3e50;cursor:pointer;background:#ecf0f1;border:none;border-radius:7px;padding:8px 20px;font-size:.88rem;font-weight:600;transition:background .2s}.bgt-btn-close:hover{background:#dee2e6}@media (max-width:768px){.bgt-container{padding:16px}.bgt-summary-cards{grid-template-columns:repeat(2,1fr)}.bgt-filter{flex-direction:column;gap:12px}.bgt-filter-group{min-width:100%}.bgt-header,.bgt-modal-foot{flex-direction:column;align-items:flex-start}.bgt-add-row{flex-direction:column}.bgt-fg,.bgt-fg-wide{min-width:100%}.bgt-fg-btn{width:100%}.bgt-btn-add{justify-content:center;width:100%}}@media (max-width:480px){.bgt-summary-cards{grid-template-columns:1fr}.bgt-card-val{font-size:1.1rem}}.rpt-page{max-width:1200px;margin:0 auto;padding:24px}.rpt-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.rpt-title-row{align-items:center;gap:10px;display:flex}.rpt-icon{color:#1a1a4e;font-size:1.4rem}.rpt-title{color:#1a1a4e;margin:0;font-size:1.4rem;font-weight:700}.rpt-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.rpt-year-select{color:#1a1a4e;background:#fff;border:1px solid #d0d5dd;border-radius:8px;padding:8px 12px;font-family:Sarabun,sans-serif;font-size:.9rem}.rpt-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-family:Sarabun,sans-serif;font-size:.88rem;font-weight:600;transition:opacity .2s;display:flex}.rpt-btn:hover{opacity:.85}.rpt-btn:disabled{opacity:.4;cursor:not-allowed}.rpt-btn-excel{color:#fff;background:#217346}.rpt-btn-print{color:#fff;background:#1a1a4e}.rpt-loading{text-align:center;color:#888;padding:48px;font-size:1rem}.rpt-cards{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-bottom:28px;display:grid}.rpt-card{text-align:center;border-radius:12px;padding:18px 16px;box-shadow:0 2px 8px #00000014}.rpt-card-num{margin-bottom:4px;font-size:1.5rem;font-weight:700}.rpt-card-label{opacity:.85;font-size:.8rem}.rpt-card-blue{color:#1a6fb5;background:#e8f4fd}.rpt-card-green{color:#1e7e44;background:#e8f8ee}.rpt-card-orange{color:#e65100;background:#fff3e0}.rpt-card-red{color:#b71c1c;background:#fdecea}.rpt-card-navy{color:#1a1a4e;background:#e8eaf6}.rpt-card-teal{color:#00695c;background:#e0f2f1}.rpt-card-gray{color:#424242;background:#f5f5f5}.rpt-section{margin-bottom:36px}.rpt-section-title{color:#1a1a4e;align-items:center;gap:8px;margin-bottom:14px;font-size:1.1rem;font-weight:700;display:flex}.rpt-table-wrap{border-radius:12px;overflow-x:auto;box-shadow:0 2px 8px #00000012}.rpt-table{border-collapse:collapse;background:#fff;width:100%;font-size:.88rem}.rpt-table th{color:#1a1a4e;text-align:left;white-space:nowrap;background:#f0f2f8;border-bottom:2px solid #d0d5dd;padding:10px 12px;font-weight:700}.rpt-table td{vertical-align:middle;border-bottom:1px solid #f0f2f8;padding:9px 12px}.rpt-table tbody tr:hover{background:#f8f9ff}.rpt-table tbody tr:last-child td{border-bottom:none}.rpt-num{text-align:right;white-space:nowrap}.rpt-green{color:#1e7e44;font-weight:600}.rpt-orange{color:#e65100;font-weight:600}.rpt-red{color:#b71c1c;font-weight:600}.rpt-empty{text-align:center;color:#999;padding:24px}.rpt-badge{white-space:nowrap;border-radius:6px;padding:2px 8px;font-size:.78rem;font-weight:600;display:inline-block}.rpt-badge-draft{color:#555;background:#f0f2f8}.rpt-badge-submitted{color:#e65100;background:#fff3e0}.rpt-badge-head{color:#1a6fb5;background:#e8f4fd}.rpt-badge-deputy{color:#3949ab;background:#e8eaf6}.rpt-badge-approved{color:#1e7e44;background:#e8f8ee}.rpt-badge-rejected{color:#b71c1c;background:#fdecea}.rpt-pb-wrap{background:#e5e7ef;border-radius:6px;min-width:100px;height:18px;position:relative;overflow:hidden}.rpt-pb-fill{border-radius:6px;height:100%;transition:width .3s}.rpt-pb-ok{background:#27ae60}.rpt-pb-warn{background:#f39c12}.rpt-pb-over{background:#e74c3c}.rpt-pb-label{color:#fff;text-shadow:0 1px 2px #0006;justify-content:center;align-items:center;font-size:.73rem;font-weight:700;display:flex;position:absolute;inset:0}@media print{.rpt-actions,.rpt-btn{display:none!important}.rpt-page{padding:0}.rpt-table-wrap{box-shadow:none}.rpt-card{box-shadow:none;border:1px solid #ddd}}@media (max-width:768px){.rpt-page{padding:16px}.rpt-cards{grid-template-columns:repeat(2,1fr)}.rpt-header{flex-direction:column;align-items:flex-start}}.monitor-page{max-width:1400px;margin:0 auto;padding:24px}.monitor-page h2{color:var(--color-navy,#1a1a4e);margin-top:0}.monitor-loading{text-align:center;color:#888;padding:40px}.monitor-grid{grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:20px;display:grid}.monitor-card{background:#fff;border-radius:10px;min-height:200px;padding:20px;box-shadow:0 2px 8px #0000000d}.monitor-card h3{color:var(--color-navy,#1a1a4e);margin-top:0;font-size:16px}.monitor-card h4{color:#555;margin:12px 0 6px;font-size:13px}.monitor-card .empty{color:#aaa;padding:8px 0;font-size:13px}.row{color:#2c3e50;background:#f8f9fb;border-radius:6px;margin-bottom:5px;padding:8px 10px;font-size:13px;text-decoration:none;display:block}.row:hover{background:#f0f0f7}.row .row-main{justify-content:space-between;align-items:center;display:flex}.row span{font-weight:600;display:block}.row small{color:#888;margin-top:2px;font-size:11px;display:block}.row.danger{background:#fdecea;border-left:3px solid #e74c3c}.row.warning{background:#fff3cd;border-left:3px solid #f39c12}.notif-type{color:#006064;background:#e0f7fa;border-radius:10px;padding:2px 8px;font-size:11px}.msg{color:#555}.activity-block{margin-bottom:14px}*,:before,:after{box-sizing:border-box}body{color:#2c3e50;background:#f4f6f9;margin:0;font-family:Sarabun,sans-serif;font-size:15px}a{color:inherit;text-decoration:none}.spin{animation:1s linear infinite spin}.swal2-container{font-family:Sarabun,sans-serif!important}@media (max-width:768px){button,.btn,a{min-height:44px}input,select,textarea{font-size:16px!important}}
