@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap";html{height:100%;margin:0;padding:0}body{width:100%;color:var(--text-dark);background:#f0f2f5;margin:0;padding:0;font-family:IBM Plex Sans,sans-serif;font-size:14px;line-height:1.4;overflow-x:hidden}:root{--primary:#009cb8;--primary-hover:#007f98;--green:#28a745;--green-hover:#218838;--red:#dc3545;--red-hover:#c82333;--gray-border:#ccc;--gray-header:#f4f6f9;--text-dark:#333;--text-mid:#555;--text-light:#777;--white:#fff;--sidebar-width:250px;--navbar-height:55px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:var(--text-dark);background:#f0f2f5;font-family:IBM Plex Sans,sans-serif;font-size:14px}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}ul{list-style:none}input,select,textarea{font-family:inherit;font-size:14px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px}.main-container{min-height:100vh;position:relative}.content-wrapper{margin-left:var(--sidebar-width);background:var(--white);flex-direction:column;width:auto;min-height:100vh;transition:margin-left .2s;display:flex}.main-container.sidebar-collapsed .content-wrapper{margin-left:70px}.page-content{background:var(--white);flex:1}.sidebar{width:var(--sidebar-width);background:var(--white);border-right:1px solid var(--gray-border);z-index:1000;flex-direction:column;height:100vh;transition:width .2s;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar-collapsed .sidebar{width:70px}.sidebar-collapsed .sidebar-brand-name,.sidebar-collapsed .sidebar-brand-sub,.sidebar-collapsed .sidebar-search-box input,.sidebar-collapsed .sidebar-search-arrow,.sidebar-collapsed .sidebar-nav-item span,.sidebar-collapsed .chevron{display:none}.sidebar-collapsed .sidebar-nav-item{justify-content:center;padding:12px}.sidebar-collapsed .sidebar-submenu{display:none!important}.sidebar-sticky-top{background:var(--white);z-index:100;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid var(--gray-border);min-height:var(--navbar-height);align-items:center;gap:10px;padding:6px 14px;display:flex}.sidebar-brand-logo{color:#fff;background:#faa61a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:26px;font-weight:800;display:flex}.sidebar-brand-text{flex-direction:column;line-height:1.15;display:flex}.sidebar-brand-name{color:var(--primary);letter-spacing:.2px;font-size:19px;font-weight:800}.sidebar-brand-sub{color:#faa61a;letter-spacing:2.5px;font-size:10.5px;font-weight:600}.sidebar-search-wrap{padding:9px 12px;position:relative}.sidebar-search-box{background:var(--white);border:1px solid #aab5bc;align-items:center;gap:6px;padding:5px 10px;display:flex}.sidebar-search-box input{color:var(--text-dark);background:0 0;border:none;outline:none;flex:1;font-size:13.5px}.sidebar-search-box input::placeholder{color:#aaa}.sidebar-search-arrow{color:#666;flex-shrink:0}.sidebar-search-dropdown{background:var(--white);z-index:1100;border:1px solid #ccc;max-height:200px;position:absolute;top:calc(100% - 9px);left:12px;right:12px;overflow-y:auto;box-shadow:0 4px 10px #0000001f}.sidebar-search-item{cursor:pointer;border-bottom:1px solid #f0f0f0;padding:9px 14px;font-size:13px}.sidebar-search-item:hover{color:var(--primary);background:#f0f8fa}.sidebar-nav{flex:1;padding:4px 0}.sidebar-nav-item{color:var(--text-dark);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:9px 14px;font-size:14.5px;font-weight:600;transition:background .15s,color .15s;display:flex}.sidebar-nav-item:hover{color:var(--primary);background:#f0f8fa}.sidebar-nav-item.active{color:var(--primary)}.sidebar-nav-item svg{flex-shrink:0}.sidebar-nav-item.has-children{justify-content:space-between}.sidebar-nav-item.has-children .item-left{align-items:center;gap:12px;display:flex}.sidebar-nav-item .chevron{flex-shrink:0;transition:transform .2s}.sidebar-nav-item.open .chevron{transform:rotate(90deg)}.sidebar-submenu{background:var(--white);display:none}.sidebar-submenu.open{display:block}.sidebar-sub-link{color:var(--text-dark);padding:8px 14px 8px 54px;font-size:14px;font-weight:400;transition:color .15s;display:block}.sidebar-sub-link:hover{color:var(--primary)}.sidebar-sub-link.active{color:var(--primary);font-weight:600}.navbar{height:var(--navbar-height);background:var(--primary);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 18px;display:flex}.header-stack{z-index:1100;background:var(--white);width:100%;position:sticky;top:0;box-shadow:0 2px 4px #0000000d}.navbar-left{align-items:center;display:flex}.navbar-hamburger{color:var(--white);background:0 0;border-radius:3px;align-items:center;padding:4px;display:flex}.navbar-hamburger:hover{background:#ffffff26}.navbar-right{align-items:center;gap:18px;display:flex}.navbar-icon-btn{color:var(--white);background:0 0;border-radius:50%;align-items:center;padding:4px;display:flex;position:relative}.navbar-icon-btn:hover{background:#ffffff26}.navbar-notif-dot{border:1.5px solid var(--primary);background:#ff5252;border-radius:50%;width:7px;height:7px;position:absolute;top:2px;right:2px}.page-lister{scrollbar-width:none;background:#f0f0f0;border-bottom:1px solid #d0d0d0;flex-shrink:0;align-items:flex-end;height:32px;padding:0 0 0 8px;display:flex;overflow:auto hidden}.page-lister::-webkit-scrollbar{display:none}.page-lister-tab{color:#fff;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;background:#b8b8b8;border:1px solid #a5a5a5;border-bottom:none;border-radius:3px 3px 0 0;align-items:center;gap:7px;height:26px;margin-right:3px;padding:4px 12px 4px 14px;font-size:12.5px;font-weight:500;display:inline-flex}.page-lister-tab:hover{background:#a5a5a5}.page-lister-tab.active{background:var(--primary);border-color:var(--primary);color:var(--white)}.page-lister-tab .tab-close{background:#00000026;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:12px;line-height:1;display:flex}.page-lister-tab .tab-close:hover{background:#0000004d}.page-lister-tab.active .tab-close{background:#ffffff40}.tab-nav{z-index:1050;background:#e6f3f5;border-bottom:1px solid #c8dde0;flex-shrink:0;align-items:center;gap:4px;height:38px;padding:0 16px;display:flex;position:sticky;top:87px}.sec-div{border:1px solid #e5e7eb;border-bottom:none;border-left:3px solid var(--primary);color:#4b5563;z-index:1;background:#fff;border-radius:4px 4px 0 0;margin:20px 0 0;padding:6px 16px;font-size:13px;font-weight:600;display:inline-block;position:relative}.form-section-container{border-top:1px solid #e5e7eb;margin-top:-1px;padding:20px 0}.form-photo-panel{flex-direction:column;flex-shrink:0;align-items:center;gap:10px;width:140px;padding-top:4px;display:flex}.photo-upload-box{cursor:pointer;color:#9ca3af;background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:10px;width:130px;height:160px;transition:all .2s;display:flex}.photo-upload-box:hover{border-color:var(--primary);color:var(--primary);background:#f0fdf4}.photo-upload-box span{text-align:center;padding:0 8px;font-size:10px;line-height:1.4}.photo-actions{grid-template-columns:1fr 1fr;gap:6px;width:100%;display:grid}.sig-upload-box{color:#9ca3af;background:#f9fafb;border:1px dashed #d1d5db;border-radius:6px;justify-content:center;align-items:center;width:100%;height:60px;margin-top:6px;font-size:12px;display:flex}.btn-upload{cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;gap:6px;width:100%;height:30px;font-size:11px;font-weight:500;transition:opacity .2s;display:flex}.btn-upload.btn-teal{background:var(--primary);color:#fff}.btn-upload.btn-dark{color:#fff;background:#374151}.btn-upload.btn-outline{color:#374151;background:#fff;border:1px solid #d1d5db}.mini-table-wrap{border:1px solid #e5e7eb;border-radius:6px;margin-bottom:20px;overflow-x:auto}.mini-tbl{border-collapse:collapse;width:100%;font-size:13px}.mini-tbl th{color:#4b5563;text-align:left;background:#f3f4f6;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-weight:600}.mini-tbl td{border-bottom:1px solid #f3f4f6;padding:8px 12px}.mini-tbl .empty-msg{text-align:center;color:#9ca3af;padding:24px;font-style:italic}.btn-add-row{color:#4b5563;cursor:pointer;background:#f3f4f6;border:1px dashed #d1d5db;border-radius:4px;margin:10px;padding:6px 16px;font-size:12px;transition:all .2s}.btn-add-row:hover{border-color:var(--primary);color:var(--primary);background:#fff}.btn-del-row{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.doc-grid{flex-wrap:wrap;gap:20px;margin-bottom:20px;display:flex}.doc-item{flex-direction:column;align-items:center;gap:8px;display:flex}.doc-box{color:#9ca3af;cursor:pointer;background:#f9fafb;border:1px dashed #d1d5db;border-radius:6px;justify-content:center;align-items:center;width:120px;height:90px;transition:all .2s;display:flex}.doc-box:hover{border-color:var(--primary);color:var(--primary);background:#f0fdf4}.doc-item span{color:#4b5563;font-size:12px;font-weight:500}.btn-doc{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:4px 12px;font-size:11px}.btn-doc:hover{border-color:var(--primary);color:var(--primary)}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:20px;display:grid}.grid-4{grid-template-columns:1fr 1fr 1fr 1fr;gap:20px;display:grid}.tab-nav-link{text-transform:uppercase;letter-spacing:.3px;color:#666;cursor:pointer;white-space:nowrap;align-items:center;height:100%;padding:0 16px;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.tab-nav-link:hover{color:var(--primary);background:#009cb80d}.tab-nav-link.active{color:var(--primary);background:#009cb814;font-weight:700}.page-title-bar{z-index:1050;background:#e6f3f5;border-bottom:1px solid #c8dde0;flex-shrink:0;align-items:center;height:38px;padding:0 16px;display:flex;position:sticky;top:87px}.page-title-bar h2{text-transform:uppercase;color:var(--primary);letter-spacing:.5px;font-size:13px;font-weight:700}.tbl-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex}.tbl-controls-left{align-items:center;gap:8px;display:flex}.show-entries{border:1px solid var(--gray-border);background:var(--white);align-items:center;height:32px;font-size:14px;display:flex}.show-entries .lbl{color:var(--text-dark);border-right:1px solid var(--gray-border);align-items:center;height:100%;padding:0 10px;font-size:14px;display:flex}.show-entries select{border:none;border-right:1px solid var(--gray-border);background:var(--white);cursor:pointer;min-width:52px;height:100%;color:var(--text-dark);outline:none;padding:0 6px;font-size:14px}.show-entries .lbl-entries{color:var(--text-dark);align-items:center;height:100%;padding:0 10px;font-size:14px;display:flex}.tbl-search{background:var(--white);border:1px solid #8a9fa8;align-items:center;height:32px;display:flex}.tbl-search input{width:220px;color:var(--text-dark);border:none;outline:none;height:100%;padding:0 10px;font-size:14px}.tbl-search input::placeholder{color:#aaa}.tbl-search-icon{color:#7c929a;background:#f0f4f6;border-left:1px solid #8a9fa8;justify-content:center;align-items:center;width:34px;height:100%;display:flex}.tbl-controls-right{align-items:center;gap:6px;display:flex}.tbl-icon-btn{border:1px solid var(--gray-border);background:var(--white);width:32px;height:32px;color:var(--text-mid);border-radius:2px;justify-content:center;align-items:center;display:flex}.tbl-icon-btn:hover{background:#f0f0f0}.btn-add{background:var(--primary);color:var(--white);cursor:pointer;white-space:nowrap;border:none;border-radius:2px;align-items:center;height:32px;padding:0 18px;font-size:14px;font-weight:600;display:inline-flex}.btn-add:hover{background:var(--primary-hover)}.data-table-wrap{padding:0 16px 12px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table thead tr th{color:var(--text-dark);text-transform:uppercase;letter-spacing:.3px;border:1px solid var(--gray-border);text-align:left;white-space:nowrap;background:#f4f6f9;padding:9px 14px;font-size:13px;font-weight:600}.data-table tbody tr td{border:1px solid var(--gray-border);color:var(--text-dark);vertical-align:middle;padding:10px 14px}.data-table tbody tr:hover td{background:#f9feff}.tbl-action-btns{align-items:center;gap:6px;display:flex}.tbl-btn-edit{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;padding:2px;display:flex}.tbl-btn-delete{color:var(--red);cursor:pointer;background:0 0;border:none;align-items:center;padding:2px;display:flex}.tbl-btn-add-row{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;padding:2px;display:flex}.tbl-footer{color:var(--text-light);padding:4px 16px 12px;font-size:13px}.pagination{justify-content:flex-end;align-items:center;gap:3px;padding:6px 16px 12px;display:flex}.pagination-btn{border:1px solid var(--gray-border);background:var(--white);min-width:30px;height:30px;color:var(--text-dark);cursor:pointer;border-radius:2px;justify-content:center;align-items:center;padding:0 6px;font-size:13px;display:flex}.pagination-btn:hover{color:var(--primary);background:#e6f3f5}.pagination-btn.active{background:var(--primary);color:var(--white);border-color:var(--primary)}.pagination-btn:disabled{opacity:.4;cursor:default}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:2px;outline:none;justify-content:center;align-items:center;gap:5px;padding:7px 22px;font-family:inherit;font-size:14px;font-weight:500;transition:opacity .15s;display:inline-flex}.btn:hover{opacity:.88}.btn-primary{background:var(--primary);color:var(--white)}.btn-success{background:var(--green);color:var(--white)}.btn-danger{background:var(--red);color:var(--white)}.btn-outline{background:var(--white);color:var(--text-dark);border:1px solid var(--gray-border)}.btn-save-data{background:var(--primary);color:var(--white);border-radius:2px;padding:7px 28px;font-size:14.5px;font-weight:700}.btn-delete-data{background:var(--red);color:var(--white);border-radius:2px;padding:7px 28px;font-size:14.5px;font-weight:700}.form-section{padding:8px 16px 0}.form-row{gap:12px;margin-bottom:12px;display:flex}.form-row.grid-2>.form-group{flex:0 0 calc(50% - 6px)}.form-row.grid-3>.form-group{flex:0 0 calc(33.333% - 8px)}.form-row.grid-4>.form-group{flex:0 0 calc(25% - 9px)}.form-group{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.form-group label{color:#6b7280;text-transform:capitalize;font-size:11px;font-weight:500}.form-group label .req{color:var(--red);margin-left:2px}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--gray-border);color:#1f2937;background:var(--white);border-radius:4px;outline:none;width:100%;height:34px;padding:0 10px;font-size:13.5px;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #2d52461a}.form-group textarea{resize:vertical;height:auto;min-height:50px;padding:8px 10px}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpolyline points='6 9' or 12'15' or 18'9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.form-check{align-items:center;gap:8px;margin-bottom:24px;display:flex}.form-check input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer}.form-check label{color:var(--text-dark);cursor:pointer;font-size:14px}.form-btn-row{justify-content:center;align-items:center;gap:14px;padding:10px 0 24px;display:flex}.module-container{background:var(--white);flex-direction:column;display:flex}.schedule-shift-bar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;padding:14px 16px 10px;display:flex}.schedule-shift-left{align-items:flex-end;gap:14px;display:flex}.schedule-shift-col{flex-direction:column;gap:5px;display:flex}.schedule-shift-label{color:var(--text-dark);font-size:13.5px;font-weight:500}.schedule-shift-select{border:1px solid var(--gray-border);min-width:240px;height:34px;color:var(--text-dark);background:var(--white);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:0 28px 0 10px;font-size:14px}.schedule-shift-btns{align-self:flex-end;gap:8px;display:flex}.period-cell{flex-direction:column;gap:5px;min-width:200px;display:flex}.period-cell select{border:1px solid var(--gray-border);background:var(--white);outline:none;width:100%;height:26px;padding:0 6px;font-size:12px}.period-cell-btn{background:var(--primary);color:var(--white);cursor:pointer;border:none;border-radius:4px;padding:4px 8px;font-size:11px;font-weight:600;transition:opacity .2s}.period-cell-btn:hover{opacity:.85}.schedule-matrix{table-layout:auto!important}.schedule-matrix .sticky-col{z-index:5;background:#fff;border-right:2px solid #d1d5db;position:sticky;left:0}.schedule-matrix thead .sticky-col{z-index:12;background:#f4f6f9}.schedule-matrix thead th{z-index:8;position:sticky;top:0}.schedule-matrix thead .sticky-col{z-index:12}.period-form-table{border-collapse:collapse;width:100%;margin-top:10px;font-size:13.5px}.period-form-table th{border:1px solid var(--gray-border);text-transform:uppercase;letter-spacing:.3px;background:#f4f6f9;padding:8px 14px;font-size:12.5px;font-weight:600}.period-form-table td{border:1px solid var(--gray-border);color:var(--text-dark);padding:8px 14px}.dashboard-wrapper{min-height:calc(100vh - var(--navbar-height));background:#f8fafc;padding:24px 30px}.dashboard-header-modern{justify-content:space-between;align-items:center;margin-bottom:30px;display:flex}.dashboard-header-modern h1{color:#1e293b;margin-bottom:4px;font-size:24px;font-weight:800}.dashboard-header-modern p{color:#64748b;font-size:14px}.date-display{color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;display:flex;box-shadow:0 1px 3px #0000000d}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 12px 20px -5px #00000014}.stat-card:after{content:"";background:var(--primary);opacity:0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.stat-card:hover:after{opacity:1}.stat-card-icon{border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;display:flex}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.stat-value{color:#1e293b;margin:4px 0;font-size:28px;font-weight:800}.stat-card-trend{color:#10b981;align-items:center;gap:4px;margin-top:8px;font-size:12px;font-weight:600;display:flex}.dashboard-row-modern{grid-template-columns:2fr 1fr;gap:24px;display:grid}.dashboard-col-actions h3,.dashboard-col-activity h3{color:#1e293b;align-items:center;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.quick-actions-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.action-tile{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;align-items:center;gap:12px;padding:20px;transition:all .2s;display:flex;position:relative}.action-tile:hover{border-color:var(--primary);background:#f0f9fa;transform:scale(1.02)}.action-tile-icon{width:40px;height:40px;color:var(--primary);background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;display:flex}.action-tile span{color:#334155;font-size:14px;font-weight:600}.action-arrow{color:#cbd5e1;opacity:0;transition:opacity .2s;position:absolute;top:12px;right:12px}.action-tile:hover .action-arrow{opacity:1}.system-status-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:8px}.status-item{border-bottom:1px solid #f1f5f9;align-items:center;gap:16px;padding:16px;display:flex}.status-item:last-child{border-bottom:none}.status-dot{border-radius:50%;width:10px;height:10px;position:relative}.status-dot.online{background:#10b981;box-shadow:0 0 0 4px #10b9811a}.status-dot.online:after{content:"";border:2px solid #10b981;border-radius:50%;animation:2s infinite pulse;position:absolute;inset:0}@keyframes pulse{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}.status-info{flex-direction:column;display:flex}.status-info span{color:#1e293b;font-size:14px;font-weight:600}.status-info small{color:#64748b;font-size:12px}.sec-div{border:1px solid var(--gray-border);border-bottom:none;border-left:3px solid var(--primary);color:#1a2e2a;z-index:10;text-transform:capitalize;background:#fff;border-radius:4px 4px 0 0;margin:24px 0 0;padding:6px 14px;font-size:13px;font-weight:700;display:inline-block;position:relative}.sec-container{border:1px solid var(--gray-border);background:#fff;border-radius:0 4px 4px;margin-top:-1px;margin-bottom:24px;padding:24px 16px 16px}.list-table-container{border:1px solid var(--gray-border);background:#fff;border-radius:4px;margin:10px 16px 20px;overflow:hidden}.list-toolbar{border-bottom:1px solid var(--gray-border);background:#fdfdfd;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;display:flex}.toolbar-filters{flex:1;align-items:center;gap:12px;display:flex}.toolbar-actions{align-items:center;gap:10px;display:flex}.list-table{border-collapse:collapse;width:100%;font-size:11.5px}.list-table th{color:#374151;text-align:left;text-transform:uppercase;white-space:nowrap;background:#f8fafb;border:1px solid #e5e7eb;padding:10px 12px;font-weight:700}.list-table td{color:#1f2937;vertical-align:middle;border:1px solid #e5e7eb;padding:8px 12px}.list-table tr:nth-child(2n){background:#fafafa}.list-table tr:hover{background:#f0fdf4}.action-btns{align-items:center;gap:6px;display:flex}.action-ico{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:4px;justify-content:center;align-items:center;width:26px;height:26px;transition:all .2s;display:flex}.action-ico:hover{border-color:var(--primary);color:var(--primary)}.action-ico.edit:hover{color:#059669;background:#ecfdf5;border-color:#059669}.action-ico.del:hover{color:#dc2626;background:#fef2f2;border-color:#dc2626}.action-ico.view:hover{color:#2563eb;background:#eff6ff;border-color:#2563eb}.img-thumb{object-fit:cover;border:1px solid #e5e7eb;border-radius:50%;width:32px;height:32px}.list-footer{border-top:1px solid var(--gray-border);color:#6b7280;background:#fdfdfd;justify-content:space-between;align-items:center;padding:12px 16px;font-size:12px;display:flex}.pagination{gap:4px;display:flex}.pg-num{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex}.pg-num:hover{border-color:var(--primary);color:var(--primary)}.pg-num.active{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-save{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:4px;height:36px;padding:0 24px;font-weight:600;transition:opacity .2s}.btn-save:hover{opacity:.9}.btn-reset{color:#4b5563;cursor:pointer;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;height:36px;padding:0 24px;font-weight:600;transition:all .2s}.btn-reset:hover{background:#e5e7eb}.btn-update{color:#fff;cursor:pointer;background:#0ea5e9;border:none;border-radius:4px;height:36px;padding:0 24px;font-weight:600}.multiselect-wrap{background:#fff;border:1px solid #d1d5db;border-radius:4px;flex-wrap:wrap;align-items:center;gap:6px;min-height:38px;padding:4px 10px;transition:border-color .2s;display:flex}.multiselect-wrap:focus-within{border-color:var(--primary)}.sec-tag{color:var(--primary);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:4px;align-items:center;gap:8px;padding:2px 10px;font-size:11px;font-weight:600;display:flex}.sec-tag-close{cursor:pointer;color:#ef4444;border-radius:50%;padding:1px}.sec-tag-close:hover{background:#fee2e2}.checkbox-wrap{cursor:pointer;-webkit-user-select:none;user-select:none;color:#374151;align-items:center;gap:8px;margin-bottom:12px;font-size:12px;display:flex}.checkbox-wrap input{width:14px;height:14px;accent-color:var(--primary)}.radio-group{align-items:center;gap:20px;display:flex}.radio-label{cursor:pointer;color:#374151;align-items:center;gap:6px;font-size:12px;display:flex}.radio-label input{accent-color:var(--primary)}.form-photo-wrap{align-items:flex-start;gap:20px;display:flex}.form-main-content{flex:1;min-width:0}.photo-panel{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;width:140px;padding-top:4px;display:flex}.photo-box{color:#9ca3af;text-align:center;cursor:pointer;background:#f9fafb;border:1px solid #d1d5db;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:10px;width:130px;height:160px;font-size:10px;transition:all .2s;display:flex}.photo-box:hover{border-color:var(--primary);color:var(--primary)}.sig-box{color:#9ca3af;background:#f9fafb;border:1px dashed #d1d5db;border-radius:4px;justify-content:center;align-items:center;width:100%;height:60px;margin-top:6px;font-size:11px;display:flex}.btn-upload-teal{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;gap:6px;width:100%;padding:6px 0;font-size:11px;font-weight:500;display:flex}.btn-upload-dark{color:#fff;cursor:pointer;background:#374151;border:none;border-radius:4px;justify-content:center;align-items:center;gap:6px;width:100%;padding:6px 0;font-size:11px;font-weight:500;display:flex}.btn-upload-outline{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:4px;width:100%;height:28px;font-size:10px;font-weight:500}.doc-upload-grid{gap:16px;margin-bottom:20px;display:flex}.doc-thumb{flex-direction:column;align-items:center;gap:6px;display:flex}.doc-thumb-box{cursor:pointer;background:#fdfdfd;border:1px dashed #d1d5db;border-radius:4px;justify-content:center;align-items:center;width:120px;height:90px;display:flex;overflow:hidden}.doc-thumb-box:hover{border-color:var(--primary)}.doc-thumb span{color:#6b7280;text-align:center;font-size:10px}.doc-thumb button{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:3px 8px;font-size:10px}.print-only-header,.print-cell-text{display:none}@media print{@page{size:A4 landscape;margin:12mm 10mm}.sidebar,.navbar,.tab-nav,.tbl-controls,.schedule-shift-bar,.tbl-footer,.modal-overlay,.confirm-modal-overlay,.period-cell-btn,button{display:none!important}body,html{background:#fff!important;margin:0!important;padding:0!important}.main-layout{background:#fff!important;margin-left:0!important;padding:0!important}.module-container{box-shadow:none!important;background:#fff!important;border:none!important;padding:0!important}.data-table-wrap{max-height:none!important;overflow:visible!important}.print-only-header{text-align:center;border-bottom:2px solid #000;margin-bottom:10px;padding-bottom:8px;display:block!important}.print-only-header .ph-school-name{text-transform:uppercase;letter-spacing:1px;margin:0;font-size:18pt;font-weight:800}.print-only-header .ph-address{color:#444;margin:2px 0 6px;font-size:10pt}.print-only-header .ph-report-title{text-transform:uppercase;letter-spacing:2px;margin:6px 0 4px;font-size:13pt;font-weight:700}.print-only-header .ph-meta{color:#555;margin:0;font-size:9pt}.schedule-matrix{border-collapse:collapse!important;table-layout:fixed!important;width:100%!important;font-size:8pt!important}.schedule-matrix th,.schedule-matrix td{vertical-align:top!important;word-break:break-word!important;border:1px solid #000!important;padding:4px 3px!important}.schedule-matrix thead th{color:#000!important;text-align:center!important;background:#e8e8e8!important;font-weight:700!important}.schedule-matrix .sticky-col{background:#f5f5f5!important;font-weight:700!important;position:static!important}.schedule-matrix select,.schedule-matrix .period-cell-btn{display:none!important}.print-cell-text{text-align:center;font-size:8pt;line-height:1.5;display:block!important}.print-cell-text .pct-subject{color:#000;font-weight:700}.print-cell-text .pct-teacher{color:#333;font-style:italic}.print-cell-text .pct-divider{border-top:1px dashed #999;margin:3px 0}.print-cell-text .pct-extra-subject{color:#000;font-size:7.5pt;font-weight:600}.print-cell-text .pct-extra-teacher{color:#444;font-size:7.5pt;font-style:italic}.schedule-matrix .print-hide,.schedule-matrix th.print-hide{display:none!important}}.login-wrapper{background:#f0f2f5;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:8px;width:100%;max-width:420px;padding:40px;box-shadow:0 4px 15px #0000000d}.login-logo{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;margin:0 auto 15px;font-size:24px;font-weight:700;display:flex}.login-header h2{color:var(--text-dark);margin-bottom:5px;font-size:20px}.login-group{margin-bottom:20px}.login-group label{color:var(--text-dark);margin-bottom:8px;font-size:14px;font-weight:500;display:block}.login-group input{border:1px solid var(--gray-border);border-radius:4px;width:100%;padding:10px 14px;font-size:14px}.login-group input:focus{border-color:var(--primary)}.login-remember{color:var(--text-mid);cursor:pointer;align-items:center;gap:6px;display:flex}.login-forgot{color:var(--primary)}.login-btn:hover{background:var(--primary-hover)}.auth-notes{color:#333;margin-top:20px;padding:15px 0;font-size:14px;line-height:1.6}.auth-notes p{margin-bottom:5px}.profile-overlay{z-index:1040;opacity:0;pointer-events:none;background:#0000004d;transition:opacity .3s;position:fixed;inset:0}.profile-overlay.show{opacity:1;pointer-events:auto}.profile-slideout{z-index:1050;background:#fff;flex-direction:column;width:250px;height:100vh;transition:right .3s;display:flex;position:fixed;top:0;right:-250px;box-shadow:-2px 0 10px #0000001a}.profile-slideout.open{right:0}.profile-close-btn{cursor:pointer;z-index:10;color:#333;background:#ffffffb3;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:absolute;top:15px;left:15px}.profile-cover{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);flex-direction:column;justify-content:flex-end;align-items:center;height:140px;padding-bottom:15px;display:flex;position:relative}.profile-avatar-wrap{background:#fff;border-radius:50%;width:80px;height:80px;padding:4px;position:absolute;bottom:-40px;left:30px;box-shadow:0 2px 10px #0000001a}.profile-avatar{color:#666;background:#f0f2f5;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.profile-avatar svg{width:45px;height:45px}.profile-name{color:var(--primary);font-size:20px;font-weight:600;position:absolute;bottom:-35px;left:125px}.profile-menu{flex:1;margin-top:55px;padding:0 0 20px;overflow-y:auto}.profile-menu-item{width:100%;color:var(--text-dark);text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #f1f1f1;align-items:center;gap:15px;padding:15px 25px;font-size:15px;transition:background .2s;display:flex}.profile-menu-item:hover:not(.read-only){background:#f8f9fa}.profile-menu-item.read-only{cursor:default}.profile-menu-item.border-bottom{border-bottom:4px solid #f1f1f1}.icon-teal{color:var(--primary)}.layout-settings{padding:20px 25px}.layout-title{color:var(--text-mid);margin-bottom:15px;font-size:18px;font-weight:600}.layout-checkbox{color:var(--text-dark);cursor:pointer;align-items:center;gap:10px;margin-bottom:12px;font-size:14px;display:flex}.layout-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.login-wrapper{background:linear-gradient(135deg,#009cb8 0%,#00d2ff 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--white);border-radius:12px;width:100%;max-width:400px;padding:40px;animation:.5s ease-out slideUp;box-shadow:0 10px 30px #0000001a}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:30px}.login-logo{background:var(--primary);color:#fff;border-radius:12px;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 15px;font-size:32px;font-weight:700;display:flex;box-shadow:0 4px 12px #009cb84d}.login-header h2{letter-spacing:-.5px;margin-bottom:5px;font-size:24px}.login-header p{color:var(--text-light);font-size:14px}.login-form .login-group{margin-bottom:20px}.login-form label{color:var(--text-mid);margin-bottom:8px;font-size:13px;font-weight:600;display:block}.login-form input{border:1px solid var(--gray-border);background:#fcfcfc;border-radius:8px;width:100%;padding:12px 16px;transition:all .2s}.login-form input:focus{border-color:var(--primary);background:#fff;outline:none;box-shadow:0 0 0 3px #009cb81a}.login-options{justify-content:space-between;align-items:center;margin-bottom:25px;font-size:13px;display:flex}.login-remember{cursor:pointer;align-items:center;gap:8px;display:flex}.login-forgot{color:var(--primary);font-weight:500}.login-btn{background:var(--primary);color:#fff;border-radius:8px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:all .3s}.login-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}
