/* مرصاد — app layout + liquid-glass component styles.
   Colors/type come only from tokens.css; this file is layout + geometry. */

/* ---- shell: the map is the full-screen canvas, glass floats over it ------- */
.app { position: relative; height: 100%; overflow: hidden; }
.map-wrap { position: absolute; inset: 0; }
#map { position: absolute; inset: 0; }

/* floating layers, inset with logical properties so RTL mirrors automatically */
.float { position: absolute; z-index: 10; }
.float--menu  { inset-block-start: 16px; inset-inline-start: 16px; max-block-size: calc(100% - 32px); display: flex; }
.float--top   { inset-block-start: 16px; inset-inline-end: 16px; display: flex; gap: 10px; align-items: center; }
.float--panel { inset-block-start: 16px; inset-inline-end: 16px; inset-block-end: 16px; width: min(390px, 92vw); }
.float--legend{ inset-block-end: 16px; inset-inline-start: 16px; }

/* ---- the glass recipe (from the skill) ------------------------------------ */
.glass {
  background: var(--glass-fill);
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  border: 1px solid var(--glass-edge);
  border-radius: var(--radius-glass);
  box-shadow: var(--glass-shadow), inset 0 1px 0 var(--glass-sheen);
}
@supports not (backdrop-filter: blur(1px)) {
  .glass { background: color-mix(in srgb, var(--surface) 90%, transparent); }
}

/* ---- glass menu (Arabic / RTL nav, active item is a solid pill) ----------- */
.glass-menu { display: flex; flex-direction: column; gap: 4px; padding: 12px; inline-size: min(272px, 82vw); overflow-y: auto; }
.glass-brand { display: flex; align-items: center; gap: 12px; padding: 6px 10px 10px; }
.glass-brand-text b { font: var(--fw-bold) var(--fs-xl)/1 var(--font-logo); color: var(--ink-strong); letter-spacing: 0.01em; }
.glass-brand-text span { display: block; font-size: var(--fs-xs); color: var(--ink-soft); margin-block-start: 3px; }
.brand-logo { display: grid; place-items: center; inline-size: 38px; block-size: 38px; flex: 0 0 auto;
  border-radius: var(--radius-md); color: var(--glow-cyan);
  background: color-mix(in srgb, var(--glow-cyan) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--glow-cyan) 35%, transparent); }
.brand-logo svg { inline-size: 22px; block-size: 22px; }

.glass-item {
  display: flex; align-items: center; gap: 12px; inline-size: 100%;
  padding-block: 11px; padding-inline: 12px; border: 0; background: transparent;
  border-radius: var(--radius-md); color: var(--ink-strong);
  font: var(--fw-med) var(--fs-md)/1 var(--font-ui); text-align: start; cursor: pointer;
  transition: background var(--dur) var(--ease);
}
.glass-item:hover { background: color-mix(in srgb, var(--ink-strong) 8%, transparent); }
.glass-item--active { background: var(--surface); color: var(--ink-strong); box-shadow: 0 8px 24px -8px rgba(0,0,0,.25); }
.glass-item .ico { inline-size: 20px; block-size: 20px; flex: 0 0 auto; }
.glass-item .count { margin-inline-start: auto; font-size: var(--fs-xs); color: var(--ink-soft); }
.glass-item--active .count { color: var(--ink); }
.glass-item .chev { inline-size: 16px; block-size: 16px; flex: 0 0 auto; color: var(--ink-soft);
  transition: transform var(--dur) var(--ease); }
.glass-item .chev.open { transform: rotate(-90deg); }

/* expandable sub-controls under a menu item */
.glass-sub { display: flex; flex-direction: column; gap: 6px; padding: 2px 10px 10px; }
.sub-row { display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 7px 10px; border-radius: var(--radius-sm); font-size: var(--fs-sm); color: var(--ink);
  background: color-mix(in srgb, var(--ink-strong) 5%, transparent); }
