@import "https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700&display=swap";:root{--obec-blue:#003087;--obec-gold:#c9a227;--obec-red:#c0392b;--obec-green:#1a7a4a;--table-head:#003087;--table-alt:#f0f4fb;--border-color:#b0bec5;--text-dark:#1a1a2e;--text-muted:#546e7a;--font-th:"Sarabun", "TH Sarabun New", sans-serif;--report-width:297mm}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-th);color:var(--text-dark);background:#e8edf2;font-size:14px;line-height:1.5}.app-shell{min-height:100vh;display:flex}.sidebar{background:linear-gradient(180deg, var(--obec-blue) 0%, #001a5e 100%);color:#fff;z-index:100;flex-direction:column;flex-shrink:0;width:260px;height:100vh;display:flex;position:fixed;overflow-y:auto}.sidebar-brand{text-align:center;border-bottom:1px solid #ffffff26;padding:20px 16px 16px}.sidebar-logo{object-fit:contain;background:#fff;border-radius:50%;width:80px;height:80px;margin-bottom:10px;margin-left:auto;margin-right:auto;padding:6px;display:block;box-shadow:0 2px 8px #0000004d}.sidebar-brand h2{color:var(--obec-gold);font-size:15px;font-weight:700}.sidebar-brand p{color:#ffffffb3;margin-top:4px;font-size:11px}.sidebar-menu{flex:1;padding:16px 0}.menu-section-title{color:#ffffff80;text-transform:uppercase;letter-spacing:1px;padding:12px 16px 6px;font-size:10px;font-weight:600}.menu-item{color:#ffffffd9;cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 16px;font-size:13.5px;text-decoration:none;transition:all .2s;display:flex}.menu-item:hover{color:#fff;background:#ffffff14}.menu-item.active{border-left-color:var(--obec-gold);color:var(--obec-gold);background:#c9a22733;font-weight:600}.menu-item .menu-icon{text-align:center;width:20px;font-size:16px}.menu-item-sub{color:#ffffffa6;border-left-color:#0000;padding-left:28px;font-size:12.5px}.menu-item-sub:hover{background:#ffffff0d}.menu-item-sub.active{border-left-color:var(--obec-gold);color:var(--obec-gold);background:#c9a22726}.main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;display:flex}.topbar{border-bottom:2px solid var(--obec-blue);z-index:50;background:#fff;justify-content:space-between;align-items:center;padding:12px 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #00000014}.topbar-title{color:var(--obec-blue);font-size:18px;font-weight:700}.topbar-subtitle{color:var(--text-muted);font-size:12px}.topbar-right{align-items:center;gap:16px;display:flex}.current-datetime{color:var(--text-muted);text-align:right;font-size:12px}.page-content{flex:1;padding:24px}.filter-panel{background:#fff;border:1px solid #dce3f0;border-radius:8px;margin-bottom:20px;padding:20px;box-shadow:0 2px 8px #0030870f}.filter-header{border-bottom:2px solid var(--obec-blue);align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.filter-header h3{color:var(--obec-blue);font-size:15px;font-weight:700}.filter-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:16px;display:grid}.filter-school{grid-column:span 2}.filter-group{flex-direction:column;gap:6px;display:flex}.filter-group label{color:var(--text-muted);font-size:12px;font-weight:600}.filter-group select,.filter-group input{font-family:var(--font-th);color:var(--text-dark);background:#fafbfc;border:1px solid #cdd5e0;border-radius:6px;width:100%;padding:8px 10px;font-size:13.5px;transition:border .2s}.filter-group select:focus,.filter-group input:focus{border-color:var(--obec-blue);background:#fff;outline:none}.school-search-wrapper{position:relative}.school-dropdown{z-index:200;background:#fff;border:1px solid #cdd5e0;border-radius:6px;max-height:220px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001f}.school-option{cursor:pointer;border-bottom:1px solid #f0f0f0;flex-direction:column;padding:8px 12px;display:flex}.school-option:hover{background:var(--table-alt)}.school-name{font-size:13px;font-weight:500}.school-area{color:var(--text-muted);font-size:11px}.school-code-badge{color:var(--obec-blue);background:#e8f0fe;border-radius:12px;margin-top:4px;padding:2px 8px;font-size:11px;display:inline-block}.search-spinner{position:absolute;top:10px;right:10px}.filter-actions{justify-content:flex-end;gap:12px;display:flex}.btn-search,.btn-clear,.btn-pdf,.btn-print{font-family:var(--font-th);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:9px 20px;font-size:13.5px;font-weight:600;transition:all .2s;display:flex}.btn-search{background:var(--obec-blue);color:#fff}.btn-search:hover{background:#004db3}.btn-search:disabled{opacity:.6;cursor:not-allowed}.btn-clear{color:var(--text-muted);background:#f0f4fb;border:1px solid #cdd5e0}.btn-clear:hover{background:#e0e8f5}.btn-pdf{background:var(--obec-red);color:#fff}.btn-pdf:hover{background:#a93226}.btn-pdf:disabled{opacity:.6;cursor:not-allowed}.btn-print{background:var(--obec-green);color:#fff}.btn-print:hover{background:#145c38}.print-actions{justify-content:flex-end;gap:10px;margin-bottom:16px;display:flex}.report-wrapper{width:100%;min-height:297mm;font-family:var(--font-th);background:#fff;border:1px solid #ccc;border-radius:4px;overflow:hidden;box-shadow:0 4px 20px #0000001f}.report-page-header{background:linear-gradient(135deg, var(--obec-blue) 0%, #0041a8 100%);color:#fff;grid-template-columns:90px 1fr 160px;align-items:center;gap:16px;padding:14px 24px;display:grid}.report-logo{object-fit:contain;background:#fff;border-radius:50%;width:72px;height:72px;padding:5px;box-shadow:0 1px 4px #00000040}.report-title-area{text-align:center}.report-ministry{color:#fffc;font-size:12px}.report-dept{color:#fffc;margin-bottom:6px;font-size:12px}.report-title{color:#fff;font-size:18px;font-weight:700;line-height:1.3}.report-subtitle{color:var(--obec-gold);margin-top:4px;font-size:13px}.report-meta-right{text-align:right;color:#fffc;font-size:11px;line-height:1.8}.report-date,.report-time,.report-page{white-space:nowrap}.report-filter-bar{background:var(--obec-gold);color:#1a1a1a;gap:8px;padding:6px 24px;font-size:12px;display:flex}.filter-label{font-weight:700}.report-body{padding:20px 24px}.report-table{border-collapse:collapse;width:100%;margin-bottom:16px;font-size:12.5px}.report-table th{background:var(--table-head);color:#fff;text-align:center;white-space:nowrap;border:1px solid #1a4a9a;padding:8px 10px;font-size:12px;font-weight:600}.report-table th.left{text-align:left}.report-table td{border:1px solid var(--border-color);vertical-align:middle;padding:6px 10px}.report-table td.center{text-align:center}.report-table td.right{text-align:right;font-variant-numeric:tabular-nums}.report-table tr:nth-child(2n) td{background:var(--table-alt)}.report-table tr:hover td{background:#dce9ff}.report-table tr.summary-row td{color:#fff;border-color:#003087;font-weight:700;background:#003087!important}.report-table tr.group-header td{color:var(--obec-blue);border-top:2px solid var(--obec-blue);background:#e8edf8;font-weight:700}.report-table tr.area-total td{border-top:2px solid var(--obec-blue);border-bottom:2px solid var(--obec-blue);background:#d4e0f8;font-weight:700}.num-positive{color:var(--obec-green);font-weight:600}.num-negative{color:var(--obec-red);font-weight:600}.num-zero{color:var(--text-muted)}.summary-cards{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px;display:grid}.summary-card{background:linear-gradient(135deg, var(--obec-blue), #0055d4);color:#fff;text-align:center;border-radius:8px;padding:14px}.summary-card.gold{background:linear-gradient(135deg, #9a7800, var(--obec-gold));color:#1a1a1a}.summary-card.green{background:linear-gradient(135deg, #0f5c33, var(--obec-green))}.summary-card.red{background:linear-gradient(135deg, #8e1c13, var(--obec-red))}.summary-card.purple{background:linear-gradient(135deg,#4a0080,#7b3fa3)}.summary-card .card-label{opacity:.85;margin-bottom:6px;font-size:11px}.summary-card .card-value{font-size:28px;font-weight:700;line-height:1}.summary-card .card-unit{opacity:.8;font-size:11px}.report-chart{margin:20px 0}.section-title{color:var(--obec-blue);border-left:4px solid var(--obec-gold);margin:20px 0 12px;padding-left:10px;font-size:14px;font-weight:700}.report-page-footer{border-top:2px solid var(--obec-blue);color:var(--text-muted);background:#f5f7fa;justify-content:space-between;padding:8px 24px;font-size:10px;display:flex}.loading-state{text-align:center;color:var(--text-muted);padding:60px 20px}.loading-spinner{border:4px solid #e0e8f5;border-top-color:var(--obec-blue);border-radius:50%;width:40px;height:40px;margin-bottom:12px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px;font-size:15px}.empty-state .empty-icon{margin-bottom:12px;font-size:48px;display:block}.badge{border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.badge-blue{color:var(--obec-blue);background:#dce9ff}.badge-green{color:var(--obec-green);background:#d4edda}.badge-red{color:var(--obec-red);background:#fde8e8}.badge-gold{color:#7a5900;background:#fef3cd}.home-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;margin-top:24px;display:grid}.report-card{cursor:pointer;color:inherit;border:1px solid #dce3f0;border-top:4px solid var(--obec-blue);background:#fff;border-radius:10px;flex-direction:column;gap:10px;padding:20px;text-decoration:none;transition:all .2s;display:flex}.report-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0030871f}.report-card.gold-top{border-top-color:var(--obec-gold)}.report-card.green-top{border-top-color:var(--obec-green)}.report-card.red-top{border-top-color:var(--obec-red)}.report-card.purple-top{border-top-color:#7b3fa3}.card-icon{font-size:32px}.card-title{color:var(--obec-blue);font-size:15px;font-weight:700}.card-desc{color:var(--text-muted);font-size:12.5px;line-height:1.6}.ss-wrapper{width:100%;position:relative}.ss-trigger{width:100%;font-family:var(--font-th);color:var(--text-dark);cursor:pointer;text-align:left;background:#fafbfc;border:1px solid #cdd5e0;border-radius:6px;justify-content:space-between;align-items:center;gap:8px;min-height:38px;padding:8px 10px;font-size:13.5px;transition:border-color .2s,box-shadow .2s;display:flex}.ss-trigger:hover:not(.disabled){border-color:var(--obec-blue)}.ss-trigger.open{border-color:var(--obec-blue);background:#fff;border-bottom-right-radius:0;border-bottom-left-radius:0;box-shadow:0 0 0 3px #0030871f}.ss-trigger.disabled{opacity:.55;cursor:not-allowed;background:#f0f0f0}.ss-trigger-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ss-trigger-label.placeholder{color:#9aa5b4}.ss-arrow{color:var(--text-muted);flex-shrink:0;font-size:9px}.ss-selected-info{align-items:center;gap:8px;margin-top:4px;display:flex}.code-badge{color:var(--obec-blue);background:#e8f0fe;border-radius:12px;padding:2px 8px;font-size:11px;display:inline-block}.ss-clear-btn{color:var(--text-muted);cursor:pointer;font-size:11px;font-family:var(--font-th);background:0 0;border:none;padding:0}.ss-clear-btn:hover{color:var(--obec-red)}.ss-dropdown{border:1px solid var(--obec-blue);z-index:500;background:#fff;border-top:none;border-bottom-right-radius:6px;border-bottom-left-radius:6px;position:absolute;top:100%;left:0;right:0;box-shadow:0 8px 24px #00308726}.ss-search-box{background:#f5f8ff;border-bottom:1px solid #e8edf5;align-items:center;gap:6px;padding:8px 10px;display:flex}.ss-search-icon{flex-shrink:0;font-size:13px}.ss-search-input{font-family:var(--font-th);color:var(--text-dark);background:0 0;border:none;outline:none;flex:1;font-size:13px}.ss-search-input::placeholder{color:#b0bec5}.ss-search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:12px}.ss-search-clear:hover{color:var(--obec-red)}.ss-list{max-height:220px;overflow-y:auto}.ss-option{cursor:pointer;border-bottom:1px solid #f0f4fb;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;transition:background .1s;display:flex}.ss-option:last-child{border-bottom:none}.ss-option:hover{background:var(--table-alt)}.ss-option.selected{background:#dce9ff}.ss-option.all-option{color:var(--text-muted);font-style:italic}.ss-opt-label{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.ss-opt-code{color:var(--text-muted);white-space:nowrap;background:#f0f4fb;border-radius:10px;flex-shrink:0;padding:1px 6px;font-size:11px}.ss-option.selected .ss-opt-code{color:var(--obec-blue);background:#c3d8ff}.ss-empty{text-align:center;color:var(--text-muted);padding:16px 12px;font-size:13px}.ss-count-hint{color:var(--text-muted);text-align:center;background:#f8f9fb;border-top:1px solid #eee;padding:6px 12px;font-size:11px}.label-hint{color:var(--obec-blue);opacity:.8;font-size:11px;font-weight:400}@media print{body{background:#fff!important}.sidebar,.topbar,.filter-panel,.print-actions,.filter-panel{display:none!important}.main-content{margin-left:0!important}.page-content{padding:0!important}.report-wrapper{box-shadow:none!important;border:none!important;border-radius:0!important}.report-table tr:hover td{background:inherit!important}@page{size:A4 landscape;margin:10mm}}
