/* ============================================================
   伴走地圖 App — 互動頁面
   ============================================================ */

:root{
  --nma-violet:#7c3aed;
  --nma-violet-deep:#5b21b6;
  --nma-violet-soft:#ede9fe;
  --nma-ink:#0f172a;
  --nma-ink-2:#1e293b;
  --nma-mute:#475569;
  --nma-mute-2:#94a3b8;
  --nma-line:#e2e8f0;
  --nma-bg:#f8fafc;
  --nma-radius:10px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;overflow:hidden}
.nma-body{
  font-family:"PingFang TC","Noto Sans TC","Microsoft JhengHei",system-ui,-apple-system,sans-serif;
  color:var(--nma-ink);
  background:var(--nma-bg);
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}

/* ============== APP LAYOUT ============== */
.nma-app{
  display:grid;grid-template-columns:380px 1fr;
  height:100vh;
}
@media (max-width:820px){
  .nma-app{grid-template-columns:1fr;grid-template-rows:auto 1fr}
}

/* ============== SIDEBAR ============== */
.nma-side{
  background:#fff;
  border-right:1px solid var(--nma-line);
  display:flex;flex-direction:column;
  overflow-y:auto;
  box-shadow:1px 0 0 rgba(15,23,42,.02), 4px 0 16px -8px rgba(15,23,42,.05);
}
.nma-side::-webkit-scrollbar{width:8px}
.nma-side::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:4px}

.nma-side-head{
  display:flex;align-items:center;gap:12px;
  padding:16px 18px 12px;
  border-bottom:1px solid var(--nma-line);
}
.nma-icon-btn{
  background:transparent;border:none;cursor:pointer;
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;color:var(--nma-ink);
  transition:background .15s;
}
.nma-icon-btn:hover{background:#f1f5f9}
.nma-brand{display:flex;align-items:center;gap:9px;font-weight:700}
.nma-brand-mark{
  width:36px;height:36px;border-radius:50%;
  display:block;object-fit:cover;
  background:#fff;
  box-shadow:0 4px 12px -4px rgba(15,23,42,.18);
}
.nma-brand-text{display:flex;flex-direction:column;line-height:1.1}
.nma-brand-text small{font-size:10.5px;font-weight:500;color:var(--nma-mute);letter-spacing:.5px}

/* ── City / Tasks row ── */
.nma-side-row{
  display:flex;gap:10px;
  padding:12px 18px;
  border-bottom:1px solid var(--nma-line);
}
.nma-city-wrap{flex:1;position:relative}
.nma-city-btn{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;
  background:var(--nma-violet);color:#fff;border:none;cursor:pointer;
  padding:10px 14px;border-radius:8px;
  font-size:14.5px;font-weight:600;font-family:inherit;
  box-shadow:0 6px 14px -4px rgba(124,58,237,.4);
  transition:background .15s;
}
.nma-city-btn:hover{background:var(--nma-violet-deep)}
.nma-city-btn[aria-expanded="true"] svg{transform:rotate(180deg)}
.nma-city-btn svg{transition:transform .2s}

/* ── City dropdown menu ── */
.nma-city-menu{
  position:absolute;top:calc(100% + 6px);left:0;
  width:280px;max-height:60vh;overflow-y:auto;
  background:#fff;border:1px solid var(--nma-line);
  border-radius:12px;
  box-shadow:0 18px 40px -10px rgba(15,23,42,.25), 0 0 0 1px rgba(124,58,237,.08);
  z-index:1000;
  opacity:0;transform:translateY(-6px) scale(.97);
  transition:opacity .18s, transform .18s;
}
.nma-city-menu.is-open{opacity:1;transform:translateY(0) scale(1)}
.nma-city-menu::-webkit-scrollbar{width:6px}
.nma-city-menu::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px}

.nma-city-search{
  position:sticky;top:0;background:#fff;
  padding:10px 12px 8px;
  border-bottom:1px solid var(--nma-line);
  z-index:2;
}
.nma-city-search input{
  width:100%;border:1px solid var(--nma-line);border-radius:8px;
  padding:8px 12px;font-size:13.5px;font-family:inherit;
  background:#f8fafc;outline:none;
  transition:border-color .15s, box-shadow .15s;
}
.nma-city-search input:focus{
  border-color:var(--nma-violet);
  background:#fff;
  box-shadow:0 0 0 3px rgba(124,58,237,.12);
}

.nma-city-group{padding:8px 0}
.nma-city-group + .nma-city-group{border-top:1px solid var(--nma-line)}
.nma-city-group-h{
  padding:4px 14px 6px;
  font-size:11px;color:var(--nma-mute-2);
  font-weight:700;letter-spacing:1px;text-transform:uppercase;
}
.nma-city-opt{
  width:100%;text-align:left;background:transparent;border:none;cursor:pointer;
  padding:9px 14px;font-family:inherit;
  font-size:14px;color:var(--nma-ink);
  transition:background .12s;
  display:flex;align-items:center;
}
.nma-city-opt::before{
  content:"📍";font-size:11px;margin-right:8px;opacity:.5;
}
.nma-city-opt:hover{background:var(--nma-violet-soft);color:var(--nma-violet-deep)}
.nma-city-opt.is-active{
  background:var(--nma-violet-soft);color:var(--nma-violet-deep);font-weight:700;
}
.nma-city-opt.is-active::before{content:"✓";opacity:1;color:var(--nma-violet)}
/* ── Search ── */
.nma-search{
  display:flex;align-items:center;gap:8px;
  margin:14px 18px 12px;
  padding:9px 12px;
  background:#fff;border:1px solid var(--nma-line);border-radius:10px;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.nma-search svg{color:var(--nma-mute-2);flex:none}
.nma-search input{
  flex:1;border:none;outline:none;background:transparent;
  font-size:14px;font-family:inherit;color:var(--nma-ink);
}
.nma-search-go{
  background:var(--nma-violet);color:#fff;border:none;cursor:pointer;
  width:30px;height:30px;border-radius:8px;
  display:grid;place-items:center;
}
.nma-search-go:hover{background:var(--nma-violet-deep)}

/* ── Profile icons ── */
.nma-profiles{
  display:flex;align-items:stretch;gap:6px;
  padding:8px 14px 14px;
  border-bottom:1px solid var(--nma-line);
}
.nma-profile{
  background:#fff;border:1px solid transparent;cursor:pointer;
  min-width:60px;padding:8px 6px 6px;
  border-radius:14px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  transition:background .15s, border-color .15s, transform .15s, box-shadow .15s;
  font-family:inherit;
  flex:1;
}
.nma-profile:hover{background:var(--nma-violet-soft);transform:translateY(-1px)}
.nma-profile-emoji{
  font-size:26px;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  height:30px;
}
.nma-profile-time{
  font-size:12px;font-weight:600;color:var(--nma-mute);
  line-height:1.1;letter-spacing:.2px;
}
.nma-profile--active{
  background:var(--nma-violet) !important;
  box-shadow:0 6px 14px -4px rgba(124,58,237,.45);
}
.nma-profile--active .nma-profile-time{color:#fff}
.nma-profile--active .nma-profile-emoji{filter:drop-shadow(0 1px 2px rgba(0,0,0,.15))}

/* 雙 emoji 組合（行李 + 嬰兒）：主 emoji + 右下角小副 emoji */
.nma-profile-dual{
  position:relative;line-height:1;display:inline-block;
}
.nma-profile-dual-sm{
  position:absolute;right:-10px;bottom:-2px;
  font-size:14px;line-height:1;
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.25));
}

/* ── Controls ── */
.nma-controls{
  padding:14px 18px 4px;
  flex:1;
}
.nma-ctrl{margin-bottom:18px}
.nma-ctrl label{
  display:block;
  font-size:13px;color:var(--nma-mute);margin-bottom:8px;
  line-height:1.5;
}
.nma-ctrl label b{color:var(--nma-ink);font-weight:700}

