*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,sans-serif;background-color:#f0f0f0;line-height:1.5}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;transition:all .3s ease}button:disabled{opacity:.6;cursor:not-allowed}.hero{min-height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;flex-direction:column;align-items:center;padding-top:1rem;padding-bottom:2rem;position:relative}.logo-overlay{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,0)}.logo-large{height:100px;object-fit:contain}.container{display:flex;flex-direction:column;gap:2rem;max-width:800px;width:100%;padding:0 1rem;margin-top:6rem}.card{background:rgba(255,255,255,.95);border-radius:12px;box-shadow:0 8px 16px #00000026;padding:2rem}h2,h3{margin-bottom:1rem;color:#003973}.form{display:flex;flex-direction:column;gap:.8rem}.form input{width:100%;padding:.6rem 1rem;border:1px solid #ccc;border-radius:8px;font-size:1rem}.form button{padding:.8rem 1.5rem;background:linear-gradient(to right,#4facfe 0%,#00f2fe 100%);border:none;border-radius:8px;color:#fff;font-weight:700;cursor:pointer;font-size:1rem;transition:all .3s ease}.form button:hover{opacity:.9}ul{list-style:none;padding-left:0;margin:0}li{padding:.5rem 0;border-bottom:1px solid #ddd}.section-label{font-weight:700;color:#222;margin-top:1.5rem;border-left:4px solid #00f2fe;padding-left:.5rem;font-size:1rem}.logo-large{height:200px;object-fit:contain;transition:transform .3s ease,opacity .3s ease;animation:fadeInLogo 1s ease forwards;opacity:0}.logo-large:hover{transform:scale(1.1)}@keyframes fadeInLogo{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}p{font-size:.95rem;margin:.5rem 0 1rem;padding:.75rem 1rem;border-radius:8px;background:#eef6ff;border-left:4px solid #4facfe;color:#003973}p.error{background:#ffeaea;border-left:4px solid #e53935;color:#b71c1c}p.success{background:#e8f5e9;border-left:4px solid #43a047;color:#2e7d32}.geo-status{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1rem}.geo-btn{background:#f0f8ff;border:1px solid #4facfe;color:#003973;padding:.5rem 1rem;border-radius:8px;font-weight:700;cursor:pointer;transition:all .3s ease}.geo-btn:hover{background:#d6ecff;border-color:#00c6ff;color:#000}.fieldset-block{border-left:4px solid #3b82f6;padding-left:1rem;margin-bottom:1.5rem;background-color:#fff;border-radius:8px;box-shadow:0 1px 2px #0000000d}.fieldset-block legend{font-weight:700;color:#003973;padding:0 .5rem;font-size:1rem}.fieldset-block input,.fieldset-block select{display:block;width:100%;box-sizing:border-box;padding:.6rem 1rem;font-size:1rem;margin-top:.5rem;margin-bottom:.8rem;border:1px solid #ccc;border-radius:8px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}}.factura-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 768px){.factura-grid{grid-template-columns:1fr}}.servicios-fecha{font-weight:700;margin:1.5rem 0 .5rem;color:#003973;border-left:4px solid #00c6ff;padding-left:.5rem}.servicio-card{background:white;border-radius:10px;padding:1rem 1.5rem;margin-bottom:1rem;box-shadow:0 4px 10px #0000001a;transition:transform .2s ease}.servicio-card:hover{transform:translateY(-3px)}.servicio-header{display:flex;justify-content:space-between;align-items:center}.servicio-info{margin-top:.5rem;font-size:.95rem;color:#333}.servicio-acciones{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.servicio-card[data-estado=registrado]{border-left:5px solid #ffb300}.servicio-card[data-estado=iniciado]{border-left:5px solid #43a047}.servicio-card[data-estado=finalizado]{border-left:5px solid #1e88e5}.servicio-card[data-estado=anulado]{border-left:5px solid #e53935}.servicio-btn{border:none;border-radius:6px;padding:.5rem 1rem;font-weight:700;color:#fff;cursor:pointer;transition:opacity .2s ease}.servicio-btn:hover{opacity:.85}.btn-iniciar{background:#43a047}.btn-anular{background:#e53935}.btn-detalle{background:#0288d1}.btn-hoja{background:#3949ab}.btn-modificar{background:#ffb300;color:#000}.layout{display:flex;width:100%;height:100vh;background:#f5f7fb;overflow:hidden}.sidebar{width:240px;height:100%;position:fixed;top:0;left:0;background:linear-gradient(to bottom,#003973,#00c6ff);color:#fff;display:flex;flex-direction:column;align-items:center;padding:1.5rem 1rem;border-right:1px solid rgba(255,255,255,.1);box-shadow:2px 0 8px #0000001a;overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:10}.sidebar-logo img{width:140px;max-width:100%;height:auto;margin-bottom:2rem}.sidebar nav ul{list-style:none;padding:0;width:100%}.sidebar nav ul li{margin-bottom:1rem}.sidebar nav ul li a{display:flex;align-items:center;padding:.75rem 1rem;border-radius:8px;font-weight:500;transition:background .3s ease;color:#fff}.sidebar nav ul li a:hover{background:rgba(255,255,255,.2)}.sidebar nav ul li a.active{background:rgba(255,255,255,.35);font-weight:700}.content{flex-grow:1;margin-left:240px;padding:2rem;background:#f5f7fb;overflow-y:auto;height:100vh;box-sizing:border-box}@media (max-width: 768px){.layout{flex-direction:column;height:auto}.sidebar{position:relative;width:100%;height:auto;flex-direction:row;justify-content:space-around;padding:.8rem;border-right:none;border-bottom:2px solid #00c6ff}.content{margin-left:0;padding:1rem;height:auto}.sidebar-logo img{display:none}.sidebar nav ul{display:flex;flex-wrap:wrap;justify-content:center}.sidebar nav ul li{margin:.3rem .8rem}}.react-calendar{border:none;width:100%}.react-calendar__tile.has-servicio{background:#3b82f6;color:#fff;border-radius:8px}.react-calendar__tile.has-servicio:hover{background:#2563eb}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:9999}.modal-content{background:white;border-radius:12px;padding:2rem;width:90%;max-width:500px;box-shadow:0 10px 20px #00000040;animation:modal-fade-in .3s ease}@keyframes modal-fade-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.45);display:flex;justify-content:center;align-items:center;z-index:2000}.modal-content{background:#fff;padding:1.5rem;border-radius:12px;max-width:500px;width:90%;box-shadow:0 8px 20px #0000004d;animation:fadeIn .3s ease-in-out}.modal-content h3{margin-top:0;margin-bottom:.5rem;color:#e53935}.modal-content p{margin:.3rem 0}.modal-content select,.modal-content textarea{width:100%;padding:.6rem;margin:.4rem 0 1rem;border-radius:8px;border:1px solid #ccc;font-size:.95rem}.modal-buttons{display:flex;justify-content:flex-end;gap:1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.selector-vehiculo{display:flex;align-items:center;justify-content:space-between;background:#ffffff;border:1px solid #e0e0e0;border-left:4px solid #00c6ff;border-radius:10px;padding:.75rem 1rem;margin-bottom:1.5rem;box-shadow:0 2px 6px #0000000d}.selector-vehiculo label{font-weight:600;color:#003973;font-size:1rem}.selector-vehiculo select{padding:.5rem 1rem;border-radius:8px;border:1px solid #ccc;background:#f9fbff;font-size:1rem;color:#003973;min-width:200px;cursor:pointer}.selector-vehiculo select:focus{outline:none;border-color:#00c6ff;box-shadow:0 0 0 2px #00c6ff33}.info-banner{background:linear-gradient(to right,#00c6ff,#0072ff);color:#fff;padding:.75rem 1rem;border-radius:8px;font-weight:500;margin-bottom:1rem;text-align:center;animation:fadeInBanner .4s ease-in-out}@keyframes fadeInBanner{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}form a[href="/forgot-password"]{color:#2563eb!important;font-weight:600;text-decoration:underline;display:block;margin-top:10px;font-size:.95rem}form a[href="/forgot-password"]:hover{opacity:.9;text-decoration:none}.btn-reenviar{background:linear-gradient(to right,#1e88e5,#00c6ff);color:#fff;font-weight:700;border:none;border-radius:6px;padding:.5rem 1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 3px 8px #00000026}.btn-reenviar:hover{background:linear-gradient(to right,#1565c0,#00a0e0);transform:translateY(-1px)}.onboarding-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:#f9fafb}.onboarding-card{background:#fff;max-width:900px;width:90%;padding:40px;border-radius:20px;box-shadow:0 4px 20px #00000014}.onboarding-title{text-align:center;font-size:28px;font-weight:700;color:#222;margin-bottom:40px}.contract-block{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:16px;padding:24px;margin-bottom:50px}.contract-title{color:#333;font-weight:600;margin-bottom:10px;font-size:18px}.contract-content{background:#fff;border:1px solid #ddd;border-radius:10px;padding:15px;height:250px;overflow-y:auto;font-size:14px;color:#333}.contract-hash{color:#666;display:block;margin-top:10px;font-size:13px}.contract-checkbox-label{display:flex;align-items:center;margin-top:10px;font-size:15px;color:#444}.contract-checkbox{width:20px;height:20px;margin-right:10px;accent-color:#16a34a;cursor:pointer}.button-container{text-align:center;margin-top:60px}.accept-button{background:linear-gradient(to right,#22c55e,#059669);color:#fff;font-size:20px;font-weight:700;padding:18px 80px;border:none;border-radius:16px;cursor:pointer;transition:transform .3s,box-shadow .3s}.accept-button:hover{transform:scale(1.05);box-shadow:0 6px 18px #0003}.accept-button.disabled{opacity:.6;cursor:not-allowed}.final-message{color:#16a34a;text-align:center;font-weight:600;margin-top:30px}.loading-text{padding:40px;text-align:center;font-size:18px}.progress-container{width:100%;background:#e5e7eb;border-radius:20px;height:18px;margin-bottom:10px;overflow:hidden;box-shadow:inset 0 1px 3px #00000026}.progress-bar{height:100%;transition:width .5s ease,background .5s ease}.progress-text{text-align:right;color:#374151;font-weight:500;font-size:14px;margin-bottom:40px}.progress-complete{text-align:center;margin-top:25px;animation:fade-in .6s ease-in-out}.checkmark{font-size:48px;line-height:1;animation:pop .4s ease-in-out}.complete-message{font-size:18px;color:#059669;font-weight:600;margin-top:8px}@keyframes pop{0%{transform:scale(.5);opacity:0}80%{transform:scale(1.2);opacity:1}to{transform:scale(1)}}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.react-calendar{width:350px;max-width:100%;background:white;border:1px solid #a0a096;font-family:Arial,Helvetica,sans-serif;line-height:1.125em}.react-calendar--doubleView{width:700px}.react-calendar--doubleView .react-calendar__viewContainer{display:flex;margin:-.5em}.react-calendar--doubleView .react-calendar__viewContainer>*{width:50%;margin:.5em}.react-calendar,.react-calendar *,.react-calendar *:before,.react-calendar *:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.react-calendar button{margin:0;border:0;outline:none}.react-calendar button:enabled:hover{cursor:pointer}.react-calendar__navigation{display:flex;height:44px;margin-bottom:1em}.react-calendar__navigation button{min-width:44px;background:none}.react-calendar__navigation button:disabled{background-color:#f0f0f0}.react-calendar__navigation button:enabled:hover,.react-calendar__navigation button:enabled:focus{background-color:#e6e6e6}.react-calendar__month-view__weekdays{text-align:center;text-transform:uppercase;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__weekdays__weekday{padding:.5em}.react-calendar__month-view__weekNumbers .react-calendar__tile{display:flex;align-items:center;justify-content:center;font:inherit;font-size:.75em;font-weight:700}.react-calendar__month-view__days__day--weekend{color:#d10000}.react-calendar__month-view__days__day--neighboringMonth,.react-calendar__decade-view__years__year--neighboringDecade,.react-calendar__century-view__decades__decade--neighboringCentury{color:#757575}.react-calendar__year-view .react-calendar__tile,.react-calendar__decade-view .react-calendar__tile,.react-calendar__century-view .react-calendar__tile{padding:2em .5em}.react-calendar__tile{max-width:100%;padding:10px 6.6667px;background:none;text-align:center;font:inherit;font-size:.833em}.react-calendar__tile:disabled{background-color:#f0f0f0;color:#ababab}.react-calendar__month-view__days__day--neighboringMonth:disabled,.react-calendar__decade-view__years__year--neighboringDecade:disabled,.react-calendar__century-view__decades__decade--neighboringCentury:disabled{color:#cdcdcd}.react-calendar__tile:enabled:hover,.react-calendar__tile:enabled:focus{background-color:#e6e6e6}.react-calendar__tile--now{background:#ffff76}.react-calendar__tile--now:enabled:hover,.react-calendar__tile--now:enabled:focus{background:#ffffa9}.react-calendar__tile--hasActive{background:#76baff}.react-calendar__tile--hasActive:enabled:hover,.react-calendar__tile--hasActive:enabled:focus{background:#a9d4ff}.react-calendar__tile--active{background:#006edc;color:#fff}.react-calendar__tile--active:enabled:hover,.react-calendar__tile--active:enabled:focus{background:#1087ff}.react-calendar--selectRange .react-calendar__tile--hover{background-color:#e6e6e6}