.sub-row .sw { inline-size: 8px; block-size: 8px; border-radius: 50%; flex: 0 0 auto; box-shadow: 0 0 6px currentColor; }
.sub-row .lbl { display: flex; align-items: center; gap: 8px; }
.sub-select {
  inline-size: 100%; padding: 8px 10px; cursor: pointer;
  border-radius: var(--radius-sm); border: 1px solid var(--glass-edge);
  background: color-mix(in srgb, var(--ink-strong) 5%, transparent);
  color: var(--ink-strong); font: var(--fw-reg) var(--fs-sm)/1.2 var(--font-ui);
}
.sub-select option { color: #16243F; background: #fff; }

/* labelled group heading inside a sub-panel */
.sub-group-title { font-size: var(--fs-xs); color: var(--ink-soft);
  letter-spacing: .03em; padding: 6px 2px 0; }
.sub-group-title:first-child { padding-block-start: 2px; }

/* mini toggle switch */
.mini-tog { inline-size: 32px; block-size: 18px; flex: 0 0 auto; border: 1px solid var(--glass-edge);
  border-radius: var(--radius-pill); background: color-mix(in srgb, var(--ink-soft) 22%, transparent);
  cursor: pointer; position: relative; transition: background var(--dur) var(--ease); padding: 0; }
.mini-tog::after { content: ''; position: absolute; inset-block-start: 2px; inset-inline-start: 2px;
  inline-size: 12px; block-size: 12px; border-radius: 50%; background: var(--surface);
  transition: transform var(--dur) var(--ease); }
.mini-tog.on { background: color-mix(in srgb, var(--glow-cyan) 45%, transparent); }
html[dir='rtl'] .mini-tog.on::after { transform: translateX(-14px); }
html[dir='ltr'] .mini-tog.on::after { transform: translateX(14px); }

/* ---- icon button (theme toggle) ------------------------------------------- */
.icon-btn {
  inline-size: 44px; block-size: 44px; display: grid; place-items: center;
  cursor: pointer; color: var(--ink-strong);
  border-radius: var(--radius-pill); background: var(--glass-fill);
  backdrop-filter: blur(24px) saturate(140%); -webkit-backdrop-filter: blur(24px) saturate(140%);
  border: 1px solid var(--glass-edge); box-shadow: var(--glass-shadow);
}
.icon-btn svg { inline-size: 22px; block-size: 22px; }

/* live clock chip next to the theme toggle */
.clock-chip { display: flex; align-items: center; gap: 8px; padding: 10px 16px;
  font-size: var(--fs-sm); color: var(--ink-strong); border-radius: var(--radius-pill); }
.clock-chip .dot { inline-size: 8px; block-size: 8px; border-radius: 50%;
  background: var(--accent-mint); box-shadow: 0 0 8px var(--accent-mint);
  animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

/* ---- detail panel ---------------------------------------------------------- */
.panel { display: flex; flex-direction: column; padding: 18px; gap: 14px; max-block-size: 100%; overflow: auto; }
.panel-head { display: flex; align-items: flex-start; gap: 10px; }
.panel-title { font: var(--fw-semi) var(--fs-xl)/1.15 var(--font-ui); color: var(--ink-strong); margin: 0; }
.panel-sub { font-size: var(--fs-sm); color: var(--ink-soft); margin-block-start: 2px; }
.panel-close {
  margin-inline-start: auto; inline-size: 30px; block-size: 30px; flex: 0 0 auto;
  border: 0; background: transparent; color: var(--ink-soft); cursor: pointer; font-size: 20px; line-height: 1;
  border-radius: var(--radius-sm);
}
.panel-close:hover { color: var(--ink-strong); background: color-mix(in srgb, var(--ink-strong) 8%, transparent); }

/* status banner (dark aircraft, tsunami, alerts…) */
.verdict { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-radius: var(--radius-md); font-weight: var(--fw-med); }
.verdict--clear  { background: color-mix(in srgb, var(--accent-mint) 16%, transparent); color: var(--ink-strong); border: 1px solid color-mix(in srgb, var(--accent-mint) 45%, transparent); }
.verdict--hit    { background: color-mix(in srgb, var(--danger) 16%, transparent);     color: var(--ink-strong); border: 1px solid color-mix(in srgb, var(--danger) 55%, transparent); }
.verdict--warn   { background: color-mix(in srgb, var(--warn) 16%, transparent);       color: var(--ink-strong); border: 1px solid color-mix(in srgb, var(--warn) 50%, transparent); }
.verdict .dot { inline-size: 10px; block-size: 10px; border-radius: 50%; flex: 0 0 auto; }
.verdict--clear .dot { background: var(--accent-mint); }
.verdict--hit .dot   { background: var(--danger); }
.verdict--warn .dot  { background: var(--warn); }

/* key/value rows */
.section-label { font-size: var(--fs-xs); letter-spacing: .04em; color: var(--ink-soft); margin-block-start: 4px; }
.rows { display: grid; grid-template-columns: auto 1fr; gap: 8px 16px; margin: 0; }
.rows dt { color: var(--ink-soft); font-size: var(--fs-sm); }
.rows dd { margin: 0; color: var(--ink-strong); font-size: var(--fs-sm); text-align: end; word-break: break-word; }

.chip { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: var(--radius-pill); font-size: var(--fs-xs); background: color-mix(in srgb, var(--ink-strong) 8%, transparent); color: var(--ink); margin: 2px 0; }
.muted { color: var(--ink-soft); font-size: var(--fs-sm); }
.ext-link { display: inline-flex; align-items: center; gap: 6px; color: var(--glow-cyan); font-size: var(--fs-sm); text-decoration: none; }
.ext-link:hover { text-decoration: underline; }
.ext-link svg { inline-size: 15px; block-size: 15px; }

/* ---- live commercial flight board (FR24, inside the airport panel) ---------- */
/* tabs: same segmented look as the imagery mode toggle */
.board-tabs { display: flex; gap: 6px; margin-block-end: 8px; }
.board-tabs button {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
  padding-block: 9px; border: 1px solid var(--glass-edge); cursor: pointer;
  background: transparent; color: var(--ink-soft); border-radius: var(--radius-md);
  font: var(--fw-med) var(--fs-sm)/1 var(--font-ui);
  transition: background var(--dur) var(--ease);
}
.board-tabs button .num { font-size: var(--fs-xs); opacity: .8; }
.board-tabs button.active {
  background: color-mix(in srgb, var(--glow-cyan) 20%, transparent);
  color: var(--ink-strong);
  border-color: color-mix(in srgb, var(--glow-cyan) 50%, transparent);
}

/* aligned 4-column rows: flight | dest/origin | type | time */
.fb-row { display: grid; grid-template-columns: 1.2fr .8fr .9fr .8fr; gap: 8px;
  align-items: center; padding: 7px 10px; border-radius: var(--radius-sm);
  font-size: var(--fs-sm); color: var(--ink-strong); }
.fb-row--head { padding-block: 2px 4px; font-size: var(--fs-xs); color: var(--ink-soft); }
.fb-list { display: flex; flex-direction: column; gap: 3px; max-block-size: 260px; overflow: auto; }
.fb-list .fb-row { background: color-mix(in srgb, var(--ink-strong) 4%, transparent); }
.fb-list .fb-row:hover { background: color-mix(in srgb, var(--ink-strong) 8%, transparent); }
.fb-flight { font-weight: var(--fw-med); }
.fb-dest { color: var(--glow-cyan); font-weight: var(--fw-med); }
.fb-type, .fb-eta { color: var(--ink-soft); font-size: var(--fs-xs); text-align: end; }
.fb-empty { padding: 14px 8px; text-align: center;
  background: color-mix(in srgb, var(--ink-strong) 4%, transparent);
  border-radius: var(--radius-sm); }

/* ---- satellite imagery (صورة فضائية) --------------------------------------- */
.btn-sat {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  inline-size: 100%; padding-block: 12px; padding-inline: 14px; cursor: pointer;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glow-cyan) 18%, transparent);
  color: var(--ink-strong); font: var(--fw-med) var(--fs-md)/1 var(--font-ui);
  border: 1px solid color-mix(in srgb, var(--glow-cyan) 45%, transparent);
  transition: background var(--dur) var(--ease);
}
.btn-sat:hover { background: color-mix(in srgb, var(--glow-cyan) 28%, transparent); }
.btn-sat svg { inline-size: 18px; block-size: 18px; }

