@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{--bg-color:#0f172a;--bg-gradient:radial-gradient(circle at top right,#1e293b,#0f172a);--glass-bg:rgba(30,41,59,.7);--glass-border:hsla(0,0%,100%,.1);--text-main:#f8fafc;--text-muted:#cbd5e1;--primary:#3b82f6;--primary-hover:#2563eb;--danger:#ef4444;--danger-hover:#dc2626;--badge-h-bg:#dcfce7;--badge-h-text:#166534;--badge-s-bg:#fef08a;--badge-s-text:#854d0e;--badge-i-bg:#e9d5ff;--badge-i-text:#6b21a8;--badge-a-bg:#ffe4e6;--badge-a-text:#be123c;--badge-inactive-bg:hsla(0,0%,100%,.05);--badge-inactive-text:#94a3b8}*{box-sizing:border-box;margin:0;padding:0;font-family:Plus Jakarta Sans,sans-serif}body{background:var(--bg-gradient);background-color:var(--bg-color);color:var(--text-main);min-height:100vh;display:flex;flex-direction:column}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px;box-shadow:0 8px 32px #0000004d}button,input,select{font-family:inherit;outline:none}.input-field{width:100%;padding:.75rem 1rem;background:#0f172a99;border:1px solid var(--glass-border);color:var(--text-main);border-radius:8px;transition:all .2s ease}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 2px #3b82f64d}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;color:#fff}.btn-primary{background:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--danger)}.btn-danger:hover{background:var(--danger-hover)}.btn-outline{background:transparent;border:1px solid var(--glass-border);color:var(--text-main)}.btn-outline:hover{background:#ffffff1a}.app-container{display:grid;grid-template-columns:minmax(0,1fr);gap:1.5rem;padding:2rem;max-width:1200px;margin:0 auto;width:100%;flex:1}.profile-header{justify-content:space-between;padding:1rem 1.5rem;margin-bottom:1rem}.profile-header,.profile-info{display:flex;align-items:center}.profile-info{gap:1rem}.role-badge{background:#3b82f633;color:#60a5fa;padding:.25rem .75rem;border-radius:999px;font-size:.85rem;font-weight:600;border:1px solid rgba(59,130,246,.3)}.dashboard-actions,.profile-actions{display:flex;gap:1rem}.dashboard-actions{margin-bottom:1.5rem;align-items:center;flex-wrap:nowrap}.table-wrapper{overflow-x:auto;word-break:break-word;border-radius:8px;background:#0003}table{width:100%;border-collapse:collapse}td,th{padding:1rem;text-align:left;border-bottom:1px solid var(--glass-border)}th{font-weight:600;color:var(--text-muted);background:#0000004d}.attendance-actions{display:flex;gap:.5rem}.badge-btn{padding:.5rem 1rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;background:var(--badge-inactive-bg);color:var(--badge-inactive-text);border:1px solid transparent}.badge-btn:hover{filter:brightness(1.2)}.badge-btn.active.hadir{background:var(--badge-h-bg);color:var(--badge-h-text)}.badge-btn.active.sakit{background:var(--badge-s-bg);color:var(--badge-s-text)}.badge-btn.active.izin{background:var(--badge-i-bg);color:var(--badge-i-text)}.badge-btn.active.alpha{background:var(--badge-a-bg);color:var(--badge-a-text)}.show-mobile{display:none}.hide-mobile{display:inline}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{width:100%;max-width:500px;padding:2rem}.modal-header{margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.close-btn,.modal-header h2{font-size:1.5rem}.close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-muted);font-size:.9rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.portal-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.portal-box{width:100%;max-width:420px;padding:2.5rem;text-align:center}.portal-title{font-size:1.8rem;margin-bottom:.5rem}.portal-subtitle{color:var(--text-muted);margin-bottom:2rem}.portal-box .form-group{text-align:left}.portal-box .btn{width:100%;margin-top:1rem}.portal-links{margin-top:1.5rem;display:flex;flex-direction:column;gap:.5rem;font-size:.9rem}.portal-links a{color:var(--primary);text-decoration:none;cursor:pointer}.portal-links a:hover{text-decoration:underline}.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.alert-error{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.alert-success{background:#22c55e33;color:#86efac;border:1px solid rgba(34,197,94,.3)}.flex-1{flex:1}.flex-row{display:flex;flex-direction:row}.flex-col{display:flex;flex-direction:column}.gap-2{gap:.5rem}.gap-4{gap:1rem}@media(max-width:768px){.app-container{padding:1rem}.profile-header.desktop-header{display:none}.profile-header.mobile-bottom-header{display:flex;position:fixed;bottom:0;left:0;right:0;border-radius:16px 16px 0 0;border-bottom:none;margin:0;font-size:.8rem;z-index:100}.profile-info h3{font-size:.9rem}.role-badge{font-size:.7rem;padding:.15rem .5rem}.profile-actions{flex-direction:row;gap:.5rem}.profile-actions .btn{padding:.5rem .75rem;font-size:.8rem}body{padding-bottom:80px}.dashboard-actions{flex-wrap:wrap;gap:.5rem}.filter-group{display:flex;width:100%;gap:.5rem}.filter-group>*{flex:1}.action-group{display:flex;width:100%;gap:.5rem}.action-group>*{flex:1;white-space:nowrap;padding:.75rem .5rem;font-size:.85rem}.hide-mobile{display:none}.show-mobile{display:inline;font-weight:800}.attendance-actions{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:4px;width:-moz-max-content;width:max-content}.badge-btn{width:1.6rem;height:1.6rem;padding:0;display:flex;align-items:center;justify-content:center;border-radius:4px}}
