*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;max-width:100vw;overflow-x:hidden}body{font-family:'Arial',sans-serif;background-color:var(--bg-primary);background-image:url('/static/images/background.svg');background-size:auto 100%;background-repeat:no-repeat;background-position:center top;color:var(--text-primary);line-height:1.6;display:grid;grid-template-rows:auto 1fr;min-height:100vh;word-wrap:break-word;overflow-wrap:break-word}.page-header{text-align:center;margin-bottom:2rem}.page-header h1{text-align:center;font-size:2.5rem;margin-bottom:1rem;color:var(--text-primary)}.page-header p{color:var(--text-secondary);font-size:1.1em;line-height:1.6}.cards-container,.route-detail-container{max-width:var(--max-content-width);margin:2rem auto;padding:20px 0 1.5rem}.cards-container p{margin-bottom:1rem}header{background-color:var(--bg-dark);padding:1em 2em;position:sticky;width:100%;max-width:100vw;top:0;z-index:1000;box-shadow:0 2px 5px var(--accent-shadow);overflow-x:hidden}.main-nav{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1em;flex-wrap:wrap}.logo{display:flex;align-items:center;gap:1em}.logo-image{width:60px;height:60px;border-radius:50%;transform:scale(2.5);filter:drop-shadow(0px 0px 8px rgba(255,232,176,1));padding-left:0.8em}.logo a{color:var(--primary-light);font-size:1.5em;font-weight:bold;text-decoration:none;display:flex;align-items:center;gap:0.5em}.nav-links{display:flex;align-items:center;gap:0.5em}.nav-links a{margin-left:0.25em}footer{background-color:var(--bg-dark);color:var(--text-light);padding:3em 0 1em;max-width:100vw;overflow-x:hidden}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-around;padding:0 2em}.footer-section{margin-bottom:2em;display:flex;flex-direction:column;align-items:flex-start;gap:0.4em;padding:0.2em}.footer-section h3{color:var(--primary-light);margin-bottom:0.75em}.footer-section a{color:var(--text-light);text-decoration:none;font-size:0.95em;font-weight:500}.footer-bottom{text-align:center;padding-top:2em;border-top:1px solid var(--overlay-dark)}.social-links{display:flex;gap:0.75em;align-items:center}.social-links a img{width:28px;height:28px;display:block;filter:brightness(0) invert(1);transition:filter 0.25s}.social-links a:hover img{filter:brightness(0) invert(1) drop-shadow(0 0 8px rgba(255,232,176,0.6))}.menu-btn{display:none;font-size:1.3em;line-height:1;padding:0.5em 0.75em}.menu-btn:hover,.menu-btn:active{transform:none}.side-menu{position:fixed;top:0;right:-250px;width:250px;height:100%;background:var(--primary-dark);box-shadow:-2px 0 5px rgba(0,0,0,0.2);padding:1em;display:flex;flex-direction:column;gap:0.7em;transition:right 0.3s ease-in-out;z-index:2000}.side-menu.open{right:0}.side-menu a{display:block;color:var(--text-light);text-decoration:none;font-size:1em;font-weight:500}.close-btn{align-self:flex-end;font-size:1.2em}.side-menu .menu-footer{margin-top:auto;padding-top:1em;border-top:1px solid rgba(255,255,255,0.2);display:flex;flex-direction:column;gap:0.5em}.menu-footer .social-icons{display:flex;gap:0.5em;margin-top:0.5em;align-items:center}.menu-footer .social-icons a{padding:0.4em}.menu-footer .social-icons a img{width:24px;height:24px;filter:brightness(0) invert(1);transition:filter 0.25s}.menu-footer .social-icons a:hover img{filter:brightness(0) invert(1) drop-shadow(0 0 6px rgba(255,232,176,0.6))}.cta-button{position:fixed;bottom:2rem;left:70%;z-index:999;pointer-events:none;transition:opacity 300ms ease,transform 300ms ease}.cta-link{pointer-events:auto}.footer-lang-switcher{display:flex;justify-content:center;align-items:center;gap:0.5em;margin-bottom:0.5em}.header-lang-switcher{display:flex;align-items:center;gap:0.5em;margin-left:1em}.lang-flag-link{display:inline-flex;align-items:center;justify-content:center}.lang-flag{font-size:26px;line-height:1}.cookie-consent-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.8);z-index:10000;display:flex;justify-content:center;align-items:center;backdrop-filter:blur(5px)}.cookie-consent-modal{background:#fff;border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.3);animation:modalSlideIn 0.3s ease-out}@keyframes modalSlideIn{from{opacity:0;transform:translateY(-20px) scale(0.95)}to{opacity:1;transform:translateY(0) scale(1)}}.cookie-consent-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0 1.5rem;border-bottom:1px solid #e0e0e0}.cookie-consent-header h2{margin:0;color:#333;font-size:1.5rem;font-weight:600}.close-cookie-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0.5rem;border-radius:50%;transition:background-color 0.2s}.close-cookie-btn:hover{background:#f0f0f0;color:#333}.cookie-consent-content{padding:1.5rem}.cookie-consent-content p{margin:0 0 1.5rem 0;color:#666;line-height:1.6}.cookie-options{margin-bottom:1.5rem}.cookie-option{margin-bottom:1.5rem;padding:1rem;border:1px solid #e0e0e0;border-radius:8px;background:#fafafa}.cookie-option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0.5rem}.cookie-option-header h3{margin:0;color:#333;font-size:1.1rem;font-weight:600}.cookie-required{background:#2E7D32;color:white;padding:0.25rem 0.5rem;border-radius:4px;font-size:0.8rem;font-weight:600}.cookie-option p{margin:0;color:#666;font-size:0.9rem;line-height:1.5}.cookie-toggle{position:relative;display:inline-block;width:50px;height:24px}.cookie-toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:0.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:white;transition:0.3s;border-radius:50%}input:checked + .toggle-slider{background-color:#4CAF50}input:checked + .toggle-slider:before{transform:translateX(26px)}.cookie-consent-actions{display:flex;gap:1rem;padding:0 1.5rem 1.5rem 1.5rem;justify-content:flex-end}.cookie-btn{padding:0.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all 0.2s;font-size:0.9rem}.cookie-btn.primary{background:#4CAF50;color:white}.cookie-btn.primary:hover{background:#45a049;transform:translateY(-1px)}.cookie-btn.secondary{background:#f0f0f0;color:#333;border:1px solid #ddd}.cookie-btn.secondary:hover{background:#e0e0e0;transform:translateY(-1px)}@media(min-width:1200px){.menu-btn{display:none !important}.nav-links{display:flex}}@media(max-width:1199px){.nav-links{display:none}.menu-btn{display:block}.header-lang-switcher{display:none}}@media(max-width:768px){.page-header h1{font-size:2rem}header{padding:0.6em 1em}.main-nav{flex-wrap:wrap;position:relative;height:70px}.logo-image{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90px;height:90px;max-width:35vw;max-height:35vw}.cta-button{left:auto;right:2rem;transform:none;bottom:4rem}.feature-list{display:none}.hero-content{top:10%;bottom:auto;padding:0 1.5rem}.about-section,.services-section,.contact-container,.cards-container,.route-detail-container{padding:2rem 1rem}.card-content{padding:1rem}.footer-content{flex-wrap:wrap;justify-content:center;gap:1rem 2rem;padding:0 1.5rem}.footer-section{flex:0 0 auto;min-width:140px;align-items:center;text-align:center;margin-bottom:0.5rem}}@media(max-width:540px){.footer-content{flex-direction:column;align-items:center;gap:0.5rem}.footer-section{min-width:auto;width:100%;max-width:280px}}@media(max-width:420px){header{padding:0.5em 0.75em}.main-nav{flex-wrap:wrap;position:relative;height:65px;padding:0.5em}.logo-image{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;max-width:30vw;max-height:30vw}.lang-flag{font-size:24px}.cta-button{left:auto;right:1.5rem;transform:none;bottom:3.5rem}.menu-btn{font-size:1.6em}.feature-list{display:none}.hero-content{top:8%;bottom:auto;padding:0 1rem}.about-section,.services-section,.contact-container,.cards-container,.route-detail-container{padding:1.5rem 0.75rem}.card-content{padding:1rem}.footer-content{padding:0 1rem}.footer-section a{font-size:0.9em}.social-links a img{width:24px;height:24px}.cookie-consent-modal{width:95%;margin:1rem}.cookie-consent-header{padding:1rem 1rem 0 1rem}.cookie-consent-content{padding:1rem}.cookie-consent-actions{padding:0 1rem 1rem 1rem;flex-direction:column}.cookie-btn{width:100%;padding:1rem}}@media(max-width:380px){.logo-image{width:70px;height:70px;max-width:28vw;max-height:28vw}.lang-flag{font-size:22px}.about-section,.services-section,.contact-container,.cards-container,.route-detail-container{padding:1rem 0.5rem}.card-content{padding:0.75rem}.main-nav{padding:0.4em}.footer-content{padding:0 1em}.footer-section a{font-size:0.85em}.social-links a img{width:22px;height:22px}.cookie-consent-header h2{font-size:1.3rem}.cookie-option-header{flex-direction:column;align-items:flex-start;gap:0.5rem}.cookie-option-header h3{font-size:1rem}}@media(max-width:360px){header{padding:0.4em 0.6em}.main-nav{height:60px}.logo-image{width:65px;height:65px;max-width:25vw;max-height:25vw}.lang-flag{font-size:20px}.about-section,.services-section,.contact-container,.cards-container,.route-detail-container{padding:0.75rem 0.25rem}.card-content{padding:0.5rem}.main-nav{padding:0.25em}.footer-content{padding:0 0.5em}.cta-button{right:1rem;bottom:3rem}.side-menu a{font-size:0.95em}.menu-footer .social-icons a img{width:20px;height:20px}}