*{box-sizing:border-box;margin:0;padding:0}html,body,#map{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#coord-bar{position:fixed;top:12px;left:50%;transform:translate(-50%);background:#fffffff2;border-radius:10px;box-shadow:0 2px 8px #0003;padding:8px 16px;z-index:1000;font-size:12px;color:#333;pointer-events:none;display:none;max-width:90vw;text-align:center;line-height:1.5}#coord-bar.show{display:block}#coord-bar .coord-addr{font-weight:500;font-size:13px;color:#111}#coord-bar .coord-latlng{font-family:monospace;font-size:11px;color:#888}#tile-preview{position:fixed;z-index:9999;pointer-events:none;display:none;background:#fff;border:2px solid #1a73e8;border-radius:4px;box-shadow:0 4px 12px #0000004d}#tile-preview img{display:block;width:256px;height:256px}.routing-popup .leaflet-popup-content{margin:12px 14px;min-width:200px}.routing-popup .rp-name{font-weight:600;font-size:14px;color:#111;margin-bottom:2px}.routing-popup .rp-display{font-size:11px;color:#666;margin-bottom:4px;line-height:1.4}.routing-popup .rp-coords{font-family:monospace;font-size:10px;color:#999;margin-bottom:8px}.routing-popup .rp-actions{display:flex;gap:6px}.routing-popup .rp-btn{flex:1;padding:8px 10px;border:1px solid #e5e5e5;border-radius:8px;background:#f8f9fa;color:#1a73e8;cursor:pointer;font-size:13px;font-weight:500}.routing-popup .rp-btn:hover{background:#e8f0fe;border-color:#1a73e8}.routing-panel{position:fixed;top:12px;left:12px;width:380px;max-width:94vw;max-height:calc(100vh - 24px);background:transparent;z-index:1002;display:flex;flex-direction:column;gap:10px;transition:transform .2s,opacity .2s}.routing-panel.hidden{transform:translate(-120%);opacity:0;pointer-events:none}.routing-panel>*{background:#fff;border-radius:14px;box-shadow:0 3px 14px #0000001f}.rp-header{display:flex;align-items:center;gap:6px;padding:10px 12px}.rp-header h3{margin:0;font-size:17px;font-weight:600;color:#111}.rp-header #routing-close{width:32px;height:32px;border:none;background:none;cursor:pointer;font-size:20px;color:#333;border-radius:50%}.rp-header #routing-close:hover{background:#f0f0f0}.rp-endpoints{display:flex;align-items:center;gap:8px;padding:14px;position:relative}.rp-endpoint-rows{flex:1;position:relative}.rp-row{display:flex;align-items:center;gap:10px;padding:4px 0}.rp-row input{flex:1;border:none;outline:none;padding:8px 0;font-size:14px;border-bottom:1px solid #e5e5e5;background:transparent;color:#202124}.rp-row input:focus{border-bottom-color:#1a73e8}.rp-row input[readonly]{color:#202124;cursor:default}.rp-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;position:relative}.rp-dot-origin{background:#ea4335;border:3px solid #fff;box-shadow:0 0 0 1px #ea4335}.rp-dot-dest{width:18px;height:18px;background:transparent;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%231a73e8' d='M12 2C8 2 5 5 5 9c0 5 7 13 7 13s7-8 7-13c0-4-3-7-7-7zm0 9.5a2.5 2.5 0 110-5 2.5 2.5 0 010 5z'/></svg>");background-size:contain;background-repeat:no-repeat}.rp-divider{position:absolute;left:6px;top:22px;bottom:22px;width:2px;background-image:linear-gradient(#bbb 50%,transparent 50%);background-size:2px 6px;background-repeat:repeat-y}.rp-swap{flex-shrink:0;width:32px;height:32px;border:1px solid #dadce0;background:#fff;border-radius:50%;cursor:pointer;font-size:16px;color:#333}.rp-swap:hover{background:#f0f0f0}.suggestions{position:absolute;top:100%;left:24px;right:0;margin-top:4px;list-style:none;padding:0;max-height:240px;overflow-y:auto;background:#fff;border:1px solid #e5e5e5;border-radius:10px;box-shadow:0 4px 16px #00000024;z-index:10}.suggestions.hidden{display:none}.suggestions li{padding:10px 12px;cursor:pointer;font-size:12px;line-height:1.4;border-bottom:1px solid #f0f0f0}.suggestions li:last-child{border-bottom:none}.suggestions li:hover{background:#f5f7fa}.suggestions li strong{font-size:13px;color:#111;font-weight:600}.suggestions li small{color:#666}.rp-vehicles{display:flex;gap:8px;padding:10px 12px}.veh-btn{flex:1;height:56px;border:none;border-radius:14px;background:#f1f3f4;color:#5f6368;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.veh-btn:hover{background:#e8eaed}.veh-btn.active{background:#1a73e8;color:#fff}.rp-summary{padding:12px 16px;font-size:15px;font-weight:600}.rp-summary.hidden{display:none}.rp-summary .rs-time{color:#1e8e3e}.rp-summary .rs-dist{color:#1a73e8;margin-left:6px;font-weight:600}.rp-summary .rs-loading{color:#5f6368;font-weight:400;display:inline-flex;align-items:center;gap:8px}.rp-spinner{display:inline-block;width:16px;height:16px;border:2px solid #dadce0;border-top-color:#1a73e8;border-radius:50%;animation:rp-spin .8s linear infinite}.rp-input-spinner{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:14px;height:14px;border:2px solid #dadce0;border-top-color:#1a73e8;border-radius:50%;animation:rp-spin .8s linear infinite;pointer-events:none}@keyframes rp-spin{to{transform:rotate(360deg)}}.rp-row{position:relative}.rp-summary .rs-err{color:#d93025;font-weight:400;font-size:13px}.rp-summary .rs-badge-fb{display:inline-block;margin-left:8px;padding:2px 6px;background:#fff3cd;color:#856404;border-radius:4px;font-size:11px;font-weight:400}.rp-steps{list-style:none;padding:8px 4px;margin:0;overflow-y:auto;max-height:45vh}.rp-steps.hidden{display:none}.rp-steps .step{display:flex;gap:10px;padding:10px 12px;border-left:2px dashed #dadce0;margin-left:18px;position:relative}.rp-steps .step:last-child{border-left-color:transparent}.rp-steps .step-icon{position:absolute;left:-12px;top:8px;width:22px;height:22px;border-radius:50%;background:#fff;border:2px solid #ea4335;display:flex;align-items:center;justify-content:center;font-size:11px;color:#111}.rp-steps .step:not(:first-child) .step-icon{border-color:#dadce0;color:#5f6368;font-size:13px}.rp-steps .step-body{flex:1}.rp-steps .step-text{font-size:14px;color:#202124;font-weight:500;line-height:1.35}.rp-steps .step-meta{font-size:12px;color:#5f6368;margin-top:2px}.rp-gmaps-btn{padding:12px 16px;border:none;border-radius:14px;background:#1a73e8;color:#fff;cursor:pointer;font-size:14px;font-weight:500}.rp-gmaps-btn:hover{background:#1765cc}.rp-dest-marker{background:transparent!important;border:none!important}:root{--tb-bg: #ffffff;--tb-border: #e5e7eb;--tb-icon: #475569;--tb-hover: #f1f5f9;--tb-active-bg: #1a73e8;--tb-active-soft: #e8f0fe;--tb-active-fg: #ffffff;--tb-shadow: 0 4px 16px rgba(15, 23, 42, .12);--tb-text: #0f172a;--tb-text-soft: #475569;--tb-radius: 12px;--tb-radius-btn: 10px}#toolbar{position:fixed;right:56px;bottom:12px;z-index:1000;display:flex;flex-direction:row;align-items:center;gap:2px;padding:4px 8px;background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:999px;box-shadow:var(--tb-shadow)}.tb-btn{width:36px;height:36px;border:none;background:transparent;border-radius:50%;color:var(--tb-icon);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background-color .15s,color .15s}.tb-btn svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}.tb-btn:hover{background:var(--tb-hover);color:var(--tb-text)}.tb-btn.active{background:var(--tb-active-bg);color:var(--tb-active-fg)}.tb-sep{width:1px;height:24px;background:var(--tb-border);margin:0 2px}#opacity-chip{position:fixed;right:12px;bottom:12px;z-index:1000;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:999px;box-shadow:var(--tb-shadow);width:34px;height:170px}#opacity-chip label{display:none}#opacity-chip input[type=range]{-webkit-appearance:slider-vertical;-moz-appearance:slider-vertical;appearance:slider-vertical;writing-mode:vertical-lr;direction:rtl;width:6px;height:120px;accent-color:var(--tb-active-bg);margin:0;padding:0}#opacity-chip #opacity-value{font-variant-numeric:tabular-nums;color:var(--tb-text);font-weight:600;font-size:11px;min-width:24px;text-align:center}.popup-panel{position:fixed;right:56px;bottom:60px;z-index:1001;display:none;min-width:260px;max-width:360px;max-height:70vh;overflow-y:auto;padding:14px 16px;background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:var(--tb-radius);box-shadow:var(--tb-shadow);color:var(--tb-text)}.popup-panel.show{display:block}.popup-panel label{display:block;font-size:12px;font-weight:600;color:var(--tb-text-soft);margin-bottom:8px;letter-spacing:.2px}.popup-panel input[type=range]{width:100%;accent-color:var(--tb-active-bg)}.popup-panel select,.popup-panel input[type=text]{width:100%;padding:6px 8px;border:1px solid var(--tb-border);border-radius:6px;font-size:13px;color:var(--tb-text);background:#fff;outline:none}.popup-panel select:focus,.popup-panel input[type=text]:focus{border-color:var(--tb-active-bg)}#sources-chip{position:fixed;top:12px;left:12px;z-index:1000;display:flex;align-items:center;gap:4px;padding:4px 6px;background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:999px;box-shadow:var(--tb-shadow)}#sources-chip select{border:none;background:transparent;font-size:13px;color:var(--tb-text);padding:6px 10px;cursor:pointer;outline:none;border-radius:999px}#sources-chip select:hover{background:var(--tb-hover)}#sources-chip #source{max-width:140px}#sources-chip #province{max-width:160px}#sources-chip .chip-sep{width:1px;height:20px;background:var(--tb-border)}#zoom-info{position:fixed;left:12px;bottom:12px;z-index:1000;padding:4px 10px;background:#0f172ac7;color:#fff;font-size:12px;font-weight:500;border-radius:999px;box-shadow:var(--tb-shadow);font-variant-numeric:tabular-nums}#measure-bar{position:fixed;left:12px;bottom:48px;background:#1a73e8f2;color:#fff;border-radius:8px;padding:6px 14px;z-index:1001;font-size:13px;font-weight:500;display:none;white-space:nowrap;box-shadow:var(--tb-shadow)}#measure-bar.show{display:block}.measure-mode-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;margin:4px 0;border:1px solid var(--tb-border);border-radius:8px;background:#fff;cursor:pointer;font-size:13px;color:var(--tb-text);text-align:left}.measure-mode-btn:hover{background:var(--tb-hover);border-color:var(--tb-active-bg)}.measure-mode-btn.active{background:var(--tb-active-soft);border-color:var(--tb-active-bg);color:var(--tb-active-bg)}.legend-group{font-weight:700;font-size:11px;color:var(--tb-active-bg);margin:10px 0 4px;text-transform:uppercase;letter-spacing:.5px}.legend-item{display:flex;align-items:center;gap:8px;padding:3px 0;font-size:12px}.legend-swatch{width:18px;height:18px;border-radius:4px;border:1px solid var(--tb-border);flex-shrink:0}.legend-code{font-weight:700;color:var(--tb-text);min-width:38px;font-size:11px}.legend-name{color:var(--tb-text-soft)}.leaflet-control-zoom{display:none!important}.leaflet-control-attribution{font-size:10px}@media (max-width: 640px){#toolbar{right:50px;bottom:8px;padding:3px 6px;gap:1px}.tb-btn{width:32px;height:32px}.tb-btn svg{width:16px;height:16px}#opacity-chip{right:8px;bottom:8px;width:30px;height:150px}#opacity-chip input[type=range]{height:104px}.popup-panel{left:8px!important;right:8px!important;bottom:52px!important;max-width:none}#sources-chip{top:8px;left:8px}#sources-chip #source{max-width:110px}#sources-chip #province{max-width:120px}#zoom-info{left:8px;bottom:8px}#measure-bar{left:8px;bottom:48px}}
