@import "https://fonts.googleapis.css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-primary:#1d4ed8;--color-primary-hover:#2563eb;--color-accent:#38bdf8;--color-navy:#051024;--color-navy-light:#0b1c3d;--color-navy-lighter:#152c5b;--color-text-main:#fff;--color-text-muted:#94a3b8;--color-text-blue:#cbd5e1;--color-border:#ffffff1a;--color-input-bg:#0b1c3d99;--color-input-border:#38bdf84d;--color-input-focus:#38bdf8;--color-danger:#ef4444;--color-success:#10b981}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--color-text-main);background-color:var(--color-navy);min-height:100vh;font-family:Inter,sans-serif;overflow-x:hidden}.app-layout{min-height:100vh;display:flex}.left-panel{flex:1;display:none;position:relative}@media (width>=1024px){.left-panel{flex-direction:column;justify-content:center;display:flex}}.left-panel-bg{z-index:1;background-image:url(/college_building_bg.png);background-position:50%;background-size:cover;width:100%;height:100%;position:absolute;top:0;left:0}.left-panel-overlay{z-index:2;background:linear-gradient(90deg,#051024e6 0%,#0b1c3db3 100%);width:100%;height:100%;position:absolute;top:0;left:0}.left-panel-content{z-index:3;max-width:800px;padding:4rem;animation:1s ease-out fadeSlideRight;position:relative}.welcome-text{color:var(--color-text-blue);letter-spacing:1px;margin-bottom:.5rem;font-size:1.25rem;font-weight:300}.main-heading{color:#fff;text-transform:uppercase;text-shadow:0 4px 12px #0000004d;margin-bottom:1.5rem;font-size:3.5rem;font-weight:700;line-height:1.1}.sub-heading{color:var(--color-text-blue);border-left:4px solid var(--color-accent);margin-bottom:3rem;padding-left:1rem;font-size:1.1rem;font-weight:300;line-height:1.6}.features-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);text-align:center;background:#ffffff0d;border-radius:16px;padding:1.5rem;transition:all .3s}.feature-card:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-5px)}.feature-icon-wrapper{width:60px;height:60px;color:var(--color-text-main);background:#ffffff1a;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.feature-title{color:#fff;margin-bottom:.5rem;font-size:1rem;font-weight:600}.feature-desc{color:var(--color-text-muted);font-size:.85rem;line-height:1.4}.right-panel{background-color:var(--color-navy);z-index:10;flex:1;justify-content:center;align-items:center;max-width:100%;padding:2rem;display:flex;position:relative;box-shadow:-10px 0 30px #0000004d}@media (width>=1024px){.right-panel{max-width:550px}}.auth-container{width:100%;max-width:420px;animation:.8s ease-out fadeSlideUp}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo-wrapper{justify-content:center;margin-bottom:1.5rem;display:flex}.auth-logo{background-color:#fff;border-radius:50%;width:110px;height:110px;padding:4px;box-shadow:0 0 20px #38bdf866}.auth-title{letter-spacing:1px;margin-bottom:.25rem;font-size:2rem;font-weight:700}.auth-subtitle{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:2px;font-size:.9rem}.auth-form-title{text-align:center;margin-bottom:.5rem;font-size:1.2rem;font-weight:600}.auth-form-subtitle{color:var(--color-text-muted);text-align:center;margin-bottom:2rem;font-size:.85rem}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--color-text-muted);transition:color .3s;position:absolute;left:1.25rem}.auth-input{background-color:var(--color-navy-light);border:1px solid var(--color-input-border);color:#fff;border-radius:8px;width:100%;padding:1rem 1rem 1rem 3rem;font-size:.95rem;transition:all .3s}.auth-input::placeholder{color:var(--color-text-muted)}.auth-input:focus{border-color:var(--color-input-focus);box-shadow:0 0 0 1px var(--color-input-focus);background-color:#0b1c3dcc;outline:none}.auth-input:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:var(--color-input-focus)}.password-toggle{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;right:1.25rem}.password-toggle:hover{color:#fff}.form-options{justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.checkbox-label{cursor:pointer;color:var(--color-text-muted);align-items:center;gap:.5rem;display:flex}.checkbox-input{appearance:none;border:1px solid var(--color-text-muted);cursor:pointer;background-color:#0000;border-radius:4px;width:16px;height:16px;position:relative}.checkbox-input:checked{background-color:var(--color-primary);border-color:var(--color-primary)}.checkbox-input:checked:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:4px;height:8px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}.forgot-password{color:var(--color-accent);text-decoration:none;transition:color .3s}.forgot-password:hover{color:#fff}.btn-primary{background:linear-gradient(to right, var(--color-primary), var(--color-accent));color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #2563eb66}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.divider{text-align:center;margin:1.5rem 0;position:relative}.divider:before{content:"";background-color:var(--color-border);height:1px;position:absolute;top:50%;left:0;right:0}.divider span{background-color:var(--color-navy);color:var(--color-text-muted);padding:0 1rem;font-size:.85rem;position:relative}.btn-sso{color:#fff;border:1px solid var(--color-border);cursor:pointer;background-color:#0000;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:1rem;font-size:.95rem;font-weight:500;transition:all .3s;display:flex}.btn-sso:hover{background-color:#ffffff0d;border-color:#fff3}.auth-footer{text-align:center;color:var(--color-text-muted);margin-top:2rem;font-size:.85rem}.auth-footer a{color:var(--color-accent);text-decoration:none}.auth-footer a:hover{text-decoration:underline}@keyframes fadeSlideRight{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.dashboard-container{background:var(--color-navy-light);border:1px solid var(--color-border);border-radius:16px;width:100%;max-width:1200px;margin:2rem auto;padding:2rem}.dashboard-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.btn-logout{color:var(--color-danger);border:1px solid var(--color-danger);cursor:pointer;background:0 0;border-radius:8px;padding:.5rem 1rem;font-weight:500;transition:all .2s}.btn-logout:hover{background:var(--color-danger);color:#fff}.notification-wrapper{z-index:9999;pointer-events:none;flex-direction:column;gap:1rem;display:flex;position:fixed}.error-wrapper{align-items:flex-end;top:1.5rem;right:1.5rem}.success-wrapper{align-items:center;top:50%;left:50%;transform:translate(-50%,-50%)}.win11-msgbox{pointer-events:auto;color:#000;background-color:#fff;border:1px solid #dc2626;border-radius:8px;width:380px;max-width:90vw;animation:.3s cubic-bezier(.16,1,.3,1) forwards win11SlideIn;overflow:hidden;box-shadow:0 8px 32px #00000026,0 0 0 1px #dc26261a}.win11-header{background-color:#f8fafc;border-bottom:1px solid #dc262626;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.win11-title-container{color:#dc2626;align-items:center;gap:.5rem;display:flex}.win11-title{font-size:.95rem;font-weight:600}.win11-close-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.win11-close-btn:hover{color:#dc2626;background-color:#fee2e2}.win11-body{padding:1.25rem 1rem;font-size:.95rem;line-height:1.5}.win11-message{margin-bottom:.75rem}.win11-solution{color:#334155;background-color:#f8fafc;border-left:3px solid #3b82f6;border-radius:6px;padding:.75rem;font-size:.85rem}.success-msgbox{pointer-events:auto;color:#0f172a;text-align:center;background-color:#fff;border:1px solid #10b981;border-radius:12px;flex-direction:column;align-items:center;gap:1rem;min-width:300px;padding:1.5rem 2rem;animation:.4s cubic-bezier(.16,1,.3,1) forwards centerPopIn;display:flex;position:relative;box-shadow:0 20px 40px #0003}.success-icon{color:#10b981;width:48px;height:48px}.success-text{font-size:1.1rem;font-weight:600}.success-close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;transition:color .2s;position:absolute;top:.75rem;right:.75rem}.success-close-btn:hover{color:#0f172a}@keyframes win11SlideIn{0%{opacity:0;transform:translate(100%)scale(.95)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes centerPopIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.admin-layout{color:#e2e8f0;background-color:#0b1121;min-height:100vh;display:flex}.admin-sidebar{color:#fff;z-index:50;background-color:#0b1121;border-right:1px solid #ffffff0d;flex-direction:column;width:280px;display:flex}.sidebar-header{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1.5rem;display:flex}.sidebar-logo{width:80px;height:80px}.sidebar-title{font-size:1.25rem;font-weight:700;line-height:1.2}.sidebar-subtitle{color:#94a3b8;text-transform:uppercase;letter-spacing:1px;font-size:.75rem}.sidebar-section-title{color:#64748b;text-transform:uppercase;letter-spacing:1px;margin-top:1rem;margin-bottom:.5rem;padding:0 1.5rem;font-size:.75rem}.sidebar-menu{flex-direction:column;flex:1;gap:.25rem;padding:0;display:flex;overflow-y:auto}.menu-item{color:#94a3b8;cursor:pointer;border-radius:8px;align-items:center;gap:1rem;margin:0 1rem;padding:.85rem 1.5rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.menu-item:hover{color:#fff;background-color:#ffffff0d}.menu-item.active{color:#fff;background-color:#2563eb}.menu-icon{color:inherit}.sidebar-footer{padding:1.5rem}.profile-card{cursor:pointer;background-color:#ffffff08;border:1px solid #ffffff0d;border-radius:12px;align-items:center;gap:1rem;padding:1rem;transition:background .2s;display:flex}.profile-card:hover{background-color:#ffffff0f}.profile-avatar{background-color:#3b82f6;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.profile-status{background-color:#10b981;border:2px solid #0b1121;border-radius:50%;width:10px;height:10px;position:absolute;bottom:0;right:0}.profile-info{flex-direction:column;flex:1;display:flex}.profile-name{font-size:.9rem;font-weight:600}.profile-role{color:#94a3b8;font-size:.75rem}.admin-main{background-color:#0b1121;flex-direction:column;flex:1;display:flex;overflow:hidden}.admin-topbar{z-index:40;justify-content:space-between;align-items:flex-start;padding:2rem 2.5rem 0;display:flex}.header-text h1{align-items:center;gap:.5rem;margin-bottom:.25rem;font-size:1.5rem;font-weight:600;display:flex}.header-text p{color:#94a3b8;font-size:.9rem}.header-actions{align-items:center;gap:1rem;display:flex}.date-dropdown{color:#cbd5e1;cursor:pointer;background-color:#1e293b;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;display:flex}.icon-btn{color:#cbd5e1;cursor:pointer;background-color:#1e293b;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;transition:background .2s;display:flex;position:relative}.icon-btn:hover{background-color:#334155}.badge{color:#fff;background-color:#3b82f6;border:2px solid #0b1121;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.admin-content{flex:1;padding:1.5rem 2.5rem;overflow-y:auto}.stats-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:1.5rem;display:grid}.stat-card{background-color:#162032;border:1px solid #ffffff0d;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a}.stat-card-top{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.stat-icon{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon.blue{background-color:#2563eb}.stat-icon.green{background-color:#10b981}.stat-icon.yellow{background-color:#f59e0b}.stat-icon.purple{background-color:#8b5cf6}.stat-info{flex:1}.stat-title{color:#94a3b8;margin-bottom:.25rem;font-size:.8rem}.stat-value-wrap{align-items:baseline;gap:.5rem;display:flex}.stat-value{color:#fff;font-size:1.75rem;font-weight:700}.stat-badge{border-radius:4px;padding:.1rem .4rem;font-size:.75rem}.stat-badge.green{color:#10b981;background-color:#10b9811a}.stat-badge.purple{color:#8b5cf6;background-color:#8b5cf61a}.stat-badge.yellow{color:#f59e0b;background-color:#f59e0b1a}.stat-card-bottom{color:#64748b;border-top:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding-top:.75rem;font-size:.8rem;display:flex}.trend-up{color:#10b981;align-items:center;gap:.25rem;display:flex}.trend-down{color:#ef4444;align-items:center;gap:.25rem;display:flex}.middle-row{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}.chart-card{background-color:#162032;border:1px solid #ffffff0d;border-radius:12px;padding:1.5rem}.chart-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.chart-title{font-size:1rem;font-weight:600}.chart-dropdown{color:#cbd5e1;background-color:#1e293b;border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:.5rem;padding:.4rem .75rem;font-size:.8rem;display:flex}.chart-stats-row{text-align:center;border-top:1px solid #ffffff0d;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1rem;padding-top:1rem;display:grid}.chart-stat-item p{color:#94a3b8;margin-bottom:.25rem;font-size:.75rem}.chart-stat-item h4{margin-bottom:.25rem;font-size:1.25rem;font-weight:600}.chart-stat-item h4.blue{color:#3b82f6}.chart-stat-item h4.green{color:#10b981}.chart-stat-item h4.red{color:#ef4444}.chart-stat-item h4.gray{color:#e2e8f0}.chart-stat-item span{color:#64748b;font-size:.7rem}.donut-legend{flex-direction:column;gap:1rem;margin-left:1rem;display:flex}.legend-item{justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.legend-label{color:#e2e8f0;align-items:center;gap:.5rem;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.legend-dot.green{background-color:#10b981}.legend-dot.yellow{background-color:#f59e0b}.legend-dot.red{background-color:#ef4444}.legend-value{color:#94a3b8}.legend-value span{color:#e2e8f0;margin-right:.5rem;font-weight:600}.btn-full{color:#e2e8f0;cursor:pointer;background-color:#1e293b;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:1.5rem;padding:.75rem;font-size:.85rem;transition:background .2s;display:flex}.btn-full:hover{background-color:#334155}.data-section{background-color:#162032;border:1px solid #ffffff0d;border-radius:12px;overflow:hidden}.data-section-header{justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.data-section-title{font-size:1.1rem;font-weight:600}.btn-outline{color:#e2e8f0;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:6px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;transition:all .2s;display:flex}.btn-outline:hover{background:#ffffff0d}.table-responsive{width:100%;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;color:#94a3b8;background-color:#1e293b;border-top:1px solid #ffffff0d;border-bottom:1px solid #ffffff0d;padding:1rem 1.5rem;font-size:.8rem;font-weight:500}.admin-table td{color:#cbd5e1;vertical-align:middle;border-bottom:1px solid #ffffff0d;padding:1rem 1.5rem;font-size:.85rem}.admin-table tbody tr:hover{background-color:#ffffff05}.status-text{border-radius:4px;padding:.2rem .5rem;font-size:.8rem;font-weight:500}.status-text.hadir{color:#10b981;border:1px solid #10b98133}.status-text.terlambat{color:#f59e0b;border:1px solid #f59e0b33}.status-text.alfa{color:#ef4444;border:1px solid #ef444433}.user-cell{align-items:center;gap:.75rem;display:flex}.user-cell-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;font-weight:600;display:flex}.user-cell-avatar.purple{background-color:#8b5cf6}.user-cell-avatar.blue{background-color:#3b82f6}.user-cell-avatar.green{background-color:#10b981}.user-cell-avatar.red{background-color:#ef4444}.user-cell-name{color:#e2e8f0}.method-cell{align-items:center;gap:.5rem;display:flex}.footer-text{text-align:center;color:#64748b;padding:1.5rem;font-size:.75rem}
