*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--primary: #6c63ff;--primary-dark: #5a52d5;--primary-light: #8b85ff;--primary-gradient: linear-gradient(135deg, #6c63ff 0%, #4834d4 100%);--success: #2ecc71;--success-dark: #27ae60;--danger: #e74c3c;--danger-dark: #c0392b;--warning: #f39c12;--warning-dark: #d68910;--bg: #f0f2f5;--card-bg: #ffffff;--text: #2c3e50;--text-secondary: #505965;--text-light: #7f8c8d;--border: #e1e8ed;--sidebar: #1a1a2e;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow: 0 2px 10px rgba(0,0,0,.08);--shadow-lg: 0 8px 30px rgba(0,0,0,.12);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans Arabic,Tahoma,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes checkIn{0%{transform:scale(1);box-shadow:0 0 #2ecc7166}50%{transform:scale(1.03);box-shadow:0 0 0 15px #2ecc7100}to{transform:scale(1);box-shadow:0 0 #2ecc7100}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-slide-up{animation:slideUp .5s ease forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}.loading-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:16px;background:var(--sidebar)}.loading-screen:before{content:"";width:48px;height:48px;border:4px solid rgba(108,99,255,.2);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-screen{color:#fff;font-size:1rem;font-weight:500}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:20px;position:relative;overflow:hidden}.login-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.login-particle{position:absolute;bottom:-20px;border-radius:50%;background:var(--primary);animation:particleRise linear infinite}@keyframes particleRise{0%{transform:translateY(0) scale(1);opacity:0}10%{opacity:.2}90%{opacity:.1}to{transform:translateY(-100vh) scale(.5);opacity:0}}.login-container{background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;padding:40px 32px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideUp .6s ease;border:1px solid rgba(255,255,255,.08)}@supports (backdrop-filter: blur(20px)){.login-container{background:#ffffffeb}}.login-header{text-align:center;margin-bottom:36px}.login-logo-wrap{position:relative;width:80px;height:80px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}.login-logo-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid rgba(108,99,255,.15);animation:logoSpin 8s linear infinite}.login-logo-ring:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px dashed rgba(108,99,255,.1);animation:logoSpin 12s linear infinite reverse}@keyframes logoSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-logo-inner{font-size:2.2rem;z-index:1;animation:float 3s ease-in-out infinite}.login-header h1{font-size:1.4rem;color:var(--text);font-weight:700;margin-bottom:6px}.login-header p{color:var(--text-light);font-size:.85rem}.login-form{animation:fadeIn .6s ease .2s both}.login-form .alert{display:flex;align-items:center;gap:8px}.remember-me{display:flex;align-items:center;gap:10px;margin-bottom:20px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.85rem;color:var(--text-secondary);position:relative;padding:4px 0}.remember-me input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.remember-checkmark{width:20px;height:20px;border-radius:6px;border:2px solid var(--border);background:var(--bg);transition:all .2s ease;flex-shrink:0;position:relative}.remember-me:hover .remember-checkmark{border-color:var(--primary)}.remember-me input:checked+.remember-checkmark{background:var(--primary-gradient);border-color:var(--primary)}.remember-me input:checked+.remember-checkmark:after{content:"";position:absolute;left:5px;top:2px;width:6px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.btn-login{position:relative;overflow:hidden;padding:16px;font-size:1rem;border-radius:14px}.btn-login:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .5s ease}.btn-login:hover:before{transform:translate(100%)}.btn-loading{display:flex;align-items:center;justify-content:center;gap:10px}.btn-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.login-logo-img{width:56px;height:56px;border-radius:14px;z-index:1;animation:float 3s ease-in-out infinite}.app-footer{text-align:center;padding:20px 16px 10px;margin-top:10px}.footer-line{display:block;width:40px;height:2px;margin:0 auto 12px;background:linear-gradient(90deg,transparent,var(--primary),transparent);border-radius:1px;animation:footerPulse 2s ease-in-out infinite}@keyframes footerPulse{0%,to{width:40px;opacity:.5}50%{width:80px;opacity:1}}.footer-text{font-size:.75rem;color:var(--text-light);letter-spacing:.3px;font-weight:400;animation:footerFade 1s ease}@keyframes footerFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.footer-highlight{font-weight:700;background:linear-gradient(135deg,#6c63ff,#e74c3c,#f39c12);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:footerShift 3s ease infinite;background-size:200% auto}@keyframes footerShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.footer-year{color:var(--text-light);font-weight:400}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:.85rem;color:var(--text)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:14px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;transition:all .25s ease;font-family:inherit;background:#fafbfc;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #6c63ff1a;background:#fff}.form-group input::placeholder{color:#b0b8c1}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.form-card{margin-bottom:20px;animation:slideUp .4s ease}.form-card h3{margin-bottom:16px;font-size:1.1rem}.btn{padding:12px 24px;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .25s ease;font-family:inherit;position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:44px;-webkit-user-select:none;user-select:none}.btn:active:not(:disabled){transform:scale(.96)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 14px #6c63ff59}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #6c63ff73;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,var(--success) 0%,#27ae60 100%);color:#fff;box-shadow:0 4px 14px #2ecc7159}.btn-success:hover:not(:disabled){box-shadow:0 6px 20px #2ecc7173;transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,var(--danger) 0%,var(--danger-dark) 100%);color:#fff;box-shadow:0 4px 14px #e74c3c4d}.btn-danger:hover:not(:disabled){box-shadow:0 6px 20px #e74c3c66;transform:translateY(-1px)}.btn-warning{background:linear-gradient(135deg,var(--warning) 0%,var(--warning-dark) 100%);color:#fff}.btn-outline{background:transparent;border:2px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:#6c63ff0a}.btn-sm{padding:8px 14px;font-size:.8rem;min-height:36px}.btn-lg{padding:16px 28px;font-size:1.05rem;border-radius:var(--radius);min-height:52px}.btn-block{width:100%}.alert{padding:14px 18px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:.9rem;animation:slideUp .3s ease}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.alert-warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.text-center{text-align:center}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.dashboard{max-width:960px;margin:0 auto;padding:16px 16px 90px;animation:fadeIn .3s ease}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 20px;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}@supports (backdrop-filter: blur(12px)){.dashboard-header{background:#ffffffeb}}.dashboard-header h1{font-size:1.15rem;font-weight:700}.header-left{display:flex;align-items:center;gap:8px}.header-left span{color:var(--text-light);font-size:.85rem;display:none}.last-updated{display:block;font-size:.7rem;color:var(--text-light);margin-top:2px;direction:ltr;text-align:right}.card{background:var(--card-bg);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:16px;transition:transform .2s ease,box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-lg)}.attendance-card{text-align:center;animation:slideUp .5s ease;background:linear-gradient(135deg,#f8f9ff,#fff);border:1px solid rgba(108,99,255,.08)}.attendance-card h2{margin-bottom:20px;font-size:1.2rem;color:var(--text)}.attendance-info{margin-top:16px}.time-display{display:flex;justify-content:space-around;margin-bottom:20px;gap:8px}.time-item{text-align:center;flex:1;padding:12px 8px;background:#6c63ff0a;border-radius:var(--radius-sm)}.time-label{display:block;font-size:.78rem;color:var(--text-light);margin-bottom:6px;font-weight:500}.time-value{display:block;font-size:1.15rem;font-weight:700;color:var(--text)}.tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--card-bg);border-radius:var(--radius);padding:4px;box-shadow:var(--shadow);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex:1;padding:12px 14px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-light);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit;white-space:nowrap;min-height:44px}.tab.active{background:var(--primary-gradient);color:#fff;box-shadow:0 2px 8px #6c63ff4d}.tab:hover:not(.active){background:var(--bg)}.tab-content{min-height:200px;animation:fadeIn .3s ease}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{font-size:1.1rem;font-weight:700}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px}.table-container::-webkit-scrollbar{height:4px}.table-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}table{width:100%;border-collapse:collapse;min-width:600px}th{background:var(--bg);padding:14px 16px;font-size:.8rem;color:var(--text-light);font-weight:700;text-align:right;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}td{padding:14px 16px;border-top:1px solid var(--border);font-size:.88rem}tr{transition:background .2s ease}tr:hover td{background:#f8f9fa}tr:last-child td:first-child{border-radius:0 0 0 var(--radius)}tr:last-child td:last-child{border-radius:0 0 var(--radius) 0}.badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600;white-space:nowrap}.badge-success{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:#155724}.badge-danger{background:linear-gradient(135deg,#fde8e8,#f5c6cb);color:#991b1b}.badge-warning{background:linear-gradient(135deg,#fff3cd,#ffeeba);color:#856404}.attendance-summary{display:flex;gap:12px;margin-bottom:16px}.stat-card{flex:1;background:var(--card-bg);padding:16px 12px;border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;transition:transform .2s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary-gradient)}.stat-card:active{transform:scale(.96)}.stat-number{display:block;font-size:1.8rem;font-weight:800;color:var(--primary);line-height:1.2}.stat-label{display:block;font-size:.75rem;color:var(--text-light);margin-top:4px;font-weight:500}.geo-card{border-radius:var(--radius-sm);padding:14px 16px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;animation:slideUp .4s ease}.geo-success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0}.geo-error{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca}.geo-warning{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a}.geo-icon{font-size:1.5rem;flex-shrink:0}.geo-info{flex:1;min-width:180px}.geo-info p{font-size:.82rem;margin-bottom:2px}.geo-status{font-weight:600;font-size:.82rem}.date-input{padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;background:#fafbfc;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.date-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #6c63ff1a}.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.summary-card{background:var(--card-bg);border-radius:var(--radius);padding:14px 12px;box-shadow:var(--shadow);text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px;transition:transform .2s ease,box-shadow .2s ease;animation:slideUp .4s ease both}.summary-card:nth-child(1){animation-delay:.05s}.summary-card:nth-child(2){animation-delay:.1s}.summary-card:nth-child(3){animation-delay:.15s}.summary-card:nth-child(4){animation-delay:.2s}.summary-card:active{transform:scale(.95)}.summary-icon{font-size:1.5rem}.summary-label{font-size:.7rem;color:var(--text-light);font-weight:500}.summary-value{font-size:1rem;font-weight:700;color:var(--primary);direction:ltr}.records-list{display:flex;flex-direction:column;gap:10px}.record-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;animation:slideUp .3s ease}.record-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg);border-bottom:1px solid var(--border)}.record-date{font-weight:700;font-size:.85rem;color:var(--text)}.record-total{font-weight:800;font-size:1rem;color:var(--success)}.record-card-body{padding:12px 16px;display:flex;gap:8px;flex-wrap:wrap}.record-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.record-stat{flex:1;min-width:80px;display:flex;flex-direction:column;gap:2px}.record-stat-full{grid-column:1 / -1}.record-stat-label{font-size:.72rem;color:var(--text-light);font-weight:500}.record-stat-value{font-size:.88rem;font-weight:600;color:var(--text);direction:ltr}.record-reason{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.today-card{padding:0;overflow:hidden}.today-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg);border-bottom:1px solid var(--border)}.today-date{font-weight:700;font-size:.9rem}.today-body{padding:4px 0}.today-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border)}.today-row:last-child{border-bottom:none}.today-row-label{font-size:.85rem;color:var(--text-light);font-weight:500}.today-row-left{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.today-time{font-size:.95rem;font-weight:700;color:var(--text);direction:ltr}.today-location{font-size:.7rem;color:var(--text-light);direction:ltr}.today-total{background:#6c63ff0a}.today-total .today-row-label{color:var(--primary);font-weight:700}.today-total .today-time{color:var(--primary);font-size:1.05rem}.empty-state{text-align:center;padding:40px 20px;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);animation:fadeIn .4s ease}.empty-icon{font-size:3rem;display:block;margin-bottom:12px}.empty-state p{color:var(--text-light);font-size:.95rem}.empty-hint{font-size:.8rem!important;margin-top:4px;opacity:.7}.detail-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}.detail-row:last-child{border-bottom:none}.detail-row span:first-child{color:var(--text-light);font-size:.85rem}.detail-row span:last-child{font-weight:600;font-size:.9rem}.btn-check-in{animation:checkIn 2s ease-in-out infinite}@media (max-width: 768px){.summary-grid{grid-template-columns:repeat(2,1fr);gap:8px}.summary-card{padding:12px 8px}.summary-icon{font-size:1.2rem}.summary-value{font-size:.9rem}.record-card-grid{grid-template-columns:1fr 1fr}:root{--radius: 10px;--radius-sm: 6px;--radius-lg: 14px}.dashboard{padding:10px 10px 80px}.dashboard-header{padding:12px 16px;flex-wrap:wrap;gap:8px}.dashboard-header h1{font-size:1rem}.login-container{padding:32px 24px;margin:16px}.login-logo{font-size:3rem}.login-header h1{font-size:1.2rem}.form-row{flex-direction:column;gap:0}.form-group input,.form-group textarea,.form-group select{padding:12px 14px;font-size:16px}.btn{padding:14px 20px;min-height:48px}.btn-sm{padding:8px 12px;min-height:36px}.tabs{padding:3px;gap:3px}.tab{padding:10px;font-size:.8rem;min-height:40px}.attendance-summary{flex-direction:column;gap:8px}.stat-card{padding:14px 12px;display:flex;align-items:center;justify-content:center;gap:8px}.stat-card:before{display:none}.stat-number{font-size:1.4rem}.time-display{flex-direction:column;gap:8px}.time-item{padding:10px;display:flex;justify-content:space-between;align-items:center}.time-label{margin-bottom:0}.card{padding:16px}.section-header{flex-wrap:wrap;gap:8px}.section-header h2{font-size:1rem}th,td{padding:10px 12px;font-size:.82rem}.header-left span{display:none}.geo-card{flex-direction:column;align-items:flex-start}.geo-info{min-width:100%}}@media (max-width: 400px){.dashboard{padding:8px 8px 76px}.dashboard-header h1{font-size:.9rem}.tab{font-size:.75rem;padding:8px}.table-container{border-radius:var(--radius-sm)}th,td{padding:8px 10px;font-size:.78rem}.btn{font-size:.85rem;padding:12px 16px}.btn-lg{padding:14px 20px;min-height:48px}.login-container{padding:24px 20px}}@supports (padding: env(safe-area-inset-bottom)){.dashboard{padding-bottom:calc(80px + env(safe-area-inset-bottom))}}@media (orientation: landscape) and (max-height: 500px){.login-page{padding:10px}.login-container{padding:20px;max-width:360px}.login-logo{font-size:2rem;margin-bottom:8px}.login-header{margin-bottom:16px}.login-header h1{font-size:1rem}.dashboard-header{position:static}}.premium-attendance{position:relative;border-radius:20px;padding:28px 20px;margin-bottom:18px;overflow:hidden;min-height:200px;animation:slideUp .5s ease}.premium-attendance.no-record{background:linear-gradient(145deg,#1a1a2e,#16213e)}.premium-attendance:not(.no-record){background:linear-gradient(145deg,#1a1a3e,#0d1b2a)}.premium-att-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 0%,rgba(108,99,255,.12) 0%,transparent 60%),radial-gradient(ellipse at 80% 100%,rgba(46,204,113,.06) 0%,transparent 50%);pointer-events:none}.premium-geo-lock{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 0;color:#e8e8f0;text-align:center}.premium-lock-icon{font-size:2.5rem;animation:float 3s ease-in-out infinite}.premium-geo-lock p{font-size:.9rem;opacity:.8}.premium-body{position:relative;display:flex;flex-direction:column;gap:18px}.premium-shift-info{display:flex;justify-content:space-between;align-items:center}.premium-shift-badge{display:flex;flex-direction:column;gap:2px}.premium-shift-badge span{font-size:.7rem;color:#ffffff80;text-transform:uppercase;letter-spacing:1px}.premium-shift-badge strong{font-size:1rem;color:#e8e8f0;font-weight:700}.premium-status-badge{padding:6px 16px;border-radius:20px;font-size:.85rem;font-weight:700}.premium-status-badge.present{background:#2ecc7126;color:#2ecc71;border:1px solid rgba(46,204,113,.3)}.premium-status-badge.late{background:#e74c3c26;color:#e74c3c;border:1px solid rgba(231,76,60,.3)}.premium-times{display:flex;align-items:center;justify-content:center;gap:20px;padding:16px;background:#ffffff0f;border-radius:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.premium-time-block{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.premium-time-label{font-size:.7rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.premium-time-value{font-size:1.3rem;font-weight:800;color:#fff;direction:ltr;font-variant-numeric:tabular-nums}.premium-time-divider{width:1px;height:40px;background:#ffffff1a}.premium-late-badge{font-size:.7rem;color:#e74c3c;font-weight:600}.premium-check-in-btn{position:relative;width:120px;height:120px;border:none;background:transparent;cursor:pointer;margin:0 auto;padding:0;-webkit-tap-highlight-color:transparent}.premium-btn-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid rgba(46,204,113,.3);animation:premiumPulse 2s ease-in-out infinite}.premium-btn-inner{position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:50%;background:linear-gradient(145deg,#2ecc71,#27ae60);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;box-shadow:0 4px 20px #2ecc7166;transition:transform .2s ease}.premium-check-in-btn:hover .premium-btn-inner{transform:scale(1.05)}.premium-check-in-btn:active .premium-btn-inner{transform:scale(.95)}.premium-check-in-btn:disabled{opacity:.5;cursor:not-allowed}.premium-btn-icon{font-size:1.5rem}.premium-btn-text{font-size:.7rem;font-weight:700;color:#fff}@keyframes premiumPulse{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.15);opacity:.6}}.premium-checkout-btn{width:100%;padding:16px;border:none;border-radius:14px;background:linear-gradient(145deg,#e74c3c,#c0392b);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 16px #e74c3c59;font-family:inherit}.premium-checkout-btn:active{transform:scale(.97)}.premium-checkout-btn:disabled{opacity:.5;cursor:not-allowed}.premium-progress-wrap{padding:12px 0}.premium-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.premium-progress-header span{font-size:.78rem;color:#fff9}.premium-progress-header strong{font-size:.85rem;color:#f39c12;font-weight:700}.premium-progress-bar{position:relative;height:6px;background:#ffffff1a;border-radius:3px;overflow:visible}.premium-progress-fill{height:100%;background:linear-gradient(90deg,#2ecc71,#f39c12);border-radius:3px;transition:width 1s ease;position:relative}.premium-progress-glow{position:absolute;top:-2px;width:10px;height:10px;border-radius:50%;background:#f39c12;transform:translate(-50%);box-shadow:0 0 8px #f39c1299;transition:left 1s ease}.premium-progress-labels{display:flex;justify-content:space-between;margin-top:4px}.premium-progress-labels span{font-size:.65rem;color:#ffffff59;direction:ltr}.premium-hours{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#2ecc7114;border-radius:12px;border:1px solid rgba(46,204,113,.15)}.premium-hours span{font-size:.85rem;color:#ffffffb3}.premium-hours strong{font-size:1.1rem;color:#2ecc71;font-weight:800;direction:ltr}.premium-geo-indicator{position:absolute;top:12px;left:14px;display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:.7rem;font-weight:600}.premium-geo-indicator.ok{background:#2ecc711f;color:#2ecc71}.premium-geo-indicator.ko{background:#e74c3c1f;color:#e74c3c}.premium-geo-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:geoBlink 2s ease-in-out infinite}@keyframes geoBlink{0%,to{opacity:1}50%{opacity:.3}}.premium-geo-hint{font-size:.75rem;color:#ffffff80;margin-top:-8px}.premium-out-of-range{text-align:center;font-size:.8rem;color:#e74c3c;background:#e74c3c14;padding:8px 12px;border-radius:10px}.premium-loader{width:28px;height:28px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@media (prefers-color-scheme: dark){:root{--bg: #0f0f1a;--card-bg: #1a1a2e;--text: #e8e8f0;--text-secondary: #b8b8c8;--text-light: #8888a0;--border: #2a2a40;--shadow: 0 2px 10px rgba(0,0,0,.3);--shadow-lg: 0 8px 30px rgba(0,0,0,.4)}@supports (backdrop-filter: blur(12px)){.dashboard-header{background:#1a1a2eeb}}body{background:var(--bg)}.attendance-card{background:linear-gradient(135deg,rgba(108,99,255,.06) 0%,var(--card-bg) 100%)}.form-group input,.form-group textarea,.form-group select{background:#12122a;border-color:var(--border);color:var(--text)}.form-group input:focus,.form-group textarea:focus{background:#181838}.date-input{background:#12122a;color:var(--text)}th{background:#12122a}tr:hover td{background:#6c63ff0a}.time-item{background:#6c63ff0f}.btn-outline{border-color:var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:#6c63ff1a}.login-container{background:#1a1a2ef5;border-color:#ffffff0a}@supports (backdrop-filter: blur(20px)){.login-container{background:#1a1a2eeb}}.login-header h1{color:#e8e8f0}.remember-checkmark{background:#12122a;border-color:var(--border)}.footer-year{color:#fff6}.footer-text{color:#ffffff80}.stat-card,.table-container{background:var(--card-bg)}}
