/* css/galaxy.css — the Knowledge Map (Galaxy layout of the Discovery Map view)
   Survey / Core / Lens engines. Token-driven so every appearance palette
   (nocturne / mistveil / emberfall / obsidian) and light/dark all work. */

.map-content--galaxy { padding: 0 !important; }

/* ── launch panel (sits in the Map tab; the real map is full-screen) ───────── */
.km-launch{
  --font: var(--font-body, 'Outfit', sans-serif);
  --font-mono: var(--font-code, 'Space Mono', monospace);
  display:flex; align-items:center; justify-content:center;
  min-height: clamp(300px, 52vh, 560px); padding:2rem 1.5rem;
  border:1px solid var(--border); border-radius:14px;
  background:
    radial-gradient(ellipse at 30% 10%, color-mix(in srgb, var(--warm) 7%, transparent), transparent 55%),
    radial-gradient(ellipse at 85% 95%, color-mix(in srgb, var(--teal) 7%, transparent), transparent 55%),
    var(--bg);
}
.km-launch-inner{ text-align:center; max-width:440px; }
.km-launch-eyebrow{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--warm); margin-bottom:.7rem; }
.km-launch-inner h3{ font-family:var(--font-display,'DM Serif Display',serif); font-style:italic; font-weight:400; font-size:1.7rem; line-height:1.15; margin:0 0 .55rem; color:var(--text); }
.km-launch-inner p{ font-family:var(--font); color:var(--text-dim); font-size:.95rem; line-height:1.55; margin:0 auto 1.4rem; }
.km-launch-btn{ font-family:var(--font-heading,'Outfit',sans-serif); font-weight:600; font-size:1rem; background:var(--warm); color:#1a1208; border:0; border-radius:12px; padding:.72rem 1.35rem; cursor:pointer; transition:transform .15s var(--ease-spring); }
.km-launch-btn:hover{ transform:translateY(-2px); }

/* ── full-screen immersive shell (hoisted to <body>) ───────────────────────── */
html.km-fs-lock, body.km-fs-lock{ overflow:hidden !important; }
/* a true full-screen map: hide ALL site chrome that would otherwise poke through
   (universal header + its controls, the notebook FAB + its toast). */
html.km-fs-lock .em-header,
html.km-fs-lock .nb-floating-btn,
html.km-fs-lock .nb-fab-toast{ display:none !important; }
.km-fs{
  --font: var(--font-body, 'Outfit', sans-serif);
  --font-mono: var(--font-code, 'Space Mono', monospace);
  position:fixed; inset:0; z-index:2147483400;     /* above every injected widget */
  background:var(--bg); isolation:isolate; overflow:hidden;
  animation: kmFsIn .22s var(--ease-spring);
}
/* save toast (bottom-center) */
.km-toast{
  position:absolute; left:50%; bottom:calc(env(safe-area-inset-bottom) + 22px); transform:translate(-50%,12px);
  z-index:25; display:flex; align-items:center; gap:14px; max-width:calc(100% - 28px);
  padding:.55rem .6rem .55rem 1rem; border-radius:999px;
  background:color-mix(in srgb,var(--bg) 92%,transparent); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  color:var(--text); border:1px solid var(--border2); box-shadow:0 14px 36px rgba(0,0,0,.5);
  font-family:var(--font); font-size:.85rem; opacity:0; pointer-events:none; transition:opacity .2s, transform .2s;
}
.km-toast.show{ opacity:1; transform:translate(-50%,0); pointer-events:auto; }
.km-toast-act{ font-family:var(--font-heading); font-weight:600; font-size:.82rem; background:var(--warm); color:#1a1208; border:0; border-radius:999px; padding:.4rem .85rem; cursor:pointer; white-space:nowrap; }
.km-toast-act:hover{ filter:brightness(1.05); }
@keyframes kmFsIn{ from{ opacity:0; } to{ opacity:1; } }
.km-stage{ position:absolute; inset:0; }
.km-stage-host{ position:absolute; inset:0; }
.km-error{
  position:absolute; inset:0; display:flex; flex-direction:column; gap:.4rem;
  align-items:center; justify-content:center; text-align:center;
  font-family:var(--font-heading); color:var(--text-dim); font-size:1rem;
}
.km-error span{ font-family:var(--font-code); font-size:.78rem; color:var(--text-muted); }

/* floating chrome bar over the full-bleed canvas */
.km-chrome{
  position:absolute; top:0; left:0; right:0; z-index:20;
  display:flex; align-items:center; gap:10px;
  padding: calc(env(safe-area-inset-top) + 12px) 14px 12px; pointer-events:none;
}
.km-chrome > *{ pointer-events:auto; }
.km-exit{
  display:inline-flex; align-items:center; gap:.35rem;
  font-family:var(--font-heading); font-weight:600; font-size:.85rem;
  background:color-mix(in srgb,var(--bg) 80%,transparent); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
  border:1px solid var(--border2); color:var(--text-dim); border-radius:11px; padding:.5rem .75rem; cursor:pointer; transition:.15s;
}
.km-exit:hover{ color:var(--text); border-color:var(--warm); }
.km-search{
  flex:1; max-width:440px; margin-left:auto; display:flex; align-items:center; gap:.6rem;
  background:color-mix(in srgb,var(--bg) 82%,transparent); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border:1px solid var(--border2); border-radius:13px; padding:.6rem .8rem; color:var(--text-muted);
  box-shadow:0 8px 30px rgba(0,0,0,.22);
}
.km-search input{ flex:1; min-width:0; background:none; border:0; color:var(--text); font-family:var(--font); font-size:.92rem; outline:none; }
.km-search input::placeholder{ color:var(--text-muted); }
.km-search:focus-within{ border-color:var(--purple); box-shadow:0 0 0 3px color-mix(in srgb,var(--purple) 16%,transparent),0 8px 30px rgba(0,0,0,.22); }
.km-dir{
  font-family:var(--font-heading); font-weight:600; font-size:.82rem; white-space:nowrap;
  background:var(--warm); color:#1a1208; border:0; border-radius:12px; padding:.58rem .95rem; cursor:pointer;
  box-shadow:0 8px 26px color-mix(in srgb,var(--warm) 28%,transparent); transition:.16s var(--ease-spring);
}
.km-dir:hover{ transform:translateY(-1px); }

/* the shell owns search + directions → hide the engine's own duplicate top bar */
.km-fs .sv-topbar{ display:none; }
/* give survey's own controls room below the chrome bar */
.km-fs .sv-zoom{ top:auto; }

/* ── mode switcher (now a static segment inside the chrome bar) ─────────────── */
.km-modes{
  display:flex; gap:4px; padding:4px; border-radius:13px;
  background:color-mix(in srgb, var(--bg) 80%, transparent);
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
  border:1px solid var(--border2); box-shadow:0 8px 26px rgba(0,0,0,.22);
}
.km-mode{
  display:flex; flex-direction:column; align-items:flex-start; gap:1px;
  padding:.32rem .62rem; border:0; border-radius:9px; cursor:pointer;
  background:none; color:var(--text-dim); transition:.15s var(--ease-spring); line-height:1.05;
}
.km-mode:hover{ color:var(--text); background:color-mix(in srgb, var(--text) 6%, transparent); }
.km-mode.on{ background:var(--warm); color:#1a1208; }
.km-mode-l{ font-family:var(--font-heading); font-weight:600; font-size:.8rem; }
.km-mode-s{ font-family:var(--font-code); font-size:.5rem; letter-spacing:.1em; text-transform:uppercase; opacity:.8; }

/* ── persistent route bar (collapsed directions; route stays drawn) ────────── */
.sv-routebar{
  position:absolute; left:50%; bottom:54px; transform:translateX(-50%); z-index:9;
  display:flex; align-items:center; gap:.35rem; max-width:calc(100% - 28px);
  background:color-mix(in srgb,var(--bg) 90%,transparent); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border:1px solid var(--border2); border-radius:13px; padding:.25rem; box-shadow:0 14px 40px rgba(0,0,0,.4);
}
.sv-rb-main{ display:flex; flex-direction:column; align-items:flex-start; background:none; border:0; color:var(--text); cursor:pointer;
  font-family:var(--font); padding:.35rem .7rem; border-radius:10px; text-align:left; min-width:0; }
.sv-rb-main:hover{ background:color-mix(in srgb,var(--text) 6%,transparent); }
.sv-rb-main b{ font-family:var(--font-display,'DM Serif Display',serif); font-style:italic; font-weight:400; font-size:1rem; max-width:48vw; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sv-rb-main span{ font-family:var(--font-mono); font-size:.55rem; letter-spacing:.06em; text-transform:uppercase; color:var(--text-muted); }
.sv-rb-x{ flex:none; width:32px; height:32px; border-radius:9px; border:1px solid var(--border2); background:var(--bg-card); color:var(--text-muted); cursor:pointer; font-size:.78rem; }
.sv-rb-x:hover{ color:var(--warm); border-color:var(--warm); }
.sv-dirpanel .sv-min{ right:2.7rem; }

/* CRITICAL: these toggle via the `hidden` attribute but set display:flex, which
   would override the UA [hidden]{display:none}. Without this, the ✕ on the route
   bar / the Core+Lens tooltips never actually hide. */
.sv-routebar[hidden], .cr-tip[hidden], .ln-tip[hidden], .km-toast[hidden]{ display:none !important; }

/* ── engine hosts ────────────────────────────────────────────────────────── */
.sv-host,.cr-host,.ln-host{
  position:absolute; inset:0; width:100%; height:100%; overflow:hidden;
  font-family:var(--font); color:var(--text); border-radius:inherit; isolation:isolate;
  background:var(--bg);
}
.sv-canvas,.cr-canvas,.ln-canvas{ position:absolute; inset:0; display:block; }
.sv-canvas{ cursor:grab; touch-action:none; }
.sv-canvas:active{ cursor:grabbing; }
.cr-canvas,.ln-canvas{ touch-action:none; }
.sv-grain{ position:absolute; inset:0; pointer-events:none; mix-blend-mode:overlay; opacity:.42;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E"); }

/* ── survey top bar (search + directions) ────────────────────────────────── */
.sv-topbar{ position:absolute; top:14px; left:14px; right:14px; display:flex; gap:10px; z-index:6; pointer-events:none; justify-content:flex-end; }
.sv-search{ pointer-events:auto; display:flex; align-items:center; gap:.6rem; width:min(420px,46%);
  background:color-mix(in srgb,var(--bg) 80%,transparent); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border:1px solid var(--border2); border-radius:13px; padding:.62rem .8rem; color:var(--text-muted);
  box-shadow:0 8px 30px rgba(0,0,0,.26); }
[data-theme="light"] .sv-search{ box-shadow:0 8px 24px rgba(80,60,30,.12); }
.sv-search input{ flex:1; min-width:0; background:none; border:0; color:var(--text); font-family:var(--font); font-size:.92rem; outline:none; }
.sv-search input::placeholder{ color:var(--text-muted); }
.sv-search kbd{ font-family:var(--font-mono); font-size:.6rem; border:1px solid var(--border2); border-radius:5px; padding:.05rem .32rem; color:var(--text-muted); }
.sv-search:focus-within{ border-color:var(--purple); box-shadow:0 0 0 3px color-mix(in srgb,var(--purple) 16%,transparent),0 8px 30px rgba(0,0,0,.26); }
.sv-dirbtn{ pointer-events:auto; font-family:var(--font-heading); font-weight:600; font-size:.82rem;
  background:var(--warm); color:#1a1208; border:0; border-radius:12px; padding:.62rem 1rem; cursor:pointer;
  box-shadow:0 8px 26px color-mix(in srgb,var(--warm) 28%,transparent); transition:.16s var(--ease-spring); white-space:nowrap; }
.sv-dirbtn:hover{ transform:translateY(-1px); }

/* legend / elevation ramp */
.sv-legend{ position:absolute; left:16px; bottom:46px; z-index:4; display:flex; flex-direction:column; gap:5px;
  font-family:var(--font-mono); font-size:.56rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); pointer-events:none; }
.sv-ramp{ width:150px; height:7px; border-radius:4px; border:1px solid var(--border2);
  background:linear-gradient(90deg,#0d1018,#2a3047 38%,var(--teal) 70%,var(--warm)); }
[data-theme="light"] .sv-ramp{ background:linear-gradient(90deg,#e7dec9,#cdb993 45%,#b79c78 75%,#a8603a); }
.sv-legb i{ font-style:normal; color:var(--text-dim); }

/* zoom controls */
.sv-zoom{ position:absolute; right:16px; bottom:46px; z-index:6; display:flex; flex-direction:column; gap:6px; }
.sv-zoom button{ width:38px; height:38px; border-radius:10px; cursor:pointer;
  background:color-mix(in srgb,var(--bg) 82%,transparent); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  border:1px solid var(--border2); color:var(--text-dim); font-size:1.05rem; display:grid; place-items:center; transition:.15s; }
.sv-zoom button:hover{ color:var(--warm); border-color:var(--warm); }

.sv-hint{ position:absolute; left:50%; bottom:14px; transform:translateX(-50%); z-index:4; pointer-events:none;
  font-family:var(--font-mono); font-size:.58rem; letter-spacing:.13em; text-transform:uppercase; color:var(--text-muted); opacity:.8; white-space:nowrap; }

/* hover card */
.sv-card{ position:absolute; z-index:7; width:250px; pointer-events:none;
  background:color-mix(in srgb,var(--bg) 90%,transparent); -webkit-backdrop-filter:blur(16px); backdrop-filter:blur(16px);
  border:1px solid var(--border2); border-radius:13px; padding:.7rem .8rem; box-shadow:0 14px 44px rgba(0,0,0,.4); }
[data-theme="light"] .sv-card{ box-shadow:0 14px 36px rgba(80,60,30,.18); }
.sv-c-eyebrow{ font-family:var(--font-mono); font-size:.56rem; letter-spacing:.13em; text-transform:uppercase; color:var(--text-muted); display:flex; align-items:center; gap:.4rem; margin-bottom:.3rem; }
.sv-c-eyebrow .dot{ width:7px; height:7px; border-radius:50%; flex:none; }
.sv-c-title{ font-family:var(--font-display); font-style:italic; font-size:1.12rem; line-height:1.15; color:var(--text); }
.sv-c-meta{ display:flex; gap:.5rem; align-items:center; margin-top:.45rem; font-family:var(--font-mono); font-size:.6rem; color:var(--text-muted); flex-wrap:wrap; }

.tierp{ font-family:var(--font-mono); font-size:.54rem; letter-spacing:.08em; text-transform:uppercase; padding:.12rem .4rem; border-radius:5px; border:1px solid var(--border2); }
.tier-gleam{ color:var(--teal); border-color:color-mix(in srgb,var(--teal) 40%,var(--border2)); }
.tier-veanor{ color:var(--blue); border-color:color-mix(in srgb,var(--blue) 40%,var(--border2)); }
.tier-article{ color:var(--warm); border-color:color-mix(in srgb,var(--warm) 40%,var(--border2)); }
.tier-overview{ color:var(--purple); border-color:color-mix(in srgb,var(--purple) 40%,var(--border2)); }
.tier-nuranor{ color:var(--pink); border-color:color-mix(in srgb,var(--pink) 40%,var(--border2)); }

/* place card + directions panel */
.sv-place,.sv-dirpanel{ position:absolute; top:64px; left:16px; z-index:8; width:330px; max-height:calc(100% - 130px); overflow:auto;
  background:color-mix(in srgb,var(--bg) 92%,transparent); -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
  border:1px solid var(--border2); border-radius:16px; padding:1.1rem 1.15rem; box-shadow:0 20px 60px rgba(0,0,0,.46); animation:svIn .22s var(--ease-spring); }
[data-theme="light"] .sv-place,[data-theme="light"] .sv-dirpanel{ box-shadow:0 20px 50px rgba(80,60,30,.2); }
@keyframes svIn{ from{ transform:translateY(8px) scale(.985); } to{ transform:none; } }
.sv-x{ position:absolute; top:.7rem; right:.7rem; width:26px; height:26px; border-radius:8px; border:1px solid var(--border2);
  background:var(--bg-card); color:var(--text-muted); cursor:pointer; font-size:.7rem; z-index:2; }
.sv-x:hover{ color:var(--warm); border-color:var(--warm); }
.sv-p-eyebrow{ font-family:var(--font-mono); font-size:.58rem; letter-spacing:.13em; text-transform:uppercase; color:var(--text-muted); display:flex; align-items:center; gap:.4rem; }
.sv-p-eyebrow .dot{ width:8px; height:8px; border-radius:50%; }
.sv-p-title{ font-family:var(--font-display); font-style:italic; font-weight:400; font-size:1.55rem; line-height:1.1; margin:.5rem 0 .55rem; color:var(--text); }
.sv-p-meta{ display:flex; gap:.5rem; align-items:center; font-family:var(--font-mono); font-size:.62rem; color:var(--text-muted); }
.sv-p-desc{ font-size:.86rem; line-height:1.55; color:var(--text-dim); font-weight:300; margin:.7rem 0; }
.sv-p-elev{ display:flex; align-items:center; gap:.55rem; margin:.5rem 0 .9rem; font-family:var(--font-mono); font-size:.56rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted); }
.sv-p-elev .bars{ display:flex; gap:2px; flex:1; }
.sv-p-elev .bars i{ flex:1; height:9px; border-radius:2px; background:var(--border2); }
.sv-p-elev .bars i.on{ background:linear-gradient(180deg,var(--warm),var(--warm2)); }
.sv-p-elev .num{ color:var(--text); font-size:.66rem; }
.sv-p-actions{ display:flex; gap:.45rem; flex-wrap:wrap; margin-bottom:.4rem; }
.sv-btn{ font-family:var(--font-heading); font-weight:600; font-size:.78rem; border-radius:9px; padding:.5rem .8rem; cursor:pointer; border:1px solid transparent; transition:.15s var(--ease-spring); text-decoration:none; display:inline-block; }
.sv-btn:hover{ transform:translateY(-1px); }
.sv-btn.warm{ background:var(--warm); color:#1a1208; }
.sv-btn.teal{ background:var(--teal); color:#06120f; }
.sv-btn.ghost{ background:var(--bg-card); color:var(--text-dim); border-color:var(--border2); }
.sv-btn.ghost:hover{ color:var(--text); border-color:var(--border-hover); }
.sv-btn.done{ background:var(--teal)!important; color:#06120f!important; }
.sv-p-group{ margin-top:.85rem; }
.sv-p-gl{ font-family:var(--font-mono); font-size:.54rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); margin-bottom:.45rem; display:flex; align-items:center; gap:.6rem; }
.sv-p-gl::after{ content:""; flex:1; height:1px; background:var(--border); }
.sv-p-chips{ display:flex; flex-wrap:wrap; gap:.35rem; }
.sv-chip{ font-family:var(--font); font-size:.74rem; background:var(--bg-card); border:1px solid var(--border); border-radius:8px; padding:.32rem .5rem; cursor:pointer; color:var(--text-dim); display:inline-flex; align-items:center; gap:.35rem; transition:.13s; text-align:left; }
.sv-chip:hover{ border-color:var(--border-hover); color:var(--text); transform:translateY(-1px); }
.sv-chip .dot{ width:6px; height:6px; border-radius:50%; flex:none; }

.sv-dir-od{ position:relative; padding:.2rem 0 .2rem .2rem; }
.sv-dir-row{ display:flex; align-items:center; gap:.7rem; }
.sv-dir-row .pin{ font-size:.85rem; width:18px; text-align:center; }
.sv-dir-row .pin.start{ color:var(--teal); }
.sv-dir-row .pin.goal{ color:var(--warm); }
.sv-dir-row i{ display:block; font-style:normal; font-family:var(--font-mono); font-size:.52rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); }
.sv-dir-row b{ font-family:var(--font-display); font-style:italic; font-weight:400; font-size:1.05rem; color:var(--text); }
.sv-dir-row b[data-pickstart]{ border-bottom:1px dashed var(--border-hover); }
.sv-dir-line{ height:16px; width:1px; background:var(--border2); margin:2px 0 2px 8px; }
.sv-dir-routes{ display:flex; flex-direction:column; gap:.4rem; margin:.9rem 0; }
.sv-route{ display:flex; align-items:center; gap:.7rem; text-align:left; cursor:pointer; width:100%;
  background:var(--bg-card); border:1px solid var(--border); border-radius:11px; padding:.55rem .7rem; transition:.14s; color:var(--text); }
.sv-route:hover{ border-color:var(--border-hover); }
.sv-route.on{ border-color:var(--teal); background:color-mix(in srgb,var(--teal) 10%,var(--bg-card)); }
.sv-route .ri{ font-size:1.05rem; width:22px; text-align:center; }
.sv-route .rt{ flex:1; }
.sv-route .rt b{ display:block; font-family:var(--font-heading); font-weight:600; font-size:.82rem; }
.sv-route .rt i{ font-style:normal; font-family:var(--font-mono); font-size:.56rem; letter-spacing:.06em; color:var(--text-muted); text-transform:uppercase; }
.sv-route .rn{ font-family:var(--font-mono); font-size:.58rem; color:var(--text-dim); text-align:right; line-height:1.4; }
.sv-route .rn span{ color:var(--text-muted); }
.sv-dir-stops{ max-height:230px; overflow:auto; margin:.4rem -.3rem; padding:0 .3rem; border-top:1px solid var(--border); }
.sv-stop{ display:flex; align-items:center; gap:.5rem; padding:.4rem .2rem; cursor:pointer; border-bottom:1px solid var(--border); }
.sv-stop:hover{ background:var(--bg-card); }
.sv-stop .si{ font-family:var(--font-mono); font-size:.6rem; color:var(--text-muted); width:18px; text-align:right; }
.sv-stop .sd{ width:8px; height:8px; border-radius:50%; flex:none; }
.sv-stop .st{ flex:1; font-size:.8rem; color:var(--text-dim); }
.sv-stop .sm{ font-family:var(--font-mono); font-size:.52rem; letter-spacing:.08em; text-transform:uppercase; color:var(--text-muted); }
.sv-dir-actions{ display:flex; gap:.45rem; margin-top:.7rem; }

/* ── Core + Lens shared chrome ───────────────────────────────────────────── */
.cr-rings-legend{ position:absolute; left:14px; bottom:12px; z-index:4; display:flex; flex-direction:column; gap:3px; pointer-events:none;
  font-family:var(--font-mono); font-size:.52rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted); }
.cr-rings-legend span{ position:relative; padding-left:14px; }
.cr-rings-legend span::before{ content:""; position:absolute; left:0; top:50%; width:8px; height:8px; border-radius:50%; transform:translateY(-50%); border:1px solid var(--border-hover); }
.cr-rings-legend span:nth-child(1)::before{ background:var(--warm); border-color:var(--warm); }
.cr-rings-legend span:nth-child(2)::before{ background:color-mix(in srgb,var(--warm) 45%,transparent); }
.cr-rings-legend span:nth-child(3)::before{ background:color-mix(in srgb,var(--teal) 35%,transparent); }
.cr-rings-legend span:nth-child(4)::before{ background:transparent; }

.cr-tip,.ln-tip{ position:absolute; z-index:7; pointer-events:none; max-width:240px;
  background:color-mix(in srgb,var(--bg) 90%,transparent); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
  border:1px solid var(--border2); border-radius:11px; padding:.5rem .65rem; box-shadow:0 12px 36px rgba(0,0,0,.4); display:flex; flex-direction:column; gap:.1rem; }
[data-theme="light"] .cr-tip,[data-theme="light"] .ln-tip{ box-shadow:0 12px 30px rgba(80,60,30,.16); }
.cr-tip b,.ln-tip b{ font-family:var(--font-display); font-style:italic; font-weight:400; font-size:1rem; color:var(--text); line-height:1.1; }
.cr-tip i,.ln-tip i{ font-style:normal; font-family:var(--font-mono); font-size:.56rem; letter-spacing:.06em; text-transform:uppercase; color:var(--text-muted); }
.cr-tip .d,.ln-tip .d{ width:8px; height:8px; border-radius:50%; margin-bottom:.15rem; }

.ln-focusbar{ position:absolute; top:14px; left:50%; transform:translateX(-50%); z-index:5; display:flex; align-items:center; gap:.6rem;
  background:color-mix(in srgb,var(--bg) 80%,transparent); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); border:1px solid var(--border2);
  border-radius:12px; padding:.5rem .8rem; box-shadow:0 8px 26px rgba(0,0,0,.3); max-width:78%; }
.ln-focusbar .lbl{ font-family:var(--font-mono); font-size:.54rem; letter-spacing:.13em; text-transform:uppercase; color:var(--text-muted); }
.ln-focusbar .ttl{ font-family:var(--font-display); font-style:italic; font-size:1.1rem; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ln-focusbar .hint{ font-family:var(--font-mono); font-size:.56rem; color:var(--text-muted); white-space:nowrap; }
.ln-back{ position:absolute; left:14px; top:58px; z-index:5; font-family:var(--font-mono); font-size:.6rem; letter-spacing:.06em;
  background:color-mix(in srgb,var(--bg) 78%,transparent); border:1px solid var(--border2); color:var(--text-dim); border-radius:9px; padding:.4rem .65rem; cursor:pointer; }
.ln-back:hover{ color:var(--warm); border-color:var(--warm); }
.ln-hint{ position:absolute; left:50%; bottom:14px; transform:translateX(-50%); z-index:4; pointer-events:none;
  font-family:var(--font-mono); font-size:.58rem; letter-spacing:.13em; text-transform:uppercase; color:var(--text-muted); opacity:.8; white-space:nowrap; }
@media (max-width:640px){ .ln-hint{ display:none; } }

/* Core/Lens chrome must clear the shell's floating top bar */
.km-fs .ln-focusbar{ top: calc(env(safe-area-inset-top) + 66px); }
.km-fs .ln-back{ top: calc(env(safe-area-inset-top) + 110px); }
.km-fs .cr-rings-legend{ bottom: calc(env(safe-area-inset-bottom) + 12px); }

/* ── mobile / touch (Apple/Google-maps feel) ─────────────────────────────── */
@media (max-width: 640px){
  .km-launch{ min-height: clamp(280px, 46vh, 440px); }
  /* chrome wraps: [exit][modes] row, search full-width below */
  .km-chrome{ flex-wrap:wrap; gap:8px; }
  .km-exit{ order:1; }
  .km-modes{ order:1; padding:3px; }
  .km-dir{ order:2; margin-left:auto; }
  .km-search{ order:3; flex-basis:100%; max-width:none; margin-left:0; }
  .km-mode{ padding:.3rem .5rem; }
  .km-mode-s{ display:none; }
  /* engine chrome must clear the taller (wrapped) mobile chrome bar */
  .km-fs .ln-focusbar{ top: calc(env(safe-area-inset-top) + 112px); max-width:calc(100% - 20px); }
  .km-fs .ln-back{ top: calc(env(safe-area-inset-top) + 156px); }
  .sv-legend{ display:none; }
  .sv-hint{ display:none; }

  /* bigger touch targets */
  .sv-zoom{ right:12px; bottom:18px; gap:8px; }
  .sv-zoom button{ width:44px; height:44px; font-size:1.2rem; }
  /* an open bottom sheet would bury the zoom stack — hide it; tap the map to dismiss */
  .sv-host.sv-sheet-open .sv-zoom{ display:none; }
  /* fat, obvious close button on the sheet */
  .sv-place .sv-x, .sv-dirpanel .sv-x{ width:36px; height:36px; font-size:1rem; top:.5rem; right:.55rem; }

  /* place card + directions become bottom sheets */
  .sv-place,.sv-dirpanel{
    top:auto; left:0; right:0; bottom:0; width:auto; border-radius:18px 18px 0 0;
    max-height:72%; padding:1.1rem 1.1rem calc(1.1rem + env(safe-area-inset-bottom));
    animation:svSheet .26s var(--ease-spring);
  }
  .sv-dirpanel{ max-height:82%; }
  .sv-dir-stops{ max-height:42vh; }
  @keyframes svSheet{ from{ transform:translateY(100%); } to{ transform:none; } }
  .sv-place::before,.sv-dirpanel::before{
    content:""; position:absolute; top:7px; left:50%; transform:translateX(-50%);
    width:38px; height:4px; border-radius:3px; background:var(--border-hover);
  }
  .sv-card{ display:none; }   /* hover card is mouse-only */
}

@media (prefers-reduced-motion: reduce){
  .sv-place,.sv-dirpanel{ animation:none; }
  .sv-btn:hover,.sv-dirbtn:hover,.sv-chip:hover{ transform:none; }
}