input[type=range]{
  -webkit-appearance:none;appearance:none;
  width:100%;height:6px;border-radius:999px;
  background:linear-gradient(90deg,#a78bfa 0%, #7c3aed 100%);
  outline:none;cursor:pointer;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:3px solid #7c3aed;
  box-shadow:0 2px 6px rgba(0,0,0,.15);
  cursor:pointer;
}
input[type=range]::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:3px solid #7c3aed;
  cursor:pointer;
}
.nma-range--warm{
  background:linear-gradient(90deg,#7c3aed 0%, #ec4899 50%, #f97316 100%) !important;
}
.nma-range--warm::-webkit-slider-thumb{border-color:#f97316}
.nma-range--warm::-moz-range-thumb{border-color:#f97316}

/* ── Toggle group ── */
.nma-ctrl-group{
  margin-bottom:18px;
}
.nma-ctrl-group-label{
  font-size:13px;color:var(--nma-mute);margin-bottom:8px;
}
.nma-toggle{
  display:flex;align-items:center;gap:12px;
  padding:8px 0;
  font-size:14px;color:var(--nma-ink);
  cursor:pointer;
  user-select:none;
}
.nma-toggle input{display:none}
.nma-toggle-track{
  position:relative;flex:none;
  width:38px;height:22px;border-radius:999px;
  background:#cbd5e1;
  transition:background .2s;
}
.nma-toggle-track::after{
  content:"";position:absolute;
  top:2px;left:2px;width:18px;height:18px;
  border-radius:50%;background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
  transition:left .2s;
}
.nma-toggle input:checked + .nma-toggle-track{background:var(--nma-violet)}
.nma-toggle input:checked + .nma-toggle-track::after{left:18px}

.nma-side-foot{
  padding:14px 18px;
  border-top:1px solid var(--nma-line);
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;
}
.nma-side-foot a{
  color:var(--nma-violet-deep);font-weight:600;
  padding:6px 10px;border-radius:6px;
  transition:background .15s;
}
.nma-side-foot a:hover{background:var(--nma-violet-soft)}

/* ============== MAP ============== */
.nma-map-wrap{
  position:relative;
  height:100vh;
  overflow:hidden;
}
.nma-map{
  width:100%;height:100%;
  background:#cfe4f5;
}

/* Leaflet controls polish */
.leaflet-control-zoom a{
  background:#fff !important;
  color:var(--nma-ink) !important;
  border:1px solid var(--nma-line) !important;
  font-weight:600 !important;
}
.leaflet-control-zoom a:hover{background:#f1f5f9 !important}

/* 點地圖即時標記 */
.nma-click-marker-wrap{background:transparent !important;border:none !important}
.nma-click-marker{
  position:relative;
  width:36px;height:42px;
  display:grid;place-items:center;
  font-size:24px;line-height:1;
  filter:drop-shadow(0 4px 6px rgba(124,58,237,.5));
  animation:nma-pin-drop .35s cubic-bezier(.34,1.56,.64,1);
  transform-origin:center bottom;
}
.nma-click-marker-pulse{
  position:absolute;left:50%;bottom:-2px;
  width:14px;height:14px;border-radius:50%;
  background:rgba(124,58,237,.45);
  transform:translate(-50%,0);
  animation:nma-pin-pulse 1.6s ease-out infinite;
}
@keyframes nma-pin-drop{
  0%{ transform:translateY(-28px) scale(.6); opacity:0 }
  60%{ transform:translateY(2px) scale(1.05) }
  100%{ transform:translateY(0) scale(1); opacity:1 }
}
@keyframes nma-pin-pulse{
  0%{ transform:translate(-50%,0) scale(.6); opacity:.8 }
  100%{ transform:translate(-50%,0) scale(3); opacity:0 }
}

/* POI markers */
.nma-poi-icon{background:transparent !important;border:none !important}
.nma-poi{
  width:32px;height:32px;border-radius:50% 50% 50% 4px;
  background:#fff;color:var(--nma-ink);
  display:grid;place-items:center;font-size:16px;
  box-shadow:0 4px 10px -2px rgba(15,23,42,.3), 0 0 0 2px var(--nma-violet);
  transform:rotate(45deg);
}
.nma-poi > *{transform:rotate(-45deg)}

/* ----- Facilities marker（捷運電梯 / 無障礙診所） ----- */
.nma-facility-icon{background:transparent !important;border:none !important}
.nma-facility-mark{
  width:30px;height:30px;border-radius:50%;
  background:var(--r);
  border:2px solid var(--c);
  color:var(--c);
  display:grid;place-items:center;
  font-size:15px;line-height:1;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.18));
}
.nma-facility-emoji{font-size:15px;line-height:1}

/* ----- Crossings 十字路口 marker ----- */
.nma-cross-icon{background:transparent !important;border:none !important}
.nma-cross-mark{
  position:relative;width:26px;height:26px;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.25));
}
.nma-cross-mark svg{display:block}
.nma-cross-mark-sig{
  position:absolute;right:-6px;bottom:-4px;
  font-size:11px;line-height:1;
  background:#fff;border-radius:50%;padding:1px;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));
}