.sat-modes { display: flex; gap: 6px; margin-block-end: 8px; }
.sat-modes button {
  flex: 1; padding-block: 8px; border: 1px solid var(--glass-edge); cursor: pointer;
  background: transparent; color: var(--ink-soft); border-radius: var(--radius-md);
  font: var(--fw-med) var(--fs-sm)/1 var(--font-ui);
}
.sat-modes button.active { background: color-mix(in srgb, var(--glow-cyan) 20%, transparent); color: var(--ink-strong); border-color: color-mix(in srgb, var(--glow-cyan) 50%, transparent); }

.swipe {
  position: relative; inline-size: 100%; aspect-ratio: 1 / 1;
  border-radius: var(--radius-md); overflow: hidden; background: var(--surface);
  user-select: none; touch-action: none;
}
.swipe-img { position: absolute; inset: 0; inline-size: 100%; block-size: 100%; object-fit: cover; pointer-events: none; }
.swipe-after { z-index: 1; }
.swipe-divider { position: absolute; inset-block: 0; z-index: 2; inline-size: 2px; background: var(--glow-core); box-shadow: 0 0 8px var(--glow-cyan); transform: translateX(-50%); }
.swipe-range { position: absolute; inset: 0; z-index: 3; inline-size: 100%; block-size: 100%; margin: 0; opacity: 0; cursor: ew-resize; }
.swipe-tag {
  position: absolute; inset-block-start: 8px; z-index: 2; padding: 3px 8px;
  font-size: var(--fs-xs); border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--bg) 70%, transparent); color: var(--ink-strong);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.swipe-tag--l { inset-inline-start: 8px; }
