*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #10b981;--green-dark: #059669;--red: #ef4444;--red-dark: #dc2626;--yellow: #f59e0b;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-500: #6b7280;--gray-700: #374151;--gray-900: #111827;--blue: #3b82f6;--radius: 12px;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1)}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gray-50);color:var(--gray-900);min-height:100dvh;-webkit-font-smoothing:antialiased}.loading-screen,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;gap:16px}.spinner{width:40px;height:40px;border:4px solid var(--gray-200);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-container{max-width:480px;margin:0 auto;padding-bottom:80px;min-height:100dvh}.page-header{background:#fff;padding:16px 20px;border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:10}.page-header h1{font-size:18px;font-weight:700}.page-header .subtitle{font-size:13px;color:var(--gray-500)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--gray-200);display:flex;justify-content:space-around;padding:8px 0 max(8px,env(safe-area-inset-bottom));z-index:100;max-width:480px;margin:0 auto}.nav-item{display:flex;flex-direction:column;align-items:center;text-decoration:none;color:var(--gray-500);font-size:11px;gap:4px;padding:4px 12px;border-radius:8px;transition:color .15s;border:none;background:none;cursor:pointer}.nav-item.active{color:var(--green)}.nav-item svg{width:24px;height:24px}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin:12px 16px;padding:16px}.card-title{font-size:14px;font-weight:600;color:var(--gray-700);margin-bottom:12px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;border-radius:20px;font-size:14px;font-weight:600}.status-badge.working{background:#d1fae5;color:var(--green-dark)}.status-badge.not-working{background:var(--gray-100);color:var(--gray-500)}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.working .status-dot{background:var(--green)}.not-working .status-dot{background:var(--gray-300);animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.punch-button{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:18px;border:none;border-radius:var(--radius);font-size:18px;font-weight:700;color:#fff;cursor:pointer;transition:transform .1s,box-shadow .15s;box-shadow:var(--shadow-lg)}.punch-button:active{transform:scale(.97)}.punch-button:disabled{opacity:.6;cursor:not-allowed}.punch-button.in{background:linear-gradient(135deg,var(--green),var(--green-dark))}.punch-button.out{background:linear-gradient(135deg,var(--red),var(--red-dark))}.punch-button.break{background:linear-gradient(135deg,var(--yellow),#d97706)}.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 16px}.stat-card{background:#fff;border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);text-align:center}.stat-value{font-size:24px;font-weight:700;color:var(--green)}.stat-label{font-size:12px;color:var(--gray-500);margin-top:4px}.progress-bar{height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden;margin:8px 0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--blue));border-radius:4px;transition:width .5s}.punch-list{list-style:none}.punch-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--gray-100)}.punch-item:last-child{border-bottom:none}.punch-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;font-weight:700;color:#fff}.punch-icon.in{background:var(--green)}.punch-icon.out{background:var(--red)}.punch-icon.break_start,.punch-icon.break_end{background:var(--yellow)}.punch-details{flex:1;min-width:0}.punch-time{font-size:15px;font-weight:600}.punch-address{font-size:12px;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.punch-meta{font-size:11px;color:var(--gray-500);margin-top:2px}.punch-status-tag{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600;text-transform:uppercase}.punch-status-tag.ok{background:#d1fae5;color:var(--green-dark)}.punch-status-tag.suspicious{background:#fef3c7;color:#92400e}.punch-status-tag.delayed_sync{background:#fee2e2;color:var(--red-dark)}.geofence-badge{font-size:11px;padding:2px 6px;border-radius:6px}.geofence-badge.inside{background:#d1fae5;color:var(--green-dark)}.geofence-badge.outside{background:#fee2e2;color:var(--red-dark)}.punch-result{margin:12px 16px;padding:16px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--green)}.punch-result.suspicious{border-left-color:var(--yellow)}.punch-result h3{font-size:15px;margin-bottom:8px}.punch-result-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;color:var(--gray-700)}.punch-result-row .label{color:var(--gray-500)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--gray-300);border-radius:8px;font-size:15px;outline:none;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--green)}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}.btn:disabled{opacity:.5}.btn-primary{background:var(--green);color:#fff}.btn-danger{background:var(--red);color:#fff}.btn-secondary{background:var(--gray-200);color:var(--gray-700)}.filters{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.filters input,.filters select{padding:8px 12px;border:1px solid var(--gray-300);border-radius:8px;font-size:13px;min-width:120px}.admin-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.admin-stat{padding:14px;border-radius:var(--radius);text-align:center}.admin-stat .value{font-size:28px;font-weight:700}.admin-stat .label{font-size:12px;color:var(--gray-500);margin-top:4px}.admin-stat.green{background:#d1fae5}.admin-stat.green .value{color:var(--green-dark)}.admin-stat.blue{background:#dbeafe}.admin-stat.blue .value{color:#1d4ed8}.admin-stat.yellow{background:#fef3c7}.admin-stat.yellow .value{color:#92400e}.admin-stat.gray{background:var(--gray-100)}.admin-stat.gray .value{color:var(--gray-700)}.tabs{display:flex;border-bottom:2px solid var(--gray-200);margin:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 12px;font-size:13px;font-weight:600;color:var(--gray-500);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s;white-space:nowrap;flex-shrink:0}.tab.active{color:var(--green);border-bottom-color:var(--green)}.simple-table{width:100%;font-size:13px}.simple-table th{text-align:left;padding:8px 4px;font-weight:600;color:var(--gray-500);border-bottom:1px solid var(--gray-200)}.simple-table td{padding:8px 4px;border-bottom:1px solid var(--gray-100)}.map-container{height:300px;border-radius:var(--radius);overflow:hidden;margin:12px 16px}.text-center{text-align:center}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.gap-2{gap:8px}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.empty-state{text-align:center;padding:40px 20px;color:var(--gray-500)}.gps-info{font-size:12px;color:var(--gray-500);margin-top:8px;padding:8px;background:var(--gray-50);border-radius:8px}.leaflet-container{width:100%;height:100%}
