*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--red: #c0392b;--red-dk: #96281b;--green: #27ae60;--blue: #2980b9;--yellow: #f39c12;--gray: #7f8c8d;--light: #f5f5f5;--white: #ffffff;--shadow: 0 2px 8px rgba(0,0,0,.12);--radius: 12px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--light);color:#2c3e50;min-height:100vh}.page{display:flex;flex-direction:column;min-height:100vh}.top-bar{display:flex;align-items:center;justify-content:space-between;background:var(--red);color:var(--white);padding:14px 16px;position:sticky;top:0;z-index:10;box-shadow:var(--shadow)}.greeting{font-weight:700;font-size:1rem;display:block}.matricule{font-size:.75rem;opacity:.85}.page-title{font-size:1.05rem;font-weight:700}.date-banner{background:var(--red-dk);color:var(--white);text-align:center;padding:6px;font-size:.82rem;letter-spacing:.04em;text-transform:capitalize}.btn-logout{background:#fff3;border:none;border-radius:50%;width:36px;height:36px;font-size:1.1rem;cursor:pointer;color:#fff}.btn-back{color:var(--white);text-decoration:none;font-size:.9rem;padding:4px 8px;border-radius:6px;background:#ffffff26}.card{margin:12px;background:var(--white);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.card-title{font-size:.95rem;font-weight:700;margin-bottom:12px;color:#333}.mvt-list{display:flex;flex-direction:column;gap:8px}.mvt-row{display:flex;align-items:center;gap:10px;padding:10px;background:var(--light);border-radius:8px}.mvt-heure{font-weight:700;font-size:.9rem;color:var(--red);min-width:50px}.mvt-info{flex:1;display:flex;flex-direction:column;gap:2px}.mvt-circuit{font-weight:600;font-size:.88rem}.mvt-vehicule{font-size:.78rem;color:var(--gray)}.mvt-badge{font-size:.72rem;background:var(--red);color:#fff;padding:2px 7px;border-radius:10px}.pointage-summary{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.p-type{padding:4px 12px;border-radius:20px;font-weight:700;font-size:.85rem;color:#fff}.p-type.arrivee{background:var(--green)}.p-type.depart{background:var(--red)}.p-type.pause_debut{background:var(--yellow);color:#333}.p-type.pause_fin{background:var(--blue)}.p-heure{font-size:.85rem;color:var(--gray)}.alert-badge{font-size:.8rem;background:#e74c3c;color:#fff;padding:2px 8px;border-radius:10px}.quick-nav{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:auto 12px 12px;padding-bottom:16px}.nav-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:20px 10px;border-radius:var(--radius);text-decoration:none;font-weight:700;font-size:.95rem;box-shadow:var(--shadow)}.nav-btn.primary{background:var(--red);color:#fff}.nav-btn.secondary{background:var(--white);color:var(--red);border:2px solid var(--red)}.nav-icon{font-size:1.6rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--red) 0%,var(--red-dk) 100%);padding:20px}.login-card{background:#fff;border-radius:20px;padding:32px 28px;width:100%;max-width:400px;box-shadow:0 8px 32px #0003}.logo-area{text-align:center;margin-bottom:28px}.logo-circle{font-size:3rem;margin-bottom:8px}.logo-area h1{font-size:1.8rem;font-weight:800;color:var(--red)}.logo-area p{color:var(--gray);font-size:.9rem}.form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-weight:600;font-size:.88rem;color:#333}.field input{padding:12px 14px;border:1.5px solid #ddd;border-radius:8px;font-size:1rem;outline:none;transition:border-color .2s}.field input:focus{border-color:var(--red)}.error-box{background:#fdecea;color:#c0392b;padding:10px 14px;border-radius:8px;font-size:.88rem;border-left:3px solid var(--red)}.btn-login{background:var(--red);color:#fff;border:none;padding:14px;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:background .2s;margin-top:4px}.btn-login:hover:not(:disabled){background:var(--red-dk)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.footer-txt{text-align:center;color:var(--gray);font-size:.78rem;margin-top:20px}.pointage-page{padding:12px;display:flex;flex-direction:column;gap:12px}.gps-status{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;font-weight:600;font-size:.9rem}.gps-wait{background:#fef9e7;color:#f39c12}.gps-ok{background:#eafaf1;color:#27ae60}.gps-error{background:#fdecea;color:#c0392b}.gps-icon{font-size:1.3rem}.coords-box{background:#fff;border-radius:10px;padding:14px;box-shadow:var(--shadow)}.coord-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.88rem;border-bottom:1px solid #f0f0f0}.coord-row:last-child{border-bottom:none}.type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.type-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 10px;background:#fff;border:2px solid #ddd;border-radius:12px;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:var(--shadow)}.type-btn.selected{border-color:var(--red);background:#fdecea;color:var(--red)}.type-icon{font-size:1.5rem}.btn-pointer{background:var(--red);color:#fff;border:none;padding:16px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;width:100%;box-shadow:var(--shadow)}.btn-pointer:disabled{opacity:.5;cursor:not-allowed}.result-box{padding:14px 16px;border-radius:10px;font-size:.9rem;font-weight:600}.result-box.ok{background:#eafaf1;color:#27ae60}.result-box.err{background:#fdecea;color:#c0392b}.result-box .warn{color:#e67e22;font-weight:500;font-size:.85rem;margin-top:6px}.histo-page{padding:12px}.histo-list{display:flex;flex-direction:column;gap:8px}.histo-row{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:10px;padding:12px 14px;box-shadow:var(--shadow)}.histo-row.hors-zone{border-left:3px solid #e74c3c}.histo-left{display:flex;flex-direction:column;gap:4px}.histo-type{font-size:.82rem;font-weight:700;padding:2px 8px;border-radius:10px;color:#fff;display:inline-block}.histo-type.arrivee{background:var(--green)}.histo-type.depart{background:var(--red)}.histo-type.pause_debut{background:var(--yellow);color:#333}.histo-type.pause_fin{background:var(--blue)}.histo-date{font-size:.8rem;color:var(--gray)}.histo-right{display:flex;gap:6px;font-size:1rem}.center-txt{text-align:center;padding:30px;color:var(--gray)}.muted{color:var(--gray)}