.swipe-tag--r { inset-inline-end: 8px; }

.sat-modal {
  position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; padding: 24px;
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
.sat-modal-card { position: relative; padding: 14px; border-radius: var(--radius-glass); }
.sat-modal-img { inline-size: min(86vmin, 900px); }
.sat-modal-img .swipe { border-radius: var(--radius-md); }
.sat-modal .panel-close { position: absolute; inset-block-start: 8px; inset-inline-end: 8px; z-index: 4; }
.spinner { inline-size: 18px; block-size: 18px; flex: 0 0 auto; border: 2px solid color-mix(in srgb, var(--ink-soft) 40%, transparent); border-block-start-color: var(--glow-cyan); border-radius: 50%; animation: spin .8s linear infinite; }
.sat-status { display: flex; align-items: center; justify-content: center; gap: 10px; min-block-size: 140px; padding: 16px; text-align: center; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ---- airport markers (Lucide plane badge) ------------------------------------ */
.airport-pin { cursor: pointer; }
.airport-pin-badge {
  inline-size: 22px; block-size: 22px; border-radius: 50%; display: grid; place-items: center;
  background: var(--route-blue); color: #fff;
  border: 1.5px solid rgba(255,255,255,0.85);
  box-shadow: 0 0 8px color-mix(in srgb, var(--route-blue) 70%, transparent), 0 1px 4px rgba(0,0,0,.3);
}
.airport-pin-badge svg { inline-size: 12px; block-size: 12px; }
.airport-pin:hover .airport-pin-badge { transform: scale(1.15); }

/* ---- route query buttons (الطيران sub-panel) --------------------------------- */
.route-query-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  inline-size: 100%; padding-block: 10px; margin-block-start: 4px; cursor: pointer;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--glow-cyan) 18%, transparent);
  color: var(--ink-strong); font: var(--fw-med) var(--fs-sm)/1 var(--font-ui);
  border: 1px solid color-mix(in srgb, var(--glow-cyan) 45%, transparent);
  transition: background var(--dur) var(--ease);
}
.route-query-btn:hover:not(:disabled) { background: color-mix(in srgb, var(--glow-cyan) 28%, transparent); }
.route-query-btn:disabled { opacity: .4; cursor: default; }
.route-query-btn svg { inline-size: 15px; block-size: 15px; }
.route-clear-btn {
  inline-size: 100%; padding-block: 8px; cursor: pointer;
  border-radius: var(--radius-md); border: 1px solid var(--glass-edge);
  background: transparent; color: var(--ink-soft);
  font: var(--fw-reg) var(--fs-xs)/1 var(--font-ui);
}
.route-clear-btn:hover { color: var(--danger); border-color: color-mix(in srgb, var(--danger) 40%, transparent); }

