*{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-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(108,99,255,.08) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(46,204,113,.05) 0%,transparent 50%);animation:float 8s ease-in-out infinite}.login-container{background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:40px 32px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideUp .6s ease}@supports (backdrop-filter: blur(20px)){.login-container{background:#ffffffeb}}.login-header{text-align:center;margin-bottom:32px}.login-logo{font-size:3.5rem;margin-bottom:12px;display:inline-block;animation:float 3s ease-in-out infinite}.login-header h1{font-size:1.4rem;color:var(--text);font-weight:700}.login-header p{color:var(--text-light);margin-top:6px;font-size:.9rem}.login-form{animation:fadeIn .6s ease .2s both}.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}}@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}@supports (backdrop-filter: blur(20px)){.login-container{background:#1a1a2eeb}}.login-header h1{color:#e8e8f0}.stat-card,.table-container{background:var(--card-bg)}}
