*{margin:0;padding:0;box-sizing:border-box}body,html{max-width:100vw;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#333}a{text-decoration:none;transition:color .2s ease}a,a:hover{color:#2563eb}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;box-shadow:0 2px 10px rgba(0,0,0,.1);position:-webkit-sticky;position:sticky;top:0;z-index:1003}.header-container{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;position:relative}.header-logo{font-size:1.5rem;font-weight:600;letter-spacing:.5px}.header-logo a{color:#fff;text-decoration:none;transition:opacity .2s ease}.header-logo a:hover{opacity:.9}.header-nav,.header-nav-wrapper{display:flex}.header-nav{gap:2rem;list-style:none;margin:0;padding:0}.header-nav li a{color:#fff;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:background-color .2s ease}.header-nav li a:hover{background-color:hsla(0,0%,100%,.1)}.hamburger-menu{display:none;flex-direction:column;justify-content:space-around;width:30px;height:30px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1002}.hamburger-line{width:100%;height:3px;background-color:#fff;border-radius:3px;transition:all .3s ease}.hamburger-line.open:first-child{transform:rotate(45deg) translate(8px,8px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.map-container{position:relative;width:100%;height:550px;background-color:#e0e0e0;overflow:hidden;min-height:500px}.map-wrapper{width:100%;height:100%;position:absolute;top:0;left:0;z-index:1;min-height:500px}.adsense-overlay-container{position:absolute;top:0;left:500px;right:0;height:110px;z-index:999;background-color:transparent;display:flex;justify-content:center;align-items:center;pointer-events:none}.adsense-overlay-container ins{display:block!important;width:100%!important;pointer-events:auto}.route-sidebar{position:absolute;top:0;left:0;background:#fff;padding:1.5rem;border-radius:0 12px 12px 0;box-shadow:0 4px 20px rgba(0,0,0,.15);z-index:1000;max-width:400px;width:400px;max-height:100%;overflow-y:auto;transition:transform .3s ease-in-out;transform:translateX(0)}.route-sidebar.closed{transform:translateX(-100%)}.sidebar-toggle{position:absolute;top:20px;width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:0 8px 8px 0;cursor:pointer;z-index:1001;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:900;box-shadow:0 2px 8px rgba(0,0,0,.2);transition:all .3s ease}.sidebar-toggle.open{left:400px}.sidebar-toggle.closed{left:0}.sidebar-toggle:hover{background:linear-gradient(135deg,#5568d3,#653a8f);box-shadow:0 4px 12px rgba(0,0,0,.3)}.route-sidebar h2{font-size:1.5rem;margin-bottom:1rem;color:#2d3748;font-weight:700}.route-sidebar h3{font-size:1.25rem;margin-bottom:1rem;color:#333;font-weight:600}.travel-modes{display:flex;gap:.5rem;margin-bottom:1.5rem}.travel-mode-btn{flex:1 1;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;background-color:#fff;color:#555;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.travel-mode-btn:hover{border-color:#667eea;color:#667eea;background-color:#f8f9fa}.travel-mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.travel-mode-btn.active:hover{background:linear-gradient(135deg,#5568d3,#653a8f)}.route-input-group{margin-bottom:1rem}.route-input-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555;font-size:.9rem}.route-input-group input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s ease;font-family:inherit}.route-input-group input:focus{outline:none;border-color:#667eea}.route-button{width:100%;padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-bottom:1rem}.route-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.route-button:active{transform:translateY(0)}.adsense-square-container{width:100%;min-height:250px;margin:1rem 0;display:flex;justify-content:center;align-items:center;background-color:transparent;border-radius:8px;padding:.5rem}.adsense-square-container ins{display:block!important;width:100%!important}.directions-list{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.directions-list h3{font-size:1rem;margin-bottom:.75rem;color:#333;font-weight:600}.direction-item{padding:.75rem;margin-bottom:.5rem;background-color:#f8f9fa;border-radius:6px;border-left:3px solid #667eea;font-size:.9rem;line-height:1.5}.direction-item strong{color:#667eea;font-weight:600}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-top:1rem;font-size:.9rem}.seo-content-sections{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e0e0e0}.seo-section{margin-bottom:1.5rem;padding:1.25rem;background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.08);border-left:4px solid;transition:transform .2s ease,box-shadow .2s ease}.seo-section:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.12)}.seo-section:first-of-type{border-left-color:#667eea}.seo-section:nth-of-type(2){border-left-color:#764ba2}.seo-section:nth-of-type(3){border-left-color:#f093fb}.seo-section:last-child{margin-bottom:0}.seo-section h3{font-size:1.1rem;margin:0 0 1rem;color:#2d3748;font-weight:700;padding-bottom:.5rem;border-bottom:2px solid rgba(102,126,234,.1)}.seo-section-content{color:#4a5568;font-size:.9rem;line-height:1.7}.seo-section-content p{margin-bottom:.875rem}.seo-section-content p:last-child{margin-bottom:0}.seo-section-content ol,.seo-section-content ul{margin-bottom:.875rem;padding-left:1.75rem}.seo-section-content li{margin-bottom:.625rem;line-height:1.7}.seo-section-content li strong{color:#667eea;font-weight:600}.seo-section-content ol li{margin-bottom:.875rem;padding-left:.5rem}.main-content{width:100%;position:relative}.home-content-section{max-width:1000px;margin:0 auto;padding:3rem 2rem;background-color:#fff}.content-block{margin-bottom:2.5rem;padding:0}.content-block:last-child{margin-bottom:0}.content-block h2{font-size:1.75rem;margin-bottom:1.25rem}.content-block h1,.content-block h2{color:#2d3748;font-weight:700;line-height:1.3}.content-block h1{font-size:2rem;margin-bottom:1.5rem}.content-block h3{font-size:1.25rem;margin-bottom:.75rem;color:#667eea;font-weight:600}.content-block p{font-size:1rem;line-height:1.8;color:#4a5568;margin-bottom:1rem}.content-block p:last-child{margin-bottom:0}.content-block ul{margin:1rem 0;padding-left:2rem;list-style-type:disc}.content-block ol{margin:1rem 0;padding-left:2.5rem;list-style-type:decimal;counter-reset:item}.content-block ol li{padding-left:.5rem;display:list-item;list-style-position:outside}.content-block ol li,.content-block ul li{margin-bottom:.75rem;line-height:1.8;color:#4a5568;font-size:1rem}.content-block li strong{color:#667eea;font-weight:600}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-top:1.5rem}.feature-item{padding:1.5rem;background:#fff;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.06);border-left:3px solid #667eea;transition:transform .2s ease,box-shadow .2s ease}.feature-item:hover{transform:translateY(-3px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.feature-item h3{font-size:1.1rem;margin-bottom:.75rem;color:#667eea;font-weight:600}.feature-item p{font-size:.95rem;line-height:1.7;color:#4a5568;margin-bottom:0}.footer{background-color:#2d3748;color:#fff;padding:2rem;text-align:center}.footer-container{max-width:1400px;margin:0 auto}.footer p{margin:0;font-size:.9rem;color:#cbd5e0}.footer-links{margin-top:1rem;display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:.5rem}.footer-links a{color:#cbd5e0;font-size:.85rem;text-decoration:none;transition:color .2s ease}.footer-links a:hover{color:#fff}.footer-separator{color:#718096;margin:0 .25rem}@media (max-width:768px){.header{padding:1rem}.header,.header-container{position:relative}.header-logo{flex:1 1}.header-logo,.header-logo a{font-size:1rem}.hamburger-menu{display:flex}.header-nav-wrapper{position:absolute;top:100%;left:0;right:0;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 10px rgba(0,0,0,.2);max-height:0;overflow:hidden;transition:max-height .3s ease;z-index:1003}.header-nav-wrapper.open{max-height:300px}.header-nav{flex-direction:column;gap:0;padding:1rem;width:100%}.header-nav li{width:100%;border-bottom:1px solid hsla(0,0%,100%,.1)}.header-nav li:last-child{border-bottom:none}.header-nav li a{display:block;padding:1rem;font-size:1rem;width:100%;border-radius:0}.header-nav li a:hover{background-color:hsla(0,0%,100%,.15)}.map-container{height:550px;overflow:visible;position:relative}.map-wrapper{z-index:1;width:100%!important;height:100%!important;position:absolute;top:0;left:0}.route-sidebar{max-width:85%;width:85%;max-width:350px;top:0;left:0;padding:1rem;border-radius:0 12px 12px 0;height:550px;max-height:550px;z-index:1000}.adsense-overlay-container{left:0;right:auto;width:calc(min(85%, 350px));justify-content:flex-start;display:none}.adsense-square-container{min-height:auto;padding:.5rem 0;width:100%}@media (max-width:768px){.adsense-square-container ins{width:100%!important}}.sidebar-toggle{top:15px;width:35px;height:35px;font-size:1.2rem;z-index:1001}.sidebar-toggle.open{left:calc(min(85%, 350px))}.sidebar-toggle.closed{left:0}.content-block ol{padding-left:2rem}.content-block ol li{padding-left:.5rem}.route-sidebar h1{font-size:1.25rem}.route-sidebar h2{font-size:1.1rem}.travel-modes{flex-direction:column;gap:.5rem}.travel-mode-btn{width:100%}.seo-section h3{font-size:1rem}.seo-section-content{font-size:.85rem}.seo-section{padding:1rem;margin-bottom:1.25rem}.seo-section-content ol,.seo-section-content ul{padding-left:1.25rem}.home-content-section{padding:2rem 1rem}.content-block{padding:0;margin-bottom:2rem}.content-block h2{font-size:1.5rem}.content-block h1{font-size:1.75rem;margin-bottom:1.25rem}.content-block h3{font-size:1.1rem}.content-block li,.content-block p{font-size:.95rem}.features-grid{grid-template-columns:1fr;gap:1.25rem}.feature-item{padding:1.25rem}}.loading{display:inline-block;width:20px;height:20px;border-radius:50%;border:3px solid hsla(0,0%,100%,.3);border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(1turn)}}.contact-form{max-width:700px;margin:2rem 0;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease;background-color:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.form-group textarea{resize:vertical;min-height:120px}.submit-btn{width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-top:1rem}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.form-message{padding:1rem;border-radius:8px;margin-bottom:1rem;font-size:.95rem}.form-message.success{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.form-message.error{background-color:#fee2e2;color:#991b1b;border:1px solid #fca5a5}@media (max-width:768px){.contact-form{padding:1.5rem;margin:1.5rem 0}.form-group input,.form-group select,.form-group textarea{font-size:16px}}