/* ---- legend ----------------------------------------------------------------- */
.legend { display: flex; flex-direction: column; gap: 5px; padding: 14px 18px; font-size: var(--fs-xs); max-block-size: 42vh; overflow: auto; inline-size: min(340px, 80vw); }
.legend-group { font-weight: var(--fw-semi); color: var(--ink-strong); padding-block-start: 6px; }
.legend-group:first-child { padding-block-start: 0; }
.legend-row { display: flex; align-items: center; gap: 8px; color: var(--ink); }
.legend-row .swatch { inline-size: 10px; block-size: 10px; border-radius: 50%; flex: 0 0 auto; box-shadow: 0 0 6px currentColor; }

/* ---- gone-dark toast stack --------------------------------------------------- */
/* gone-dark alerts stack directly UNDER the clock (top corner, inline-end —
   the left side in this RTL layout) */
.toast-stack { position: fixed; z-index: 120; top: 76px; inset-inline-end: 16px; display: flex; flex-direction: column; gap: 10px; inline-size: min(330px, 80vw); }
.toast { position: relative; padding: 14px 16px; cursor: pointer; border-inline-start: 3px solid var(--danger); animation: toast-in .25s var(--ease); }
@keyframes toast-in { from { transform: translateY(-10px); opacity: 0; } to { transform: none; opacity: 1; } }
.toast-close { position: absolute; inset-block-start: 6px; inset-inline-end: 8px; border: 0; background: transparent; color: var(--ink-soft); cursor: pointer; font-size: 18px; line-height: 1; }
.toast-close:hover { color: var(--ink-strong); }
.toast-head { display: flex; align-items: center; gap: 8px; font-size: var(--fs-xs); color: var(--danger); font-weight: var(--fw-semi); }
.toast-dot { inline-size: 9px; block-size: 9px; border-radius: 50%; background: var(--danger); box-shadow: 0 0 8px var(--danger); animation: pulse 1.4s ease-in-out infinite; }
.toast-title { margin-block: 6px 8px; font: var(--fw-semi) var(--fs-lg)/1.1 var(--font-ui); color: var(--ink-strong); display: flex; align-items: center; gap: 8px; }
.toast-rows { display: grid; grid-template-columns: auto 1fr; gap: 4px 14px; margin: 0; }
.toast-rows dt { color: var(--ink-soft); font-size: var(--fs-xs); }
.toast-rows dd { margin: 0; color: var(--ink-strong); font-size: var(--fs-xs); text-align: start; }

/* ---- GDELT alert pins (glass + glow, RTL labels) ----------------------------- */
.ge-pin { cursor: pointer; }
.ge-pin-inner { position: relative; display: flex; flex-direction: column; align-items: center; }
.ge-pin-ring { position: absolute; inset-block-start: -7px; inline-size: 40px; block-size: 40px;
  border-radius: 50%; border: 2px solid var(--c, var(--imp-low));
  animation: ge-ring 2.2s ease-out infinite; opacity: .8; }
@keyframes ge-ring { 0% { transform: scale(.55); opacity: .85; } 100% { transform: scale(1.5); opacity: 0; } }
.ge-pin-core { inline-size: 26px; block-size: 26px; border-radius: 50%; display: grid; place-items: center;
  background: var(--c, var(--imp-low)); color: #fff;
  box-shadow: 0 0 14px color-mix(in srgb, var(--c, var(--imp-low)) 80%, transparent), 0 2px 8px rgba(0,0,0,.35);
  border: 1.5px solid rgba(255,255,255,.65); }
.ge-pin-core svg { inline-size: 15px; block-size: 15px; }
.ge-pin-badge { position: absolute; inset-block-start: -6px; inset-inline-end: -8px;
  min-inline-size: 17px; block-size: 17px; padding-inline: 4px; border-radius: var(--radius-pill);
  display: grid; place-items: center; font: var(--fw-semi) 10px/1 var(--font-num);
  background: var(--ink-strong); color: var(--bg); border: 1px solid var(--bg); }
