*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw;height:100%;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-text-size-adjust:100%}body{background:#f5f5f5}.container{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.header{background:linear-gradient(135deg,#1a5f2a,#2d8f4e);color:white;padding:.75rem 1rem;text-align:center;box-shadow:0 2px 10px rgba(0,0,0,.2);position:-webkit-sticky;position:sticky;top:0;z-index:100}.header h1{font-size:1.1rem;margin-bottom:.15rem}.header p{font-size:.8rem;opacity:.9}@media (min-width:768px){.header{padding:1rem}.header h1{font-size:1.5rem}.header p{font-size:.9rem}}.main-content{flex:1 1;display:flex;flex-direction:column;position:relative;overflow:hidden;min-height:0}@media (min-width:768px){.main-content{flex-direction:row}}.map-container{height:55%;min-height:200px;position:relative}.map-container .leaflet-container{height:100%!important;width:100%!important}.leaflet-control-attribution{font-size:8px!important;background:rgba(255,255,255,.5)!important;padding:2px 5px!important;opacity:.6}.leaflet-control-attribution a{color:#333!important}@media (min-width:768px){.map-container{height:auto;flex:1 1}}.sidebar{flex:none;height:45%;background:white;padding:.75rem 1rem;box-shadow:0 -4px 20px rgba(0,0,0,.15);overflow-y:auto;border-radius:20px 20px 0 0;position:relative}.sidebar:before{content:"";display:block;width:40px;height:4px;background:#ddd;border-radius:2px;margin:0 auto .75rem}@media (min-width:768px){.sidebar{width:380px;flex:none;height:100%;border-radius:0;padding:1.5rem;box-shadow:-2px 0 10px rgba(0,0,0,.1)}.sidebar:before{display:none}}.step-indicator{display:flex;justify-content:center;gap:.5rem;margin-bottom:.75rem}.step-dot{width:12px;height:12px;border-radius:50%;background:#ddd;transition:all .3s ease}.step-dot.active{background:#2d8f4e;transform:scale(1.2)}.step-dot.completed{background:#1a5f2a}.step-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-title{font-size:1.25rem;color:#333;margin-bottom:.5rem}.step-description{color:#666;font-size:.9rem;margin-bottom:1rem}.instruction-box{background:#e8f5e9;border-left:4px solid #2d8f4e;padding:1rem;border-radius:0 8px 8px 0;margin-bottom:1rem}.instruction-box p{color:#1a5f2a;font-size:.9rem}.point-info{background:#f5f5f5;padding:.75rem;border-radius:8px;margin-bottom:.5rem;gap:.75rem}.point-info,.point-marker{display:flex;align-items:center}.point-marker{width:24px;height:24px;border-radius:50%;justify-content:center;color:white;font-size:.75rem;font-weight:700;flex-shrink:0}.point-marker.origin{background:#4CAF50}.point-marker.destination{background:#f44336}.point-details{flex:1 1;min-width:0}.point-label{font-size:.75rem;color:#666;text-transform:uppercase}.point-coords{font-size:.85rem;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-remove{background:none;border:none;color:#999;cursor:pointer;padding:.25rem;font-size:1.25rem;line-height:1}.btn-remove:hover{color:#f44336}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-weight:500;color:#333;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2d8f4e}.form-group .input-with-prefix{position:relative}.form-group .input-with-prefix span{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#666}.form-group .input-with-prefix input{padding-left:2rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;width:100%}.btn-primary{background:linear-gradient(135deg,#2d8f4e,#1a5f2a);color:white}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(45,143,78,.4)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#f5f5f5;color:#333;border:2px solid #e0e0e0}.btn-secondary:hover{background:#eeeeee}.btn-outline{background:transparent;color:#2d8f4e;border:2px solid #2d8f4e}.btn-outline:hover{background:#e8f5e9}.btn-group{display:flex;gap:.75rem;margin-top:1rem}.btn-group .btn{flex:1 1}.success-message{text-align:center;padding:2rem}.success-icon{width:80px;height:80px;background:#e8f5e9;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:2.5rem}.success-message h2{color:#1a5f2a;margin-bottom:.5rem}.success-message p{color:#666;margin-bottom:1.5rem}.custom-marker{display:flex;align-items:center;justify-content:center;width:32px!important;height:32px!important;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 2px 8px rgba(0,0,0,.3)}.custom-marker span{transform:rotate(45deg);color:white;font-weight:700;font-size:14px}.marker-origin{background:#4CAF50}.marker-destination{background:#f44336}.leaflet-tooltip{background:white;border:none;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.2);padding:.5rem .75rem;font-size:.85rem}.loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,.9);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999}.spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#2d8f4e;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay p{margin-top:1rem;color:#666}@media (max-width:767px){.step-title{font-size:1rem;margin-bottom:.25rem}.step-description{font-size:.8rem;margin-bottom:.5rem}.btn{padding:.75rem;font-size:.95rem;min-height:44px}.btn-outline{padding:.6rem}.point-info{padding:.5rem;margin-bottom:.4rem}.instruction-box{padding:.6rem;margin-bottom:.5rem}.instruction-box p{font-size:.8rem}.form-group{margin-bottom:.75rem}.form-group label{font-size:.85rem;margin-bottom:.3rem}.form-group input,.form-group select,.form-group textarea{padding:.6rem}.success-message{padding:1rem}.success-icon{width:50px;height:50px;font-size:1.5rem}}.map-instruction-toast{position:absolute;top:10px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.8);color:white;padding:.75rem 1.25rem;border-radius:25px;font-size:.85rem;z-index:1000;white-space:nowrap;box-shadow:0 2px 10px rgba(0,0,0,.3);animation:fadeInDown .3s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@supports (padding-top:env(safe-area-inset-top)){.header{padding-top:calc(.75rem + env(safe-area-inset-top))}.sidebar{padding-bottom:calc(1rem + env(safe-area-inset-bottom))}}