*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0f14;--bg2: #13161e;--bg3: #1a1e2a;--card: #1e2230;--card2: #252a3a;--border: #2d334a;--accent: #6c63ff;--accent2: #4ecdc4;--accent3: #ff6b6b;--accent4: #ffd93d;--text: #eef0f8;--text2: #8892b0;--text3: #4a5270;--green: #43e97b;--red: #ff6b6b;--orange: #ffa94d;--blue: #74b9ff;--sidebar-w: 260px;--radius: 16px;--radius-sm: 10px;--shadow: 0 8px 32px rgba(0, 0, 0, .4);--shadow-sm: 0 2px 12px rgba(0, 0, 0, .3);--font-head: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--transition: all .25s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg: #f0f2f8;--bg2: #e8eaf4;--bg3: #dde1f0;--card: #ffffff;--card2: #f4f6ff;--border: #d0d5e8;--text: #1a1e2a;--text2: #5a6280;--text3: #9aa0b8;--shadow: 0 8px 32px rgba(108, 99, 255, .12);--shadow-sm: 0 2px 12px rgba(0, 0, 0, .08)}html{font-size:16px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:700;line-height:1.2}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;width:100%;max-width:100%;overflow-x:hidden;margin-left:var(--sidebar-w);padding:32px;min-height:100vh;background:var(--bg);transition:var(--transition)}@media (max-width: 768px){.main-content{margin-left:0;padding:80px 16px 16px}:root{--sidebar-w: 0px}}.sidebar{width:var(--sidebar-w);height:100vh;background:var(--bg2);border-right:1px solid var(--border);position:fixed;left:0;top:0;display:flex;flex-direction:column;padding:24px 16px;z-index:1000;overflow-y:auto;transition:transform .3s ease}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:260px}.sidebar.open{transform:translate(0)}}.close-btn{position:absolute;top:16px;right:16px;background:var(--card);border:1px solid var(--border);width:34px;height:34px;border-radius:8px;cursor:pointer;font-size:1.2rem;color:var(--text2);display:none;align-items:center;justify-content:center;z-index:1100;transition:.2s}.close-btn:hover{border-color:var(--red);color:var(--red)}@media (max-width: 768px){.close-btn{display:flex}}.sidebar-logo{display:flex;flex-direction:column;align-items:center;gap:6px;padding:0 8px 20px;border-bottom:1px solid var(--border);margin-bottom:20px}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px}.logo-text{font-family:var(--font-head);font-size:1.3rem;font-weight:800;color:var(--text)}.logo-sub{font-size:.7rem;color:var(--text2);font-weight:400}.nav-section-label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);padding:0 8px;margin:16px 0 6px}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--radius-sm);color:var(--text2);text-decoration:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);border:1px solid transparent;margin-bottom:2px;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--card);color:var(--text);border-color:var(--border)}.nav-item.active{background:linear-gradient(135deg,#6c63ff33,#4ecdc41a);color:var(--accent);border-color:#6c63ff4d}.nav-item .nav-icon{font-size:1.1rem;width:20px;text-align:center}.sidebar-footer{margin-top:auto;padding-top:20px;border-top:1px solid var(--border)}.user-card{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border)}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0}.user-info{flex:1;overflow:hidden}.user-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;color:var(--text2);text-transform:capitalize}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);transition:var(--transition)}.card:hover{border-color:#6c63ff4d;box-shadow:var(--shadow)}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden;transition:var(--transition)}@media (max-width: 480px){.stat-card{width:100%;min-width:0;padding:18px;border-radius:var(--radius);transition:var(--transition)}.stat-value{font-size:1.4rem}.stat-label{font-size:.75rem}}@media (max-width: 600px){.stat-value{font-size:1.4rem}.stat-label{font-size:.8rem}}@media (max-width: 768px){.grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.stat-card{width:100%;padding:18px}.stat-value{font-size:clamp(1.2rem,2.5vw,1.6rem)}.stat-label{font-size:clamp(.7rem,1.5vw,.9rem)}}.stat-card:before{content:"";position:absolute;top:0;right:0;width:80px;height:80px;border-radius:0 16px 0 80px;opacity:.1}.stat-card.blue:before{background:var(--blue)}.stat-card.green:before{background:var(--green)}.stat-card.red:before{background:var(--red)}.stat-card.orange:before{background:var(--orange)}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.stat-icon{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:16px}.stat-icon.blue{background:#74b9ff26}.stat-icon.green{background:#43e97b26}.stat-icon.red{background:#ff6b6b26}.stat-icon.orange{background:#ffa94d26}.stat-value{font-size:1.6rem;font-weight:800;color:var(--text);line-height:1;margin-bottom:6px}.stat-label{font-size:.85rem;color:var(--text2);font-weight:500}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);border:1px solid transparent;text-decoration:none;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;box-shadow:0 4px 15px #6c63ff66}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6c63ff80}.btn-secondary{background:var(--card2);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--card);border-color:var(--accent);color:var(--accent)}.btn-success{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#0d0f14;font-weight:600}.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 15px #43e97b66}.btn-danger{background:linear-gradient(135deg,var(--red),#ee5a24);color:#fff}.btn-danger:hover{transform:translateY(-1px);box-shadow:0 4px 15px #ff6b6b66}.btn-sm{padding:6px 11px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-full{width:100%;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-group{margin-bottom:20px}.form-group.full-width{grid-column:1 / -1}.form-label{display:block;font-size:.85rem;font-weight:600;color:var(--text2);margin-bottom:8px;letter-spacing:.02em}.form-control{width:100%;padding:12px 16px;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:.95rem;transition:var(--transition);outline:none}.form-control:focus{border-color:var(--accent);background:var(--card);box-shadow:0 0 0 3px #6c63ff26}.form-control::placeholder{color:var(--text3)}.form-error{font-size:.78rem;color:var(--red);margin-top:5px}.table-wrapper{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.88rem}thead{background:var(--bg2)}th{padding:14px 16px;text-align:left;font-family:var(--font-head);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text2);border-bottom:1px solid var(--border);white-space:nowrap}td{padding:14px 16px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{transition:var(--transition)}tbody tr:hover{background:var(--card2)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:99px;font-size:.75rem;font-weight:600}.badge-present{background:#43e97b26;color:var(--green)}.badge-absent{background:#ff6b6b26;color:var(--red)}.badge-late{background:#ffa94d26;color:var(--orange)}.badge-halfday{background:#74b9ff26;color:var(--blue)}.badge-pending{background:#fdcb6e26;color:#ffd93d}.badge-approved{background:#43e97b26;color:var(--green)}.badge-rejected{background:#ff6b6b26;color:var(--red)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:12px;flex-wrap:wrap}.page-title{font-size:clamp(1rem,2.5vw,1.8rem);font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px;flex-wrap:wrap;line-height:1.2}@media (min-width: 1400px){.page-title{font-size:2rem}}@media (max-width: 1024px){.page-title{font-size:1.6rem}}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start}.page-title{margin-top:2px;font-size:1.1rem}}@media (max-width: 480px){.page-title{margin-top:2px;font-size:1.2rem}.page-subtitle{font-size:.75rem}}@media (max-width: 360px){.page-title{margin-top:-50px;font-size:1rem}}@media (max-width: 600px){.page-title{font-size:1.3rem}.page-subtitle{font-size:.8rem}.page-header{flex-direction:column;align-items:flex-start}}.page-subtitle{font-size:clamp(.75rem,1.5vw,.9rem);color:var(--text2);margin-top:4px}.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}@media (max-width: 1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.grid-4{grid-template-columns:1fr}}@media (max-width: 480px){.card{max-width:100%;padding:16px}}@media (max-width: 360px){.card{width:100%;max-width:100%;padding:14px;border-radius:12px}.auth-card{width:100%;max-width:100%;padding:18px 14px;border-radius:12px}.stat-card{width:100%;padding:14px;border-radius:12px}.modal-box{width:100%;max-width:100%;padding:14px;border-radius:12px}.page-title{font-size:.95rem;margin-top:2px}.btn{padding:8px 7px;font-size:.75rem}.form-control{padding:10px 12px;font-size:.85rem}}@media (max-width: 320px){.card{width:100%;max-width:100%;padding:12px 10px;border-radius:12px;overflow:hidden}}@media (max-width: 1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3,.grid-2{grid-template-columns:1fr}}@media (max-width: 360px){.grid-4{grid-template-columns:1fr!important}}.auth-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden;padding:10px}.auth-bg:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(108,99,255,.12) 0%,transparent 70%);top:-200px;right:-200px}.auth-bg:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(78,205,196,.08) 0%,transparent 70%);bottom:-100px;left:-100px}.auth-card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:48px 40px;width:100%;max-width:460px;position:relative;z-index:1;box-shadow:var(--shadow)}@media (max-width: 992px){.auth-card{max-width:400px;padding:40px 30px}}@media (max-width: 600px){.auth-card{max-width:95%;padding:28px 20px;border-radius:16px}}@media (max-width: 400px){.auth-card{padding:22px 16px}}.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px;justify-content:center}.auth-title{font-size:1.9rem;font-weight:800;margin-bottom:6px;text-align:center;margin-top:-20px}.auth-subtitle{color:var(--text2);font-size:.9rem;text-align:center;margin-bottom:32px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;gap:16px}@media (max-width: 768px){.topbar{display:none!important}}.topbar-right{display:flex;align-items:center;gap:12px}.theme-toggle{width:40px;height:40px;border-radius:50%;background:var(--card);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:var(--transition);color:var(--text2)}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.clock-widget{background:linear-gradient(135deg,#6c63ff33,#4ecdc426);border:1px solid rgba(108,99,255,.3);border-radius:var(--radius);padding:32px;text-align:center}.clock-time{font-family:var(--font-head);font-size:3rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:8px}.clock-date{color:var(--text2);font-size:.9rem}.checkin-btn{width:140px;height:140px;border-radius:50%;border:none;cursor:pointer;font-family:var(--font-head);font-size:1rem;font-weight:700;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;transition:var(--transition)}.checkin-btn.in{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#0d0f14;box-shadow:0 0 40px #43e97b4d}.checkin-btn.out{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;box-shadow:0 0 40px #ff6b6b4d}.checkin-btn:hover{transform:scale(1.05)}.checkin-btn .btn-icon{font-size:2rem}.timer-display{font-size:1.5rem;font-weight:700;color:var(--accent2);letter-spacing:.05em}.search-bar{display:flex;align-items:center;gap:8px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;transition:var(--transition)}.search-bar:focus-within{border-color:var(--accent)}.search-bar input{background:none;border:none;outline:none;color:var(--text);font-family:var(--font-body);font-size:.9rem;flex:1;min-width:0}.search-bar input::placeholder{color:var(--text3)}.search-icon{color:var(--text3);font-size:1rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:999;display:flex;align-items:center;justify-content:center;padding:20px}.modal-box{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:32px;width:100%;max-width:584px;box-shadow:0 24px 60px #00000080;position:relative;max-height:90vh;overflow-y:auto}@media (max-width: 768px){.modal-box{margin-top:70px;max-width:95%;padding:14px;border-radius:16px}}@media (max-width: 480px){.modal-box{margin-top:50px;max-width:100%;padding:20px 16px;border-radius:14px}}@media (max-width: 360px){.modal-box{margin-top:50px;padding:16px 12px}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:1.2rem;font-weight:700}.modal-close{background:var(--bg3);border:1px solid var(--border);color:var(--text2);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.modal-close:hover{border-color:var(--red);color:var(--red)}.divider{height:1px;background:var(--border);margin:20px 0}.text-accent{color:var(--accent)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-muted{color:var(--text2)}.fw-bold{font-weight:700}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.text-center{text-align:center}.w-full{width:100%}.empty-state{text-align:center;padding:60px 20px;color:var(--text3)}.empty-state .empty-icon{font-size:3rem;margin-bottom:12px}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px;flex-direction:column;gap:12px}.loading-text{color:var(--text3);font-size:.9rem}.mobile-topbar{display:none;position:fixed;top:0;left:0;width:100%;height:60px;background:var(--bg2);border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;padding:0 12px;z-index:1200}.mobile-topbar .left,.mobile-topbar .right{display:flex;align-items:center;gap:10px}.menu-btn{background:var(--card);border:1px solid var(--border);width:34px;height:34px;border-radius:8px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center}.menu-btn:hover{border-color:var(--accent);color:var(--accent)}.theme-toggle{width:34px;height:34px;font-size:1rem}@media (max-width: 768px){.mobile-topbar{display:flex;position:fixed;top:0;left:0;width:100%;height:60px;background:var(--bg2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:0 12px;z-index:2000}.mobile-topbar .left,.mobile-topbar .right{display:flex;align-items:center;gap:10px}.menu-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--card);display:flex;align-items:center;justify-content:center}.mobile-logo img{width:80px;height:auto}.theme-toggle{width:34px;height:34px}}@media (max-width: 600px){.mobile-topbar{height:56px;padding:0 10px}.mobile-logo img{width:75px}}@media (max-width: 400px){.mobile-topbar{height:52px}.menu-btn,.theme-toggle{width:30px;height:30px}.mobile-logo img{width:65px}}.mobile-logo img{width:85px;height:auto;object-fit:contain}@media (max-width: 480px){.mobile-topbar{height:55px}.mobile-logo img{width:65px}.menu-btn,.theme-toggle{width:30px;height:30px}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-topbar{display:flex}}.chart-container{width:100%;height:clamp(220px,30vw,350px);min-height:220px}@media (max-width: 768px){.chart-container{height:240px}}@media (max-width: 480px){.chart-container{height:200px}}.hours-bar{height:8px;background:var(--bg3);border-radius:99px;overflow:hidden;margin-top:8px}.hours-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width 1s ease}.logo-img{width:98px;height:40px;object-fit:contain}
