@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";:root{--font-family:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--primary:#0fae5e;--primary-hover:#0c8d4d;--primary-light:#0fae5e26;--primary-glow:#0fae5e66;--bg-app:#0f1319;--bg-sidebar:#0b0e13;--bg-card:#171c26;--bg-card-hover:#1f2533;--border:#2b303b;--border-focus:#0fae5e;--text-main:#edeff3;--text-muted:#9da3af;--text-inverse:#0f1319;--success:#22c35d;--warning:#f59f0a;--danger:#e8304f;--info:#13b6ec;--shadow-sm:0 2px 8px #0003;--shadow-md:0 8px 24px #0000004d;--shadow-lg:0 16px 48px #0006;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-app:#f9fafb;--bg-sidebar:#f0f2f5;--bg-card:#fff;--bg-card-hover:#f3f5f7;--border:#dce0e5;--text-main:#171c26;--text-muted:#676f7e;--shadow-md:0 8px 24px #0000000d}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-app);color:var(--text-main);-webkit-font-smoothing:antialiased;transition:background-color var(--transition-normal), color var(--transition-normal);line-height:1.5;overflow-x:hidden}.app-container{min-height:100vh;display:flex}.sidebar{background-color:var(--bg-sidebar);border-right:1px solid var(--border);z-index:10;flex-direction:column;flex-shrink:0;width:280px;height:100vh;padding:2rem 1.5rem;display:flex;position:sticky;top:0}.logo-section{align-items:center;gap:12px;margin-bottom:2.5rem;padding:0 .5rem;display:flex}.logo-section svg{color:var(--primary);filter:drop-shadow(0 0 8px var(--primary-glow))}.logo-text h1{letter-spacing:-.5px;font-size:1.15rem;font-weight:800;line-height:1.2}.logo-text span{color:var(--text-muted);font-size:.75rem;font-weight:500}.nav-links{flex-direction:column;gap:8px;list-style:none;display:flex}.nav-item{color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;font-weight:600;text-decoration:none;display:flex}.nav-item:hover{color:var(--text-main);background-color:var(--primary-light)}.nav-item.active{color:var(--text-main);background-color:var(--primary);border-color:var(--primary-hover);box-shadow:0 4px 12px var(--primary-glow)}.nav-item svg{width:20px;height:20px}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:auto;padding-top:1.5rem;display:flex}.status-badge{background-color:var(--border);border-radius:20px;align-items:center;gap:6px;width:fit-content;padding:6px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.status-badge.online{color:var(--success);background-color:#22c35d26}.status-badge.offline{color:var(--warning);background-color:#f59f0a26}.main-content{flex-grow:1;width:calc(100% - 280px);max-width:1400px;margin:0 auto;padding:2.5rem}.header-bar{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.header-title h2{letter-spacing:-.5px;font-size:1.75rem;font-weight:700}.header-title p{color:var(--text-muted);font-size:.9rem}.grid-stats{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2.5rem;display:grid}.card{background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);padding:1.5rem}.card:hover{border-color:var(--primary-glow);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card{align-items:center;gap:1.25rem;display:flex}.stat-icon{border-radius:var(--radius-md);background-color:var(--primary-light);width:54px;height:54px;color:var(--primary);justify-content:center;align-items:center;display:flex}.stat-details h3{font-size:1.75rem;font-weight:800;line-height:1.2}.stat-details p{color:var(--text-muted);font-size:.85rem;font-weight:600}.section-header{align-items:center;gap:8px;margin-bottom:1.25rem;font-size:1.15rem;font-weight:700;display:flex}.section-header:before{content:"";background-color:var(--primary);border-radius:2px;width:4px;height:18px;display:inline-block}.form-group{flex-direction:column;gap:6px;margin-bottom:1.25rem;display:flex}.form-group label{color:var(--text-muted);font-size:.85rem;font-weight:600}.form-control,select,textarea{background-color:var(--bg-app);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-main);font-family:var(--font-family);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:12px 16px;font-size:.95rem}.form-control:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-light);outline:none}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-hover));color:#fff;box-shadow:0 4px 12px var(--primary-glow)}.btn-primary:hover{box-shadow:0 6px 16px var(--primary-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(1px)}.btn-secondary{background-color:var(--border);color:var(--text-main);border-color:var(--border)}.btn-secondary:hover{background-color:var(--bg-card-hover)}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover{background-color:#dc1839}.btn-sm{border-radius:var(--radius-sm);padding:6px 12px;font-size:.85rem}.filters-bar{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.search-input-wrapper{flex-grow:1;min-width:250px;position:relative}.search-input-wrapper input{padding-left:42px}.search-input-wrapper svg{color:var(--text-muted);pointer-events:none;width:18px;height:18px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.table-container{border-radius:var(--radius-lg);border:1px solid var(--border);background-color:var(--bg-card);box-shadow:var(--shadow-sm);margin-bottom:2rem;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%;font-size:.95rem}.data-table th{background-color:var(--bg-sidebar);color:var(--text-muted);border-bottom:1px solid var(--border);padding:14px 20px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-main);padding:14px 20px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background-color var(--transition-fast)}.data-table tbody tr:hover{background-color:var(--bg-card-hover)}.checkbox-custom{cursor:pointer;align-items:center;display:inline-flex;position:relative}.checkbox-custom input{opacity:0;width:0;height:0;position:absolute}.checkmark{background-color:var(--bg-app);border:2px solid var(--border);width:20px;height:20px;transition:all var(--transition-fast);border-radius:4px;justify-content:center;align-items:center;display:flex}.checkbox-custom:hover input~.checkmark{border-color:var(--primary)}.checkbox-custom input:checked~.checkmark{background-color:var(--primary);border-color:var(--primary)}.checkmark:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:10px;display:none;transform:rotate(45deg)translate(-1px,-1px)}.checkbox-custom input:checked~.checkmark:after{display:block}.upload-zone{border:2.5px dashed var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;background-color:var(--bg-card);transition:all var(--transition-normal);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem 2rem;display:flex}.upload-zone:hover,.upload-zone.drag-active{border-color:var(--primary);background-color:var(--primary-light);box-shadow:0 0 20px var(--primary-glow)}.upload-icon{background-color:var(--primary-light);width:64px;height:64px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;margin-bottom:.5rem;display:flex}.upload-zone h4{font-size:1.15rem;font-weight:700}.upload-zone p{color:var(--text-muted);font-size:.85rem}.validation-container{border:1px solid var(--border);border-radius:var(--radius-md);background-color:var(--bg-sidebar);margin-top:1.5rem;padding:1.25rem}.validation-header{align-items:center;gap:8px;margin-bottom:.75rem;font-size:.95rem;font-weight:700;display:flex}.validation-list{flex-direction:column;gap:6px;max-height:200px;list-style:none;display:flex;overflow-y:auto}.validation-item{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:8px 12px;font-size:.85rem;display:flex}.validation-item.error{color:var(--danger);border-left:3px solid var(--danger);background-color:#e8304f1a}.validation-item.success{color:var(--success);border-left:3px solid var(--success);background-color:#22c35d1a}.sync-toolbar{background-color:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 1.5rem;display:flex}.sync-info{flex-direction:column;gap:2px;display:flex}.sync-info label{color:var(--text-muted);font-size:.8rem;font-weight:600}.sync-info span{font-size:.9rem;font-weight:700}.logo-upload-wrapper{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);align-items:center;gap:1.5rem;padding:1.25rem;display:flex}.logo-preview-box{border-radius:var(--radius-md);border:1px solid var(--border);background-color:#fff;justify-content:center;align-items:center;width:80px;height:80px;padding:5px;display:flex;overflow:hidden}.logo-preview-box img{object-fit:contain;max-width:100%;max-height:100%}.logo-preview-box span{color:#333;text-align:center;font-size:.7rem}@media print{@page{size:21.5cm 33cm;margin:0!important}html,body{color:#000!important;font-family:var(--font-family)!important;background-color:#fff!important;font-size:11pt!important}.sidebar,.main-content>.header-bar,.main-content>.sync-toolbar,.main-content>.filters-bar,.main-content>.table-container,.main-content>.card,.btn,.logo-upload-wrapper,.form-group,.upload-zone,.status-badge,footer,.preview-toolbar,.no-print{display:none!important}.app-container{min-height:0!important;display:block!important}.main-content{width:100%!important;max-width:100%!important;margin:0!important;padding:0!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.print-report-sheet{box-sizing:border-box;flex-direction:column;page-break-after:always!important;color:#000!important;background-color:#fff!important;width:21.5cm!important;height:33cm!important;margin:0!important;padding:1.5cm 2cm 2.5cm 3cm!important;display:flex!important}.print-report-sheet:last-child{page-break-after:avoid!important}.print-kop-surat{border-bottom:3px double #000;align-items:center;width:100%;margin-bottom:20px;padding-bottom:12px;display:flex!important}.print-kop-logo{justify-content:center;align-items:center;width:80px;height:80px;margin-right:20px;display:flex}.print-kop-logo img{max-width:80px;max-height:80px}.print-kop-text{flex-grow:1}.print-kop-text h2{margin:0;font-weight:800;line-height:1.2;color:#000!important;font-size:18pt!important}.print-kop-text p.sub1{margin:2px 0 0;font-weight:600;color:#333!important;font-size:11pt!important}.print-kop-text p.sub2{margin:1px 0 0;color:#555!important;font-size:10pt!important}.print-kop-text p.sub3{margin:2px 0 0;font-weight:700;color:#000!important;font-size:9pt!important}.print-meta-table{border-collapse:collapse!important;width:100%!important;margin-bottom:8px!important}.print-meta-table td{color:#000!important;box-sizing:border-box!important;vertical-align:middle!important;border:1px solid #000!important;height:28px!important;padding:4px 8px!important;font-size:9.5pt!important;line-height:1.2!important}.print-meta-table td.label-cell{white-space:nowrap!important;background-color:#fff!important;width:18%!important;font-weight:700!important}.print-meta-table td.value-cell{width:32%!important;font-weight:500!important}.print-section-title{letter-spacing:.5px;text-transform:uppercase;text-align:center!important;margin-top:8px!important;margin-bottom:4px!important;font-size:10.5pt!important;font-weight:700!important}.print-data-table{border-collapse:collapse!important;width:100%!important;margin-bottom:8px!important}.print-data-table th{color:#000!important;text-align:center!important;background-color:#e6e6e6!important;border:1px solid #000!important;padding:4px!important;font-size:9pt!important;font-weight:700!important;line-height:1.2!important}.print-data-table td{color:#000!important;vertical-align:middle!important;box-sizing:border-box!important;border:1px solid #000!important;height:38px!important;padding:3px 6px!important;font-size:9pt!important}.print-data-table td.center{text-align:center!important}.print-half-tables-wrapper{gap:15px!important;width:100%!important;margin-bottom:8px!important;display:flex!important}.print-half-table-container{flex:1!important;display:block!important}.print-catatan-box{border:1px solid #000!important;border-radius:0!important;min-height:42px!important;margin-bottom:12px!important;padding:6px 10px!important;font-size:9pt!important;line-height:1.3!important}.print-signatures-wrapper{padding-bottom:5px;page-break-inside:avoid!important;width:100%!important;margin-top:10px!important;font-size:9.5pt!important;display:block!important}.print-sig-date{text-align:center!important;width:100%!important;margin-bottom:2px!important}.print-sig-mengetahui{text-align:center!important;width:100%!important;margin-bottom:12px!important}.print-sig-row{justify-content:space-between!important;width:100%!important;display:flex!important}.print-sig-col{flex-direction:column!important;width:45%!important;display:flex!important}.print-sig-col.left{text-align:left!important;align-items:flex-start!important}.print-sig-col.right{text-align:right!important;align-items:flex-end!important;margin-top:14px!important}.print-sig-space{height:54px!important}.print-sig-name{font-weight:700!important;text-decoration:underline!important}.print-sig-line{font-weight:700!important}.print-page-container{display:none}.print-preview-page .print-page-container{display:block!important}.print-preview-page{box-sizing:border-box;background-color:#3b3e40;flex-direction:column;align-items:center;width:100vw;min-height:100vh;padding:1.5rem;display:flex;overflow-y:auto}.preview-toolbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-lg);z-index:1000;width:100%;max-width:215mm;box-shadow:var(--shadow-xl);color:#fff;box-sizing:border-box;background-color:#0f172af2;border:1px solid #ffffff1a;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:.75rem 1.5rem;display:flex;position:sticky;top:1rem}.preview-sheets-container{flex-direction:column;align-items:center;gap:2rem;width:100%;display:flex}@media screen{.preview-sheets-container .print-report-sheet{color:#000!important;box-sizing:border-box!important;background-color:#fff!important;width:215mm!important;height:330mm!important;padding:15mm!important;position:relative!important;overflow:hidden!important;box-shadow:0 10px 25px #00000059!important}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:95%;max-width:850px;max-height:90vh;box-shadow:var(--shadow-xl);flex-direction:column;display:flex;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h3{color:var(--text-main);margin:0;font-size:1.25rem;font-weight:600}.modal-body{flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:1.25rem 1.5rem;display:flex}.modal-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.modal-close-btn:hover{color:var(--text-main);background-color:#ffffff1a}.form-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--primary);border-left:3px solid var(--primary);margin-bottom:.75rem;padding-left:8px;font-size:.9rem;font-weight:600}.form-grid-3{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.form-grid-4{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}.month-edit-card{border:1px solid var(--border);border-radius:var(--radius-md);background-color:#ffffff05;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.month-title{color:var(--text-main);border-bottom:1px solid var(--border);padding-bottom:4px;font-size:.95rem;font-weight:600}
