/* Map page specific styles */ .map-container { height: calc(100dvh - 140px); margin: -16px; margin-bottom: 1rem; position: relative; } /* Fullscreen map styles */ .fullscreen-container { position: absolute; top: 0; left: 0; width: 100vw; height: 100dvh; padding: 0; margin: 0; max-width: none; } .fullscreen-map { width: 100%; height: 100%; } .fullscreen-loading { display: flex; justify-content: center; align-items: center; height: 100dvh; width: 100vw; font-size: 1.8rem; font-weight: 600; color: var(--text-color); } /* Map marker and popup styles */ .stop-marker { box-shadow: 0 0 5px rgba(0, 0, 0, 0.3); transition: all 0.2s ease-in-out; } .stop-marker:hover { transform: scale(1.2); } .maplibregl-popup { max-width: 250px; } .maplibregl-popup-content { padding: 12px; border-radius: 8px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); } .popup-line-icons { display: flex; flex-wrap: wrap; margin: 6px 0; gap: 5px; } .popup-line { display: inline-block; background-color: var(--button-background-color); color: white; padding: 2px 6px; margin-right: 4px; border-radius: 4px; font-size: 0.8rem; font-weight: 500; } .popup-link { display: block; margin-top: 8px; color: var(--button-background-color); text-decoration: none; font-weight: 500; } .popup-link:hover { text-decoration: underline; }