@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');
:root{--primary:#00D4FF;--primary-dark:#0099CC;--primary-glow:rgba(0,212,255,0.25);--secondary:#7B2FBE;--accent:#00FF88;--bg-deep:#020712;--bg-surface:#0B1120;--bg-elevated:#111827;--border:rgba(0,212,255,0.15);--border-strong:rgba(0,212,255,0.35);--text-primary:#F0F6FC;--text-muted:#8B9EB7;--danger:#FF4757;--warning:#FFA502;--success:#00FF88;--radius:12px;--radius-lg:20px;--shadow-glow:0 0 30px rgba(0,212,255,0.2);--shadow-card:0 8px 32px rgba(0,0,0,0.4);--transition:all 0.3s cubic-bezier(0.4,0,0.2,1);--font-display:'Space Grotesk',sans-serif;--font-body:'Inter',sans-serif;--font-mono:'JetBrains Mono',monospace;--sidebar-w:260px;}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}html{scroll-behavior:smooth;}body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text-primary);min-height:100vh;}a{text-decoration:none;color:inherit;}ul{list-style:none;}
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}.auth-bg{position:absolute;inset:0;background:var(--bg-deep);z-index:0;}.auth-bg::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(0,212,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,0.04) 1px,transparent 1px);background-size:60px 60px;}.auth-orb{position:absolute;border-radius:50%;filter:blur(100px);}.auth-orb-1{width:500px;height:500px;background:rgba(0,212,255,0.07);top:-150px;right:-100px;}.auth-orb-2{width:400px;height:400px;background:rgba(123,47,190,0.08);bottom:-100px;left:-100px;}.auth-box{background:rgba(11,17,32,0.9);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:440px;position:relative;z-index:1;backdrop-filter:blur(20px);}.auth-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),var(--secondary),transparent);}.auth-logo{display:flex;align-items:center;gap:0.75rem;margin-bottom:2rem;}.auth-logo img{height:36px;}.auth-logo span{font-family:var(--font-display);font-weight:700;font-size:1.1rem;}.auth-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:0.5rem;}.auth-subtitle{font-size:0.88rem;color:var(--text-muted);margin-bottom:2rem;}.form-group{margin-bottom:1.2rem;}.form-label{display:block;font-size:0.8rem;font-weight:600;color:var(--text-muted);margin-bottom:0.4rem;text-transform:uppercase;letter-spacing:0.5px;}.input-wrap{position:relative;}.input-wrap i{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:0.9rem;}.form-control{width:100%;padding:0.85rem 1rem 0.85rem 2.75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:0.9rem;transition:var(--transition);}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);}.form-control::placeholder{color:var(--text-muted);}.form-control.no-icon{padding-left:1rem;}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;padding:0.85rem 1.75rem;border-radius:10px;font-weight:600;font-size:0.9rem;font-family:var(--font-display);cursor:pointer;border:none;transition:var(--transition);}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#020712;box-shadow:0 0 20px var(--primary-glow);width:100%;}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 35px rgba(0,212,255,0.5);}.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text-muted);width:100%;}.btn-outline:hover{border-color:var(--primary);color:var(--primary);}.btn-sm{padding:0.5rem 1rem;font-size:0.8rem;width:auto;}.btn-danger{background:rgba(255,71,87,0.15);border:1px solid rgba(255,71,87,0.3);color:var(--danger);width:auto;}.otp-boxes{display:flex;gap:0.75rem;justify-content:center;margin:1.5rem 0;}.otp-input{width:52px;height:56px;text-align:center;font-size:1.4rem;font-weight:700;font-family:var(--font-mono);background:var(--bg-elevated);border:1.5px solid var(--border);border-radius:10px;color:var(--text-primary);transition:var(--transition);}.otp-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);}.auth-divider{text-align:center;font-size:0.8rem;color:var(--text-muted);margin:1.25rem 0;position:relative;}.auth-divider::before{content:'';position:absolute;left:0;right:0;top:50%;height:1px;background:var(--border);}.auth-divider span{background:rgba(11,17,32,0.9);padding:0 0.75rem;position:relative;}.auth-footer{text-align:center;margin-top:1.5rem;font-size:0.85rem;color:var(--text-muted);}.auth-footer a{color:var(--primary);}.alert{padding:0.85rem 1rem;border-radius:10px;font-size:0.85rem;margin-bottom:1rem;display:none;}.alert.show{display:block;}.alert-error{background:rgba(255,71,87,0.1);border:1px solid rgba(255,71,87,0.3);color:var(--danger);}.alert-success{background:rgba(0,255,136,0.1);border:1px solid rgba(0,255,136,0.3);color:var(--accent);}.alert-info{background:rgba(0,212,255,0.1);border:1px solid rgba(0,212,255,0.3);color:var(--primary);}
.portal-layout{display:flex;min-height:100vh;}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:var(--transition);}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:0.75rem;}.sidebar-header img{height:32px;}.sidebar-header span{font-family:var(--font-display);font-weight:700;}.sidebar-nav{padding:1rem;flex:1;overflow-y:auto;}.sidebar-section{margin-bottom:1.5rem;}.sidebar-section-title{font-size:0.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;padding:0 0.75rem;margin-bottom:0.5rem;display:block;}.sidebar-link{display:flex;align-items:center;gap:0.75rem;padding:0.7rem 0.75rem;border-radius:10px;font-size:0.88rem;color:var(--text-muted);transition:var(--transition);margin-bottom:0.15rem;cursor:pointer;}.sidebar-link i{width:18px;text-align:center;font-size:0.95rem;}.sidebar-link:hover{background:var(--bg-elevated);color:var(--text-primary);}.sidebar-link.active{background:rgba(0,212,255,0.1);color:var(--primary);border:1px solid rgba(0,212,255,0.2);}.sidebar-footer{padding:1rem;border-top:1px solid var(--border);}.sidebar-user{display:flex;align-items:center;gap:0.75rem;padding:0.75rem;border-radius:10px;background:var(--bg-elevated);}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.85rem;color:#020712;flex-shrink:0;}.user-name{font-size:0.85rem;font-weight:600;display:block;}.user-role{font-size:0.73rem;color:var(--text-muted);}.portal-main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;}.portal-topbar{padding:1rem 2rem;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;}.portal-topbar h1{font-family:var(--font-display);font-size:1.2rem;font-weight:700;}.topbar-actions{display:flex;align-items:center;gap:1rem;}.notif-btn{width:38px;height:38px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;}.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--danger);}.portal-content{padding:2rem;flex:1;}
.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem;}.dash-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;position:relative;overflow:hidden;}.dash-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary),var(--secondary));}.dash-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:1rem;}.dash-card-icon.cyan{background:rgba(0,212,255,0.1);color:var(--primary);}.dash-card-icon.purple{background:rgba(123,47,190,0.1);color:#a855f7;}.dash-card-icon.green{background:rgba(0,255,136,0.1);color:var(--accent);}.dash-card-icon.orange{background:rgba(255,165,2,0.1);color:var(--warning);}.dash-card h3{font-family:var(--font-display);font-size:1.8rem;font-weight:700;}.dash-card p{font-size:0.82rem;color:var(--text-muted);margin-top:0.25rem;}.section-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;}.section-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border);}.section-card-header h2{font-family:var(--font-display);font-size:1rem;font-weight:700;}.table-wrap{overflow-x:auto;}.table{width:100%;border-collapse:collapse;}.table thead th{font-size:0.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;padding:0.75rem 1rem;text-align:left;border-bottom:1px solid var(--border);}.table tbody td{padding:0.85rem 1rem;font-size:0.88rem;border-bottom:1px solid rgba(255,255,255,0.04);}.table tbody tr:hover{background:var(--bg-elevated);}.status-badge{display:inline-flex;align-items:center;gap:0.35rem;padding:0.25rem 0.75rem;border-radius:50px;font-size:0.75rem;font-weight:600;}.status-badge.active{background:rgba(0,255,136,0.1);color:var(--accent);border:1px solid rgba(0,255,136,0.2);}.status-badge.pending{background:rgba(255,165,2,0.1);color:var(--warning);border:1px solid rgba(255,165,2,0.2);}.status-badge.approved{background:rgba(0,212,255,0.1);color:var(--primary);border:1px solid rgba(0,212,255,0.2);}.status-badge.rejected{background:rgba(255,71,87,0.1);color:var(--danger);border:1px solid rgba(255,71,87,0.2);}
.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;}.quick-action-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;align-items:center;gap:0.75rem;cursor:pointer;transition:var(--transition);text-align:center;}.quick-action-btn:hover{border-color:var(--primary);background:rgba(0,212,255,0.05);}.quick-action-btn i{font-size:1.5rem;color:var(--primary);}.quick-action-btn span{font-size:0.85rem;font-weight:600;}
.payslips-list{display:flex;flex-direction:column;gap:0.75rem;}.payslip-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;transition:var(--transition);}.payslip-card:hover{border-color:var(--border-strong);}.payslip-month{font-family:var(--font-display);font-weight:700;font-size:1rem;}.payslip-amount{font-size:1.3rem;font-weight:700;color:var(--accent);font-family:var(--font-display);}.profile-header{display:flex;align-items:center;gap:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem;}.profile-avatar-lg{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:2rem;color:#020712;flex-shrink:0;}.profile-meta h2{font-family:var(--font-display);font-size:1.3rem;font-weight:700;}.profile-meta p{color:var(--text-muted);font-size:0.88rem;}.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}.tab-nav{display:flex;gap:0.25rem;background:var(--bg-elevated);border-radius:10px;padding:0.25rem;margin-bottom:1.5rem;}.tab-btn{flex:1;padding:0.65rem 1rem;border-radius:8px;font-size:0.85rem;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--text-muted);transition:var(--transition);}.tab-btn.active{background:var(--bg-surface);color:var(--primary);border:1px solid var(--border);}.tab-panel{display:none;}.tab-panel.active{display:block;}.toast{position:fixed;top:1.5rem;right:1.5rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;align-items:center;gap:0.75rem;z-index:9999;box-shadow:var(--shadow-card);transform:translateX(120%);transition:transform 0.3s ease;min-width:280px;}.toast.show{transform:translateX(0);}.toast i{font-size:1.1rem;}.toast.success{border-left:4px solid var(--accent);}.toast.success i{color:var(--accent);}.toast.error{border-left:4px solid var(--danger);}.toast.error i{color:var(--danger);}.toast.info{border-left:4px solid var(--primary);}.toast.info i{color:var(--primary);}.cert-preview{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;text-align:center;font-family:var(--font-mono);font-size:0.85rem;color:var(--text-muted);}.progress-bar{height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden;margin-top:0.5rem;}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:3px;transition:width 0.5s ease;}@media(max-width:768px){.sidebar{transform:translateX(-100%);}.sidebar.open{transform:translateX(0);}.portal-main{margin-left:0;}.form-2col{grid-template-columns:1fr;}}
.admin-badge{background:linear-gradient(135deg,rgba(255,71,87,0.15),rgba(123,47,190,0.1));border:1px solid rgba(255,71,87,0.3);color:var(--danger);padding:0.2rem 0.6rem;border-radius:50px;font-size:0.7rem;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;}.sidebar-link.active.admin{background:rgba(255,71,87,0.1);color:var(--danger);border-color:rgba(255,71,87,0.2);}.admin-stat h3{color:var(--danger);}.cert-actions{display:flex;gap:0.5rem;flex-wrap:wrap;}.modal-overlay{position:fixed;inset:0;background:rgba(2,7,18,0.85);backdrop-filter:blur(8px);z-index:500;display:none;align-items:center;justify-content:center;}.modal-overlay.open{display:flex;}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;position:relative;}.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:var(--radius-lg) var(--radius-lg) 0 0;}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:0.25rem;}.modal-close:hover{color:var(--danger);}.cert-template{background:#fff;color:#000;padding:3rem;border-radius:var(--radius);font-family:serif;text-align:center;position:relative;overflow:hidden;border:3px solid #c0a060;margin:1.5rem 0;}.cert-template .cert-border{position:absolute;inset:8px;border:1px solid #c0a060;border-radius:4px;pointer-events:none;}.cert-logo{height:60px;margin:0 auto 1.5rem;}.cert-title{font-size:2rem;font-weight:700;color:#1a1a2e;margin-bottom:0.5rem;letter-spacing:2px;}.cert-subtitle{font-size:0.9rem;color:#666;text-transform:uppercase;letter-spacing:3px;margin-bottom:2rem;}.cert-body{font-size:1rem;color:#333;line-height:2;max-width:480px;margin:0 auto 2rem;}.cert-name{font-size:1.5rem;font-weight:700;color:#1a1a2e;border-bottom:2px solid #c0a060;display:inline-block;padding:0 1rem 0.25rem;margin:0.5rem 0;}.cert-footer{display:flex;justify-content:space-between;align-items:flex-end;margin-top:2rem;}.cert-sign{text-align:center;}.cert-sign-line{width:150px;height:1px;background:#333;margin:0.5rem auto;}.cert-sign p{font-size:0.8rem;color:#666;}.search-bar{display:flex;gap:0.75rem;margin-bottom:1.5rem;}.search-input{flex:1;padding:0.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:0.88rem;}.search-input:focus{outline:none;border-color:var(--primary);}.filter-select{padding:0.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:0.88rem;cursor:pointer;}.filter-select:focus{outline:none;border-color:var(--primary);}
