*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f5f5;color:#333;line-height:1.6}:root{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #f8f9fa;--text-primary: #333333;--text-secondary: #666666;--text-muted: #999999;--border-primary: #e0e0e0;--border-secondary: #ddd;--accent-primary: #007bff;--accent-hover: #0056b3;--waze-primary: #33CDFF;--waze-hover: #1bb3e6;--shadow-light: rgba(0, 0, 0, .1);--shadow-medium: rgba(0, 0, 0, .15);--overlay-bg: rgba(255, 255, 255, .95)}@media (prefers-color-scheme: dark){:root:not(.theme-light){--bg-primary: #121212;--bg-secondary: #1e1e1e;--bg-tertiary: #2a2a2a;--text-primary: #ffffff;--text-secondary: #b3b3b3;--text-muted: #8a8a8a;--border-primary: #404040;--border-secondary: #555555;--accent-primary: #33CDFF;--accent-hover: #1bb3e6;--waze-primary: #33CDFF;--waze-hover: #1bb3e6;--shadow-light: rgba(0, 0, 0, .3);--shadow-medium: rgba(0, 0, 0, .4);--overlay-bg: rgba(30, 30, 30, .95)}}:root.theme-dark{--bg-primary: #121212;--bg-secondary: #1e1e1e;--bg-tertiary: #2a2a2a;--text-primary: #ffffff;--text-secondary: #b3b3b3;--text-muted: #8a8a8a;--border-primary: #404040;--border-secondary: #555555;--accent-primary: #33CDFF;--accent-hover: #1bb3e6;--waze-primary: #33CDFF;--waze-hover: #1bb3e6;--shadow-light: rgba(0, 0, 0, .3);--shadow-medium: rgba(0, 0, 0, .4);--overlay-bg: rgba(30, 30, 30, .95)}*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;width:100%;max-width:100vw}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}#root{min-height:100vh}.layout{display:flex;flex-direction:column;min-height:100vh;padding-bottom:80px;overflow-x:hidden}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:1rem;position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.logo{font-size:1.5rem;font-weight:700;text-decoration:none;color:var(--waze-primary)}.nav{display:none}.user-menu{display:flex;align-items:center;gap:1rem}.user-email{font-size:.9rem;color:var(--text-secondary)}.main-content{flex:1;padding:1rem;max-width:1200px;margin:0 auto;width:100%}.mobile-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-primary);display:flex;justify-content:space-around;padding:.5rem 0;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;text-decoration:none;color:var(--text-secondary);padding:.5rem;border:none;background:none;cursor:pointer;font-size:.8rem;transition:color .2s}.nav-item.active,.nav-item:hover{color:var(--waze-primary)}.nav-icon{font-size:1.2rem;margin-bottom:.25rem}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:url(/background_login.jpg) center/cover no-repeat;background-attachment:fixed;position:relative}.auth-container:before{content:"";position:absolute;inset:0;background:#0000004d;z-index:1}.auth-form{position:relative;z-index:2;background:var(--bg-secondary);padding:2rem;border-radius:8px;box-shadow:0 4px 6px var(--shadow-light);width:100%;max-width:400px}.auth-form h1{text-align:center;margin-bottom:.5rem;color:var(--waze-primary)}.auth-form h2{text-align:center;margin-bottom:1.5rem;color:var(--text-primary)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border-secondary);border-radius:4px;font-size:1rem;background:var(--bg-secondary);color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--waze-primary);box-shadow:0 0 0 2px #33cdff40}.btn-primary{background:var(--waze-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;width:100%;margin-top:.5rem;transition:background .2s}.btn-primary:hover:not(:disabled){background:var(--waze-hover)}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:.75rem 1rem;border-radius:4px;cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s}.btn-secondary:hover{background:#545b62}.btn-danger{background:#dc3545;color:#fff;border:none;padding:.75rem 1rem;border-radius:4px;cursor:pointer;transition:background .2s}.btn-danger:hover{background:#c82333}.btn-share{background:#28a745;color:#fff;border:none;padding:.75rem 1rem;border-radius:4px;cursor:pointer;transition:background .2s}.btn-share:hover{background:#218838}.btn-waze-primary{background:var(--waze-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-weight:700;font-size:1rem;transition:background .2s;display:flex;align-items:center;justify-content:center}.btn-waze-secondary{background:var(--waze-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}.btn-waze-secondary:hover{background:var(--waze-hover)}.btn-waze{background:var(--waze-primary);color:#fff;border:none;padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background .2s;display:flex;align-items:center;justify-content:center}.btn-waze:hover{background:var(--waze-hover)}.btn-logout{background:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s}.btn-logout:hover{background:#c82333}.btn-remove{background:#dc3545;color:#fff;border:none;padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.8rem;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-remove:hover{background:#c82333}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.dashboard-header h1{margin:0}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state .btn-primary{width:auto;margin-top:1rem}.itineraries-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.itinerary-card{background:var(--bg-secondary);padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px var(--shadow-light);border:1px solid var(--border-primary);position:relative}.itinerary-delete-btn{position:absolute;top:.75rem;right:.75rem;background:none;border:none;font-size:1.5rem;color:#dc3545;cursor:pointer;padding:.25rem;line-height:1;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s}.itinerary-delete-btn:hover{background-color:#dc3545;color:#fff}.itinerary-header h3{margin:0 0 .5rem;color:var(--text-primary)}.itinerary-stats{display:flex;gap:1rem;margin:1rem 0;padding:.75rem;background:var(--bg-primary);border-radius:6px}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-value{font-size:1.25rem;font-weight:600;color:var(--text-primary);line-height:1.2}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.itinerary-meta{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.itinerary-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.itinerary-date{color:#999;font-size:.8rem;margin-top:.5rem}.route-builder-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.route-builder-header h1{margin:0}.route-actions{display:flex;gap:.5rem;flex-wrap:wrap}.route-form{margin-bottom:2rem}.route-content{display:grid;grid-template-columns:minmax(300px,400px) 1fr;gap:2rem;width:100%;max-width:100%;overflow:hidden}.route-sidebar{display:flex;flex-direction:column;gap:1.5rem;min-width:300px;max-width:400px;width:100%;overflow:hidden}.route-map{position:relative;min-width:0;width:100%;flex:1}.map-instructions{text-align:center;padding:1rem;color:#666;font-size:.9rem;background:#f8f9fa;border-radius:4px;margin-top:.5rem}.address-search{background:var(--bg-secondary);padding:1rem;border-radius:8px;box-shadow:0 2px 4px var(--shadow-light);border:1px solid var(--border-primary);width:100%;max-width:100%;overflow:hidden;flex-shrink:0}.address-search h3{margin:0 0 .75rem;color:var(--text-primary);font-size:1.1rem}.route-title-input{background:var(--bg-secondary);padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid var(--border-primary)}.title-input{width:100%;padding:.75rem;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;transition:border-color .2s}.title-input:focus{outline:none;border-color:var(--waze-primary)}.title-input::placeholder{color:var(--text-secondary)}.search-input-container{display:flex;gap:.5rem;position:relative}.search-input{flex:1;padding:.75rem;border:1px solid var(--border-secondary);border-radius:4px;font-size:1rem;background:var(--bg-secondary);color:var(--text-primary)}.search-input:focus{outline:none;border-color:var(--waze-primary);box-shadow:0 0 0 2px #33cdff40}.search-button{background:var(--waze-primary);color:#fff;border:none;padding:.75rem 1rem;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background .2s}.search-button:hover:not(:disabled){background:var(--waze-hover)}.search-button:disabled{background:#ccc;cursor:not-allowed}.search-loading{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:var(--waze-primary);font-size:.8rem;pointer-events:none}.search-results{margin-top:.5rem;max-height:150px;overflow-y:auto;border-radius:4px;border:1px solid var(--border-primary);background:var(--bg-secondary)}.search-result-item{padding:.75rem;border-bottom:1px solid var(--border-primary);cursor:pointer;transition:background .2s;background:var(--bg-secondary)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-tertiary)}.result-name{font-weight:500;margin-bottom:.25rem;overflow:hidden;word-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;max-width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.result-coords{color:#666;font-size:.8rem}.no-results{padding:1rem;text-align:center;color:var(--text-secondary);border:1px solid var(--border-primary);margin-top:.5rem;background:var(--bg-secondary);border-radius:4px}.stops-list{background:var(--bg-secondary);border-radius:8px;box-shadow:0 2px 4px var(--shadow-light);border:1px solid var(--border-primary);width:100%;max-width:100%;display:flex;flex-direction:column;flex:1;min-height:200px;overflow:hidden}.stops-list-header{padding:1rem;border-bottom:1px solid var(--border-primary);background:var(--bg-tertiary);flex-shrink:0}.stops-list-content{padding:1rem;overflow-y:auto;flex:1;min-height:0}.stops-list h3{margin:0 0 1rem;color:var(--text-primary)}.stops-empty{text-align:center;padding:2rem;color:#666;font-style:italic}.stops-container{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:100%;overflow-y:auto;overflow-x:hidden;flex:1;min-height:0;padding-right:4px;max-height:300px}.stops-container::-webkit-scrollbar{width:6px}.stops-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.stops-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.stops-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.stop-item{display:flex;align-items:flex-start;padding:.75rem;background:var(--bg-tertiary);border-radius:6px;border:1px solid var(--border-primary);transition:all .2s;cursor:grab;min-height:65px;gap:.75rem;width:100%;max-width:100%;overflow:hidden}.stop-item:hover{background:var(--bg-secondary);border-color:var(--waze-primary);transform:translateY(-1px);box-shadow:0 2px 8px #33cdff26}.stop-item.dragging{opacity:.8;transform:rotate(2deg);box-shadow:0 4px 8px #0003}.stop-number{background:var(--waze-primary);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0;box-shadow:0 2px 4px #33cdff4d}.stop-content{flex:1;min-width:0;overflow:hidden;max-width:calc(100% - 90px);display:flex;flex-direction:column;gap:.25rem}.stop-name{font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4;max-width:100%;width:100%;color:var(--text-primary);font-size:.95rem}.stop-coords{color:var(--text-secondary);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin:0}.stop-actions{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0;align-items:flex-end;width:80px;max-width:80px;min-width:80px;justify-content:center}.route-summary{background:var(--bg-secondary);padding:1rem;border-radius:8px;box-shadow:0 2px 4px var(--shadow-light);border:1px solid var(--border-primary);flex-shrink:0;margin-top:auto}.route-summary h4{margin:0 0 .75rem;color:var(--text-primary)}.summary-item{margin-bottom:.5rem;font-size:.9rem;display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.summary-item:last-child{margin-bottom:0}.summary-item strong{color:var(--text-primary);font-weight:500}.summary-value{color:var(--text-secondary);font-weight:400;text-align:right}.shared-route{max-width:800px;margin:0 auto}.shared-route-header{text-align:center;margin-bottom:2rem}.shared-route-header h1{margin:0 0 .5rem}.route-meta{color:#666;margin-bottom:1.5rem}.navigation-controls{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.shared-route-content{display:flex;flex-direction:column;gap:2rem}.stops-overview h3{margin:0 0 1rem}.stops-list-shared{display:flex;flex-direction:column;gap:.5rem}.stop-item-shared{display:flex;align-items:center;padding:.75rem;background:#fff;border-radius:4px;box-shadow:0 2px 4px #0000001a;border:1px solid #e0e0e0;transition:all .2s}.stop-item-shared.current{border-color:#39d9a0;background:#f0fdf7}.stop-item-shared .stop-number{background:#6c757d}.stop-item-shared.current .stop-number{background:#39d9a0}.loading{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.error-message{color:#dc3545;background:#f8d7da;border:1px solid #f5c6cb;padding:.75rem;border-radius:4px;margin:.5rem 0}.error-container{text-align:center;padding:3rem 1rem}.error-container h1{color:#dc3545;margin-bottom:1rem}.custom-marker{background:#007bff;color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;border:2px solid white;box-shadow:0 2px 4px #0000004d}.numbered-marker{background:transparent!important;border:none!important}@media (min-width: 768px){.nav{display:flex;gap:2rem}.nav a{text-decoration:none;color:#666;font-weight:500;padding:.5rem 0;border-bottom:2px solid transparent;transition:all .2s}.nav a.active,.nav a:hover{color:#007bff;border-bottom-color:#007bff}.mobile-nav{display:none}.layout{padding-bottom:0}.main-content{padding:2rem}}@media (max-width: 767px){.itineraries-grid{grid-template-columns:1fr}.main-content{overflow-x:hidden}.route-content{grid-template-columns:1fr;gap:1rem;overflow-x:hidden;width:100%;max-width:100vw}.route-sidebar{width:100%;min-width:0;overflow-x:hidden;max-width:100%}.route-map{height:400px!important;min-height:400px!important;width:100%!important;max-width:100%!important;position:relative!important;overflow:hidden!important}.route-map>div{height:400px!important;width:100%!important;max-width:100%!important}.stop-item{align-items:flex-start;padding:.5rem;min-height:50px}.stop-content{min-width:0;flex:1;overflow:hidden;max-width:calc(100% - 80px)}.stop-name{font-size:.9rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;width:100%}.stop-coords{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.stop-actions{flex-direction:row;gap:.25rem;width:70px;max-width:70px;min-width:70px}.btn-waze{padding:.2rem .5rem;font-size:.7rem}.btn-remove{padding:.2rem .4rem;font-size:.8rem;min-width:20px;height:20px}.address-search{padding:.75rem;width:100%;max-width:100%}.search-input{width:100%;max-width:100%}.search-result-item{padding:.5rem}.result-name{font-size:.9rem;line-height:1.2}.shared-route-content{flex-direction:column-reverse}.dashboard-header,.route-builder-header{flex-direction:column;align-items:stretch}.route-actions,.navigation-controls{justify-content:stretch}.route-actions>*,.navigation-controls>*{flex:1}.itinerary-actions{justify-content:stretch}.itinerary-actions>*{flex:1}.waze-route-header{flex-direction:column;align-items:stretch}.route-actions{justify-content:stretch}.route-actions>*{flex:1}}.waze-route{max-width:800px;margin:0 auto;padding:2rem 1rem}.route-instructions{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;padding:1rem;margin-bottom:1.5rem;font-size:.95rem;color:var(--text-secondary);text-align:center;box-shadow:0 2px 4px var(--shadow-light)}.waze-route-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.waze-route-header h1{color:var(--text-primary);font-size:2rem;margin:0}.trip-points-container{margin-bottom:2rem}.trip-points-container h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.5rem}.waze-route .stops-list{display:flex;flex-direction:column;gap:1rem;background:transparent;padding:0;border:none;box-shadow:none}.waze-route .stop-item{display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:1rem;box-shadow:0 2px 4px var(--shadow-light);transition:all .2s ease;cursor:pointer;min-height:auto}.waze-route .stop-item:hover{box-shadow:0 4px 8px var(--shadow-medium);transform:translateY(-1px);border-color:var(--waze-primary)}.clickable-stop{cursor:pointer}.clickable-stop:hover{background:var(--bg-tertiary)}.waze-route .stop-item.current-stop{border-color:var(--waze-primary);background:var(--bg-tertiary)}.waze-route .stop-info{display:flex;align-items:center;gap:1rem;flex:1}.waze-route .stop-number{background:var(--waze-primary);color:#fff;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:1rem;margin-top:0}.waze-route .current-stop .stop-number{background:#28a745}.waze-route .stop-details{flex:1}.waze-route .stop-name{color:var(--text-primary);font-size:1.1rem;margin:0 0 .25rem;font-weight:500;overflow:visible;white-space:normal;text-overflow:unset;-webkit-line-clamp:unset;-webkit-box-orient:unset;display:block}.waze-route .stop-coordinates{color:var(--text-secondary);font-size:.9rem;margin:0}.waze-route .stop-actions{flex-shrink:0;flex-direction:row;width:auto;max-width:none;min-width:auto}.waze-icon{display:flex;align-items:center;justify-content:center;padding:.5rem}.waze-logo-icon{width:24px;height:24px;object-fit:contain}.no-stops{text-align:center;padding:2rem;color:var(--text-secondary)}.route-progress{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px var(--shadow-light)}.route-progress h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.25rem}.progress-info{display:flex;flex-direction:column;gap:.5rem}.progress-bar{background:#e9ecef;border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:#007bff;height:100%;transition:width .3s ease}.map-layout{height:100vh;display:flex;flex-direction:column;overflow:hidden}.map-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;z-index:1000;height:60px;flex-shrink:0}.map-header-left{display:flex;align-items:center;gap:2rem}.map-header-right{display:flex;align-items:center;gap:1rem}.top-nav{display:flex;gap:1.5rem;align-items:center}.nav-link{color:#666;text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;gap:.5rem}.nav-link:hover,.nav-link.active{background:#f8f9fa;color:#007bff}.user-info{color:#666;font-size:.9rem;margin-right:1rem;display:flex;align-items:center;gap:.5rem}.btn-login,.btn-register{color:#007bff;text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;gap:.5rem;font-size:.9rem}.btn-login:hover{background:#f8f9fa;color:#0056b3}.btn-register{background:#007bff;color:#fff;margin-left:.5rem}.btn-register:hover{background:#0056b3;color:#fff}.save-notice{font-size:.85rem;color:#666;line-height:1.4;background:#f8f9fa;border-radius:4px;padding:.5rem;border:1px solid #e9ecef}.route-summary-overlay{position:absolute;top:1rem;right:1rem;z-index:300}.summary-compact{background:var(--overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;padding:.75rem 1rem;box-shadow:0 2px 12px var(--shadow-medium);border:1px solid var(--border-primary)}.summary-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-primary);font-weight:500}.summary-label{white-space:nowrap}.summary-divider{color:#999;font-weight:400}.save-action{background:var(--bg-secondary);padding:1rem;border-radius:8px;box-shadow:0 2px 4px var(--shadow-light);border:1px solid var(--border-primary);text-align:center}.action-buttons{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.btn-save-mobile,.btn-waze-mobile{width:100%}.btn-waze-primary{background:#39d9a0;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-weight:600;font-size:.9rem;transition:background .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-waze-primary:hover{background:var(--waze-hover)}.btn-waze-primary:active{background:#20b486}.map-main{display:flex;height:calc(100vh - 60px);overflow:hidden}.map-sidebar{width:400px;min-width:400px;max-width:400px;background:var(--bg-tertiary);border-right:1px solid var(--border-primary);overflow-y:auto;overflow-x:hidden;padding:0;display:flex;flex-direction:column;z-index:100;height:100%}.map-sidebar::-webkit-scrollbar{width:8px}.map-sidebar::-webkit-scrollbar-track{background:#f1f1f1}.map-sidebar::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.map-sidebar::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.sidebar-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;flex:1;min-height:0}.sidebar-content>*{flex-shrink:0}.sidebar-content .stops-list{flex:1;min-height:200px;display:flex;flex-direction:column}.map-content{flex:1;position:relative;overflow:hidden}.full-screen-map{width:100%;height:100%;position:relative}.full-screen-map>div{width:100%!important;height:100%!important}.sidebar-header{background:#fff;padding:1.25rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;border:1px solid #e0e0e0;flex-shrink:0}.sidebar-header h2{margin:0 0 1rem;color:#333;font-size:1.5rem}.sidebar-actions{display:flex;gap:.5rem;flex-wrap:wrap}.route-title-section{background:var(--bg-secondary);padding:1rem;border-radius:8px;box-shadow:0 2px 4px var(--shadow-light);border:1px solid var(--border-primary);flex-shrink:0}.route-title-section label{display:block;margin-bottom:.5rem;font-weight:700;color:var(--text-primary)}.title-input{width:100%;padding:.75rem;border:1px solid var(--border-secondary);border-radius:4px;font-size:1rem;transition:border-color .2s;background:var(--bg-secondary);color:var(--text-primary)}.title-input:focus{outline:none;border-color:var(--waze-primary);box-shadow:0 0 0 2px #33cdff40}.guest-notice{background:#f0f7ff;border:1px solid #007bff;border-radius:6px;padding:1rem;text-align:center;color:#0056b3;font-size:.9rem}.guest-save-notice{font-size:.9rem;color:#666;text-align:center;padding:.5rem}.map-instructions{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#fffffff2;padding:.75rem 1.5rem;border-radius:6px;box-shadow:0 2px 8px #00000026;font-size:.9rem;color:#666;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media (max-width: 1024px){.map-sidebar{width:350px;min-width:350px}}@media (max-width: 768px){.map-layout{flex-direction:column}.map-header{display:none}.map-main{flex-direction:column;height:100vh}.map-sidebar{width:100%;min-width:100%;height:auto;min-height:auto;max-height:50vh;order:1;border-right:none;border-bottom:1px solid var(--border-primary)}.sidebar-content{padding:1rem;gap:.75rem}.route-title-input{display:none}.address-search{padding:.75rem;margin-bottom:0}.address-search h3,.stops-list h3{display:none}.stops-container{max-height:200px;overflow-y:auto}.stop-item{padding:.5rem;min-height:50px}.stop-content{max-width:calc(100% - 80px)}.stop-actions{width:70px;max-width:70px;flex-direction:row;gap:.25rem}.map-content{order:2;height:50vh;min-height:300px}.map-instructions{bottom:.5rem;left:1rem;right:1rem;transform:none;text-align:center;padding:.5rem 1rem;font-size:.8rem}.save-action{padding:.75rem}.save-notice{font-size:.8rem;padding:.4rem}}@media (min-width: 769px){.action-buttons{flex-direction:row;gap:.75rem}.btn-save-mobile,.btn-waze-mobile{flex:1}.save-action .action-buttons button{min-width:120px}}.trip-summary-overlay{position:absolute;top:1rem;right:1rem;z-index:1000;min-width:200px}.trip-summary-card{background:var(--overlay-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1rem;box-shadow:0 4px 20px var(--shadow-medium);border:1px solid var(--border-primary)}.trip-summary-title{margin:0 0 .75rem;font-size:.9rem;font-weight:600;color:var(--text-primary);text-align:center}.trip-summary-stats{display:flex;flex-direction:column;gap:.5rem}.trip-stat{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0}.trip-stat-value{font-size:1rem;font-weight:600;color:#2563eb;min-width:80px;text-align:right}.trip-stat-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}@media (max-width: 768px){.trip-summary-overlay{display:none}}.btn-waze-logo{width:20px;height:20px;background-image:url(/waze-logo.png);background-size:contain;background-repeat:no-repeat;background-position:center;display:inline-block;flex-shrink:0;margin-right:.5rem}.btn-theme-toggle{background:none;border:1px solid var(--border-primary);color:var(--text-secondary);padding:.5rem;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .2s;display:flex;align-items:center;justify-content:center;width:36px;height:36px}.btn-theme-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--waze-primary)}.home-page{min-height:100vh;background:var(--bg-primary)}.hero-section{background:url(/background_login.jpg) center/cover no-repeat;background-attachment:fixed;color:#fff;padding:4rem 2rem;text-align:center;min-height:80vh;display:flex;align-items:center;justify-content:center;position:relative}.hero-section:before{content:"";position:absolute;inset:0;background:#0006;z-index:1}.hero-content{position:relative;z-index:2;max-width:800px;margin:0 auto}.hero-title{font-size:3.5rem;font-weight:700;margin-bottom:1.5rem;line-height:1.1;text-shadow:0 2px 4px rgba(0,0,0,.3)}.hero-subtitle{font-size:1.25rem;line-height:1.6;margin-bottom:2.5rem;opacity:.95;max-width:600px;margin-left:auto;margin-right:auto}.hero-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.btn-large{padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:8px;text-decoration:none;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;min-width:200px}.btn-primary{background:var(--waze-primary);color:#fff;border:none}.btn-primary:hover{background:var(--waze-hover);transform:translateY(-2px);box-shadow:0 8px 25px #33cdff66}.btn-secondary{background:transparent;color:#fff;border:2px solid white}.btn-secondary:hover{background:#fff;color:#667eea;transform:translateY(-2px);box-shadow:0 8px 25px #ffffff4d}.feature-badges{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.badge{background:#fff3;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.features-section,.how-it-works-section,.use-cases-section,.faq-section{padding:4rem 0}.features-section h2,.how-it-works-section h2,.use-cases-section h2,.faq-section h2{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:var(--text-primary);font-weight:700}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-top:2rem}.feature-card{background:var(--bg-secondary);padding:2rem;border-radius:12px;box-shadow:0 4px 20px var(--shadow-light);border:1px solid var(--border-primary);text-align:center;transition:transform .3s ease,box-shadow .3s ease}.feature-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px var(--shadow-medium)}.feature-icon{font-size:3rem;margin-bottom:1rem;display:block}.feature-card h3{font-size:1.5rem;margin-bottom:1rem;color:var(--text-primary);font-weight:600}.feature-card p{color:var(--text-secondary);line-height:1.6;margin:0}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.step-card{background:var(--bg-secondary);padding:2rem;border-radius:12px;box-shadow:0 4px 20px var(--shadow-light);border:1px solid var(--border-primary);text-align:center;position:relative}.step-number{background:var(--waze-primary);color:#fff;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto 1.5rem;box-shadow:0 4px 15px #33cdff4d}.step-card h3{font-size:1.25rem;margin-bottom:1rem;color:var(--text-primary);font-weight:600}.step-card p{color:var(--text-secondary);line-height:1.6;margin:0}.use-cases-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.use-case{background:var(--bg-secondary);padding:1.5rem;border-radius:8px;box-shadow:0 2px 10px var(--shadow-light);border:1px solid var(--border-primary);transition:transform .3s ease}.use-case:hover{transform:translateY(-3px)}.use-case h3{margin-bottom:.75rem;color:var(--text-primary);font-size:1.1rem;font-weight:600}.use-case p{color:var(--text-secondary);line-height:1.5;margin:0;font-size:.95rem}.faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-top:2rem}.faq-item{background:var(--bg-secondary);padding:2rem;border-radius:12px;box-shadow:0 4px 20px var(--shadow-light);border:1px solid var(--border-primary)}.faq-item h3{color:var(--text-primary);font-size:1.2rem;margin-bottom:1rem;font-weight:600;line-height:1.3}.faq-item p{color:var(--text-secondary);line-height:1.6;margin:0}.cta-section{background:linear-gradient(135deg,var(--waze-primary) 0%,#1bb3e6 100%);color:#fff;text-align:center;padding:4rem 2rem}.cta-section h2{font-size:2.5rem;margin-bottom:1rem;font-weight:700}.cta-section p{font-size:1.2rem;margin-bottom:2rem;opacity:.95;max-width:600px;margin-left:auto;margin-right:auto}.cta-actions{display:flex;justify-content:center}.cta-actions .btn-primary{background:#fff;color:var(--waze-primary);font-weight:700}.cta-actions .btn-primary:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 8px 25px #ffffff4d}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-actions{flex-direction:column;align-items:center}.btn-large{width:100%;max-width:300px}.features-grid,.steps-grid{grid-template-columns:1fr}.use-cases-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.faq-grid{grid-template-columns:1fr}.container{padding:0 1rem}.features-section h2,.how-it-works-section h2,.use-cases-section h2,.faq-section h2,.cta-section h2{font-size:2rem}}.legal-page{min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}.legal-nav{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:1rem 2rem;position:sticky;top:0;z-index:100}.back-home{color:var(--accent-primary);text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:.5rem;transition:color .2s ease}.back-home:hover{color:var(--accent-hover)}.legal-content{max-width:800px;margin:0 auto;padding:2rem;background:var(--bg-secondary);box-shadow:0 2px 10px var(--shadow-light);border-radius:8px;margin-top:2rem;margin-bottom:2rem}.legal-content h1{font-size:2.5rem;margin-bottom:2rem;color:var(--text-primary);border-bottom:2px solid var(--border-primary);padding-bottom:1rem}.legal-content h2{font-size:1.8rem;margin:2rem 0 1rem;color:var(--text-primary)}.legal-content h3{font-size:1.4rem;margin:1.5rem 0 .75rem;color:var(--text-primary)}.legal-content h4{font-size:1.2rem;margin:1rem 0 .5rem;color:var(--text-primary)}.legal-content p{margin-bottom:1rem;line-height:1.7;color:var(--text-secondary)}.legal-content ul{margin:1rem 0;padding-left:2rem;color:var(--text-secondary)}.legal-content li{margin-bottom:.5rem;line-height:1.6}.legal-section{margin-bottom:2rem}.legal-section:last-of-type{margin-bottom:1rem}.legal-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-primary);text-align:center;color:var(--text-muted);font-size:.9rem}@media (max-width: 768px){.legal-nav{padding:1rem}.legal-content{margin:1rem;padding:1.5rem;border-radius:0}.legal-content h1{font-size:2rem}.legal-content h2{font-size:1.5rem}.legal-content h3{font-size:1.2rem}.legal-content h4{font-size:1.1rem}.legal-content ul{padding-left:1.5rem}}.site-footer{background:var(--bg-tertiary);border-top:1px solid var(--border-primary);margin-top:4rem;padding:3rem 0 1rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}.footer-section h4{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:1rem}.footer-nav{display:flex;flex-direction:column;gap:.5rem}.footer-link{color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:color .2s ease}.footer-link:hover{color:var(--accent-primary)}.footer-description{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin:0}.footer-bottom{border-top:1px solid var(--border-primary);padding-top:1.5rem;text-align:center}.footer-bottom p{color:var(--text-muted);font-size:.85rem;margin:0}@media (max-width: 768px){.site-footer{padding:2rem 0 1rem}.footer-content{grid-template-columns:1fr;gap:1.5rem}.footer-section{text-align:center}.footer-nav{align-items:center}}
