:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.smart-tv-layout{display:flex;flex-direction:column;height:100vh;width:100vw;background:linear-gradient(135deg,#0f172a,#1e293b);color:#f8fafc;font-family:Poppins,sans-serif;overflow:hidden}header{display:flex;justify-content:space-between;align-items:center;background:#0f172af2;padding:20px 50px;border-bottom:3px solid #38bdf8;box-shadow:0 4px 20px #38bdf833;gap:30px}header h1{font-size:2.8rem;color:#38bdf8;margin:0;text-shadow:0 2px 10px rgba(56,189,248,.3);flex-shrink:0}.emergency-switch-container{display:flex;align-items:center;gap:15px;background:#1e293bcc;padding:12px 20px;border-radius:15px;border:2px solid rgba(56,189,248,.3);transition:all .3s ease}.emergency-switch-container:has(input:checked){border-color:#ef444499;background:#ef44441a;box-shadow:0 0 20px #ef44444d}.switch{position:relative;display:inline-block;width:60px;height:30px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background:linear-gradient(135deg,#22c55e,#16a34a);transition:.4s;border-radius:30px;box-shadow:inset 0 2px 5px #0003,0 4px 10px #22c55e4d}.slider:before{position:absolute;content:"";height:24px;width:24px;left:3px;bottom:3px;background:#fff;transition:.4s;border-radius:50%;box-shadow:0 2px 5px #0000004d}input:checked+.slider{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:inset 0 2px 5px #0003,0 4px 10px #ef444480}input:checked+.slider:before{transform:translate(30px)}.switch-label{font-size:1.3rem;font-weight:700;color:#22c55e;text-transform:uppercase;letter-spacing:1px;text-shadow:0 2px 5px rgba(34,197,94,.3);transition:all .3s ease;white-space:nowrap}.switch-label.active{color:#ef4444;text-shadow:0 2px 5px rgba(239,68,68,.5);animation:pulse-red 1.5s ease-in-out infinite}@keyframes pulse-red{0%,to{text-shadow:0 2px 5px rgba(239,68,68,.5)}50%{text-shadow:0 2px 15px rgba(239,68,68,.8)}}.datetime-display{display:flex;flex-direction:column;align-items:flex-end;gap:5px}.current-date{font-size:1.4rem;font-weight:500;color:#cbd5e1;letter-spacing:.5px}.current-time{font-size:2.8rem;font-weight:700;color:#38bdf8;text-shadow:0 2px 10px rgba(56,189,248,.4)}.carousel-main-content{flex:1;display:flex;justify-content:center;align-items:center;padding:30px;text-align:center}.slide-content{width:95%;height:90%;max-width:1900px;background:linear-gradient(145deg,#1e293bfa,#0f172afa);border-radius:25px;padding:40px;box-shadow:0 15px 50px #000000b3,0 0 0 1px #38bdf81a;display:flex;flex-direction:column;align-items:center;overflow:hidden;animation:fadeIn .8s ease-in-out;border:1px solid rgba(56,189,248,.2)}.slide-content h2{font-size:2.8rem;color:#38bdf8;margin-bottom:30px;text-transform:uppercase;letter-spacing:2px;text-shadow:0 2px 15px rgba(56,189,248,.4);font-weight:700}.dashboard-slide{max-height:85vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#38bdf8 #1e293b;scroll-behavior:auto}.dashboard-slide::-webkit-scrollbar{width:10px}.dashboard-slide::-webkit-scrollbar-thumb{background:#38bdf8;border-radius:5px}.dashboard-slide::-webkit-scrollbar-track{background:#1e293b80}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:25px;width:100%;margin-bottom:40px}.stat-card{background:linear-gradient(145deg,#38bdf826,#1e293bcc);padding:30px;border-radius:20px;text-align:center;border:1px solid rgba(56,189,248,.3);box-shadow:0 8px 25px #0000004d;transition:all .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 12px 35px #38bdf866}.stat-icon{font-size:3.5rem;margin-bottom:15px}.stat-value{font-size:3.5rem;font-weight:700;color:#38bdf8;margin-bottom:10px;text-shadow:0 2px 10px rgba(56,189,248,.4)}.stat-label{font-size:1.4rem;color:#cbd5e1;text-transform:uppercase;letter-spacing:1px}.monthly-section{width:100%;margin-top:30px}.monthly-section h3{font-size:2.2rem;color:#38bdf8;margin-bottom:25px;text-align:center;text-shadow:0 2px 10px rgba(56,189,248,.3)}.monthly-section h4{font-size:1.8rem;color:#38bdf8;margin:30px 0 15px;text-align:center}.monthly-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:25px;width:100%;margin-bottom:30px}.monthly-stat-card{background:linear-gradient(145deg,#1e293be6,#0f172ae6);padding:35px 25px;border-radius:20px;text-align:center;border:2px solid;box-shadow:0 8px 25px #0000004d;transition:all .3s ease}.monthly-stat-card:hover{transform:translateY(-5px);box-shadow:0 12px 35px #00000080}.hadir-card{border-color:#22c55e;background:linear-gradient(145deg,#22c55e1a,#1e293be6)}.hadir-card:hover{box-shadow:0 12px 35px #22c55e66}.telat-card{border-color:#facc15;background:linear-gradient(145deg,#facc151a,#1e293be6)}.telat-card:hover{box-shadow:0 12px 35px #facc1566}.izin-card{border-color:#38bdf8;background:linear-gradient(145deg,#38bdf81a,#1e293be6)}.izin-card:hover{box-shadow:0 12px 35px #38bdf866}.cuti-card{border-color:#3b82f6;background:linear-gradient(145deg,#3b82f61a,#1e293be6)}.cuti-card:hover{box-shadow:0 12px 35px #3b82f666}.tidak-hadir-card{border-color:#ef4444;background:linear-gradient(145deg,#ef44441a,#1e293be6)}.tidak-hadir-card:hover{box-shadow:0 12px 35px #ef444466}.monthly-stat-icon{font-size:3.5rem;margin-bottom:15px}.monthly-stat-value{font-size:4rem;font-weight:700;margin-bottom:10px}.hadir-card .monthly-stat-value{color:#22c55e;text-shadow:0 2px 10px rgba(34,197,94,.4)}.telat-card .monthly-stat-value{color:#facc15;text-shadow:0 2px 10px rgba(250,204,21,.4)}.izin-card .monthly-stat-value{color:#38bdf8;text-shadow:0 2px 10px rgba(56,189,248,.4)}.cuti-card .monthly-stat-value{color:#3b82f6;text-shadow:0 2px 10px rgba(59,130,246,.4)}.tidak-hadir-card .monthly-stat-value{color:#ef4444;text-shadow:0 2px 10px rgba(239,68,68,.4)}.monthly-stat-label{font-size:1.4rem;color:#cbd5e1;text-transform:uppercase;letter-spacing:1px;font-weight:600}.monthly-table-section{width:100%;margin-top:20px}.monthly-table-wrapper{max-height:400px;overflow-y:auto;border-radius:15px;background:#0f172a80;scrollbar-width:thin;scrollbar-color:#38bdf8 #1e293b}.monthly-table-wrapper::-webkit-scrollbar{width:10px}.monthly-table-wrapper::-webkit-scrollbar-thumb{background:#38bdf8;border-radius:5px}.monthly-table-wrapper::-webkit-scrollbar-track{background:#1e293b80}.monthly-table{width:100%;border-collapse:collapse;font-size:1.4rem}.monthly-table thead{position:sticky;top:0;background:linear-gradient(135deg,#1e293b,#0f172a);z-index:10}.monthly-table th{padding:15px;text-align:center;color:#38bdf8;font-weight:600;text-transform:uppercase;letter-spacing:1px}.monthly-table td{padding:12px 15px;text-align:center;border-bottom:1px solid rgba(148,163,184,.1);color:#cbd5e1}.monthly-table tbody tr{transition:all .2s ease}.monthly-table tbody tr:hover{background:#38bdf81a}.monthly-table tbody tr:nth-child(2n){background:#ffffff05}.monthly-table .hadir{color:#22c55e;font-weight:600}.monthly-table .telat{color:#facc15;font-weight:600}.monthly-table .izin{color:#38bdf8;font-weight:600}.monthly-table .tidak-hadir{color:#ef4444;font-weight:600}.monthly-table .total{color:#f8fafc;font-weight:700}.attendance-slide-container{width:100%;height:100%;overflow:hidden;padding:20px 40px;display:flex;flex-direction:column;align-items:center}.attendance-slide-container h2{font-size:2.6rem;color:#38bdf8;text-transform:uppercase;letter-spacing:2px;margin-bottom:25px;text-shadow:0 2px 15px rgba(56,189,248,.4);font-weight:700}.table-wrapper{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.feed-scroll-container{width:100%;max-height:65vh;overflow-y:auto;padding-right:10px;scrollbar-width:thin;scrollbar-color:#38bdf8 #0f172a;scroll-behavior:smooth}.feed-scroll-container::-webkit-scrollbar{width:12px}.feed-scroll-container::-webkit-scrollbar-thumb{background:#38bdf8;border-radius:6px}.feed-scroll-container::-webkit-scrollbar-track{background:#1e293b99}.attendance-table{width:100%;border-collapse:collapse;background:#0f172a;border-radius:12px;overflow:hidden}.attendance-table thead{background:linear-gradient(135deg,#1e293b,#0f172a);position:sticky;top:0;z-index:10}.attendance-table th{padding:18px 16px;font-size:1.5rem;font-weight:700;color:#38bdf8;text-transform:uppercase;letter-spacing:1.2px;text-align:center}.attendance-table th:first-child{text-align:left;width:50%;padding-left:30px}.attendance-table tbody{background:#0f172af2}.attendance-table td{padding:16px;font-size:1.4rem;color:#e2e8f0;text-align:center;border-bottom:1px solid rgba(148,163,184,.15);font-weight:500}.attendance-table tbody td:first-child{text-align:left;padding-left:30px;font-weight:600}.attendance-table tbody tr:nth-child(2n){background:#ffffff0a}.attendance-table tbody tr:hover{background:#38bdf826;transition:all .3s ease}.status-badge{padding:6px 14px;border-radius:16px;font-weight:700;font-size:1.2rem;text-align:center;display:inline-block;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #0003}.status-badge.tepat-waktu{background:linear-gradient(135deg,#22c55e40,#22c55e26);color:#22c55e;border:2px solid rgba(34,197,94,.5);text-shadow:0 1px 3px rgba(0,0,0,.3)}.status-badge.terlambat{background:linear-gradient(135deg,#ef444440,#ef444426);color:#ef4444;border:2px solid rgba(239,68,68,.5);text-shadow:0 1px 3px rgba(0,0,0,.3)}.status-badge.cuti{background:linear-gradient(135deg,#3b82f640,#3b82f626);color:#60a5fa;border:2px solid rgba(59,130,246,.5);text-shadow:0 1px 3px rgba(0,0,0,.3)}.status-badge.dinas-luar{background:linear-gradient(135deg,#a855f740,#a855f726);color:#c084fc;border:2px solid rgba(168,85,247,.5);text-shadow:0 1px 3px rgba(0,0,0,.3)}.status-badge.sakit{background:linear-gradient(135deg,#fb923c40,#fb923c26);color:#fb923c;border:2px solid rgba(251,146,60,.5);text-shadow:0 1px 3px rgba(0,0,0,.3)}.status-badge.izin{background:linear-gradient(135deg,#38bdf840,#38bdf826);color:#38bdf8;border:2px solid rgba(56,189,248,.5);text-shadow:0 1px 3px rgba(0,0,0,.3)}.status-badge.tidak-hadir,.status-badge.alpha{background:linear-gradient(135deg,#94a3b840,#94a3b826);color:#94a3b8;border:2px solid rgba(148,163,184,.5);text-shadow:0 1px 3px rgba(0,0,0,.3)}.status-badge.n-a{background:linear-gradient(135deg,#64748b40,#64748b26);color:#64748b;border:2px solid rgba(100,116,139,.5);text-shadow:0 1px 3px rgba(0,0,0,.3)}.photo-display{border-radius:20px;width:60%;max-width:900px;max-height:70vh;object-fit:cover;box-shadow:0 12px 35px #00000080;margin-top:20px;transition:transform .5s ease,opacity .5s ease}.photo-display.large{width:80%;max-width:1200px;max-height:80vh}.late-slide,.manual-slide{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.info-box{margin-top:20px;padding:15px 25px;border-radius:12px;font-size:1.6rem;background:#00000040;box-shadow:0 4px 15px #0000004d}.photo-row{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-top:30px;width:100%}.photo-card{display:flex;flex-direction:column;align-items:center;background:linear-gradient(145deg,#1e293be6,#0f172ae6);padding:20px;border-radius:20px;box-shadow:0 8px 25px #0006;width:320px;border:1px solid rgba(56,189,248,.2);transition:all .3s ease}.photo-card:hover{transform:translateY(-5px);box-shadow:0 12px 35px #38bdf84d}.photo-card img{width:100%;height:280px;object-fit:cover;border-radius:16px;border:2px solid rgba(56,189,248,.3)}.photo-card .info-box{margin-top:15px;padding:15px 20px;border-radius:12px;font-size:1.4rem;background:#38bdf81a;width:100%;text-align:center}.photo-card h3{margin:0 0 10px;font-size:1.7rem;color:#38bdf8;font-weight:600}.photo-card p{margin:5px 0;font-size:1.3rem;color:#cbd5e1}.tahanan-slide{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;height:100%;color:#fff;overflow:hidden;padding:20px}.tahanan-table-container{flex:1;width:100%;max-height:70vh;overflow-y:auto;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#38bdf8 #1e293b}.tahanan-table{width:100%;border-collapse:collapse;font-size:1.6rem;color:#f8fafc;min-width:1200px}.tahanan-table th,.tahanan-table td{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.2)}.tahanan-table th{background-color:#ffffff1a;font-weight:600;text-align:left}.tahanan-table-container::-webkit-scrollbar{width:10px}.tahanan-table-container::-webkit-scrollbar-thumb{background:#38bdf8;border-radius:6px}.tahanan-table-container::-webkit-scrollbar-track{background:#1e293b80}footer{text-align:center;background:#0f172af2;padding:20px;font-size:1.5rem;color:#94a3b8;border-top:2px solid #334155}@keyframes fadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.loading-text{font-size:2rem;color:#cbd5e1;margin-top:50px}.no-data{font-size:2rem;color:#94a3b8;margin-top:50px}.pengumuman-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;padding:40px}.pengumuman-image{max-width:90%;max-height:75vh;width:auto;height:auto;object-fit:contain;border-radius:25px;box-shadow:0 20px 60px #0009,0 0 0 3px #38bdf84d;animation:fadeInScale .8s ease-out;border:3px solid rgba(56,189,248,.4)}.pengumuman-message{margin-top:30px;font-size:2.5rem;color:#38bdf8;text-align:center;font-weight:700;text-transform:uppercase;letter-spacing:2px;text-shadow:0 3px 15px rgba(56,189,248,.5);animation:fadeInUp 1s ease-out .3s both}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.attendance-slide-container:has(h2:contains("Rekap")) .attendance-table th:first-child,.attendance-slide-container:has(h2:contains("Rekap")) .attendance-table td:first-child{width:40%}.rekap-table th:first-child,.rekap-table td:first-child{width:40%;text-align:left;padding-left:30px}.rekap-table th:not(:first-child),.rekap-table td:not(:first-child){width:15%;text-align:center}.attendance-table .absen tr td:nth-child(2){transform:translate(calc(13% - 30px))}.attendance-table .absen tr td:nth-child(3){transform:translate(calc(18% - 30px))}.hilang{opacity:0;position:absolute;top:0;left:0;width:100%;pointer-events:none}.rekap{margin-left:-18px}html,body,#root{height:100%;width:100%;font-family:Poppins,sans-serif;background:linear-gradient(135deg,#007aff,#00c6ff);display:flex;justify-content:center;align-items:center}.login-page{display:flex;justify-content:center;align-items:center;width:100%;height:100%;padding:20px}.login-box{background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.25);border-radius:20px;padding:40px 50px;width:100%;max-width:420px;text-align:center;color:#fff;box-shadow:0 10px 40px #00000040;animation:fadeInUp .8s ease}.login-header{margin-bottom:30px}.login-logo{width:90px;height:90px;border-radius:50%;object-fit:cover;margin-bottom:10px;box-shadow:0 0 25px #fff6}.login-header h2{margin:0;font-size:26px;font-weight:700;letter-spacing:.5px}.subtitle{font-size:14px;opacity:.9;margin-top:5px}.login-form{display:flex;flex-direction:column;gap:18px;margin-top:10px}.form-group label{text-align:left;font-size:14px;color:#fff;opacity:.9;font-weight:500}.form-group input{width:100%;padding:12px 15px;border-radius:10px;border:none;background:#ffffff40;color:#fff;font-size:15px;transition:all .3s ease}.form-group input::placeholder{color:#ffffffbf}.form-group input:focus{outline:none;background:#ffffff59;box-shadow:0 0 0 2px #00c6ff}.login-btn{background:linear-gradient(90deg,#00c6ff,#007aff);color:#fff;border:none;padding:13px 0;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.login-btn:hover{background:linear-gradient(90deg,#007aff,#005ecb);transform:translateY(-2px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.error-text{color:#ff6b6b;background:#ffffff1a;padding:8px;border-radius:8px;font-size:14px}.login-footer{margin-top:25px;font-size:13px;color:#fffc}@keyframes fadeInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.login-box{padding:30px 25px;max-width:90%}.login-logo{width:70px;height:70px}.login-header h2{font-size:22px}}.dashboard-layout{display:flex;min-height:100vh;width:100%;font-family:Inter,Arial,sans-serif;background:#f4f6f9;color:#1e293b;margin:0;padding:0}.sidebar{width:240px;min-width:240px;background:#0f172a;color:#fff;display:flex;flex-direction:column;padding:16px;transition:transform .3s ease,margin-left .3s ease;box-shadow:4px 0 10px #0003;z-index:100;height:100vh;position:sticky;top:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px solid #334155;font-weight:600}.sidebar-menu{margin-top:32px;flex-grow:1}.sidebar-link{width:100%;background:none;border:none;color:#cbd5e1;text-align:left;padding:10px 12px;border-radius:8px;margin-bottom:6px;cursor:pointer;font-size:15px;font-weight:500;display:flex;align-items:center;gap:12px;transition:background .2s ease,color .2s ease}.sidebar-link:hover{background:#334155;color:#fff;transform:none}.sidebar-link.active{background:#3b82f6;color:#fff;font-weight:600;box-shadow:0 4px 6px #3b82f64d}.logout-btn{margin-top:auto;background:#dc2626;border:none;color:#fff;padding:12px;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s ease}.logout-btn:hover{background:#b91c1c}.main-content{flex-grow:1;background:#f4f6f9;display:flex;flex-direction:column;min-height:100%;overflow-y:auto}.topbar{background:#fff;color:#1e293b;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 4px #0000000d;position:sticky;top:0;z-index:50;border-bottom:1px solid #e2e8f0}.dashboard-home h2{font-size:2rem;font-weight:700;color:#1e293b}.dashboard-subtitle{color:#64748b;margin-bottom:2rem;font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;box-shadow:0 4px 12px #00000014;transition:all .3s ease;border-left:5px solid transparent}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001f}.stat-icon{font-size:2.8rem;background:#f1f5f9;border-radius:50%;padding:10px;line-height:1}.stat-info h3{color:#1e293b;font-size:2rem;margin:0;font-weight:700}.stat-info p{margin:0;color:#64748b;font-size:.95rem;font-weight:500}.blue .stat-icon{color:#3b82f6;background:#eff6ff}.green .stat-icon{color:#10b981;background:#ecfdf5}.orange .stat-icon{color:#f97316;background:#fff7ed}.red .stat-icon{color:#ef4444;background:#fee2e2}.blue,.green,.orange,.red{border-left:none}.absen-table-container{overflow-x:auto;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 12px #0000000d;background:#fff}.absen-table th{background:#f1f5f9;font-weight:600;color:#1e293b;text-transform:capitalize;font-size:14px}.info-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 12px #0000000d}.info-section h3{color:#3b82f6;border-bottom:2px solid #eef2ff;padding-bottom:8px;margin-bottom:12px}.status-online{color:#10b981;font-weight:600}@media(max-width:768px){.dashboard-layout.sidebar-open .sidebar{transform:translate(0);box-shadow:2px 0 5px #0003}}.pegawai-foto{width:50px;height:50px;object-fit:cover;border-radius:50%;border:2px solid #ddd}.absen-layout{display:flex;min-height:100vh;font-family:Poppins,sans-serif;background:#f9fafb;color:#333}.sidebar-menu{display:flex;flex-direction:column;padding:1rem 0;flex:1}.sidebar-link{color:#fff;text-align:left;padding:.8rem 1rem;margin:.3rem 1rem;border-radius:8px;display:flex;align-items:center;gap:.8rem;cursor:pointer;transition:background .2s ease,transform .1s ease}.sidebar-link.active{background:#06c;font-weight:600;box-shadow:0 0 5px #0003}.logout-btn{background:#f44;color:#fff;border:none;margin:1rem;padding:.7rem 1rem;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s ease}.menu-toggle{background:transparent;border:none;font-size:1.5rem;color:#004aad;cursor:pointer;display:none}.content{flex:1;padding:1.5rem;overflow-y:auto}.absen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.btn-add{background:#28a745;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s ease,transform .1s ease}.btn-add:hover{background:#218838;transform:translateY(-1px)}.absen-table-container{box-shadow:0 4px 10px #0000000d;border-radius:8px;overflow:hidden;background:#fff}.absen-table{width:100%;border-collapse:collapse;min-width:700px}.absen-table th,.absen-table td{padding:1rem;border-bottom:1px solid #eee;text-align:left}.foto-preview{width:50px;height:50px;object-fit:cover;border-radius:50%;border:2px solid #ddd}.btn-edit{background:#007bff;color:#fff;border:none;padding:.5rem .8rem;border-radius:6px;margin-right:.3rem;cursor:pointer;transition:background .2s ease}.btn-edit:hover{background:#0069d9}.btn-delete{background:#dc3545;color:#fff;border:none;padding:.5rem .8rem;border-radius:6px;cursor:pointer;transition:background .2s ease}.btn-delete:hover{background:#c82333}.absen-form{background:#fff;padding:2rem;border-radius:12px;max-width:500px;margin:2rem auto;display:flex;flex-direction:column;gap:1.2rem;box-shadow:0 4px 12px #00000014}.absen-form label{font-weight:600;color:#333;margin-bottom:.3rem;display:block}.absen-form input{width:100%;padding:.7rem;border-radius:6px;border:1px solid #ccc;transition:border-color .2s,box-shadow .2s}.absen-form input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff40}.absen-form select,.time-select select{width:100%;padding:.7rem;border-radius:6px;border:1px solid #ccc;background:#fff;color:#333;cursor:pointer;font-size:1rem;transition:border-color .2s,box-shadow .2s;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23333'%3e%3cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd' /%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem center;background-size:.8em}.time-select{display:flex;align-items:center;gap:.5rem}.time-select select{width:auto;min-width:60px}.absen-form select:focus,.time-select select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff40}.form-buttons{display:flex;gap:.7rem;margin-top:1rem}.btn-save,.btn-cancel{flex:1;color:#fff;border:none;padding:.7rem 1rem;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s ease}.btn-save{background:#28a745}.btn-cancel{background:#dc3545}@media(max-width:768px){.sidebar{position:fixed;height:100vh;transform:translate(-100%);z-index:1000}.absen-layout.sidebar-open .sidebar{transform:translate(0)}.topbar .menu-toggle{display:block}.absen-form{width:100%;margin:1rem 0}.absen-table th,.absen-table td{font-size:.85rem;padding:.7rem}}*{margin:0;padding:0;box-sizing:border-box}body,html{width:100%;height:100%;font-family:Poppins,sans-serif;background-color:#f8fafc;color:#1e293b;overflow-x:hidden}.pegawai-container{display:flex;width:100%;height:100vh;background:#f8fafc}.sidebar{width:250px;background:#1e293b;color:#fff;display:flex;flex-direction:column;transition:all .3s ease;position:sticky;top:0;height:100vh;box-shadow:2px 0 10px #00000026;z-index:100}.sidebar.collapsed{width:70px}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem;background:#0f172a}.sidebar-header h2{font-size:1rem;transition:.3s}.sidebar.collapsed .sidebar-header h2{opacity:0;width:0}.btn-toggle{background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;transition:transform .3s ease}.btn-toggle:hover{transform:scale(1.1)}.sidebar-nav{display:flex;flex-direction:column}.sidebar-nav button{background:none;color:#fff;border:none;text-align:left;padding:.9rem 1rem;border-radius:6px;cursor:pointer;font-size:.95rem;transition:.3s}.sidebar-nav button:hover{background:#334155}.sidebar.collapsed .sidebar-nav button{text-align:center;font-size:1.3rem;padding:1rem 0}.pegawai-page{flex:1;padding:1rem;width:100%;background:#f8fafc;display:flex;flex-direction:column}.pegawai-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.pegawai-header h1,.pegawai-header h2{font-size:1.5rem;font-weight:600;color:#0f172a}.btn-add{background:#2563eb;color:#fff;border:none;padding:.6rem 1rem;border-radius:6px;cursor:pointer;transition:background .3s ease,transform .2s ease}.btn-add:hover{background:#1d4ed8;transform:translateY(-2px)}.pegawai-table-wrapper{width:100%;overflow-x:auto}.pegawai-table{width:100%;border-collapse:collapse;background:#fff;color:#222;border-radius:6px;box-shadow:0 2px 8px #00000014}.pegawai-table th,.pegawai-table td{border:1px solid #e5e7eb;padding:.7rem;text-align:center}.pegawai-table th{background:#2563eb;color:#fff;font-weight:600}.pegawai-foto{width:60px;height:60px;border-radius:8px;object-fit:cover;border:1px solid #ddd}.btn-edit,.btn-delete{border:none;background:none;cursor:pointer;font-size:1.2rem;margin:0 5px;transition:color .3s ease,transform .2s ease}.btn-edit:hover{color:#f59e0b;transform:scale(1.1)}.btn-delete:hover{color:#dc2626;transform:scale(1.1)}.pegawai-form{display:flex;flex-direction:column;gap:1rem;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 3px 10px #0000001a;max-width:600px;margin:auto}.pegawai-form label{font-weight:500;color:#1e293b}.pegawai-form input{width:100%;padding:.6rem;border-radius:6px;border:1px solid #cbd5e1;font-size:1rem}.form-buttons{display:flex;gap:1rem;margin-top:1rem}.btn-save{background:#16a34a;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:8px;font-weight:500;cursor:pointer;transition:background .3s ease,transform .2s ease}.btn-save:hover{background:#15803d;transform:translateY(-2px)}.btn-cancel{background:#e5e7eb;border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-weight:500}.btn-cancel:hover{background:#d1d5db}.pegawai-cards{display:none;margin-top:1rem}.pegawai-card{background:#fff;border-radius:8px;box-shadow:0 3px 10px #00000014;padding:1rem;margin-bottom:1rem}.card-header{display:flex;align-items:center;gap:1rem}.no-foto{width:60px;height:60px;background:#e2e8f0;display:flex;align-items:center;justify-content:center;border-radius:8px}.card-actions{display:flex;justify-content:space-between;margin-top:.5rem}@media(max-width:768px){.sidebar{position:fixed;height:100vh;transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}.pegawai-table{display:none}.pegawai-cards{display:block}.pegawai-header{flex-direction:column;align-items:flex-start}.btn-add{width:100%}}#root{display:block!important}.absen-layout{display:flex;min-height:100vh;width:100%;font-family:Poppins,sans-serif;background:#f9fafb;color:#333}.sidebar{width:250px;min-width:250px;background:#004aad;color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;transition:transform .3s ease;box-shadow:2px 0 6px #00000026;z-index:1000}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#003580}.sidebar-header h2{margin:0;font-size:1.4rem;font-weight:700}.close-sidebar{background:transparent;border:none;color:#fff;font-size:1.4rem;cursor:pointer;transition:opacity .2s}.close-sidebar:hover{opacity:.8}.sidebar-link{background:transparent;border:none;color:#fff;text-align:left;padding:.8rem 1rem;margin:.3rem 1rem;border-radius:8px;display:flex;align-items:center;gap:.8rem;cursor:pointer;transition:background .2s ease,transform .1s ease}.sidebar-link:hover{background:#ffffff40;transform:translate(2px)}.sidebar-menu button:nth-child(2){background:#06c;font-weight:600}.logout-btn{background:#f44;border:none;color:#fff;margin:1rem;padding:.7rem;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s ease;margin-top:auto}.logout-btn:hover{background:#e63939}.absen-page{flex:1;display:flex;flex-direction:column}.topbar{background:#fff;color:#004aad;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:0 2px 4px #0000001a}.topbar h1{font-size:1.5rem;margin:0}.menu-toggle{background:transparent;border:none;font-size:1.6rem;color:#004aad;cursor:pointer;display:none}.content{flex:1;padding:1.5rem}.content h2{color:#004aad;margin-top:0;margin-bottom:1.5rem}.absen-table{width:100%;border-collapse:collapse;background:#fff;min-width:650px;border-radius:8px;overflow:hidden;box-shadow:0 4px 10px #0000000d}.absen-table th,.absen-table td{padding:.8rem 1rem;border-bottom:1px solid #eee;text-align:left}.absen-table th{background:#f1f1f1;color:#004aad;font-weight:700;text-transform:uppercase;font-size:.9rem}.absen-table tbody tr:hover{background:#fcfcfd}.absen-table td:last-child{font-weight:600}.time-select{display:flex;align-items:center;gap:.2rem}.time-select:before{content:":";font-weight:600;color:#333}.time-select select{background:#fff;color:#333;border:1px solid #ccc;border-radius:6px;padding:.3rem .1rem;font-size:.85rem;cursor:pointer;transition:border-color .2s,box-shadow .2s;appearance:none;width:50px;text-align:center;text-align-last:center;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23333'%3e%3cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd' /%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .2rem center;background-size:.6em}.time-select select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.btn-save,.btn-cancel{font-weight:600;transition:background .2s ease,transform .1s ease;padding:.6rem 1.2rem;border-radius:8px}.btn-save{background:#28a745;color:#fff;border:none;cursor:pointer}.btn-save:hover{background:#218838}.btn-cancel{background:#dc3545;color:#fff;border:none;cursor:pointer;margin-left:.7rem}.btn-cancel:hover{background:#c82333}@media(max-width:768px){.sidebar{position:fixed;height:100vh;transform:translate(-100%);transition:transform .3s;z-index:1000}.absen-layout.sidebar-open .sidebar{transform:translate(0)}.topbar .menu-toggle{color:#004aad;display:block}.content{padding:1rem}.absen-table th,.absen-table td{font-size:.75rem;padding:.5rem}.time-select select{width:45px;padding:.2rem .1rem;font-size:.7rem}}.form-container{max-width:700px;margin:30px auto;background:linear-gradient(145deg,#1e293be6,#0f172ae6);padding:40px;border-radius:20px;box-shadow:0 10px 40px #00000080;border:1px solid rgba(56,189,248,.2)}.form-group{margin-bottom:25px}.form-group label{display:block;font-size:1.2rem;font-weight:600;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.form-control{width:100%;padding:12px 16px;font-size:1.1rem;border:2px solid rgba(56,189,248,.3);border-radius:10px;background:#0f172acc;color:#e2e8f0;transition:all .3s ease;font-family:Poppins,sans-serif}.form-control:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf833;background:#0f172af2}.form-control:disabled,.form-control:read-only{background:#64748b33;cursor:not-allowed;opacity:.6}.form-control option{background:#1e293b;color:#e2e8f0}.form-group .time-select{display:flex;align-items:center;gap:10px}.form-group .time-select select{flex:1;padding:12px 16px;font-size:1.1rem;border:2px solid rgba(56,189,248,.3);border-radius:10px;background:#0f172acc;color:#e2e8f0;transition:all .3s ease}.form-group .time-select select:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf833}.form-group .time-select select:disabled{opacity:.5;cursor:not-allowed;background:#64748b33}.form-group .time-select span{font-size:1.5rem;font-weight:700;color:#38bdf8}.form-actions{display:flex;gap:15px;margin-top:35px;justify-content:center}.form-actions .btn-save,.form-actions .btn-cancel{flex:1;max-width:200px;padding:14px 28px;font-size:1.2rem;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.form-actions .btn-save{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 4px 15px #22c55e66}.form-actions .btn-save:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 6px 20px #22c55e99;transform:translateY(-2px)}.form-actions .btn-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-actions .btn-cancel{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 15px #ef444466}.form-actions .btn-cancel:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 6px 20px #ef444499;transform:translateY(-2px)}@media(max-width:768px){.form-container{padding:25px;margin:20px}.form-group label{font-size:1rem}.form-control{padding:10px 14px;font-size:1rem}.form-actions{flex-direction:column}.form-actions .btn-save,.form-actions .btn-cancel{max-width:100%}}.absen-layout{display:flex;min-height:100vh;width:100%;font-family:Inter,Arial,sans-serif;background:#f8fafc;color:#334155;margin:0;padding:0}.sidebar{width:240px;min-width:240px;background:#1e293b;color:#fff;display:flex;flex-direction:column;padding:16px;transition:transform .3s ease,margin-left .3s ease;box-shadow:2px 0 5px #0000001a;z-index:100;height:100vh;position:sticky;top:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid #334155}.sidebar-menu{margin-top:24px;flex-grow:1}.sidebar-link{width:100%;background:none;border:none;color:#fff;text-align:left;padding:10px 12px;border-radius:6px;margin-bottom:4px;cursor:pointer;font-size:15px;font-weight:500;display:flex;align-items:center;gap:12px;transition:background .2s ease,transform .1s ease}.sidebar-link:hover{background:#334155;transform:translate(2px)}.sidebar-link.active{background:#3b82f6;font-weight:700}.logout-btn{margin-top:auto;background:#ef4444;border:none;color:#fff;padding:10px;border-radius:6px;cursor:pointer;font-weight:700;transition:background .2s ease}.logout-btn:hover{background:#dc2626}.absen-page{flex-grow:1;background:#f8fafc;display:flex;flex-direction:column;min-height:100%}.topbar{background:#fff;color:#1e293b;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #0000001a;top:0;z-index:50}.menu-toggle{background:none;border:none;color:#1e293b;font-size:24px;cursor:pointer;display:none}.content{padding:20px;flex-grow:1}.absen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid #e2e8f0}.absen-header h2{color:#1e293b}.btn-add{background:#3b82f6;color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:700;transition:background .2s ease,transform .1s ease;box-shadow:0 2px 5px #3b82f64d}.btn-add:hover{background:#2563eb;transform:translateY(-1px)}.absen-table-container{overflow-x:auto;border:1px solid #cbd5e1;border-radius:8px;box-shadow:0 4px 6px #0000000d;background:#fff}.absen-table{width:100%;border-collapse:collapse;min-width:600px}.absen-table th,.absen-table td{border:none;border-bottom:1px solid #e2e8f0;padding:12px 15px;text-align:left}.absen-table th{background:#f1f5f9;font-weight:700;color:#1e293b;text-transform:uppercase;font-size:14px}.absen-table tr:last-child td{border-bottom:none}.absen-table tbody tr:hover{background:#f8fafc}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;height:100vh;transform:translate(-100%);box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:2px 0 5px #0003}.menu-toggle{display:block}}.search-filter-container{background:linear-gradient(145deg,#f8fafc,#e2e8f0);border-radius:12px;padding:25px;margin-bottom:25px;box-shadow:0 4px 15px #0000001a;border:1px solid #cbd5e1}.filter-row{display:flex;align-items:flex-end;gap:15px;margin-bottom:15px}.filter-group{display:flex;flex-direction:column;gap:8px;flex:1}.filter-group label{font-size:.95rem;font-weight:600;color:#334155}.date-input{padding:12px 15px;border:2px solid #cbd5e1;border-radius:8px;font-size:1rem;transition:all .3s ease}.date-input:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf81a}.btn-reset{padding:12px 24px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 10px #ef444433;white-space:nowrap}.btn-reset:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 6px 15px #ef44444d}.filter-info{background:#fff;padding:15px;border-radius:8px;border-left:4px solid #38bdf8}.filter-info p{margin:5px 0;color:#475569;font-size:.95rem}.result-count{font-weight:700;color:#0f172a!important;margin-top:10px!important}.result-count strong{color:#38bdf8;font-size:1.1rem}.status-badge{padding:4px 12px;border-radius:12px;font-weight:600;font-size:.85rem;text-transform:uppercase;display:inline-block}.status-badge.tepat-waktu{background:#dcfce7;color:#16a34a;border:1px solid #86efac}.status-badge.terlambat{background:#fee2e2;color:#dc2626;border:1px solid #fca5a5}.status-badge.cuti{background:#dbeafe;color:#2563eb;border:1px solid #93c5fd}.status-badge.dinas-luar{background:#f3e8ff;color:#9333ea;border:1px solid #d8b4fe}.status-badge.sakit{background:#fed7aa;color:#ea580c;border:1px solid #fdba74}.status-badge.tidak-hadir,.status-badge.alpha{background:#f1f5f9;color:#64748b;border:1px solid #cbd5e1}:root{--primary: #004aad;--secondary: #0066cc;--accent: #28a745;--danger: #dc3545;--light-bg: #f9fafb}.upacara-layout,.dashboard-layout{display:flex;min-height:100vh;font-family:Poppins,sans-serif;background:var(--light-bg);color:#333;width:100%}.sidebar{width:250px;min-width:250px;color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;box-shadow:2px 0 6px #00000026;z-index:1000;transition:transform .3s ease}.sidebar-header{padding:1rem;background:#003580;display:flex;justify-content:space-between;align-items:center}.sidebar-menu{padding:1rem 0;flex:1}.sidebar-link{padding:.8rem 1rem;margin:.3rem 1rem;display:flex;gap:.8rem;border-radius:8px;cursor:pointer;color:#fff;text-decoration:none;transition:background .2s ease}.sidebar-link:hover{background:#ffffff40}.sidebar-link.active{background:var(--secondary);font-weight:600}.main-content{flex:1;display:flex;flex-direction:column;width:100%}.topbar{background:#fff;padding:1rem 1.5rem;color:var(--primary);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:50;box-shadow:0 2px 4px #0000001a}.upacara-page{width:100%}.content{flex:1;width:100%;padding:1.5rem}.upacara-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee;padding-bottom:.5rem;margin-bottom:1.5rem}.btn-add{background:var(--accent);color:#fff;padding:.6rem 1.2rem;border-radius:8px;font-weight:600;border:none;cursor:pointer}.btn-add:hover{background:#218838}.table-wrapper{width:100%;border-radius:8px;overflow:hidden;box-shadow:0 4px 10px #0000000d}.upacara-table{width:100%;border-collapse:collapse}.upacara-table th,.upacara-table td{padding:1rem;border-bottom:1px solid #eee}.upacara-table th{background:#f1f1f1;color:var(--primary);font-weight:700;font-size:.9rem}.status-badge{padding:.4rem .8rem;border-radius:12px;font-size:.85rem;font-weight:600}.status-badge.izin{background:#cce5ff;color:#004085}.status-badge.sakit{background:#f8d7da;color:#721c24}.status-badge.cuti{background:#d4edda;color:#155724}.status-badge.dinas-luar{background:#e2e3e5;color:#383d41}.date-selector{width:100%;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 6px #00000014;margin-bottom:1.5rem;display:flex;flex-wrap:wrap;gap:1rem}.date-input{padding:.7rem;border-radius:6px;border:1px solid #ccc}.btn-load{background:var(--secondary);color:#fff;padding:.7rem 1.2rem;border-radius:6px;border:none;font-weight:600}.upacara-form{background:#fff;padding:2rem;border-radius:12px;max-width:500px;margin:2rem auto;display:flex;flex-direction:column;gap:1.2rem;box-shadow:0 4px 12px #00000014}.upacara-form label{font-weight:600;color:var(--primary)}.upacara-form select,.upacara-form input[type=date],.upacara-form textarea{width:100%;padding:.75rem 1rem;border-radius:8px;border:1px solid #ccc;font-size:1rem}.form-buttons{display:flex;gap:1rem;justify-content:center}.btn-save{background:var(--accent);color:#fff;padding:.75rem 2rem;border-radius:8px;border:none;font-weight:600}.btn-cancel{background:var(--danger);color:#fff;padding:.75rem 2rem;border-radius:8px;border:none;font-weight:600}@media(max-width:768px){.sidebar{position:fixed;transform:translate(-100%)}.sidebar-open .sidebar{transform:translate(0)}.form-buttons{flex-direction:column}}
