@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--primary:#7857db;--primary-hover:#562dd2;--primary-light:#f1eefb;--bg-app:#f6f7f9;--bg-card:#fff;--text-main:#1d2330;--text-muted:#6c7993;--text-inverse:#fff;--success:#25b15f;--success-light:#eefbf4;--danger:#df2030;--danger-light:#fcedee;--warning:#f2930d;--warning-light:#fef6ec;--border:#e2e4e9;--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--shadow-sm:0 2px 8px #1217210a;--shadow-md:0 6px 16px #12172114;--shadow-lg:0 12px 28px #1217211f;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-circle:50%}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-app);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}.app-container{flex-direction:column;justify-content:flex-start;align-items:center;width:100%;min-height:100vh;padding:0;display:flex}.mobile-view{background-color:var(--bg-app);flex-direction:column;width:100%;max-width:480px;min-height:100vh;display:flex;position:relative}h1,h2,h3,h4{letter-spacing:-.02em;font-weight:600}.login-screen{background-color:var(--bg-card);flex-direction:column;flex:1;justify-content:center;padding:24px;display:flex}.login-header{text-align:center;margin-bottom:40px}.logo-icon{background:linear-gradient(135deg, var(--primary), #af57db);width:64px;height:64px;color:var(--text-inverse);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);justify-content:center;align-items:center;margin:0 auto 16px;font-size:24px;font-weight:700;display:flex}.login-header h2{color:var(--text-main);margin-bottom:8px;font-size:24px}.login-header p{color:var(--text-muted);font-size:14px}.form-group{flex-direction:column;margin-bottom:20px;display:flex}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:13px;font-weight:500}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:14px}.form-control{width:100%;font-family:var(--font-sans);color:var(--text-main);background-color:var(--bg-app);border:1px solid var(--border);border-radius:var(--radius-md);outline:none;padding:12px 14px 12px 42px;font-size:15px;transition:border-color .2s,background-color .2s}.form-control:focus{border-color:var(--primary);background-color:var(--bg-card)}.forgot-password-link{color:var(--primary);align-self:flex-end;margin-bottom:24px;font-size:13px;font-weight:500;text-decoration:none}.btn{font-family:var(--font-sans);color:var(--text-inverse);background-color:var(--primary);border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;transition:background-color .2s,transform .1s;display:inline-flex}.btn:active{transform:scale(.98)}.btn:hover{background-color:var(--primary-hover)}.btn:disabled{background-color:var(--border);color:var(--text-muted);cursor:not-allowed;transform:none}.btn-secondary{background-color:var(--border);color:var(--text-main)}.btn-secondary:hover{background-color:#cacfd8}.btn-danger{background-color:var(--danger)}.btn-danger:hover{background-color:#bb1b28}.btn-success{background-color:var(--success)}.btn-success:hover{background-color:#1e8f4d}.dashboard-view{flex-direction:column;flex:1;gap:16px;padding:16px;display:flex}.profile-bar{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:16px;display:flex}.profile-info{flex-direction:column;display:flex}.profile-info h3{color:var(--text-main);margin-bottom:2px;font-size:18px}.profile-info span{color:var(--text-muted);font-size:12px;font-weight:500}.logout-btn{color:var(--danger);border-radius:var(--radius-md);cursor:pointer;background:0 0;background-color:var(--danger-light);border:none;justify-content:center;align-items:center;width:38px;height:38px;transition:background-color .2s;display:flex}.logout-btn:hover{background-color:#f9d2d6}.attendance-hud{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:center;flex-direction:column;align-items:center;padding:24px;display:flex}.date-display{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:14px;font-weight:600}.time-display{color:var(--text-main);margin-bottom:20px;font-size:28px;font-weight:700}.action-card{flex-direction:column;align-items:center;width:100%;margin-bottom:20px;display:flex}.action-btn{border-radius:var(--radius-circle);width:130px;height:130px;color:var(--text-inverse);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;border:none;flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:16px;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 8px 24px #7857db4d}.action-btn:active{transform:scale(.96)}.btn-check-in{background:linear-gradient(135deg, var(--primary), #8d52e0)}.btn-lunch-out{background:linear-gradient(135deg, var(--warning), #f46a25);box-shadow:0 8px 24px #f2930d4d}.btn-lunch-in{background:linear-gradient(135deg, var(--primary), #5269e0)}.btn-check-out{background:linear-gradient(135deg, var(--danger), #e8306e);box-shadow:0 8px 24px #df20304d}.btn-completed{background:var(--success-light);color:var(--success);box-shadow:none;cursor:default}.completed-state{color:var(--success);flex-direction:column;align-items:center;gap:12px;padding:20px 0;font-size:18px;font-weight:600;display:flex}.completed-icon{border-radius:var(--radius-circle);background-color:var(--success-light);border:2px solid var(--success);justify-content:center;align-items:center;width:64px;height:64px;font-size:28px;display:flex}.sequence-hud{border-top:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:8px;width:100%;margin-top:24px;padding-top:16px;display:grid}.sequence-step{color:var(--text-muted);flex-direction:column;align-items:center;gap:6px;font-size:10px;font-weight:600;display:flex}.step-indicator{border-radius:var(--radius-circle);background-color:var(--border);width:24px;height:24px;color:var(--text-muted);justify-content:center;align-items:center;font-size:11px;display:flex}.sequence-step.active{color:var(--primary)}.sequence-step.active .step-indicator{background-color:var(--primary-light);color:var(--primary);border:1.5px solid var(--primary)}.sequence-step.completed{color:var(--success)}.sequence-step.completed .step-indicator{background-color:var(--success-light);color:var(--success)}.gps-board{background-color:var(--primary-light);border-radius:var(--radius-md);color:var(--primary);border:1px solid #ddd5f6;align-items:center;gap:12px;width:100%;margin-top:16px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.gps-error-alert{background-color:var(--danger-light);border-radius:var(--radius-md);color:var(--danger);text-align:left;border:1px solid #f9d2d6;align-items:center;gap:12px;width:100%;margin-top:16px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.history-card{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;flex:1;padding:20px;display:flex}.history-card h3{color:var(--text-main);margin-bottom:14px;font-size:16px}.history-list{flex-direction:column;gap:12px;max-height:350px;display:flex;overflow-y:auto}.history-item{border:1px solid var(--border);border-radius:var(--radius-md);background-color:var(--bg-card);flex-direction:column;padding:12px 16px;display:flex}.history-item-header{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:6px;display:flex}.history-date{color:var(--text-main);font-size:14px;font-weight:600}.history-hours{color:var(--success);background-color:var(--success-light);border-radius:var(--radius-sm);padding:2px 6px;font-size:12px;font-weight:500}.history-grid{grid-template-columns:repeat(2,1fr);gap:8px 16px;display:grid}.history-time-col{flex-direction:column;display:flex}.time-label{color:var(--text-muted);text-transform:uppercase;font-size:10px;font-weight:500}.time-val{color:var(--text-main);font-size:12px;font-weight:500}.late-tag{color:var(--warning);background-color:var(--warning-light);border-radius:var(--radius-sm);margin-left:6px;padding:1px 4px;font-size:10px;font-weight:600}.toast{background-color:var(--text-main);color:var(--text-inverse);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:2000;text-align:center;pointer-events:none;max-width:90%;padding:12px 24px;font-size:14px;font-weight:500;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.admin-layout{background-color:var(--bg-app);flex-direction:column;width:100%;min-height:100vh;display:flex}.admin-header{background-color:var(--bg-card);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:14px 24px;display:flex;position:sticky;top:0}.admin-brand{color:var(--text-main);align-items:center;gap:10px;font-size:18px;font-weight:700;display:flex}.admin-brand .badge{background-color:var(--primary-light);color:var(--primary);border-radius:var(--radius-sm);text-transform:uppercase;padding:3px 8px;font-size:11px;font-weight:600}.admin-nav{background-color:var(--bg-card);border-bottom:1px solid var(--border);z-index:99;display:flex;position:sticky;top:60px;overflow-x:auto}.admin-nav-item{font-family:var(--font-sans);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:8px;padding:16px 20px;font-size:13px;font-weight:600;transition:color .2s,border-color .2s;display:flex}.admin-nav-item:hover{color:var(--text-main)}.admin-nav-item.active{color:var(--primary);border-bottom-color:var(--primary)}.admin-content{flex-direction:column;flex:1;gap:24px;width:100%;max-width:1200px;margin:0 auto;padding:24px;display:flex}.stats-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (width>=768px){.stats-grid{grid-template-columns:repeat(6,1fr)}}.stat-card{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:6px;padding:20px;display:flex}.stat-card-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.stat-card-value{color:var(--text-main);font-size:24px;font-weight:700}.stat-card.primary{border-left:4px solid var(--primary)}.stat-card.success{border-left:4px solid var(--success)}.stat-card.danger{border-left:4px solid var(--danger)}.stat-card.warning{border-left:4px solid var(--warning)}.activity-feed-card{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;padding:24px;display:flex}.activity-feed-list{flex-direction:column;gap:14px;margin-top:16px;display:flex}.activity-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:12px;font-size:13px;display:flex}.activity-meta{align-items:center;gap:12px;display:flex}.activity-avatar{border-radius:var(--radius-circle);background-color:var(--primary-light);width:36px;height:36px;color:var(--primary);justify-content:center;align-items:center;font-weight:600;display:flex}.activity-text h4{color:var(--text-main);font-size:14px}.activity-text span{color:var(--text-muted);font-size:11px}.activity-badge{border-radius:var(--radius-sm);padding:4px 10px;font-size:11px;font-weight:600}.badge-in{background-color:var(--primary-light);color:var(--primary)}.badge-out-l{background-color:var(--warning-light);color:var(--warning)}.badge-in-l{background-color:var(--primary-light);color:var(--primary)}.badge-out{background-color:var(--danger-light);color:var(--danger)}.table-card{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.table-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.table-responsive{width:100%;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%;font-size:13.5px}.data-table th{background-color:var(--bg-app);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:14px 20px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-main);vertical-align:middle;padding:14px 20px}.data-table tr:hover{background-color:#f9fafb}.status-pill{border-radius:var(--radius-sm);text-transform:uppercase;padding:3px 8px;font-size:11px;font-weight:600}.status-pill.active{background-color:var(--success-light);color:var(--success)}.status-pill.inactive{background-color:var(--danger-light);color:var(--danger)}.filter-bar{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);grid-template-columns:1fr;gap:16px;padding:20px;display:grid}@media (width>=768px){.filter-bar{grid-template-columns:repeat(5,1fr)}}.filter-group{flex-direction:column;gap:6px;display:flex}.filter-group label{color:var(--text-muted);text-transform:uppercase;font-size:11px;font-weight:600}.filter-control{font-family:var(--font-sans);border:1px solid var(--border);border-radius:var(--radius-md);background-color:var(--bg-app);outline:none;padding:10px 12px;font-size:13.5px}.filter-control:focus{border-color:var(--primary);background-color:var(--bg-card)}.modal-backdrop{z-index:1000;background-color:#13172066;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:540px;max-height:90vh;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-body{flex-direction:column;gap:16px;padding:24px;display:flex;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.form-grid{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=768px){.form-grid{grid-template-columns:repeat(2,1fr)}}.map-link{color:var(--primary);align-items:center;gap:4px;font-weight:500;text-decoration:none;display:inline-flex}.map-link:hover{text-decoration:underline}@media print{body{color:#000;background-color:#fff;font-size:12pt}.admin-layout,.admin-header,.admin-nav,.admin-content,.filter-bar,.table-header,.btn,.logout-btn{display:none!important}.print-only{width:100%;display:block!important}.print-page{page-break-after:always;padding:20mm}}
