*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #2c3e50;--secondary-color: #3498db;--success-color: #27ae60;--error-color: #e74c3c;--warning-color: #f39c12;--background-color: #ecf0f1;--text-color: #2c3e50;--border-color: #bdc3c7;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15);--marker-default: #3498db;--marker-reference: #e74c3c;--marker-hover: #2980b9;--label-bg: #ffffff;--label-border: #2c3e50;--label-text: #2c3e50}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--text-color);background-color:var(--background-color);line-height:1.6}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.app-header{background-color:var(--primary-color);color:#fff;padding:1rem 2rem;box-shadow:var(--shadow);z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;gap:2rem}.header-text{flex:1}.app-header h1{font-size:1.75rem;font-weight:600;margin-bottom:.25rem}.subtitle{font-size:.9rem;opacity:.9}.reference-indicator{display:flex;flex-direction:column;align-items:flex-end;padding:.5rem 1rem;background:#ffffff1a;border-radius:4px;border-left:3px solid var(--error-color)}.reference-indicator.hidden{display:none}.reference-label{font-size:.75rem;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.reference-name{font-size:1rem;font-weight:600;margin-top:.25rem}.main-content{flex:1;position:relative;overflow:hidden}.loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:2rem;border-radius:8px;box-shadow:var(--shadow-lg);text-align:center;z-index:1000}.loading-indicator.hidden{display:none}.spinner{width:40px;height:40px;margin:0 auto 1rem;border:4px solid var(--border-color);border-top-color:var(--secondary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-container{position:absolute;top:1rem;left:50%;transform:translate(-50%);max-width:500px;width:90%;z-index:1000}.error-container.hidden{display:none}.error-content{background:#fff;border-left:4px solid var(--error-color);padding:1rem;border-radius:4px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:.75rem}.error-icon{font-size:1.5rem}.error-message{color:var(--text-color);line-height:1.5}.error-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn-dismiss,.btn-retry{border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s;font-weight:500}.btn-dismiss{background:var(--error-color);color:#fff}.btn-dismiss:hover{background:#c0392b}.btn-retry{background:var(--secondary-color);color:#fff}.btn-retry:hover{background:#2980b9}.btn-retry.hidden{display:none}.info-panel{position:absolute;top:1rem;right:1rem;width:350px;max-width:90vw;background:#fff;border-radius:8px;box-shadow:var(--shadow-lg);z-index:500;animation:slideIn .3s ease-out}.info-panel.hidden{display:none}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.info-panel-content{padding:1.5rem;position:relative}.btn-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:var(--text-color);opacity:.6;transition:opacity .2s;padding:.25rem .5rem}.btn-close:hover{opacity:1}.facility-name{font-size:1.25rem;font-weight:600;margin-bottom:1rem;padding-right:2rem;color:var(--primary-color)}.info-details{display:flex;flex-direction:column;gap:.75rem}.info-item{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;background:#ecf0f14d;border-radius:4px;transition:background .2s ease}.info-item:hover{background:#ecf0f180}.info-label{font-size:.85rem;font-weight:600;color:var(--text-color);opacity:.7;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1rem;color:var(--text-color);font-weight:500}.info-hint{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);text-align:center}.info-hint small{color:var(--text-color);opacity:.7;font-size:.85rem;line-height:1.4}@media (max-width: 768px){.app-header{padding:.75rem 1rem}.header-content{flex-direction:column;align-items:flex-start;gap:.75rem}.reference-indicator{align-items:flex-start;width:100%}.app-header h1{font-size:1.25rem}.subtitle{font-size:.8rem}.info-panel{width:320px;top:.5rem;right:.5rem;max-height:calc(100vh - 1rem);overflow-y:auto}.info-panel-content{padding:1rem}.facility-name{font-size:1.1rem}.error-container{max-width:calc(100vw - 2rem);width:auto}.loading-indicator{padding:1.5rem;max-width:90vw}}@media (max-width: 480px){.app-header{padding:.5rem .75rem}.app-header h1{font-size:1.1rem}.subtitle{font-size:.75rem}.info-panel{width:calc(100vw - 1rem);left:.5rem;right:.5rem;top:.5rem;max-height:calc(100vh - 1rem)}.info-panel-content{padding:.875rem}.facility-name{font-size:1rem;margin-bottom:.75rem}.info-details{gap:.5rem}.info-label{font-size:.75rem}.info-value{font-size:.9rem}.btn-close{font-size:1.75rem;top:.25rem;right:.25rem}.error-container{top:.5rem;max-width:calc(100vw - 1rem)}.error-content{padding:.875rem;gap:.5rem}.error-icon{font-size:1.25rem}.error-message{font-size:.9rem}.btn-dismiss,.btn-retry{padding:.4rem .75rem;font-size:.85rem}.loading-indicator{padding:1.25rem;font-size:.9rem}.spinner{width:32px;height:32px}}@media (min-width: 1200px){.info-panel{width:400px}.app-header h1{font-size:2rem}.subtitle{font-size:1rem}}.visually-hidden,.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}button:focus-visible,.btn-close:focus-visible,.btn-dismiss:focus-visible,.btn-retry:focus-visible{outline:3px solid var(--secondary-color);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--primary-color);color:#fff;padding:8px;text-decoration:none;z-index:10000}.skip-link:focus{top:0}@media (prefers-contrast: high){.info-panel,.error-content,.loading-indicator{border:2px solid var(--text-color)}.btn-close,.btn-dismiss,.btn-retry{border:2px solid currentColor}.distance-label{border-width:3px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.spinner{animation:none;border-top-color:var(--secondary-color)}.marker-icon.reference{animation:none}}.marker-icon.reference:before{content:"★";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:16px;font-weight:700}@media (prefers-color-scheme: dark){:root{--background-color: #1a1a1a;--text-color: #e0e0e0;--primary-color: #34495e;--border-color: #555;--label-bg: #2c2c2c;--label-text: #ffffff}body{background-color:var(--background-color);color:var(--text-color)}.info-panel,.error-content,.loading-indicator{background:#2c2c2c;color:var(--text-color)}.info-item{background:#ffffff0d}.info-item:hover{background:#ffffff1a}}.map-container{width:100%;height:100%;position:relative}.map-controls{position:absolute;top:10px;left:50%;transform:translate(-50%);background:#fff;padding:.5rem 1rem;border-radius:4px;box-shadow:0 2px 6px #0000004d;z-index:10}.distance-label{background:var(--label-bg, white);border:2px solid var(--label-border, #2c3e50);border-radius:4px;padding:5px 10px;font-size:12px;font-weight:700;color:var(--label-text, #2c3e50);white-space:nowrap;box-shadow:0 2px 6px #0000004d;pointer-events:none;-webkit-user-select:none;user-select:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;letter-spacing:.3px;text-shadow:0 0 2px rgba(255,255,255,.8)}.distance-label.error{background:#fee;border-color:#e74c3c;color:#c0392b;font-weight:700}.custom-marker-label{background:#fff;border:1px solid #ccc;border-radius:3px;padding:2px 6px;font-size:11px;font-weight:500;box-shadow:0 1px 3px #0003}.route-polyline{stroke:var(--secondary-color, #3498db);stroke-width:3;stroke-opacity:.7}.route-polyline.reference{stroke:var(--marker-reference, #e74c3c);stroke-width:4;stroke-opacity:.8}.route-polyline.error{stroke:var(--error-color, #e74c3c);stroke-width:2;stroke-opacity:.5;stroke-dasharray:5,5}.marker-icon{width:32px;height:32px;background-color:var(--marker-default, #3498db);border:3px solid white;border-radius:50%;box-shadow:0 3px 8px #0006;cursor:pointer;transition:transform .2s ease}.marker-icon:hover{transform:scale(1.1);background-color:var(--marker-hover, #2980b9)}.marker-icon.reference{background-color:var(--marker-reference, #e74c3c);width:40px;height:40px;border-width:4px;box-shadow:0 4px 12px #e74c3c80;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 4px 12px #e74c3c80}50%{box-shadow:0 4px 20px #e74c3ccc}}.marker-icon:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#fff;border-radius:50%}.map-container.loading{background:#ecf0f1;display:flex;align-items:center;justify-content:center}.map-container.loading:before{content:"Loading map...";color:#7f8c8d;font-size:1.2rem}.map-container.error{background:#fee;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:2rem;text-align:center}.map-container.error:before{content:"⚠️";font-size:3rem;margin-bottom:1rem}.map-container.error:after{content:"Failed to load map. Please check your internet connection and API key.";color:#e74c3c;font-size:1rem}@media (max-width: 768px){.map-container{min-height:400px}.distance-label{font-size:11px;padding:3px 6px;border-width:1.5px}.marker-icon{width:28px;height:28px}.marker-icon.reference{width:36px;height:36px}.map-controls{padding:.4rem .75rem;font-size:.9rem}}@media (max-width: 480px){.map-container{min-height:300px}.distance-label{font-size:10px;padding:2px 5px;border-width:1px}.marker-icon{width:24px;height:24px;border-width:2px}.marker-icon.reference{width:32px;height:32px;border-width:3px}.map-controls{padding:.3rem .5rem;font-size:.85rem;top:5px}.custom-marker-label{font-size:10px;padding:1px 4px}}@media (min-width: 1200px){.distance-label{font-size:13px;padding:5px 10px}.marker-icon{width:36px;height:36px}.marker-icon.reference{width:44px;height:44px}}@media (max-width: 768px) and (orientation: landscape){.info-panel{max-height:calc(100vh - 1rem);overflow-y:auto}.map-container{min-height:250px}}@media (hover: none) and (pointer: coarse){.btn-close{padding:.5rem;min-width:44px;min-height:44px}.btn-dismiss,.btn-retry{min-height:44px;padding:.5rem 1rem}.distance-label,.marker-icon{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.marker-icon{width:36px;height:36px}.marker-icon.reference{width:44px;height:44px}}.map-container:focus{outline:3px solid var(--secondary-color, #3498db);outline-offset:-3px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media print{.map-controls,.info-panel,.loading-indicator,.error-container{display:none!important}.map-container{page-break-inside:avoid}}