.ge-pin-name { margin-block-start: 4px; padding: 2px 8px; font-size: 11px; white-space: nowrap;
  color: var(--ink-strong); border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  border: 1px solid var(--glass-edge);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.ge-pin.active .ge-pin-core { transform: scale(1.18); border-color: #fff; }

/* region bubble (zoomed out) */
.ge-region { cursor: pointer; }
.ge-region-bubble { display: flex; align-items: center; gap: 8px; padding: 6px 12px;
  border-radius: var(--radius-pill); color: #fff; font: var(--fw-semi) var(--fs-sm)/1 var(--font-ui);
  border: 1.5px solid rgba(255,255,255,.5); box-shadow: 0 0 18px rgba(0,0,0,.3); white-space: nowrap; }
.ge-region-bubble .n { font-family: var(--font-num); font-weight: 900; }

/* ---- GDELT event card (glass panel) ------------------------------------------ */
.ge-card { display: flex; flex-direction: column; gap: 12px; padding: 18px; max-block-size: 100%; overflow: auto;
  border-inline-start: 3px solid var(--cc, var(--imp-low)); }
.ge-card-cat { display: inline-flex; align-items: center; gap: 8px; font-size: var(--fs-xs); color: var(--ink-soft); }
.ge-card-cat .dot { inline-size: 9px; block-size: 9px; border-radius: 50%; background: var(--cc); box-shadow: 0 0 8px var(--cc); }
.ge-card-title { margin: 0; font: var(--fw-semi) var(--fs-lg)/1.4 var(--font-ui); color: var(--ink-strong); }
.ge-card-summary { margin: 0; color: var(--ink); font-size: var(--fs-sm); line-height: 1.7; }
.ge-card-body { margin: 0; color: var(--ink-soft); font-size: var(--fs-sm); line-height: 1.8; }
.ge-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ge-meta-item { padding: 8px 10px; border-radius: var(--radius-sm); background: color-mix(in srgb, var(--ink-strong) 5%, transparent); }
.ge-meta-label { font-size: var(--fs-xs); color: var(--ink-soft); }
.ge-meta-value { font-size: var(--fs-sm); color: var(--ink-strong); margin-block-start: 2px; }
.ge-when { display: flex; align-items: center; gap: 6px; font-size: var(--fs-xs); color: var(--ink-soft); }
.ge-when svg { inline-size: 14px; block-size: 14px; }
.ge-nav { display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding-block-start: 8px; border-block-start: 1px solid var(--glass-edge); }
.ge-nav button { inline-size: 32px; block-size: 32px; display: grid; place-items: center; cursor: pointer;
  border: 1px solid var(--glass-edge); border-radius: var(--radius-sm); background: transparent; color: var(--ink-strong); }
.ge-nav button:disabled { opacity: .3; cursor: default; }
.ge-nav button svg { inline-size: 16px; block-size: 16px; }
.ge-nav-counter { font-size: var(--fs-xs); color: var(--ink-soft); }

/* subtle slide+fade when the card switches to another event */
.ge-swap { animation: geSwap .22s var(--ease); }
@keyframes geSwap { from { opacity: 0; transform: translateX(var(--swapdx, 10px)); } to { opacity: 1; transform: none; } }

/* ---- misc ---------------------------------------------------------------------- */
.coord-chip { position: absolute; z-index: 9; inset-block-end: 14px; inset-inline-end: 14px;
  padding: 4px 10px; font-size: 11px; color: var(--ink-soft); border-radius: var(--radius-pill);
  background: color-mix(in srgb, var(--bg) 60%, transparent);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); pointer-events: none; }

/* keep Mapbox attribution readable on both themes */
.mapboxgl-ctrl-attrib { font-family: var(--font-ui) !important; }

@media (max-width: 640px) {
  .float--panel { inset-inline: 12px; inset-block-end: 12px; inset-block-start: auto; width: auto; max-block-size: 58vh; }
  .glass-menu { inline-size: min(232px, 74vw); }
  .ge-meta { grid-template-columns: 1fr; }
}