/* ===== 圖例 toggle button (右側) ===== */
.nma-legend-toggle{
  position:absolute;top:14px;right:14px;
  width:42px;height:42px;border-radius:10px;
  background:#fff;border:1px solid var(--nma-line);
  cursor:pointer;color:var(--nma-ink);
  display:grid;place-items:center;
  box-shadow:0 4px 12px -4px rgba(15,23,42,.18);
  transition:opacity .2s, transform .2s, background .15s;
  z-index:600;
}
.nma-legend-toggle:hover{background:#f8fafc;transform:translateY(-1px)}
.nma-legend-toggle.is-hidden{opacity:0;pointer-events:none;transform:scale(.9)}

/* ===== 我的位置 ===== */
.nma-locate-btn{
  position:absolute;top:64px;right:14px;
  width:42px;height:42px;border-radius:10px;
  background:#fff;border:1px solid var(--nma-line);
  cursor:pointer;color:var(--nma-violet-deep);
  display:grid;place-items:center;
  box-shadow:0 4px 12px -4px rgba(15,23,42,.18);
  transition:background .15s, color .15s, transform .15s;
  z-index:600;
}
.nma-locate-btn:hover{background:var(--nma-violet-soft);transform:translateY(-1px);color:var(--nma-violet)}
.nma-locate-btn.is-loading{
  color:var(--nma-violet);
  animation:nma-locate-pulse 1.2s ease-in-out infinite;
}
@keyframes nma-locate-pulse{
  0%,100%{box-shadow:0 4px 12px -4px rgba(15,23,42,.18), 0 0 0 0 rgba(124,58,237,.3)}
  50%    {box-shadow:0 4px 12px -4px rgba(15,23,42,.18), 0 0 0 8px rgba(124,58,237,0)}
}

/* ===== 圖層開關 toggle / panel ===== */
.nma-layers-toggle{
  position:absolute;top:114px;right:14px;
  width:42px;height:42px;border-radius:10px;
  background:#fff;border:1px solid var(--nma-line);
  cursor:pointer;color:var(--nma-violet-deep);
  display:grid;place-items:center;
  box-shadow:0 4px 12px -4px rgba(15,23,42,.18);
  transition:opacity .2s, transform .2s, background .15s, color .15s;
  z-index:600;
}
.nma-layers-toggle:hover{background:var(--nma-violet-soft);transform:translateY(-1px);color:var(--nma-violet)}
.nma-layers-toggle.is-hidden{opacity:0;pointer-events:none;transform:scale(.9)}

.nma-layers-panel[hidden]{display:none}
.nma-layers-panel{
  position:absolute;top:114px;right:14px;
  width:260px;max-width:calc(100vw - 28px);
  background:#fff;border:1px solid var(--nma-line);
  border-radius:14px;
  box-shadow:0 12px 30px -8px rgba(15,23,42,.22), 0 4px 12px -4px rgba(15,23,42,.08);
  z-index:610;
  display:flex;flex-direction:column;
  opacity:0;transform:translateX(20px) scale(.96);
  transition:opacity .25s, transform .25s;
}
.nma-layers-panel.is-open{
  opacity:1;transform:translateX(0) scale(1);
}
.nma-layers-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px 10px;
  border-bottom:1px solid var(--nma-line);
}
.nma-layers-head h3{margin:0;font-size:14px;font-weight:700;color:var(--nma-violet-deep)}
.nma-layers-close{
  background:transparent;border:none;cursor:pointer;
  width:26px;height:26px;border-radius:50%;
  font-size:18px;color:var(--nma-mute-2);line-height:1;
}
.nma-layers-close:hover{background:#f1f5f9;color:var(--nma-ink)}
.nma-layers-mode{
  display:flex;align-items:center;gap:8px;
  margin:8px 10px 4px;padding:8px 10px;
  background:linear-gradient(135deg, var(--nma-violet-soft), #fff);
  border:1px solid var(--nma-violet-soft);
  border-radius:8px;cursor:pointer;
  font-size:12.5px;font-weight:600;color:var(--nma-violet-deep);
}
.nma-layers-mode input{accent-color:var(--nma-violet);width:14px;height:14px}
.nma-layers-mode:hover{border-color:var(--nma-violet)}
.nma-layers-mode--accent{
  background:linear-gradient(135deg, #dbeafe, #fff);
  border-color:#bfdbfe;color:#1d4ed8;
}
.nma-layers-mode--accent:hover{border-color:#2563eb}

.nma-layers-body{padding:8px 6px;max-height:50vh;overflow-y:auto}
.nma-layers-item{
  display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;cursor:pointer;
  font-size:13px;color:var(--nma-ink);
  transition:background .15s;
}
.nma-layers-item:hover{background:var(--nma-violet-soft)}
.nma-layers-item input{accent-color:var(--nma-violet);width:14px;height:14px}
.nma-layers-item-emoji{
  flex:none;width:22px;height:22px;border-radius:50%;
  display:grid;place-items:center;font-size:12px;
  border:1.5px solid var(--c,#888);background:var(--r,#fff);color:var(--c,#333);
}
.nma-layers-item-label{flex:1}
.nma-layers-foot{
  display:flex;gap:6px;padding:8px 12px 12px;border-top:1px solid var(--nma-line);
}
.nma-layers-action{
  flex:1;padding:6px;border-radius:6px;border:1px solid var(--nma-line);background:#fff;
  font-size:12px;font-weight:600;color:var(--nma-ink-2,#475569);cursor:pointer;
  font-family:inherit;
  transition:background .15s, color .15s, border-color .15s;
}
.nma-layers-action:hover{background:var(--nma-violet-soft);color:var(--nma-violet-deep);border-color:var(--nma-violet-soft)}

/* ===== 免責聲明 toggle button ===== */
.nma-disclaimer-toggle{
  position:absolute;top:164px;right:14px;
  width:42px;height:42px;border-radius:10px;
  background:#fff;border:1px solid var(--nma-line);
  cursor:pointer;color:var(--nma-violet-deep);
  display:grid;place-items:center;
  box-shadow:0 4px 12px -4px rgba(15,23,42,.18);
  transition:opacity .2s, transform .2s, background .15s, color .15s;
  z-index:600;
}
.nma-disclaimer-toggle:hover{background:var(--nma-violet-soft);transform:translateY(-1px);color:var(--nma-violet)}
.nma-disclaimer-toggle.is-hidden{opacity:0;pointer-events:none;transform:scale(.9)}

/* ===== 免責聲明面板 ===== */
.nma-disclaimer-panel{
  position:absolute;top:164px;right:14px;
  width:320px;max-width:calc(100vw - 28px);
  background:#fff;border:1px solid var(--nma-line);
  border-radius:14px;
  box-shadow:0 12px 30px -8px rgba(15,23,42,.22), 0 4px 12px -4px rgba(15,23,42,.08);
  z-index:610;
  opacity:0;transform:translateX(20px) scale(.96);
  transition:opacity .25s, transform .25s;
}
.nma-disclaimer-panel.is-open{
  opacity:1;transform:translateX(0) scale(1);
}
.nma-disclaimer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 10px;
  border-bottom:1px solid var(--nma-line);
}
.nma-disclaimer-head h3{
  margin:0;font-size:15px;font-weight:700;color:#b45309;
}
.nma-disclaimer-close{
  background:transparent;border:none;cursor:pointer;
  width:28px;height:28px;border-radius:50%;
  font-size:20px;color:var(--nma-mute-2);line-height:1;
}
.nma-disclaimer-close:hover{background:#f1f5f9;color:var(--nma-ink)}
.nma-disclaimer-body{
  padding:12px 16px 16px;
  font-size:12.5px;line-height:1.65;color:var(--nma-ink-2,#475569);
}
.nma-disclaimer-body p{margin:0 0 8px}
.nma-disclaimer-body p:last-child{margin-bottom:0}
.nma-disclaimer-body strong{color:#b91c1c}

/* ===== 圖例 滑出面板 ===== */
.nma-legend-panel{
  position:absolute;top:14px;right:14px;
  width:320px;max-width:calc(100vw - 28px);
  background:#fff;border:1px solid var(--nma-line);
  border-radius:14px;
  box-shadow:0 12px 30px -8px rgba(15,23,42,.22), 0 4px 12px -4px rgba(15,23,42,.08);
  z-index:610;
  opacity:0;transform:translateX(20px) scale(.96);
  transition:opacity .25s, transform .25s;
  max-height:calc(100vh - 28px);overflow-y:auto;
}
.nma-legend-panel.is-open{
  opacity:1;transform:translateX(0) scale(1);
}
.nma-legend-panel::-webkit-scrollbar{width:6px}
.nma-legend-panel::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px}

.nma-legend-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 10px;
  border-bottom:1px solid var(--nma-line);
}
.nma-legend-head h3{
  margin:0;font-size:17px;font-weight:700;color:var(--nma-ink);
}
.nma-legend-close{
  background:transparent;border:none;cursor:pointer;
  width:28px;height:28px;border-radius:50%;
  font-size:20px;color:var(--nma-mute-2);line-height:1;
}
.nma-legend-close:hover{background:#f1f5f9;color:var(--nma-ink)}

.nma-legend-section{
  border-bottom:1px solid var(--nma-line);
}
.nma-legend-section:last-child{border-bottom:none}

.nma-legend-row-h{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  background:transparent;border:none;cursor:pointer;
  padding:14px 16px;
  font-family:inherit;font-size:14px;font-weight:600;color:var(--nma-ink);
  transition:background .15s;
}
.nma-legend-row-h:hover{background:#f8fafc}
.nma-legend-acc{
  font-size:10px;color:var(--nma-mute-2);
  transition:transform .2s;
}
.nma-legend-section.is-open .nma-legend-acc{color:var(--nma-violet)}

.nma-legend-content{
  display:none;
  padding:4px 16px 14px;
}
.nma-legend-section.is-open .nma-legend-content{display:block}

.nma-legend-item{
  display:flex;align-items:center;gap:12px;
  padding:6px 0;font-size:13.5px;color:var(--nma-ink-2);
}
.nma-legend-line{
  flex:none;width:48px;height:4px;border-radius:2px;
}
.nma-legend-line--fast{background:#2563eb}    /* 平坦 <3% */
.nma-legend-line--mid{background:#ec4899}     /* 中坡 3-8% */
.nma-legend-line--slow{background:#f59e0b}    /* 陡坡 8-12% */
.nma-legend-line--blocked{
  background:transparent;
  border-top:2px dashed #ef4444;               /* 不可通行 >12% */
  height:0;
}
.nma-legend-dot{
  flex:none;width:14px;height:14px;border-radius:50%;
  font-size:0;
}
.nma-legend-icon{
  flex:none;width:24px;text-align:center;font-size:16px;
}
.nma-legend-swatch{
  flex:none;width:24px;height:18px;border-radius:3px;
  border:1px solid var(--nma-line);
}
.nma-legend-name{flex:1}

/* 路口 / 樓梯 / 積分 swatch */
.nma-legend-cross{
  flex:none;width:28px;height:28px;border-radius:4px;
  background:#f8fafc;border:1px solid var(--nma-line);
  position:relative;
}
.nma-legend-cross::before,
.nma-legend-cross::after{
  content:"";position:absolute;background:#94a3b8;
}
.nma-legend-cross::before{top:50%;left:4px;right:4px;height:2px;transform:translateY(-50%)}
.nma-legend-cross::after{left:50%;top:4px;bottom:4px;width:2px;transform:translateX(-50%)}
.nma-legend-cross--full{background:#dcfce7;border-color:#16a34a}
.nma-legend-cross--full::before,.nma-legend-cross--full::after{background:#16a34a}
.nma-legend-cross--partial{background:#fef3c7;border-color:#f59e0b}
.nma-legend-cross--partial::before{background:#f59e0b}
.nma-legend-cross--partial::after{background:#cbd5e1}
.nma-legend-cross--none{background:#fee2e2;border-color:#ef4444}
.nma-legend-cross--none::before,.nma-legend-cross--none::after{background:#ef4444}
.nma-legend-cross--signal{background:#e0f2fe;border-color:#0ea5e9}
.nma-legend-cross--signal::before,.nma-legend-cross--signal::after{background:#0ea5e9}

.nma-legend-stair{
  flex:none;width:28px;height:28px;border-radius:4px;
  display:grid;place-items:center;font-size:14px;
  background:#f1f5f9;color:var(--nma-ink-2);
}
.nma-legend-stair--solid{background:#f1f5f9}
.nma-legend-stair--solid::before{content:"🪜"}
.nma-legend-stair--elev{background:#dbeafe}
.nma-legend-stair--elev::before{content:"🛗"}
.nma-legend-stair--ramp{background:#dcfce7}
.nma-legend-stair--ramp::before{content:"🛤"}

.nma-legend-facility{
  flex:none;width:28px;height:28px;border-radius:50%;
  display:grid;place-items:center;font-size:13px;line-height:1;
  border:2px solid;
}
.nma-legend-facility--metro{background:#dbeafe;border-color:#1d4ed8;color:#1d4ed8}
.nma-legend-facility--clinic{background:#d1fae5;border-color:#059669;color:#059669}

.nma-legend-info-btn{
  flex:none;margin-left:auto;
  width:22px;height:22px;border-radius:50%;
  background:transparent;border:1px solid var(--nma-line);
  color:var(--nma-violet);cursor:pointer;
  font-size:11px;font-weight:700;line-height:1;
  display:grid;place-items:center;
  transition:background .15s, border-color .15s, color .15s;
}
.nma-legend-info-btn:hover{background:var(--nma-violet-soft);border-color:var(--nma-violet);color:var(--nma-violet-deep)}

/* ============== 認證標準 Modal ============== */
.nma-std-modal[hidden]{display:none}
.nma-std-modal{
  position:fixed;inset:0;z-index:9800;
  display:grid;place-items:center;padding:16px;
}
.nma-std-backdrop{
  position:absolute;inset:0;background:rgba(15,23,42,.5);
  backdrop-filter:blur(2px);
}
.nma-std-card{
  position:relative;width:min(580px,100%);max-height:88vh;
  background:#fff;border-radius:18px;
  box-shadow:0 24px 60px -12px rgba(15,23,42,.45);
  display:flex;flex-direction:column;overflow:hidden;
}
.nma-std-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--nma-line);
  background:linear-gradient(180deg,#faf7ff 0%,#fff 100%);
}
.nma-std-head h2{
  margin:0;font-size:16px;font-weight:700;
  color:#059669;
  display:flex;align-items:center;gap:6px;
}
.nma-std-close{
  background:transparent;border:none;cursor:pointer;
  width:30px;height:30px;border-radius:50%;
  font-size:22px;color:var(--nma-mute-2);line-height:1;
}
.nma-std-close:hover{background:#f1f5f9;color:var(--nma-ink)}

.nma-std-intro{
  padding:14px 20px 6px;
  border-bottom:1px dashed var(--nma-line);
}
.nma-std-intro p{margin:0 0 6px;font-size:13px;line-height:1.6;color:var(--nma-ink-2,#475569)}
.nma-std-intro p:last-child{margin-bottom:0}
.nma-std-intro strong{color:var(--nma-ink);font-weight:700}
.nma-std-note{color:var(--nma-mute) !important;font-size:11.5px !important}

.nma-std-body{
  padding:14px 20px;overflow-y:auto;flex:1;
}
.nma-std-section{margin-bottom:16px}
.nma-std-section:last-child{margin-bottom:0}
.nma-std-section h3{
  margin:0 0 8px;font-size:14px;font-weight:700;color:var(--nma-violet-deep);
  display:flex;align-items:center;gap:6px;
}
.nma-std-list{
  margin:0;padding-left:20px;
  display:flex;flex-direction:column;gap:6px;
  font-size:13px;line-height:1.7;color:var(--nma-ink);
}
.nma-std-list strong{color:#7c2d12;font-weight:700;background:#fef3c7;padding:0 4px;border-radius:3px}
.nma-std-sublist{
  margin:6px 0 0;padding-left:18px;
  display:flex;flex-direction:column;gap:3px;
  font-size:12.5px;color:var(--nma-ink-2,#475569);
}
.nma-std-sublist strong{background:#dbeafe;color:#1d4ed8}
.nma-std-footer-note{
  margin:12px 0 0;padding:10px 12px;
  background:#f8fafc;border-radius:8px;
  font-size:11.5px;color:var(--nma-mute);line-height:1.55;
}

.nma-std-foot{
  padding:12px 20px;
  border-top:1px solid var(--nma-line);background:#fafbfc;
  display:flex;justify-content:flex-end;
}

.nma-legend-score{
  flex:none;width:28px;height:28px;border-radius:50%;
  display:grid;place-items:center;
  font-size:13px;font-weight:800;color:#fff;
}
.nma-legend-score--a{background:#16a34a}
.nma-legend-score--b{background:#84cc16}
.nma-legend-score--c{background:#f59e0b}
.nma-legend-score--d{background:#ef4444}

.nma-legend-note{
  margin:0 0 10px;padding:8px 10px;
  background:var(--nma-violet-soft);
  border-radius:8px;
  font-size:12.5px;color:var(--nma-violet-deep);
  line-height:1.5;
}

/* ============== FEEDBACK MODAL ============== */
.nma-fb{
  position:fixed;inset:0;z-index:8000;
  opacity:0;transition:opacity .2s;pointer-events:none;
}
.nma-fb.is-open{opacity:1;pointer-events:auto}
.nma-fb-backdrop{
  position:absolute;inset:0;
  background:rgba(15,23,42,.55);
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
.nma-fb-dialog{
  position:relative;
  width:520px;max-width:calc(100vw - 32px);
  margin:5vh auto;
  background:#fff;border-radius:18px;
  box-shadow:0 24px 50px -10px rgba(15,23,42,.4);
  overflow:hidden;
  transform:translateY(20px) scale(.96);
  transition:transform .25s ease;
  max-height:90vh;display:flex;flex-direction:column;
}
.nma-fb.is-open .nma-fb-dialog{transform:translateY(0) scale(1)}

.nma-fb-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px 14px;
  border-bottom:1px solid var(--nma-line);
}
.nma-fb-head h3{
  margin:0;font-size:18px;font-weight:700;color:var(--nma-ink);
}
.nma-fb-x{
  background:transparent;border:none;cursor:pointer;
  width:32px;height:32px;border-radius:50%;
  font-size:22px;color:var(--nma-mute-2);line-height:1;
}
.nma-fb-x:hover{background:#f1f5f9;color:var(--nma-ink)}

.nma-fb-body{
  padding:18px 22px;
  overflow-y:auto;
  flex:1;
}

.nma-fb-coord{
  display:inline-block;padding:4px 10px;border-radius:6px;
  background:var(--nma-violet-soft);color:var(--nma-violet-deep);
  font-size:12.5px;font-weight:600;font-family:'Menlo','Consolas',monospace;
  margin-bottom:14px;
}

.nma-fb-types{
  border:none;padding:0;margin:0 0 18px;
}
.nma-fb-types legend{
  font-size:13px;font-weight:600;color:var(--nma-mute);
  margin-bottom:8px;padding:0;
}

.nma-fb-check{
  display:flex;align-items:flex-start;gap:10px;
  padding:8px 0;
  font-size:14.5px;color:var(--nma-ink);
  cursor:pointer;user-select:none;
}
.nma-fb-check--inline{padding:4px 0;font-size:13.5px}
.nma-fb-check input{display:none}
.nma-fb-box{
  flex:none;width:20px;height:20px;border-radius:5px;
  border:2px solid var(--nma-line);
  background:#fff;
  position:relative;margin-top:1px;
  transition:background .15s, border-color .15s;
}
.nma-fb-box::after{
  content:"";position:absolute;
  top:1px;left:5px;width:6px;height:11px;
  border:solid #fff;border-width:0 2.5px 2.5px 0;
  transform:rotate(45deg) scale(0);
  transition:transform .15s;
}
.nma-fb-check input:checked + .nma-fb-box{
  background:var(--nma-violet);border-color:var(--nma-violet);
}
.nma-fb-check input:checked + .nma-fb-box::after{transform:rotate(45deg) scale(1)}

/* 嚴重度 radio */
.nma-fb-severity{
  display:flex;flex-direction:column;gap:6px;
  margin-top:6px;
}
.nma-fb-radio{
  display:flex;align-items:center;gap:8px;cursor:pointer;
  padding:6px 10px;border-radius:8px;
  background:#f8fafc;
  font-size:13px;color:var(--nma-ink);
  transition:background .15s, box-shadow .15s;
}
.nma-fb-radio:hover{background:var(--nma-violet-soft)}
.nma-fb-radio input{accent-color:var(--nma-violet)}
.nma-fb-radio input:checked ~ span{font-weight:700}
.nma-fb-radio:has(input:checked){
  background:var(--nma-violet-soft);
  box-shadow:inset 0 0 0 1px var(--nma-violet);
}

/* 使用者回報三角形 marker */
.nma-report-icon{background:transparent !important;border:none !important}
.nma-report-mark{
  width:24px;height:24px;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.25));
}
.nma-report-mark svg{display:block}

.nma-fb-field{margin-bottom:16px}
.nma-fb-label{
  display:block;
  font-size:13px;font-weight:600;color:var(--nma-mute);
  margin-bottom:8px;
}

.nma-fb-textarea{
  width:100%;border:1px solid var(--nma-line);border-radius:10px;
  padding:10px 12px;font-family:inherit;font-size:14px;
  resize:vertical;min-height:78px;
  color:var(--nma-ink);background:#fff;
  outline:none;transition:border-color .15s, box-shadow .15s;
}
.nma-fb-textarea:focus{
  border-color:var(--nma-violet);
  box-shadow:0 0 0 3px rgba(124,58,237,.15);
}

.nma-fb-drop{
  border:2px dashed var(--nma-line);
  border-radius:12px;padding:18px;
  background:#fafbfc;cursor:pointer;
  transition:border-color .15s, background .15s;
}
.nma-fb-drop:hover,
.nma-fb-drop.is-drag{
  border-color:var(--nma-violet);
  background:var(--nma-violet-soft);
}
.nma-fb-drop-inner{
  display:flex;align-items:center;gap:14px;
}
.nma-fb-drop-icon{
  font-size:32px;flex:none;
}
.nma-fb-drop-text{
  flex:1;font-size:13.5px;color:var(--nma-mute);line-height:1.6;
}
.nma-fb-drop-text strong{color:var(--nma-violet-deep);font-weight:700}
.nma-fb-drop-text small{font-size:11.5px;color:var(--nma-mute-2)}
.nma-fb-drop-btn{
  background:var(--nma-violet);color:#fff;border:none;cursor:pointer;
  padding:8px 14px;border-radius:8px;
  font-family:inherit;font-size:13px;font-weight:600;
  flex:none;
}
.nma-fb-drop-btn:hover{background:var(--nma-violet-deep)}

.nma-fb-thumbs{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));
  gap:10px;margin-top:12px;
}
.nma-fb-thumb{
  position:relative;
  border-radius:8px;overflow:hidden;
  border:1px solid var(--nma-line);
  aspect-ratio:1/1;
  background:#f1f5f9;
}
.nma-fb-thumb img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.nma-fb-thumb-x{
  position:absolute;top:4px;right:4px;
  background:rgba(15,23,42,.7);color:#fff;
  border:none;cursor:pointer;
  width:22px;height:22px;border-radius:50%;
  font-size:14px;line-height:1;
  display:grid;place-items:center;
}
.nma-fb-thumb-x:hover{background:#ef4444}
.nma-fb-thumb-name{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent, rgba(15,23,42,.75));
  color:#fff;font-size:10px;padding:8px 4px 4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

.nma-fb-share-row{margin-top:10px}

.nma-fb-foot{
  display:flex;border-top:1px solid var(--nma-line);
}
.nma-fb-cancel,.nma-fb-submit{
  flex:1;padding:16px;
  background:transparent;border:none;cursor:pointer;
  font-family:inherit;font-size:15px;font-weight:700;
  transition:background .15s;
}
.nma-fb-cancel{color:var(--nma-mute);border-right:1px solid var(--nma-line)}
.nma-fb-cancel:hover{background:#f8fafc;color:var(--nma-ink)}
.nma-fb-submit{color:#fff;background:linear-gradient(135deg,#7c3aed,#a855f7)}
.nma-fb-submit:hover{background:linear-gradient(135deg,#6d28d9,#9333ea)}

/* ===== Coord dropdown menu (整合到側欄) ===== */
.nma-coord-card{
  margin:0 18px 16px;
  background:#fff;border:1px solid var(--nma-violet);
  border-radius:14px;
  box-shadow:
    0 0 0 3px rgba(124,58,237,.12),
    0 8px 20px -6px rgba(124,58,237,.25);
  opacity:0;transform:translateY(-6px);
  transition:opacity .25s ease, transform .25s ease;
  overflow:hidden;
}
.nma-coord-card.is-open{
  opacity:1;transform:translateY(0);
  animation:nma-coord-attn .8s ease-out;
}
@keyframes nma-coord-attn{
  0%{ box-shadow:0 0 0 3px rgba(124,58,237,.12), 0 8px 20px -6px rgba(124,58,237,.25) }
  30%{ box-shadow:0 0 0 8px rgba(124,58,237,.25), 0 12px 28px -6px rgba(124,58,237,.45) }
  100%{ box-shadow:0 0 0 3px rgba(124,58,237,.12), 0 8px 20px -6px rgba(124,58,237,.25) }
}
.nma-coord-head{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  border-bottom:1px solid var(--nma-line);
  background:linear-gradient(180deg,#faf7ff 0%,#fff 100%);
}
.nma-coord-pin{
  width:30px;height:30px;border-radius:8px;
  background:var(--nma-violet-soft);
  display:grid;place-items:center;font-size:14px;
  flex:none;
}
.nma-coord-text{
  flex:1;
  font-size:15px;font-weight:700;color:var(--nma-ink);
  font-family:'Menlo','Consolas',monospace;
  letter-spacing:.3px;
}
.nma-coord-close{
  background:transparent;border:none;cursor:pointer;
  font-size:20px;color:var(--nma-mute-2);line-height:1;
  width:28px;height:28px;border-radius:50%;
  flex:none;
}
.nma-coord-close:hover{background:#f1f5f9;color:var(--nma-ink)}

.nma-coord-actions[hidden]{display:none}
.nma-coord-actions{
  display:flex;flex-direction:column;
  padding:6px 0;
}
.nma-coord-act{
  display:flex;align-items:center;gap:12px;
  background:transparent;border:none;cursor:pointer;
  padding:11px 16px;
  font-family:inherit;text-align:left;
  transition:background .15s;
  width:100%;
}
.nma-coord-act + .nma-coord-act{border-top:1px solid #f1f5f9}
.nma-coord-act:hover{background:var(--nma-violet-soft)}
.nma-coord-act:hover .nma-coord-act-arrow{transform:translateX(2px);color:var(--nma-violet)}

.nma-coord-act-text{
  flex:1;display:flex;flex-direction:column;gap:2px;line-height:1.3;
}
.nma-coord-act-text strong{
  font-size:14px;font-weight:600;color:var(--nma-ink);
}
.nma-coord-act-text small{
  font-size:11.5px;color:var(--nma-mute);font-weight:400;
}
.nma-coord-act-arrow{
  font-size:18px;color:var(--nma-mute-2);font-weight:600;
  flex:none;transition:transform .15s, color .15s;
}

/* 三顆動作按鈕在路線面板內的樣式（從座標卡移入後的微調） */
.nma-coord-actions--inroute{
  margin-top:10px;
  padding:4px 0 0;
  border-top:1px dashed var(--nma-violet-soft);
  background:#fff;
  border-radius:10px;
  overflow:hidden;
  opacity:0;transform:translateY(-4px);
  transition:opacity .2s ease, transform .2s ease;
}
.nma-coord-actions--inroute.is-open{
  opacity:1;transform:translateY(0);
}
.nma-coord-actions--inroute .nma-coord-act{padding:10px 12px}
.nma-coord-actions--inroute .nma-coord-act:hover{background:var(--nma-violet-soft)}

/* ============== A → B ROUTE PANEL (整合到側欄) ============== */
.nma-route-panel{
  margin:6px 18px 16px;
  padding:14px;
  background:linear-gradient(180deg,#faf7ff 0%,#fff 100%);
  border:1px solid var(--nma-violet-soft);
  border-radius:14px;
  box-shadow:
    0 1px 2px rgba(15,23,42,.04),
    0 4px 12px -4px rgba(124,58,237,.12);
}
.nma-route-panel-h{
  display:flex;align-items:center;gap:6px;
  font-size:11.5px;font-weight:700;letter-spacing:1px;
  color:var(--nma-violet-deep);text-transform:uppercase;
  margin-bottom:8px;
}
.nma-route-panel-h::before{
  content:"";flex:none;width:14px;height:2px;border-radius:1px;
  background:linear-gradient(90deg,#7c3aed,#ec4899);
}

.nma-route-row{
  display:flex;align-items:center;gap:10px;
  padding:8px;border-radius:10px;
  background:#f8fafc;
  transition:background .15s;
}
.nma-route-row:focus-within{background:#f1f5f9}
.nma-route-dot{
  flex:none;width:24px;height:24px;border-radius:50%;
  display:grid;place-items:center;
  color:#fff;font-size:12px;font-weight:800;
  box-shadow:0 2px 6px -1px rgba(0,0,0,.2);
}
.nma-route-dot--a{background:#16a34a}
.nma-route-dot--b{background:#ef4444}
.nma-route-dot--c{background:#f59e0b}

/* 中繼點 C row / toggle 按鈕 */
.nma-route-via-toggle{
  display:block;width:100%;
  margin:6px 0 2px;
  padding:6px 8px;
  background:transparent;border:1px dashed var(--nma-violet-soft);
  color:var(--nma-violet-deep);
  border-radius:8px;cursor:pointer;
  font-size:12px;font-weight:600;font-family:inherit;
  transition:background .15s, border-color .15s;
}
.nma-route-via-toggle:hover{background:var(--nma-violet-soft);border-color:var(--nma-violet)}
.nma-route-via-toggle.is-active{display:none}

.nma-route-row--via[hidden]{display:none}
.nma-route-row--via{margin-top:6px}
.nma-route-row input{
  flex:1;border:none;outline:none;background:transparent;
  font-size:14px;font-family:inherit;color:var(--nma-ink);
  cursor:text;
}
.nma-route-row input::placeholder{color:var(--nma-mute-2)}
.nma-route-row input.is-invalid{color:#dc2626}
.nma-route-row:has(input.is-invalid){
  background:#fef2f2;
  animation:nma-shake .3s ease-in-out;
}
@keyframes nma-shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-3px)}
  75%{transform:translateX(3px)}
}
.nma-route-clear{
  background:transparent;border:none;cursor:pointer;
  width:22px;height:22px;border-radius:50%;
  color:var(--nma-mute-2);font-size:16px;line-height:1;
  display:grid;place-items:center;
}
.nma-route-clear:hover{background:#e2e8f0;color:var(--nma-ink)}

.nma-route-divider{
  display:flex;align-items:center;gap:10px;
  padding:4px 0 4px 18px;
  position:relative;
}
.nma-route-line{
  flex:1;height:1px;
  background:repeating-linear-gradient(90deg,#94a3b8 0 3px,transparent 3px 7px);
}
.nma-route-swap{
  background:#fff;border:1px solid var(--nma-line);cursor:pointer;
  width:28px;height:28px;border-radius:50%;
  font-size:13px;color:var(--nma-violet-deep);font-weight:700;
  display:grid;place-items:center;
  margin-right:8px;
  transition:background .15s,transform .2s;
}
.nma-route-swap:hover{background:var(--nma-violet-soft);transform:rotate(180deg)}

.nma-route-summary[hidden]{display:none}
.nma-route-summary{
  margin-top:12px;padding-top:12px;
  border-top:1px solid var(--nma-line);
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;
}
.nma-route-summary-stat{
  display:flex;flex-direction:column;align-items:center;
  padding:4px;
}
.nma-route-summary-stat strong{
  font-size:17px;color:var(--nma-ink);font-weight:800;line-height:1;
}
.nma-route-summary-stat span{
  font-size:11px;color:var(--nma-mute);margin-top:4px;
}
.nma-route-stat-note{
  display:inline-block;margin-top:2px;
  font-size:9.5px;color:#b45309;
  background:#fef3c7;
  padding:1px 5px;border-radius:999px;
  letter-spacing:.3px;cursor:help;
}
.nma-route-warn[hidden]{display:none}

/* 路線摘要：Google 街景按鈕列 */
.nma-route-streetview{
  grid-column:1/-1;
  display:flex;align-items:center;gap:6px;
  margin-top:8px;padding:6px 10px;
  background:#f8fafc;border:1px solid var(--nma-line);
  border-radius:8px;
}
.nma-route-streetview-label{
  font-size:11.5px;color:var(--nma-mute);font-weight:600;
  margin-right:auto;
}
.nma-sv-btn[hidden]{display:none}
.nma-sv-btn{
  width:30px;height:26px;border-radius:6px;
  background:#fff;border:1px solid var(--nma-line);
  font-family:inherit;font-size:12px;font-weight:700;color:var(--nma-ink);
  cursor:pointer;
  transition:background .15s, border-color .15s, color .15s, transform .15s;
}
.nma-sv-btn:hover{
  background:#fef3c7;border-color:#fcd34d;color:#92400e;
  transform:translateY(-1px);
}
.nma-route-warn{
  grid-column:1/-1;
  margin-top:8px;padding:8px 10px;
  background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;
  border-radius:8px;
  font-size:12.5px;line-height:1.45;
}
.nma-route-warn strong{color:#991b1b}

.nma-route-go{
  grid-column:1/-1;margin-top:8px;
  padding:10px;border-radius:10px;border:none;cursor:pointer;
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  color:#fff;font-size:14px;font-weight:700;font-family:inherit;
  letter-spacing:.5px;
  box-shadow:0 8px 16px -6px rgba(124,58,237,.5);
  transition:transform .15s, box-shadow .15s;
}
.nma-route-go:hover{transform:translateY(-1px);box-shadow:0 10px 20px -6px rgba(124,58,237,.6)}

/* ── 分享回饋（可拍照）常駐入口 ── */
.nma-route-fb{
  margin-top:12px;
  width:100%;
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;
  background:linear-gradient(135deg,#fef3c7,#fce7f3);
  border:1px solid #fce7f3;
  border-radius:12px;
  cursor:pointer;font-family:inherit;text-align:left;
  transition:transform .15s, box-shadow .15s, border-color .15s;
  box-shadow:0 2px 6px -2px rgba(236,72,153,.18);
}
.nma-route-fb:hover{
  transform:translateY(-1px);
  border-color:#ec4899;
  box-shadow:0 8px 16px -4px rgba(236,72,153,.28);
}
.nma-route-fb-ic{
  flex:none;width:36px;height:36px;border-radius:10px;
  background:#fff;
  display:grid;place-items:center;font-size:18px;
  box-shadow:0 2px 6px -1px rgba(15,23,42,.12);
}
.nma-route-fb-text{
  flex:1;display:flex;flex-direction:column;gap:1px;line-height:1.3;
}
.nma-route-fb-text strong{
  font-size:13.5px;font-weight:700;color:#7c2d12;
}
.nma-route-fb-text small{
  font-size:11px;color:#9f1239;font-weight:500;
}
.nma-route-fb-arrow{
  flex:none;font-size:18px;color:#be185d;font-weight:600;
  transition:transform .15s;
}
.nma-route-fb:hover .nma-route-fb-arrow{transform:translateX(2px)}

/* ===== 路線動作列：歷史 + 分享 ===== */
.nma-route-actions-row{
  margin-top:10px;display:flex;gap:6px;
}
.nma-route-share-btn{
  flex:none;
  display:inline-flex;align-items:center;gap:5px;
  padding:8px 12px;
  background:#fff;border:1px solid var(--nma-line);
  border-radius:10px;cursor:pointer;
  font-size:13px;font-weight:600;font-family:inherit;color:var(--nma-ink);
  transition:background .15s, border-color .15s, color .15s;
}
.nma-route-share-btn:hover{
  background:var(--nma-violet-soft);border-color:var(--nma-violet-soft);
  color:var(--nma-violet-deep);
}
.nma-route-share-btn.is-copied{
  background:#dcfce7;border-color:#86efac;color:#15803d;
}

/* ============== 分享路線 modal ============== */
.nma-share-modal{position:fixed;inset:0;z-index:9700;display:grid;place-items:center;padding:16px}
.nma-share-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(2px)}
.nma-share-card{
  position:relative;width:min(420px,100%);
  background:#fff;border-radius:18px;
  box-shadow:0 24px 60px -12px rgba(15,23,42,.45);
  overflow:hidden;
  animation:nma-share-in .25s ease-out;
}
@keyframes nma-share-in{
  from{ opacity:0; transform:translateY(12px) scale(.96) }
  to  { opacity:1; transform:translateY(0) scale(1) }
}
.nma-share-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--nma-line);
  background:linear-gradient(180deg,#faf7ff 0%,#fff 100%);
}
.nma-share-head h3{margin:0;font-size:15px;font-weight:700;color:var(--nma-violet-deep)}
.nma-share-close{
  background:transparent;border:none;cursor:pointer;
  width:30px;height:30px;border-radius:50%;
  font-size:22px;color:var(--nma-mute-2);line-height:1;
}
.nma-share-close:hover{background:#f1f5f9;color:var(--nma-ink)}
.nma-share-body{padding:14px 18px 18px}

.nma-share-summary{
  background:#f8fafc;border:1px solid var(--nma-line);
  border-radius:10px;padding:10px 12px;margin-bottom:14px;
  font-size:12.5px;line-height:1.6;
}
.nma-share-summary-row{display:flex;align-items:center;gap:8px}
.nma-share-dot{
  flex:none;width:18px;height:18px;border-radius:50%;
  display:grid;place-items:center;color:#fff;font-size:10px;font-weight:800;
}
.nma-share-dot--a{background:#16a34a}
.nma-share-dot--b{background:#ef4444}

.nma-share-link-label{
  display:block;font-size:11px;font-weight:600;color:var(--nma-mute);
  margin-bottom:5px;letter-spacing:.2px;
}
.nma-share-link-row{display:flex;gap:6px;margin-bottom:14px}
.nma-share-link-row input{
  flex:1;padding:8px 10px;
  border:1px solid var(--nma-line);border-radius:8px;
  font-family:Menlo,Consolas,monospace;font-size:11.5px;color:var(--nma-ink);
  background:#f8fafc;
}
.nma-share-link-copy{
  flex:none;padding:8px 14px;border-radius:8px;
  background:var(--nma-violet);color:#fff;border:none;cursor:pointer;
  font-size:12.5px;font-weight:700;font-family:inherit;
  transition:background .15s;
}
.nma-share-link-copy:hover{background:var(--nma-violet-deep)}
.nma-share-link-copy.is-copied{background:#16a34a}

.nma-share-targets{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
}
.nma-share-target{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:10px 6px;border-radius:10px;
  background:#fff;border:1px solid var(--nma-line);cursor:pointer;
  font-size:11px;font-weight:600;color:var(--nma-ink);font-family:inherit;
  transition:background .15s, transform .15s, border-color .15s;
}
.nma-share-target:hover{background:#f8fafc;transform:translateY(-1px);border-color:var(--nma-violet-soft)}
.nma-share-target-ic{
  width:32px;height:32px;border-radius:50%;
  display:grid;place-items:center;
  color:#fff;font-size:15px;font-weight:800;
}

.nma-share-qr{
  margin-top:14px;padding:14px;
  background:#f8fafc;border-radius:10px;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.nma-share-qr img{width:180px;height:180px;display:block}
.nma-share-qr-hint{font-size:11.5px;color:var(--nma-mute)}

/* ===== 最近路線 history ===== */
.nma-route-history-btn{
  flex:1;
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;
  background:#fff;border:1px solid var(--nma-line);
  border-radius:10px;cursor:pointer;
  font-size:13px;font-weight:600;font-family:inherit;color:var(--nma-ink);
  transition:background .15s, border-color .15s;
}
.nma-route-history-btn:hover{background:var(--nma-violet-soft);border-color:var(--nma-violet-soft)}
.nma-route-history-ic{font-size:14px}
.nma-route-history-count{
  margin-left:auto;
  background:var(--nma-violet);color:#fff;
  font-size:10.5px;font-weight:700;
  padding:2px 7px;border-radius:999px;
  min-width:18px;text-align:center;
}
.nma-route-history-count[hidden]{display:none}

.nma-route-history-list[hidden]{display:none}
.nma-route-history-list{
  margin-top:6px;
  background:#fff;border:1px solid var(--nma-line);
  border-radius:10px;
  max-height:240px;overflow-y:auto;
}
.nma-route-history-empty{
  padding:14px;color:var(--nma-mute);font-size:12.5px;text-align:center;
}
.nma-route-history-item{
  display:flex;align-items:center;gap:6px;
  padding:8px 10px;
  border-bottom:1px solid #f1f5f9;cursor:pointer;
  transition:background .12s;
}
.nma-route-history-item:last-child{border-bottom:none}
.nma-route-history-item:hover{background:var(--nma-violet-soft)}
.nma-route-history-text{
  flex:1;font-size:11.5px;line-height:1.6;color:var(--nma-ink);
  overflow:hidden;text-overflow:ellipsis;
}
.nma-route-history-dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  margin-right:6px;vertical-align:middle;
}
.nma-route-history-dot--a{background:#16a34a}
.nma-route-history-dot--b{background:#ef4444}
.nma-route-history-via{
  display:block;margin-left:14px;
  font-size:10.5px;color:var(--nma-mute);
}
.nma-route-history-del{
  flex:none;background:transparent;border:none;cursor:pointer;
  width:22px;height:22px;border-radius:50%;
  color:var(--nma-mute-2);font-size:14px;line-height:1;
}
.nma-route-history-del:hover{background:#fee2e2;color:#b91c1c}

/* A / B markers */
.nma-ab-icon{background:transparent !important;border:none !important}
.nma-ab{
  width:34px;height:34px;border-radius:50%;
  color:#fff;font-size:16px;font-weight:800;
  display:grid;place-items:center;
  box-shadow:0 6px 14px -2px rgba(15,23,42,.35), 0 0 0 3px #fff;
  border:2px solid rgba(255,255,255,.5);
}

/* Coord card 圓點 in actions */
.nma-act-dot{
  display:inline-grid;place-items:center;
  width:18px;height:18px;border-radius:50%;
  color:#fff;font-size:10px;font-weight:800;
  margin-right:4px;vertical-align:middle;
}
.nma-act-dot--a{background:#16a34a}
.nma-act-dot--b{background:#ef4444}
.nma-act-dot--c{background:#f59e0b}

/* Top-right brand stamp */
.nma-map-stamp{
  position:absolute;bottom:6px;right:8px;
  background:rgba(255,255,255,.85);
  padding:3px 8px;border-radius:6px;
  font-size:10.5px;color:var(--nma-mute);
  z-index:500;
}

/* Tour entry button (sidebar header) */
.nma-side-head-actions{
  margin-left:auto;
  display:inline-flex;align-items:center;gap:6px;
}
.nma-tour-btn{
  padding:6px 12px;border-radius:999px;
  background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;
  border:none;cursor:pointer;font-family:inherit;
  font-size:12.5px;font-weight:700;letter-spacing:.3px;
  display:inline-flex;align-items:center;gap:5px;
  box-shadow:0 4px 12px -4px rgba(124,58,237,.55);
  transition:transform .15s, box-shadow .15s;
}
.nma-tour-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px -4px rgba(124,58,237,.7)}
.nma-tour-btn span{font-size:14px}

.nma-lang-btn{
  padding:6px 10px;border-radius:999px;
  background:#fff;color:var(--nma-violet-deep);
  border:1px solid var(--nma-violet-soft);cursor:pointer;font-family:inherit;
  font-size:12px;font-weight:700;
  display:inline-flex;align-items:center;gap:4px;
  transition:background .15s, border-color .15s, color .15s;
}
.nma-lang-btn:hover{background:var(--nma-violet-soft);border-color:var(--nma-violet);color:var(--nma-violet)}
.nma-lang-btn span:first-child{font-size:13px}
.nma-lang-btn span:last-child{font-weight:800;letter-spacing:.3px}

/* ============== TAKE A TOUR OVERLAY ============== */
.nma-tour{
  position:fixed;inset:0;z-index:9000;
  pointer-events:none;
  opacity:0;transition:opacity .2s;
}
.nma-tour.is-open{
  pointer-events:auto;opacity:1;
}
.nma-tour-spotlight{
  position:absolute;
  border-radius:14px;
  background:transparent;
  /* 多層 box-shadow：
     1. 內框白色邊（讓 target 邊緣發亮）
     2. 內框白色 glow（讓 target 內部變亮）
     3. 9999px 暗色外框（dim 整片頁面）
     4. 紫色細邊
     5. 大範圍白色 halo（讓 spotlight 周圍融出柔光）
     6. 紫色 outer glow
  */
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,.7),
    inset 0 0 28px 4px rgba(255,255,255,.35),
    0 0 0 9999px rgba(15,23,42,.62),
    0 0 0 3px rgba(124,58,237,.85),
    0 0 48px 14px rgba(255,255,255,.55),
    0 0 70px 18px rgba(124,58,237,.5);
  transition:top .3s ease, left .3s ease, width .3s ease, height .3s ease;
  pointer-events:none;
  z-index:1;
  /* 內部使用 mix-blend-mode 額外提亮 */
}
/* 用 ::before 疊一層柔白色提亮層，blend mode 讓底下的 UI 變亮 */
.nma-tour-spotlight::before{
  content:"";
  position:absolute;inset:0;
  border-radius:inherit;
  background:radial-gradient(ellipse at center, rgba(255,255,255,.28) 0%, rgba(255,255,255,0) 70%);
  mix-blend-mode:screen;
  pointer-events:none;
}

.nma-tour-card{
  position:absolute;
  width:360px;max-width:calc(100vw - 40px);
  background:#fff;border-radius:16px;
  padding:22px 22px 18px;
  z-index:2;
  /* 卡片亮度 + 紫色光暈 + 白色外圈 halo（讓周圍 dim 區也透出微光） */
  box-shadow:
    0 0 0 1px rgba(124,58,237,.2),
    0 24px 50px -12px rgba(15,23,42,.55),
    0 0 60px 12px rgba(255,255,255,.4),
    0 0 100px 24px rgba(124,58,237,.35);
  transition:top .3s ease, left .3s ease;
}
.nma-tour-card::before{
  content:"";position:absolute;
  width:14px;height:14px;
  background:#fff;
  transform:rotate(45deg);
  box-shadow:-1px -1px 0 rgba(124,58,237,.12);
}
.nma-tour-card[data-arrow="left"]::before{left:-7px;top:50%;margin-top:-7px}
.nma-tour-card[data-arrow="right"]::before{right:-7px;top:50%;margin-top:-7px;box-shadow:1px 1px 0 rgba(124,58,237,.12)}
.nma-tour-card[data-arrow="top"]::before{top:-7px;left:50%;margin-left:-7px}
.nma-tour-card[data-arrow="bottom"]::before{bottom:-7px;left:50%;margin-left:-7px;box-shadow:1px 1px 0 rgba(124,58,237,.12)}
.nma-tour-card[data-arrow="none"]::before{display:none}

.nma-tour-close{
  position:absolute;top:10px;right:12px;
  background:transparent;border:none;cursor:pointer;
  width:28px;height:28px;border-radius:50%;
  font-size:20px;color:var(--nma-mute-2);line-height:1;
}
.nma-tour-close:hover{background:#f1f5f9;color:var(--nma-ink)}

.nma-tour-step{
  display:inline-block;
  padding:3px 10px;border-radius:999px;
  background:var(--nma-violet-soft);color:var(--nma-violet-deep);
  font-size:11.5px;font-weight:700;letter-spacing:.5px;
  margin-bottom:10px;
}
.nma-tour-title{
  margin:0 0 10px;
  font-size:18px;font-weight:800;color:var(--nma-ink);
  letter-spacing:-.2px;
}
.nma-tour-desc{
  margin:0 0 14px;
  font-size:14.5px;line-height:1.6;color:var(--nma-mute);
}

.nma-tour-dots{
  display:flex;gap:6px;margin-bottom:14px;
}
.nma-tour-dot{
  width:8px;height:8px;border-radius:50%;
  background:#e2e8f0;transition:background .2s, transform .2s;
}
.nma-tour-dot.is-done{background:#c4b5fd}
.nma-tour-dot.is-active{
  background:var(--nma-violet);transform:scale(1.3);
  box-shadow:0 0 0 3px rgba(124,58,237,.25);
}

.nma-tour-actions{
  display:flex;gap:8px;align-items:center;
  border-top:1px solid var(--nma-line);
  padding-top:12px;
}
.nma-tour-skip{
  background:transparent;border:none;cursor:pointer;
  font-family:inherit;font-size:13px;color:var(--nma-mute);
  padding:8px 4px;
}
.nma-tour-skip:hover{color:var(--nma-ink)}
.nma-tour-prev{
  margin-left:auto;
  background:#fff;border:1px solid var(--nma-line);cursor:pointer;
  font-family:inherit;font-size:13px;font-weight:600;color:var(--nma-ink);
  padding:8px 14px;border-radius:8px;
  transition:background .15s;
}
.nma-tour-prev:hover{background:#f8fafc}
.nma-tour-prev:disabled{opacity:.4;cursor:not-allowed}
.nma-tour-next{
  background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;
  border:none;cursor:pointer;
  font-family:inherit;font-size:13.5px;font-weight:700;
  padding:8px 18px;border-radius:8px;
  box-shadow:0 6px 14px -4px rgba(124,58,237,.5);
  transition:transform .15s, box-shadow .15s;
}
.nma-tour-next:hover{transform:translateY(-1px);box-shadow:0 8px 18px -4px rgba(124,58,237,.65)}

/* Mobile */
@media (max-width:820px){
  .nma-side{max-height:46vh}
  .nma-map-wrap{height:54vh}
  .nma-coord-card{min-width:0;width:calc(100% - 24px)}
  .nma-tour-btn{padding:4px 10px;font-size:11.5px}
  .nma-tour-card{width:calc(100% - 32px);left:16px !important}
  .nma-tour-card::before{display:none}
}

/* ============== COOKIE CONSENT ============== */
.nma-cookie-banner[hidden]{display:none}
.nma-cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;
  z-index:9500;
  background:#fff;
  border:1px solid var(--nma-line);
  border-radius:14px;
  box-shadow:0 14px 36px -10px rgba(15,23,42,.32), 0 4px 12px -4px rgba(15,23,42,.12);
  padding:14px 16px;
  display:flex;align-items:center;gap:16px;
  font-size:13px;color:var(--nma-ink);
  animation:nma-cookie-in .35s ease-out;
}
@keyframes nma-cookie-in{
  from{ opacity:0; transform:translateY(20px) }
  to  { opacity:1; transform:translateY(0) }
}
.nma-cookie-banner-body{flex:1;min-width:0}
.nma-cookie-banner-title{
  margin:0 0 4px;font-size:14px;font-weight:700;color:var(--nma-violet-deep);
}
.nma-cookie-banner-text{
  margin:0;font-size:12.5px;line-height:1.55;color:var(--nma-ink-2,#475569);
}
.nma-cookie-banner-text a{color:var(--nma-violet);text-decoration:underline}
.nma-cookie-banner-text strong{color:var(--nma-ink);font-weight:700}
.nma-cookie-banner-actions{
  flex:none;display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.nma-cookie-btn{
  padding:8px 14px;border-radius:8px;
  font-family:inherit;font-size:13px;font-weight:600;
  cursor:pointer;border:1px solid transparent;
  transition:background .15s, transform .15s, border-color .15s, color .15s;
}
.nma-cookie-btn--primary{
  background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;
  box-shadow:0 4px 12px -4px rgba(124,58,237,.55);
}
.nma-cookie-btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px -4px rgba(124,58,237,.7)}
.nma-cookie-btn--ghost{
  background:#fff;color:var(--nma-ink);border-color:var(--nma-line);
}
.nma-cookie-btn--ghost:hover{background:#f1f5f9;border-color:var(--nma-mute-2)}
.nma-cookie-btn--link{
  background:transparent;color:var(--nma-violet-deep);padding:8px 6px;
}
.nma-cookie-btn--link:hover{text-decoration:underline}

@media (max-width:680px){
  .nma-cookie-banner{
    flex-direction:column;align-items:stretch;
    left:12px;right:12px;bottom:12px;padding:12px;
  }
  .nma-cookie-banner-actions{justify-content:flex-end}
}

/* Cookie 設定 Modal */
.nma-cookie-modal[hidden]{display:none}
.nma-cookie-modal{
  position:fixed;inset:0;z-index:9700;
  display:grid;place-items:center;padding:16px;
}
.nma-cookie-modal-backdrop{
  position:absolute;inset:0;
  background:rgba(15,23,42,.45);
  backdrop-filter:blur(2px);
}
.nma-cookie-modal-card{
  position:relative;width:min(480px,100%);
  background:#fff;border-radius:18px;
  box-shadow:0 24px 60px -12px rgba(15,23,42,.45);
  overflow:hidden;
}
.nma-cookie-modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;border-bottom:1px solid var(--nma-line);
}
.nma-cookie-modal-head h2{margin:0;font-size:16px;font-weight:700;color:var(--nma-violet-deep)}
.nma-cookie-modal-close{
  background:transparent;border:none;cursor:pointer;
  width:30px;height:30px;border-radius:50%;
  font-size:22px;color:var(--nma-mute-2);line-height:1;
}
.nma-cookie-modal-close:hover{background:#f1f5f9;color:var(--nma-ink)}
.nma-cookie-modal-intro{
  margin:0;padding:12px 18px 0;font-size:12.5px;color:var(--nma-mute);line-height:1.55;
}
.nma-cookie-modal-body{padding:8px 18px 18px;display:flex;flex-direction:column;gap:12px}
.nma-cookie-modal-item{
  background:#f8fafc;border:1px solid var(--nma-line);
  border-radius:10px;padding:12px 14px;
}
.nma-cookie-modal-item-head{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;
}
.nma-cookie-modal-item-head h3{margin:0;font-size:13.5px;font-weight:700;color:var(--nma-ink)}
.nma-cookie-modal-item p{margin:0;font-size:12px;color:var(--nma-mute);line-height:1.55}
.nma-cookie-locked{
  font-size:11px;font-weight:600;color:var(--nma-mute-2);
  padding:3px 8px;border-radius:999px;background:#fff;
  border:1px solid var(--nma-line);
}
.nma-cookie-switch{position:relative;display:inline-block;width:36px;height:20px}
.nma-cookie-switch input{opacity:0;width:0;height:0}
.nma-cookie-switch span{
  position:absolute;cursor:pointer;inset:0;
  background:#cbd5e1;border-radius:999px;
  transition:background .2s;
}
.nma-cookie-switch span::after{
  content:"";position:absolute;left:2px;top:2px;
  width:16px;height:16px;border-radius:50%;
  background:#fff;transition:transform .2s;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.nma-cookie-switch input:checked + span{background:var(--nma-violet)}
.nma-cookie-switch input:checked + span::after{transform:translateX(16px)}
.nma-cookie-modal-actions{
  display:flex;justify-content:flex-end;gap:8px;
  padding:14px 18px;border-top:1px solid var(--nma-line);background:#fafbfc;
}

/* ============== 開始導航 全螢幕 modal ============== */
.nma-nav-modal[hidden]{display:none}
.nma-nav-modal{
  /* 桌面：縮到左側直欄（像 Google Maps 路線欄），地圖佔右側 */
  position:fixed; left:0; top:0; bottom:0; z-index:9800;
  width:min(400px, 92vw);
  background:#fff;
  display:flex;flex-direction:column;
  border-radius:0 20px 20px 0;
  box-shadow:8px 0 28px rgba(0,0,0,.18);
  animation:nma-nav-in .25s ease-out;
}
@keyframes nma-nav-in{
  from{ opacity:0; transform:translateX(-20px) }
  to  { opacity:1; transform:translateX(0) }
}
/* 手機窄螢幕：退回底部面板（左側欄太窄不好用） */
@media (max-width:640px){
  .nma-nav-modal{
    left:0; right:0; top:auto; bottom:0;
    width:auto; max-height:56vh;
    border-radius:20px 20px 0 0;
    box-shadow:0 -8px 28px rgba(0,0,0,.18);
  }
}

.nma-nav-head{
  display:flex;align-items:center;gap:12px;
  padding:12px 18px;
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  color:#fff;
  flex:none;
  box-shadow:0 4px 12px -4px rgba(124,58,237,.4);
}
.nma-nav-profile-tag{
  display:flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.18);
  padding:6px 12px;border-radius:999px;
  font-size:13px;font-weight:600;
}
.nma-nav-profile-emoji{font-size:18px;line-height:1}
.nma-nav-eta{
  margin-left:auto;text-align:right;line-height:1.2;
}
.nma-nav-eta strong{font-size:18px;font-weight:800;display:block}
.nma-nav-eta span{font-size:11.5px;opacity:.85}
.nma-nav-close{
  background:rgba(255,255,255,.18);border:none;cursor:pointer;
  width:36px;height:36px;border-radius:50%;
  color:#fff;font-size:22px;line-height:1;
  transition:background .15s;
}
.nma-nav-close:hover{background:rgba(255,255,255,.32)}

.nma-nav-current{
  display:flex;align-items:center;gap:18px;
  padding:24px 24px 20px;
  background:linear-gradient(180deg,#faf5ff 0%,#fff 100%);
  border-bottom:1px solid #ede9fe;
  flex:none;
}
.nma-nav-current-icon{
  flex:none;width:64px;height:64px;
  background:linear-gradient(135deg,#a78bfa,#7c3aed);
  color:#fff;border-radius:18px;
  display:grid;place-items:center;
  font-size:34px;
  box-shadow:0 10px 24px -6px rgba(124,58,237,.5);
}
.nma-nav-current-info{flex:1;min-width:0}
.nma-nav-current-instr{
  font-size:20px;font-weight:800;color:var(--nma-ink);
  line-height:1.3;margin-bottom:4px;
  word-break:break-word;
}
.nma-nav-current-dist{
  font-size:13px;color:var(--nma-violet-deep);font-weight:600;
}

.nma-nav-progress{
  padding:12px 24px 8px;flex:none;
}
.nma-nav-progress-track{
  width:100%;height:5px;
  background:#f1f5f9;border-radius:999px;overflow:hidden;
}
.nma-nav-progress-bar{
  height:100%;width:0;
  background:linear-gradient(90deg,#7c3aed,#a855f7);
  border-radius:999px;
  transition:width .35s ease;
}
.nma-nav-progress-label{
  font-size:11.5px;color:var(--nma-mute);font-weight:600;
  margin-top:6px;letter-spacing:.5px;
}

.nma-nav-list{
  flex:1;overflow-y:auto;
  margin:0;padding:0 12px 16px;
  list-style:none;
  counter-reset:nav;
}
.nma-nav-step{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 12px;border-radius:10px;
  margin:4px 0;
  cursor:pointer;
  transition:background .12s, transform .12s;
  counter-increment:nav;
}
.nma-nav-step:hover{background:#f8fafc}
.nma-nav-step.is-current{
  background:linear-gradient(135deg,#ede9fe,#fef3c7);
  box-shadow:0 4px 12px -4px rgba(124,58,237,.18);
  transform:translateX(2px);
}
.nma-nav-step.is-past{
  opacity:.5;
}
.nma-nav-step.is-past .nma-nav-step-icon{filter:grayscale(.6)}
.nma-nav-step-icon{
  flex:none;width:36px;height:36px;
  background:#f1f5f9;color:var(--nma-violet-deep);
  border-radius:50%;
  display:grid;place-items:center;
  font-size:18px;
}
.nma-nav-step.is-current .nma-nav-step-icon{
  background:linear-gradient(135deg,#a78bfa,#7c3aed);color:#fff;
}
.nma-nav-step-text{
  flex:1;min-width:0;
}
.nma-nav-step-instr{
  display:block;
  font-size:14px;font-weight:600;color:var(--nma-ink);
  line-height:1.45;word-break:break-word;
}
.nma-nav-step-instr::before{
  content:counter(nav) '. ';
  color:var(--nma-mute);font-weight:500;margin-right:4px;
}
.nma-nav-step-dist{
  display:block;margin-top:2px;
  font-size:11.5px;color:var(--nma-mute);font-weight:500;
}
.nma-nav-step-empty{
  padding:24px;text-align:center;color:var(--nma-mute);
  font-size:13.5px;background:#fef3c7;border-radius:10px;
  list-style:none;
}

.nma-nav-controls{
  display:grid;grid-template-columns:1fr 1.5fr 1fr;gap:8px;
  padding:12px 16px 16px;
  border-top:1px solid var(--nma-line);background:#fafbfc;
  flex:none;
}
.nma-nav-ctrl-btn{
  padding:12px 8px;border-radius:10px;
  background:#fff;border:1px solid var(--nma-line);
  font-family:inherit;font-size:13px;font-weight:700;color:var(--nma-ink);
  cursor:pointer;
  transition:background .15s, transform .12s, box-shadow .15s;
}
.nma-nav-ctrl-btn:hover{background:#f1f5f9;transform:translateY(-1px)}
.nma-nav-ctrl-btn--primary{
  background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;
  border-color:transparent;
  box-shadow:0 6px 14px -4px rgba(124,58,237,.4);
}
.nma-nav-ctrl-btn--primary:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 20px -6px rgba(124,58,237,.55);
}

/* 響應式 */
@media (max-width:560px){
  .nma-nav-head{padding:10px 14px}
  .nma-nav-eta strong{font-size:15px}
  .nma-nav-current{padding:18px 16px;gap:12px}
  .nma-nav-current-icon{width:52px;height:52px;font-size:26px;border-radius:14px}
  .nma-nav-current-instr{font-size:17px}
  .nma-nav-list{padding:0 8px 12px}
}
