:root{--bg: #eef1f5;--panel: #ffffff;--panel-2: #f4f6f9;--panel-3: #eceff4;--input: #f7f9fb;--line: rgba(15, 23, 42, .1);--line-2: rgba(15, 23, 42, .16);--text: #16202e;--muted: #5a6678;--faint: #93a0b4;--accent: #3b5bdb;--accent-h: #4263eb;--accent-2: #b07bff;--on-accent: #ffffff;--accent-soft: rgba(59, 91, 219, .12);--warn: #b07d12;--warn-soft: rgba(224, 150, 42, .14);--crit: #e5484d;--ok: #2fbf71;--overlay: rgba(255, 255, 255, .9);--shadow-color: rgba(20, 28, 45, .16);--error: #c0362c;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 24px;--s-6: 32px;--r-sm: 8px;--r: 9px;--r-lg: 14px;--pill: 999px;--nav-h: 56px;--shadow-1: 0 1px 2px var(--shadow-color);--shadow-2: 0 18px 50px var(--shadow-color);--font-display: "Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-body: "IBM Plex Sans", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans TC", sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;font-family:var(--font-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;color-scheme:light}[data-theme=dark]{--bg: #0c111b;--panel: #0e1521;--panel-2: #131b28;--panel-3: #1a2433;--input: #0a0f18;--line: rgba(255, 255, 255, .08);--line-2: rgba(255, 255, 255, .14);--text: #eef2f8;--muted: #aab6c8;--faint: #5d6b80;--accent: #5b7cfa;--accent-h: #6e8bff;--accent-2: #b07bff;--on-accent: #ffffff;--accent-soft: rgba(91, 124, 250, .16);--warn: #f2b134;--warn-soft: rgba(242, 177, 52, .12);--crit: #ff6166;--ok: #2fbf71;--overlay: rgba(14, 21, 33, .92);--shadow-color: rgba(0, 0, 0, .4);--error: #ff8a82;color-scheme:dark}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]){--bg: #0c111b;--panel: #0e1521;--panel-2: #131b28;--panel-3: #1a2433;--input: #0a0f18;--line: rgba(255, 255, 255, .08);--line-2: rgba(255, 255, 255, .14);--text: #eef2f8;--muted: #aab6c8;--faint: #5d6b80;--accent: #5b7cfa;--accent-h: #6e8bff;--accent-2: #b07bff;--on-accent: #ffffff;--accent-soft: rgba(91, 124, 250, .16);--warn: #f2b134;--warn-soft: rgba(242, 177, 52, .12);--crit: #ff6166;--ok: #2fbf71;--overlay: rgba(14, 21, 33, .92);--shadow-color: rgba(0, 0, 0, .4);--error: #ff8a82;color-scheme:dark}}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);line-height:1.5;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:var(--pill)}[id^=kofi-widget-overlay],[id^=kofi-wo-container]{display:none!important}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.app{display:flex;flex-direction:column;height:100vh;height:100dvh}.app-header{height:58px;flex:0 0 auto;padding:0 18px;padding-top:env(safe-area-inset-top);padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right));border-bottom:1px solid var(--line);background:var(--panel);display:flex;align-items:center;justify-content:space-between;gap:var(--s-3)}.app-title{min-width:0;display:flex;align-items:baseline;gap:12px}.app-header h1{margin:0;font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.01em;color:var(--text);white-space:nowrap}.app-header p{margin:0;color:var(--faint);font-size:11.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-controls{display:flex;align-items:center;gap:var(--s-2);flex:0 0 auto}.saved-toggle,.lang-select{background:transparent;color:var(--muted);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:7px 11px;font:inherit;font-size:12.5px;min-height:34px;cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s,background .15s}.saved-toggle:hover{border-color:var(--accent);color:var(--accent)}.saved-toggle b{font-family:var(--font-mono);font-weight:500;color:var(--accent)}.theme-toggle{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--muted);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:7px 12px;min-height:34px;font:inherit;font-size:12.5px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:border-color .15s,color .15s}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.theme-dot{width:12px;height:12px;border-radius:50%;border:1px solid var(--line-2);flex:0 0 auto}.theme-dot.is-light{background:#f2c14e;border-color:#f2c14e}.theme-dot.is-dark{background:#2b3550;border-color:var(--line-2)}.theme-dot.is-auto{background:linear-gradient(90deg,#f2c14e 50%,#2b3550 50%)}.app-credit{margin-top:var(--s-4);padding-top:var(--s-3);border-top:1px solid var(--line);color:var(--faint);font-size:11px;text-align:center}.saved-list{margin-bottom:var(--s-4)}.saved-list h2{margin:0 0 var(--s-2)}.saved-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--s-3)}.saved-header h2{margin:0}.saved-actions-header{display:flex;gap:var(--s-2);align-items:center}.saved-list ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--s-2)}.saved-list li{display:flex;flex-direction:column;gap:var(--s-1)}.saved-item{flex:1;display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-2);text-align:left;background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:var(--r);padding:12px 13px;min-height:44px;cursor:pointer;transition:border-color .15s,background .15s}.saved-item:hover{border-color:var(--accent)}.saved-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.saved-name{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-notes{font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-date{color:var(--faint);font-size:10.5px;font-family:var(--font-mono);flex:0 0 auto}.saved-item-editing{flex:1;display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-2);background:var(--panel-2);border:1px solid var(--accent);border-radius:var(--r);padding:12px 13px;min-height:44px}.saved-item-editing input{flex:1;border:none;background:transparent;color:var(--text);font-size:14px;outline:none;padding:0;font-family:inherit}.saved-actions{display:flex;gap:var(--s-3);padding-left:13px}.saved-modal{position:relative;width:min(420px,100%);max-height:84vh;overflow-y:auto;padding:var(--s-5);background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--shadow-2)}.saved-modal .saved-list{margin:0}.result-actions{display:flex;gap:7px;align-items:stretch;margin-top:var(--s-4);flex-wrap:wrap}.result-actions>*{flex:1;min-width:64px}.result-actions .gmaps-link{margin-top:0}.layout{display:flex;flex:1;min-height:0;position:relative}.sidebar{flex:0 0 372px;width:372px;display:flex;flex-direction:column;min-height:0;border-right:1px solid var(--line);background:var(--panel)}.sidebar-scroll{flex:1;overflow-y:auto;padding:var(--s-4) var(--s-4) var(--s-3)}.sidebar-foot{flex:0 0 auto;padding:13px var(--s-4) calc(13px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--panel)}.support-line{text-align:center;margin-top:10px;font-size:11px;color:var(--faint)}.support-line a{color:#f2b134;text-decoration:none;cursor:pointer}.support-line a:hover{text-decoration:underline}.map-wrap{flex:1;min-width:0;position:relative}.map{height:100%;width:100%}.map-stats{position:absolute;top:16px;left:16px;right:16px;z-index:1000;display:flex;align-items:stretch;background:var(--overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line-2);border-radius:11px;overflow:hidden;box-shadow:var(--shadow-1)}.map-stat{flex:1;padding:11px 16px;min-width:0}.map-stat+.map-stat{border-left:1px solid var(--line)}.map-stat-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--faint);text-transform:uppercase;white-space:nowrap}.map-stat-value{font-family:var(--font-display);font-weight:600;font-size:18px;color:var(--text);margin-top:2px;white-space:nowrap}.map-stat.is-warn{background:var(--warn-soft)}.map-stat.is-warn .map-stat-label,.map-stat.is-warn .map-stat-value{color:var(--warn)}.mobile-nav{display:none;border-top:1px solid var(--line);background:var(--panel);padding:8px 6px;padding-bottom:calc(8px + env(safe-area-inset-bottom));z-index:1200}.mobile-nav button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:none;border:none;border-radius:0;color:var(--faint);min-height:var(--nav-h);padding:4px;font-size:11px}.mobile-nav button.active{color:var(--accent)}.mobile-nav svg{width:22px;height:22px}.map-legend{position:absolute;bottom:16px;left:16px;z-index:1000;background:var(--overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line-2);border-radius:11px;padding:12px 14px;max-width:240px;box-shadow:var(--shadow-1);font-size:11.5px;color:var(--muted)}.map-legend-title{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:9px}.map-legend ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}.map-legend li{display:flex;align-items:baseline;gap:9px}.map-legend .swatch{flex:0 0 auto;width:16px;height:3px;border-radius:2px;transform:translateY(-2px)}.map-legend .legend-name{font-weight:600;flex:0 0 auto;color:var(--text)}.map-legend .legend-charge{color:var(--muted)}.leaflet-tooltip.leaflet-tooltip-top{font-size:12px}.map-basemap-toggle{position:absolute;top:16px;right:16px;z-index:1000;display:flex;gap:2px;padding:3px;background:var(--overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line-2);border-radius:10px;box-shadow:var(--shadow-1)}.map-basemap-toggle button{border:none;background:none;cursor:pointer;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:5px 9px;border-radius:7px}.map-basemap-toggle button.active{background:var(--accent, var(--line-2));color:var(--text)}.leaflet-control-zoom a{background:var(--panel)!important;color:var(--muted)!important;border-color:var(--line)!important}.leaflet-control-zoom a:hover{color:var(--accent)!important}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:var(--panel);color:var(--text);box-shadow:var(--shadow-2)}.leaflet-bar{border-radius:var(--r-sm);overflow:hidden}.map-wrap .leaflet-top{top:80px}h2{font-family:var(--font-display);font-size:17px;font-weight:700;margin:0 0 var(--s-2);letter-spacing:-.01em}h3{font-family:var(--font-mono);font-size:10.5px;font-weight:500;margin:var(--s-4) 0 9px;color:var(--faint);text-transform:uppercase;letter-spacing:.1em}.hint{color:var(--muted);font-size:12.5px;margin:0 0 var(--s-3);line-height:1.55}.planner h2{display:none}.planner>.hint{display:none}.classic-routes{margin-bottom:var(--s-4)}.classic-routes-toggle{width:100%}.classic-routes-toggle.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.route-selector{margin-top:var(--s-3)}.route-selector h2{font-size:15px;margin:0 0 var(--s-1)}.route-selector .hint{margin:0 0 var(--s-3)}.route-cards{display:flex;flex-direction:column;gap:var(--s-2)}.route-card{border:1px solid var(--line-2);border-radius:var(--r);background:var(--panel);padding:var(--s-3);cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .05s}.route-card:hover{border-color:var(--accent);box-shadow:var(--shadow-1)}.route-card:active{transform:scale(.995)}.route-card-selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent) inset}.route-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--s-2);margin-bottom:var(--s-2)}.route-card-name{margin:0;font-size:14px;font-weight:600}.route-card-difficulty{flex:0 0 auto;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:2px 8px;border-radius:var(--pill);background:var(--panel-3);color:var(--muted)}.route-card-difficulty-easy{background:#2fbf7124;color:var(--ok)}.route-card-difficulty-moderate{background:var(--warn-soft);color:var(--warn)}.route-card-difficulty-challenging{background:#e0833a29;color:#c2641a}.route-card-difficulty-difficult{background:#e5484d24;color:var(--crit)}.route-card-details{display:flex;flex-direction:column;gap:var(--s-1);font-size:13px}.route-card-detail{display:flex;gap:var(--s-2)}.route-card-label{flex:0 0 auto;color:var(--faint)}.route-card-value{color:var(--text);font-weight:500}.route-card-route{font-weight:400}.route-card-highlights{margin-top:var(--s-2)}.route-card-highlight-list{display:flex;flex-wrap:wrap;gap:var(--s-1);margin-top:var(--s-1)}.route-card-highlight,.route-card-highlight-more{font-size:12px;padding:2px 8px;border-radius:var(--pill);background:var(--panel-2);border:1px solid var(--line)}.route-card-highlight-more{color:var(--faint)}.vehicle-class-selector{margin-bottom:9px}.vehicle-class-selector label,.date-input-group label{display:block;margin-bottom:6px;font-family:var(--font-mono);font-size:9.5px;font-weight:500;color:var(--faint);text-transform:uppercase;letter-spacing:.1em}.vehicle-class-selector select{width:100%;padding:10px 36px 10px 12px;border-radius:var(--r);border:1px solid var(--line-2);background-color:var(--input);color:var(--text);font:inherit;font-size:16px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2393a0b4' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;transition:border-color .15s,box-shadow .15s}.vehicle-class-selector select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.date-selector{display:flex;gap:9px;margin-bottom:var(--s-4)}.date-input-group{display:flex;flex-direction:column;gap:6px;min-width:0;background:var(--input);border:1px solid var(--line-2);border-radius:var(--r);padding:8px 11px}.date-input-group:first-child{flex:1.4}.date-input-group:last-child{flex:1}.date-input-group input{width:100%;padding:0;border:none;background:transparent;color:var(--text);font-family:var(--font-mono);font-size:13px}.date-input-group input:focus{outline:none}.date-input-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6}[data-theme=dark] .date-input-group input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.8)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .date-input-group input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.8)}}.stops{position:relative;list-style:none;padding:0;margin:0}.stops:before{content:"";position:absolute;left:11px;top:16px;bottom:16px;width:2px;background:var(--line-2)}.stops>li{position:relative;display:grid;grid-template-columns:24px 1fr;gap:11px;align-items:start}.stops>li+li{margin-top:13px}.stop-badge{z-index:1;width:24px;height:24px;border-radius:50%;background:var(--panel);border:2px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;color:var(--muted);margin-top:2px}.stop-badge-origin{border-color:var(--ok);color:var(--ok)}.stop-badge-dest{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.stop-row{min-width:0}.stop-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.role{font-family:var(--font-mono);font-size:9.5px;font-weight:500;color:var(--faint);text-transform:uppercase;letter-spacing:.12em}.stops>li:first-child .stop-head{display:none}.combo{position:relative;display:flex;align-items:center;gap:6px}.combo input{flex:1;padding:9px 11px;border-radius:var(--r);border:1px solid var(--line-2);background:var(--input);color:var(--text);font:inherit;font-size:16px;transition:border-color .15s,box-shadow .15s}.combo input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.stops>li:last-child .combo input{border-color:var(--accent)}.combo .ok{color:var(--ok);font-family:var(--font-mono);font-size:11px;font-weight:500}.suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:1000;list-style:none;margin:0;padding:4px;max-height:240px;overflow-y:auto;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-sm);box-shadow:var(--shadow-2)}.suggestions li{padding:10px 9px;border-radius:6px;font-size:13px;cursor:pointer}.suggestions li:hover{background:var(--accent);color:var(--on-accent)}.suggestions li.suggestions-head{display:flex;justify-content:space-between;align-items:center;padding:4px 8px 6px;font-family:var(--font-mono);font-size:10px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;cursor:default}.suggestions li.suggestions-head:hover{background:none;color:var(--faint)}.suggestions li.suggestions-head .link{font-size:11px}.planner-actions{display:flex;flex-direction:column;gap:var(--s-2);margin-top:var(--s-4)}button{font:inherit;cursor:pointer;border-radius:var(--r-sm);border:1px solid var(--line-2);padding:9px 14px;min-height:38px;color:var(--text);background:transparent;transition:background .15s,border-color .15s,color .15s,opacity .15s,filter .15s}button.primary{background:var(--accent);border-color:transparent;color:var(--on-accent);font-weight:600;width:100%;padding:13px;font-size:14px;border-radius:10px}button.primary:hover:not(:disabled){background:var(--accent-h)}button.primary:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:transparent;color:var(--muted);border:1px dashed var(--line-2);width:100%;font-size:12.5px}button.secondary:hover{border-color:var(--accent);color:var(--accent)}.result-actions button.secondary,.result-actions .gmaps-link{border-style:solid}button.link{background:none;border:none;color:var(--accent);padding:6px 2px;min-height:32px;font-size:12px}button.link:hover{color:var(--accent-h)}.gmaps-link,.result-actions button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 12px;border-radius:var(--r-sm);background:transparent;border:1px solid var(--line-2);color:var(--muted);font-size:11.5px;font-weight:600;text-decoration:none;text-align:center;transition:border-color .15s,color .15s}.result-actions button:first-child{background:var(--accent);border-color:transparent;color:var(--on-accent)}.gmaps-link:hover,.result-actions button:hover{border-color:var(--accent);color:var(--accent)}.result-actions button:first-child:hover{background:var(--accent-h);color:var(--on-accent)}.install-banner{display:flex;align-items:center;gap:var(--s-3);margin:var(--s-3);padding:var(--s-3);background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1)}.install-icon{border-radius:var(--r-sm);flex:0 0 auto}.install-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.install-text strong{font-size:14px}.install-text span{font-size:12px;color:var(--muted);line-height:1.45}.install-action{flex:0 0 auto;min-height:38px;padding:8px 14px;width:auto;background:var(--accent);border-color:transparent;color:var(--on-accent);font-weight:600}.install-dismiss{flex:0 0 auto;background:none;border:none;color:var(--muted);min-width:38px;min-height:38px;font-size:15px;padding:0}.install-dismiss:hover{color:var(--text)}.offline-banner{display:flex;align-items:flex-start;gap:var(--s-3);margin:var(--s-3);padding:var(--s-3);background:#fff3cd;border:1px solid #ffc107;border-radius:var(--r-lg);box-shadow:var(--shadow-1)}.offline-icon{flex:0 0 auto;font-size:20px;line-height:1}.offline-text{display:flex;flex-direction:column;gap:6px;min-width:0;flex:1}.offline-text strong{font-size:14px;color:#856404}.offline-text>span{font-size:12px;color:#856404;line-height:1.45}.offline-features{margin:0;padding-left:0;font-size:12px;color:#856404;line-height:1.6;list-style:none}.offline-features li{margin:0}.offline-available{font-size:12px;color:#856404;opacity:.85;font-style:italic}.offline-dismiss{flex:0 0 auto;background:none;border:none;color:#856404;min-width:38px;min-height:38px;font-size:15px;padding:0;align-self:flex-start}.offline-dismiss:hover{color:#533f03;opacity:1}.kofi-header{display:none;align-items:center;flex:0 0 auto;background:#00b9fe;color:#fff;border:1px solid #00b9fe;border-radius:var(--r-sm);padding:7px 11px;min-height:34px;font:inherit;font-size:12.5px;font-weight:600;white-space:nowrap;text-decoration:none}.kofi-header:hover{filter:brightness(1.07)}.help-toggle{width:32px;min-width:32px;height:32px;min-height:32px;padding:0;border-radius:var(--r-sm);font-weight:600;line-height:1;font-size:13px;background:transparent;border:1px solid var(--line-2);color:var(--muted)}.help-toggle:hover{border-color:var(--accent);color:var(--accent)}.tour-backdrop{position:fixed;inset:0;z-index:2000;display:grid;place-items:center;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.tour-spotlight{position:fixed;z-index:2000;border-radius:var(--r);box-shadow:0 0 0 9999px #0000008c;outline:2px solid var(--accent);pointer-events:none}.tour-card{z-index:2001;width:min(360px,calc(100vw - 32px));background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--shadow-2);padding:18px;display:flex;flex-direction:column;gap:var(--s-2)}.tour-card strong{font-family:var(--font-display);font-size:17px;font-weight:600}.tour-card p{font-size:13px;color:var(--muted);line-height:1.55;margin:0}.tour-actions{display:flex;align-items:center;gap:var(--s-2);margin-top:var(--s-3)}.tour-step{font-family:var(--font-mono);font-size:11px;color:var(--faint);margin-left:auto}.tour-actions .primary{flex:0 0 auto;width:auto;padding:8px 16px;font-size:12.5px;border-radius:var(--r-sm)}.tour-actions button:not(.primary){width:auto;padding:8px 14px;font-size:12.5px;border-style:solid;color:var(--muted)}.save-dialog-overlay{position:fixed;inset:0;z-index:2100;display:grid;place-items:center;padding:var(--s-4);background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.save-dialog-modal{position:relative;width:min(420px,100%);display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--shadow-2)}.save-dialog-close{position:absolute;top:var(--s-3);right:var(--s-3);z-index:3;width:30px;height:30px;min-height:0;padding:0;display:grid;place-items:center;font-size:16px;line-height:1;cursor:pointer;background:transparent;color:var(--faint);border:none;border-radius:var(--pill)}.save-dialog-close:hover{color:var(--accent)}.save-dialog-body{padding:18px}.save-dialog-body h2{font-family:var(--font-display);font-size:15px;font-weight:600;margin:0 0 var(--s-4)}.save-dialog-form{display:flex;flex-direction:column;gap:var(--s-3);margin-bottom:var(--s-4)}.save-dialog-field{display:flex;flex-direction:column;gap:var(--s-1)}.save-dialog-field label{font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--faint);text-transform:uppercase;letter-spacing:.08em}.save-dialog-field input,.save-dialog-field textarea{padding:10px 12px;background:var(--input);border:1px solid var(--line-2);border-radius:var(--r);font-size:14px;font-family:inherit;color:var(--text);resize:vertical}.save-dialog-field input:focus,.save-dialog-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.save-dialog-actions{display:flex;gap:var(--s-2)}.save-dialog-actions button{flex:1}.save-dialog-actions .primary{width:auto;padding:11px;font-size:13px;border-radius:var(--r)}.save-dialog-actions button:not(.primary){width:auto;border-style:solid;color:var(--muted)}.feedback-status{margin:0 0 var(--s-3);font-size:13px;font-weight:600}.feedback-status-ok{color:var(--accent)}.feedback-status-err{color:var(--error)}.checklist-overlay{position:fixed;inset:0;z-index:2100;display:grid;place-items:center;padding:var(--s-4);background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.checklist-modal{position:relative;width:min(600px,100%);max-height:86vh;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--shadow-2);overflow:hidden}.checklist-modal-close{position:absolute;top:var(--s-3);right:var(--s-3);z-index:3;width:30px;height:30px;min-height:0;padding:0;display:grid;place-items:center;font-size:16px;line-height:1;cursor:pointer;background:transparent;color:var(--faint);border:none;border-radius:var(--pill)}.checklist-modal-close:hover{color:var(--accent)}.checklist-modal-body{overflow-y:auto}.checklist{padding:0 18px 18px}.checklist h2{font-family:var(--font-display);font-size:16px;font-weight:600;margin:0}.checklist>h2{padding-top:18px}.checklist-header{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);padding:16px 44px 14px 18px;margin:0 -18px var(--s-2);background:var(--panel);border-bottom:1px solid var(--line)}.checklist-intro{color:var(--faint);font-size:11.5px;line-height:1.5;margin:var(--s-2) 0 var(--s-4)}.checklist-countries{display:flex;flex-direction:column;gap:var(--s-4)}.checklist-country{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:14px}.checklist-country-header{display:flex;align-items:center;gap:var(--s-2);margin:0 0 var(--s-3);font-family:var(--font-display);font-size:14px;font-weight:600}.checklist-flag{font-size:20px}.checklist-section{margin-top:var(--s-3)}.checklist-section h4{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin:0 0 var(--s-2);font-weight:500}.checklist-label{font-size:12.5px;color:var(--muted);margin:0 0 var(--s-1)}.checklist-list{margin:0;padding-left:var(--s-4);display:flex;flex-direction:column;gap:var(--s-1)}.checklist-list li{font-size:13px;line-height:1.5}.checklist-rules{list-style:none;padding-left:0}.checklist-rule-required{padding-left:var(--s-4);position:relative}.checklist-rule-required:before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:700}.checklist-rule-detail,.checklist-ztl-detail{color:var(--muted);font-size:12.5px}.checklist-rule-note{color:var(--muted)}.checklist-ztl-fine{color:var(--warn)}.checklist a{color:var(--accent)}.checklist-footer{margin-top:var(--s-4)}.checklist .caveat{color:var(--faint);font-size:11px;line-height:1.5;margin:0}.checklist .muted{color:var(--muted)}@media(max-width:640px){.checklist-modal{width:100%;max-height:92vh}}.stages-panel{padding:0 var(--s-4) var(--s-4)}.stages-intro{color:var(--faint);font-size:11.5px;line-height:1.5;margin:var(--s-2) 0 var(--s-4)}.stages-list{display:flex;flex-direction:column;gap:var(--s-2);margin-bottom:var(--s-4)}.stage-item{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}.stage-header{width:100%;display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3);background:transparent;border:none;cursor:pointer;text-align:left;transition:background .15s}.stage-header:hover{background:var(--panel-2)}.stage-number{display:flex;flex-direction:column;align-items:center;flex:0 0 auto}.stage-number-label{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);font-weight:500}.stage-number-value{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--accent);line-height:1}.stage-summary{flex:1;min-width:0}.stage-route{display:flex;align-items:center;gap:var(--s-2);margin-bottom:4px}.stage-town{font-weight:600;font-size:13px;color:var(--text)}.stage-arrow{color:var(--faint);font-size:12px}.stage-stats{display:flex;align-items:center;gap:var(--s-2);font-size:11.5px;color:var(--muted)}.stage-stat{font-family:var(--font-mono)}.stage-stat-separator{color:var(--faint)}.stage-toggle{flex:0 0 auto;color:var(--faint);font-size:10px;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.stage-details{padding:0 var(--s-4) var(--s-3);border-top:1px solid var(--line);background:var(--panel-2)}.stage-detail-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line)}.stage-detail-row:last-child{border-bottom:none}.stage-detail-label{font-size:12.5px;color:var(--muted)}.stage-detail-value{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--text)}.stage-accommodation{margin-top:var(--s-3);padding-top:var(--s-3);border-top:1px solid var(--line)}.stage-accommodation h4{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin:0 0 var(--s-2);font-weight:500}.accommodation-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--s-2)}.accommodation-item{padding:var(--s-2);background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm)}.accommodation-name{font-size:12.5px;font-weight:600;color:var(--text);margin-bottom:4px}.albergue-badge{margin-right:4px}.accommodation-details{display:flex;gap:var(--s-3);font-size:11.5px;color:var(--muted)}.accommodation-capacity{font-family:var(--font-mono)}.accommodation-price{font-family:var(--font-mono);font-weight:500;color:var(--accent)}.accommodation-more{padding:var(--s-2);font-size:11.5px;color:var(--faint);text-align:center}.error,.error-inline{color:var(--error);font-size:12.5px}.error{margin-top:var(--s-3)}.error-inline{margin:4px 0 0}.result{margin-top:var(--s-2)}.summary{display:flex;flex-wrap:wrap;gap:var(--s-3);font-size:12px;color:var(--muted);line-height:1.5;margin:0 0 var(--s-2);background:var(--input);border:1px solid var(--line);border-radius:var(--r);padding:10px 12px}.camino-metadata{display:flex;flex-direction:column;gap:var(--s-3);padding:var(--s-4);background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r);margin-top:var(--s-3)}.metadata-item{display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-2);font-size:13px}.metadata-label{color:var(--muted);font-weight:500}.metadata-value{color:var(--text);font-weight:600;font-family:var(--font-mono)}.difficulty-easy{color:var(--ok)}.difficulty-moderate{color:var(--accent)}.difficulty-challenging,.difficulty-hard{color:var(--warn)}.difficulty-difficult{color:var(--crit)}.route-description{color:var(--muted);font-size:12px;line-height:1.6;margin-top:var(--s-2);padding-top:var(--s-2);border-top:1px solid var(--line)}.fees{width:100%;border-collapse:collapse;font-size:12.5px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}.fees th,.fees td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--line);vertical-align:top}.fees tr:last-child th,.fees tr:last-child td{border-bottom:none}.fees th{color:var(--faint);font-weight:500;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em}.fees a{color:var(--accent);text-decoration:none}.fees a:hover{text-decoration:underline}.fees .price,.toll-row .dist{font-family:var(--font-mono)}.total{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);margin:var(--s-4) 0 0;padding:13px 14px;background:var(--panel-2);border-radius:11px;font-size:12.5px;color:var(--muted)}.total strong{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--text)}.muted{color:var(--muted)}.checklist-action{margin-top:var(--s-3)}.checklist-button{width:100%;border-style:solid;color:var(--muted);font-size:12.5px;font-weight:600}.checklist-button:hover{border-color:var(--accent);color:var(--accent)}.ztl-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-2)}.ztl{border:1px solid var(--line);border-radius:var(--r);padding:11px 12px;background:var(--panel-2)}.ztl-top{display:flex;align-items:center;gap:var(--s-2);font-size:12.5px}.ztl-top .dist{margin-left:auto;color:var(--muted);font-size:11px;font-family:var(--font-mono)}.ztl-meta{color:var(--muted);font-size:11.5px;margin-top:4px}.ztl-warn{background:var(--warn-soft);border:1px solid var(--warn-soft);border-radius:var(--r);color:var(--warn);font-size:11.5px;line-height:1.45;margin-top:6px;padding:11px 12px}.badge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:var(--pill)}.badge-critical{background:var(--crit);color:#fff}.badge-warning{background:var(--warn);color:#1a1a1a}.badge-none{background:var(--line-2);color:var(--text)}.caveat{font-size:10.5px;color:var(--faint);margin-top:var(--s-4);line-height:1.5;padding-top:var(--s-3);border-top:1px solid var(--line)}.eta-section{margin-bottom:var(--s-3)}.eta-toggle-container{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);padding:12px 14px;background:var(--panel-2);border-radius:var(--r);border:1px solid var(--line)}.eta-display{display:flex;align-items:center;gap:var(--s-2);flex-wrap:wrap;font-size:13px}.eta-label{color:var(--muted);font-weight:500}.eta-value{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--text)}.eta-delay{color:var(--warn);font-size:11.5px;font-family:var(--font-mono);margin-left:4px}.eta-toggle-button{flex-shrink:0;background:var(--input);border:1px solid var(--line-2);color:var(--muted);padding:7px 12px;border-radius:var(--r-sm);font-size:11.5px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}.eta-toggle-button:hover{border-color:var(--accent);color:var(--accent)}.vignette-duration-selector{display:flex;flex-direction:column;gap:var(--s-2)}.duration-label{font-weight:600}.duration-options{display:flex;flex-direction:column;gap:var(--s-1)}.duration-option{display:flex;align-items:center;gap:6px;cursor:pointer}.duration-option input[type=radio]{cursor:pointer;accent-color:var(--accent)}.duration-text{font-size:13px}.suggestion-badge{margin-left:var(--s-2);font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--warn);background:var(--warn-soft);padding:2px 8px;border-radius:var(--pill);white-space:nowrap}.parking-btn{margin-top:6px}.stop-nearby{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}.stop-nearby .link{font-size:10.5px;padding:3px 8px;min-height:0;border-radius:6px;background:var(--panel-2);color:var(--muted)}.stop-nearby .link:hover{color:var(--accent)}.parking-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.parking-item,.lodging-leg .parking-item{border:1px solid var(--line);border-radius:11px;padding:12px;background:var(--panel-2)}.parking-top{display:flex;align-items:baseline;gap:var(--s-2)}.parking-top strong{font-size:13.5px;font-weight:600}.parking-top .dist{margin-left:auto;color:var(--ok);font-size:13px;font-family:var(--font-mono)}.parking-meta{color:var(--muted);font-size:11px;margin-top:6px}.weather-chip{color:var(--text);font-weight:500;font-family:var(--font-mono)}.weather-banner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:12.5px;margin:0 0 13px;padding:10px 12px;color:var(--text);border-radius:10px;border:1px solid var(--accent-soft);background:var(--accent-soft)}.recommended-badge{display:inline-block;margin-bottom:8px;padding:2px 7px;border-radius:5px;background:var(--accent-2);color:#1a1320;font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;vertical-align:middle}.lodging-leg+.lodging-leg{margin-top:var(--s-3)}.parking-links{display:flex;gap:9px;margin-top:9px;align-items:center;flex-wrap:wrap}.parking-links a{color:var(--faint);text-decoration:none;font-size:11px}.parking-links a:hover{color:var(--accent);text-decoration:underline}.add-waypoint-btn{border:none;background:none;color:var(--accent);padding:0;min-height:0;font-size:11px;cursor:pointer}.add-waypoint-btn:hover{color:var(--accent-h)}.add-waypoint-btn.is-added{color:var(--crit)}.poi-marker{font-size:18px;line-height:22px;text-align:center;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.stop-pin{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:12px;font-weight:500;background:var(--panel);border:2px solid var(--line-2);color:var(--muted);box-shadow:0 1px 4px var(--shadow-color)}.stop-pin-origin{border-color:var(--ok);color:var(--ok)}.stop-pin-dest{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.right-panel{flex:0 0 332px;width:332px;min-height:0;display:flex;flex-direction:column;background:var(--panel);border-left:1px solid var(--line);overflow:hidden}.right-panel-head{display:flex;align-items:center;gap:4px;padding:12px 12px 0}.right-tabs{display:flex;flex:1;min-width:0;gap:3px}.right-tab{flex:1;border:1px solid transparent;background:none;color:var(--faint);cursor:pointer;padding:8px 4px;min-height:38px;font-size:11px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;gap:4px;transition:color .15s,background .15s}.right-tab.active{color:var(--text);background:var(--panel-2);border-color:var(--line)}.right-tab .tab-dot{width:6px;height:6px;border-radius:50%;flex:0 0 auto}.right-tab .tab-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.right-tab .tab-count{font-family:var(--font-mono);font-size:9.5px;background:var(--accent-soft);color:var(--accent);border-radius:var(--pill);padding:0 5px;min-width:15px;text-align:center}.right-panel-close{border:none;background:none;color:var(--faint);cursor:pointer;padding:0 10px;min-width:28px;font-size:16px}.right-panel-close:hover{color:var(--text)}.right-panel-body{overflow-y:auto;padding:13px 14px}.right-panel-body .parking h3{margin-top:var(--s-3)}.along-controls{display:flex;align-items:center;gap:var(--s-2);margin:var(--s-2) 0 var(--s-3)}.along-controls label{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted)}.along-controls input{width:76px;padding:9px 8px;border-radius:var(--r-sm);border:1px solid var(--line-2);background:var(--input);color:var(--text);font:inherit;font-size:16px}.along-controls .primary{flex:1;width:auto;padding:9px 10px;font-size:13px;border-radius:var(--r-sm)}.along-hint{margin-top:var(--s-3)}.along-note{color:var(--error);margin:6px 0}.along-leg{margin-top:var(--s-3)}.along-leg-head{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--muted);padding:7px 10px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);margin-bottom:var(--s-2);text-transform:uppercase;letter-spacing:.06em}.right-panel-fab{position:absolute;top:96px;right:16px;z-index:1000;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-2);background:var(--overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--muted);border-radius:10px;padding:9px 13px;min-height:38px;cursor:pointer;font-size:12px;box-shadow:var(--shadow-1)}.right-panel-fab:hover{color:var(--accent);border-color:var(--accent)}.right-panel-fab .fab-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-2);flex:0 0 auto}.map-contextmenu{position:absolute;z-index:1200;min-width:170px;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-sm);box-shadow:var(--shadow-2);padding:4px;display:flex;flex-direction:column}.map-contextmenu button{border:none;background:none;color:var(--text);text-align:left;padding:9px 10px;border-radius:6px;cursor:pointer;font-size:13px;min-height:38px}.map-contextmenu button:hover{background:var(--accent);color:var(--on-accent)}.poi-popup-btn{border:none;background:var(--accent);color:var(--on-accent);border-radius:6px;cursor:pointer;font-size:13px;padding:7px 12px;min-height:34px}.toll-row td{padding-top:2px}@media(min-width:769px)and (max-width:1024px){.sidebar{flex-basis:clamp(300px,34vw,372px);width:clamp(300px,34vw,372px)}.right-panel{width:clamp(290px,36vw,332px)}}@media(max-width:768px){.app-header{padding:0 var(--s-4)}.app-header p,.saved-toggle{display:none}.kofi-header{display:inline-flex}[id^=kofi-wo-container],[id^=kofi-widget-overlay]{display:none!important}.layout{position:relative}.map-wrap{order:1;flex:1 1 auto;min-height:0}.sidebar{position:absolute;inset:0;z-index:1100;width:100%;max-width:none;flex:1 1 auto;border-right:none;background:var(--bg);display:none}.layout[data-mobile-view=plan] .sidebar{display:flex}.right-panel{position:absolute;inset:0;width:100%;max-width:none;z-index:1100;flex:1 1 auto;border:none;border-radius:0;display:none;padding-bottom:env(safe-area-inset-bottom)}.layout[data-mobile-view=poi] .right-panel{display:flex}.right-panel-fab{display:none}.layout:not([data-mobile-view=map]) .map-stats,.layout:not([data-mobile-view=map]) .map-legend{display:none}.map-stats{inset:auto 14px 16px;transform:none;max-width:none;display:flex;border-radius:14px}.map-stat{flex:1;padding:9px 8px;text-align:center}.map-stat-value{font-size:15px}.map-stat-label{font-size:9px}.mobile-nav{display:flex}.map-legend{max-width:56vw;bottom:96px;left:14px}}@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}.embed-widget{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg);overflow:hidden;max-width:100%;box-sizing:border-box}.embed-map{flex:1 1 auto;position:relative;min-height:0;overflow:hidden}.embed-map .map{height:100%;width:100%}.embed-summary{flex:0 0 auto;background:var(--panel);border-top:1px solid var(--line);padding:var(--s-4);display:flex;flex-direction:column;gap:var(--s-3);overflow-x:hidden;max-width:100%;box-sizing:border-box}.embed-stats{display:flex;gap:var(--s-4);flex-wrap:wrap;overflow-x:hidden}.embed-stat{display:flex;flex-direction:column;gap:2px;min-width:80px;flex-shrink:1}.embed-stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.embed-stat-value{font-size:16px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.embed-countries{display:flex;flex-direction:column;gap:var(--s-2);overflow-x:hidden}.embed-countries-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.embed-countries-list{display:flex;flex-wrap:wrap;gap:var(--s-2);overflow-x:hidden}.embed-country{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);font-size:13px;flex-shrink:0}.embed-country-flag{font-size:16px;line-height:1}.embed-country-code{font-weight:500;color:var(--text)}.embed-cta{display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:var(--on-accent);text-decoration:none;padding:var(--s-3) var(--s-4);border-radius:var(--r);font-weight:700;font-size:14px;transition:background .15s ease,transform .15s ease;border:none;cursor:pointer;box-shadow:0 2px 8px #3b5bdb4d;width:100%;text-align:center}.embed-cta:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:0 4px 12px #3b5bdb66}.embed-cta:active{transform:translateY(0)}.embed-loading,.embed-error{display:flex;align-items:center;justify-content:center;height:100%;padding:var(--s-5);text-align:center;color:var(--muted)}.embed-error{color:var(--error)}@media(max-width:600px),(max-height:400px){.embed-summary{padding:var(--s-3);gap:var(--s-2)}.embed-stats{gap:var(--s-3)}.embed-stat{min-width:70px}.embed-stat-label{font-size:10px}.embed-stat-value{font-size:14px}.embed-country{padding:3px 6px;font-size:12px;gap:4px}.embed-country-flag{font-size:14px}.embed-cta{font-size:13px;padding:10px var(--s-3)}}@media(max-width:320px),(max-height:240px){.embed-summary{padding:var(--s-2);gap:var(--s-2)}.embed-stats{gap:var(--s-2)}.embed-stat{min-width:50px}.embed-stat-label{font-size:9px;letter-spacing:.1px}.embed-stat-value{font-size:12px}.embed-countries{gap:var(--s-1)}.embed-countries-label{font-size:9px}.embed-country{padding:2px 4px;font-size:11px;gap:3px}.embed-country-flag{font-size:12px}.embed-cta{font-size:12px;padding:8px var(--s-2);font-weight:700}}.driving-guide{margin-top:var(--s-4)}.driving-guide>h2{font-family:var(--font-display);font-size:16px;font-weight:700;margin:0 0 var(--s-1)}.guide-subtitle{color:var(--muted);font-size:12.5px;margin:0 0 var(--s-3)}.guide-countries{display:flex;flex-direction:column;gap:var(--s-3)}.guide-country{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r);padding:var(--s-3)}.guide-country-header{display:flex;align-items:center;gap:var(--s-2);margin:0 0 var(--s-2);font-size:14px;font-weight:600}.guide-flag{font-size:18px;line-height:1}.guide-topics{display:flex;flex-direction:column;gap:var(--s-1)}.guide-topic{border-top:1px solid var(--line)}.guide-topic:first-child{border-top:none}.guide-topic-header{display:flex;align-items:center;gap:var(--s-2);width:100%;padding:var(--s-2) 0;background:none;border:none;cursor:pointer;color:var(--text);font:inherit;font-size:13px;text-align:left}.guide-topic-header:hover{color:var(--accent)}.guide-topic-icon{font-size:15px;line-height:1;flex:0 0 auto}.guide-topic-title{flex:1 1 auto}.guide-topic-toggle{color:var(--muted);font-size:10px;flex:0 0 auto}.guide-topic-content{padding:0 0 var(--s-2) calc(15px + var(--s-2));color:var(--muted);font-size:12.5px;line-height:1.5}.guide-topic-content p{margin:0}.guide-footer{margin-top:var(--s-3)}
