/* ============================================================
   marketsbubbles.com — live crypto & stock bubble maps
   Premium dark design system + Pro theme palettes.
   The canvas bubble engine (.bub-* / .bd-*) is themed entirely
   through the CSS variables declared here — every derived token
   recomputes from --accent / --bg / --text, so all 7 palettes
   theme the whole UI for free. Bubble fill colours (gain/loss)
   live in the JS engine and are intentionally palette-independent.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ---- Default theme: Midnight (free) ---- */
:root {
  --bg: #080c16;
  --bg2: #0b1020;
  --surface: #10172a;
  --surface2: #18223b;
  --border: #233149;
  --text: #eaf0fb;
  --text-dim: #93a1bd;
  --na: #77859f;
  --accent: #38bdf8;
  --accent2: #4f7bf6;
  --maple: #f0584b;       /* error / down accent for chrome */
  --warn: #f5a524;
  --ink: #04111f;         /* readable text on the accent fill */
  --drizzle: linear-gradient(100deg, var(--accent), var(--accent2));
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
  --font-display: 'Space Grotesk', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;

  /* layout */
  --maxw: 1180px;
  --pad-x: max(20px, calc(50% - 590px));
  --r-xs: 8px; --r-sm: 11px; --r-md: 14px; --r-lg: 18px; --r-xl: 24px;

  /* derived tokens — recompute from --accent/--bg/--text, so every theme themes them for free */
  --border-gold: color-mix(in srgb, var(--accent) 26%, var(--border));
  --hairline: color-mix(in srgb, var(--text) 8%, transparent);
  --glow-gold: 0 1px 0 color-mix(in srgb, #fff 22%, transparent) inset, 0 10px 26px -10px color-mix(in srgb, var(--accent) 70%, transparent);
  --shadow-slab: inset 0 1px 0 color-mix(in srgb, #fff 5%, transparent), 0 24px 60px -30px rgba(0,0,0,0.85);
  --shadow-card: 0 1px 0 color-mix(in srgb, #fff 4%, transparent) inset, 0 14px 40px -28px rgba(0,0,0,0.7);
  --shadow-pop: 0 30px 70px -28px rgba(0,0,0,0.85), 0 2px 0 color-mix(in srgb, #fff 5%, transparent) inset;
  --glass: color-mix(in srgb, var(--surface) 72%, transparent);
  --mk-stage-glow: color-mix(in srgb, var(--accent) 13%, transparent);
  --mk-stage-veil: color-mix(in srgb, var(--bg) 70%, transparent);
  --mk-spin-track: color-mix(in srgb, var(--accent) 22%, transparent);
  --mk-line: color-mix(in srgb, var(--text) 10%, transparent);
  color-scheme: dark;
  accent-color: var(--accent);
}

/* ---- Daylight: free light theme (light mode shouldn't be a Pro paywall) ---- */
[data-theme="daylight"]{ --bg:#eef2f8; --bg2:#e6ecf5; --surface:#ffffff; --surface2:#f1f5fb; --border:#d2dbea; --text:#111a2e; --text-dim:#46557a; --na:#697694; --accent:#1f6fd6; --accent2:#3b82f6; --maple:#dc4436; --warn:#b9770f; --ink:#ffffff;
  --shadow-slab: 0 18px 44px -28px rgba(30,55,100,0.34); --shadow-card: 0 12px 32px -26px rgba(30,55,100,0.3); --glass: color-mix(in srgb, var(--surface) 82%, transparent); color-scheme: light; }

/* ---- Pro themes ---- */
[data-theme="aurora"]   { --bg:#06110f; --bg2:#091a17; --surface:#0e1c1a; --surface2:#142a27; --border:#1f3d39; --text:#e7f6f0; --text-dim:#8fb8ad; --na:#6f8a7e; --accent:#2dd4bf; --accent2:#22d3ee; --maple:#fb7185; --ink:#03110e; }
[data-theme="solar"]    { --bg:#100b06; --bg2:#170f07; --surface:#1c130a; --surface2:#261a0d; --border:#3b2a15; --text:#f6ecd9; --text-dim:#b59a73; --na:#9a8259; --accent:#f6a82b; --accent2:#ffce6b; --maple:#eb5f55; --ink:#251704; }
[data-theme="neon"]     { --bg:#09060f; --bg2:#0e0818; --surface:#150b1f; --surface2:#1f1230; --border:#34204c; --text:#f3e9ff; --text-dim:#a98fc7; --na:#8a72a9; --accent:#e879f9; --accent2:#818cf8; --maple:#fb7185; --ink:#13041a; }
[data-theme="terminal"] { --bg:#030708; --bg2:#050d0a; --surface:#07120d; --surface2:#0b1c14; --border:#143a2b; --text:#c8f5d8; --text-dim:#5f9c79; --na:#579070; --accent:#22c55e; --accent2:#4ade80; --maple:#f87171; --ink:#04140b; --font-body:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace; --font-display:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace; }
[data-theme="mono"]     { --bg:#0b0b0c; --bg2:#101012; --surface:#151517; --surface2:#1e1e21; --border:#2f2f34; --text:#ededf0; --text-dim:#9a9aa2; --na:#84848c; --accent:#d4d4d8; --accent2:#fafafa; --maple:#ef5350; --ink:#0c0c0d; }
[data-theme="sandstone"]{ --bg:#f3ede1; --bg2:#efe6d4; --surface:#fbf6ec; --surface2:#efe6d4; --border:#dac9ab; --text:#2b2517; --text-dim:#6a5f49; --na:#6e6149; --accent:#985f0f; --accent2:#dd9b34; --maple:#c0392b; --warn:#985f0f; --ink:#fffaf0;
  --shadow-slab: 0 18px 44px -28px rgba(80,60,20,0.5); --shadow-card: 0 12px 32px -26px rgba(80,60,20,0.45); --glass: color-mix(in srgb, var(--surface) 80%, transparent); color-scheme: light; }

/* ---- page ---- */
body {
  background-color: var(--bg);
  background-image:
    radial-gradient(1200px 620px at 50% -12%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 62%),
    radial-gradient(900px 540px at 100% -4%, color-mix(in srgb, var(--accent2) 10%, transparent), transparent 56%),
    radial-gradient(820px 520px at 0% 8%, color-mix(in srgb, var(--accent) 7%, transparent), transparent 55%),
    radial-gradient(circle at 1px 1px, color-mix(in srgb, var(--text) 4%, transparent) 1px, transparent 0),
    linear-gradient(180deg, var(--bg2), var(--bg) 38%);
  background-size: auto, auto, auto, 28px 28px, auto;
  background-attachment: fixed;
  color: var(--text);
  font-family: var(--font-body);
  font-size: 14px; line-height: 1.55; letter-spacing: -0.006em;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  min-height: 100dvh;
  display: flex; flex-direction: column;
}
body::after { content:''; position:fixed; top:0; left:0; right:0; height:2px; z-index:60; pointer-events:none; background: var(--drizzle); opacity:0.9; }
::selection { background: var(--accent); color: var(--ink); }
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 8px; border: 3px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: var(--na); background-clip: padding-box; border: 3px solid transparent; }
a { color: var(--accent); text-decoration: none; }
h1, h2, h3 { font-family: var(--font-display); }

/* visible keyboard focus on every interactive control (WCAG 2.4.7) */
:where(button, a, input, select, [tabindex]):focus-visible {
  outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 8px;
}
.bub-search:focus-visible { outline-offset: 1px; }
:focus:not(:focus-visible) { outline: none; }

/* ---- header ---- */
header {
  position: relative; z-index: 40;
  border-bottom: 1px solid var(--hairline);
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 55%, transparent), transparent);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  padding: 11px 18px;
}
.hd-wrap { display: flex; align-items: center; gap: 16px; max-width: none; margin: 0; }
.brand { display: inline-flex; align-items: center; gap: 11px; text-decoration: none; }
.brand-mark { width: 32px; height: 32px; flex: 0 0 auto; filter: drop-shadow(0 4px 10px color-mix(in srgb, var(--accent) 45%, transparent)); transform-origin: 50% 50%; }
/* logo bubbles spin while the page hard-refreshes (paired with the canvas swirl) — accelerating like the drain */
@keyframes brand-spin { from { transform: rotate(0); } to { transform: rotate(720deg); } }
.brand-mark.spin { animation: brand-spin 0.95s cubic-bezier(0.5, 0, 0.75, 0) both; }
@media (prefers-reduced-motion: reduce) { .brand-mark.spin { animation-duration: 0.6s; } }
.brand-name { font: 700 1.24rem var(--font-display); letter-spacing: -0.035em; color: var(--text); }
.brand-name b { font-weight: 700; background: var(--drizzle); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.brand-name i { font-style: normal; font-weight: 500; font-size: 0.74em; color: var(--na); letter-spacing: -0.01em; }
.hd-spacer { flex: 1 1 auto; }
.hd-acct { margin-left: auto; display: flex; align-items: center; gap: 9px; }

.acct-up, .acct-link, .acct-pro {
  font: 700 0.82rem var(--font-body); border-radius: 999px; padding: 8px 16px; cursor: pointer;
  border: 1px solid transparent; white-space: nowrap; transition: filter .15s, color .15s, border-color .15s, background .15s, transform .15s;
}
.acct-up { color: var(--ink); background: var(--drizzle); box-shadow: var(--glow-gold); border: 0; }
.acct-up:hover { filter: brightness(1.07); transform: translateY(-1px); }
.acct-up:active { transform: translateY(0); }
.acct-pro { color: var(--accent); background: color-mix(in srgb, var(--accent) 13%, transparent); border-color: var(--border-gold); cursor: default; }
.acct-link { background: none; color: var(--text-dim); border-color: var(--border); font-weight: 600; }
.acct-link:hover { color: var(--text); border-color: var(--na); }

/* ---- theme picker ---- */
.theme-btn {
  display: inline-grid; place-items: center; width: 40px; height: 40px; border-radius: 999px; cursor: pointer;
  background: var(--surface); border: 1px solid var(--border); color: var(--text-dim); position: relative; transition: color .15s, border-color .15s, transform .15s;
}
.theme-btn:hover { color: var(--text); border-color: var(--na); transform: translateY(-1px); }
.theme-btn .lock { position: absolute; right: -3px; bottom: -3px; font-size: 10px; background: var(--surface2); border-radius: 50%; width: 16px; height: 16px; display: grid; place-items: center; border: 1px solid var(--border); }
.theme-pop {
  position: absolute; top: 54px; right: 16px; z-index: 70;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 14px;
  box-shadow: var(--shadow-pop); width: 244px;
}
.theme-pop[hidden] { display: none; }
.theme-pop h4 { font: 700 0.68rem var(--font-body); text-transform: uppercase; letter-spacing: 0.1em; color: var(--na); margin-bottom: 10px; }
.theme-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.theme-opt {
  display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: var(--r-xs); cursor: pointer;
  border: 1px solid var(--border); background: var(--surface2); color: var(--text); font: 600 0.78rem var(--font-body); text-align: left; transition: border-color .15s, box-shadow .15s;
}
.theme-opt:hover { border-color: var(--accent); }
.theme-opt.active { border-color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); }
.theme-opt .sw { width: 16px; height: 16px; border-radius: 6px; flex: 0 0 auto; border: 1px solid rgba(255,255,255,0.16); box-shadow: 0 2px 6px -1px rgba(0,0,0,.5); }
.theme-opt .pro-tag { margin-left: auto; font-size: 0.58rem; font-weight: 800; color: var(--accent); letter-spacing: 0.06em; }
.theme-opt[data-locked="1"] { opacity: 0.7; }
.theme-foot { margin-top: 12px; font: 500 0.68rem var(--font-body); color: var(--na); line-height: 1.45; }
.theme-foot a { cursor: pointer; color: var(--accent); font-weight: 700; }

/* ---- share / saved-views popover ---- */
.share-pop {
  position: absolute; top: 54px; right: 16px; z-index: 70;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 16px;
  box-shadow: var(--shadow-pop); width: 300px; max-width: calc(100vw - 24px);
}
.share-pop[hidden] { display: none; }
.share-pop h4 { font: 700 0.68rem var(--font-body); text-transform: uppercase; letter-spacing: 0.1em; color: var(--na); margin-bottom: 8px; }
.share-sub { font: 500 0.74rem var(--font-body); color: var(--text-dim); line-height: 1.45; margin-bottom: 12px; }
.share-acts { display: flex; gap: 8px; }
.share-acts .set-btn { flex: 1; }
.share-url { width: 100%; margin-top: 10px; font: 500 0.72rem var(--font-body); color: var(--text-dim);
  background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r-xs); padding: 8px 10px; overflow: hidden; text-overflow: ellipsis; }
.share-saved { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; max-height: 168px; overflow: auto; }
.share-chip { display: flex; align-items: center; gap: 8px; width: 100%; text-align: left; cursor: pointer;
  background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r-xs); padding: 8px 10px; transition: border-color .15s; }
.share-chip:hover { border-color: var(--accent); }
.share-chip-name { font: 700 0.8rem var(--font-body); color: var(--text); }
.share-chip-meta { font: 600 0.66rem var(--font-body); color: var(--na); text-transform: capitalize; }
.share-del { margin-left: auto; color: var(--na); font-size: 16px; line-height: 1; padding: 0 4px; border-radius: 4px; }
.share-del:hover { color: var(--maple); }

/* ---- settings panel ---- */
.settings-pop {
  position: absolute; top: 54px; right: 16px; z-index: 70;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 16px;
  box-shadow: var(--shadow-pop); width: 300px; max-width: calc(100vw - 24px);
}
.settings-pop[hidden] { display: none; }
.settings-pop h4 { font: 700 0.68rem var(--font-body); text-transform: uppercase; letter-spacing: 0.1em; color: var(--na); margin-bottom: 10px; }
.set-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.set-row label { font: 600 0.82rem var(--font-body); color: var(--text); }
.set-row select {
  appearance: none; -webkit-appearance: none; background: var(--surface2); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--r-xs); font: 600 0.8rem var(--font-body);
  padding: 8px 28px 8px 12px; cursor: pointer; min-width: 130px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23889' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center;
}
.set-row select:hover { border-color: var(--na); }
.set-toggle { width: 44px; height: 25px; border-radius: 999px; border: 1px solid var(--border); background: var(--surface2); position: relative; cursor: pointer; transition: background .15s, border-color .15s; flex: 0 0 auto; }
.set-toggle span { position: absolute; top: 2px; left: 2px; width: 19px; height: 19px; border-radius: 50%; background: var(--na); transition: transform .18s, background .18s; }
.set-toggle.on { background: color-mix(in srgb, var(--accent) 30%, transparent); border-color: var(--border-gold); }
.set-toggle.on span { transform: translateX(19px); background: var(--accent); }
.set-sep { height: 1px; background: var(--border); margin: 14px 0; }
.set-lists { display: grid; gap: 6px; margin-bottom: 10px; }
.set-empty { font: 500 0.74rem var(--font-body); color: var(--na); line-height: 1.45; }
.set-list { display: flex; align-items: center; gap: 8px; background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r-xs); padding: 7px 10px; }
.set-list-name { font: 600 0.8rem var(--font-body); color: var(--text); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.set-list-n { font: 700 0.7rem var(--font-body); color: var(--na); background: color-mix(in srgb, var(--text) 7%, transparent); border-radius: 999px; padding: 2px 8px; }
.set-list-del { background: none; border: 0; color: var(--na); font-size: 17px; line-height: 1; cursor: pointer; padding: 0 2px; }
.set-list-del:hover { color: var(--maple); }
.set-newlist { display: flex; gap: 8px; }
.set-newlist input {
  flex: 1; background: var(--surface2); color: var(--text); border: 1px solid var(--border);
  border-radius: var(--r-xs); padding: 8px 12px; font: 500 0.8rem var(--font-body); outline: none; min-width: 0;
}
.set-newlist input:focus { border-color: var(--accent); }
.set-btn { background: var(--drizzle); color: var(--ink); border: 0; border-radius: var(--r-xs); font: 700 0.8rem var(--font-body); padding: 8px 14px; cursor: pointer; white-space: nowrap; }
.set-btn:hover { filter: brightness(1.07); }
.set-actions { display: grid; gap: 4px; }
.set-link { background: none; border: 0; text-align: left; color: var(--text-dim); font: 600 0.8rem var(--font-body); padding: 8px 8px; border-radius: var(--r-xs); cursor: pointer; }
.set-link:hover { color: var(--text); background: var(--surface2); }
.set-embed { margin-top: 10px; }
.set-embed[hidden] { display: none; }
.set-embed p { font: 500 0.74rem var(--font-body); color: var(--text-dim); margin-bottom: 7px; }
.set-embed textarea { width: 100%; background: var(--surface2); color: var(--text); border: 1px solid var(--border); border-radius: var(--r-xs); padding: 9px 11px; font: 500 0.72rem ui-monospace, monospace; resize: vertical; outline: none; }
.set-embed textarea:focus { border-color: var(--accent); }
.set-embed .set-btn { margin-top: 8px; }

/* ---- hero ---- */
.hero { padding: 40px var(--pad-x) 30px; position: relative; }
.hero-wrap { max-width: var(--maxw); margin: 0 auto; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px; font: 700 0.7rem var(--font-body);
  text-transform: uppercase; letter-spacing: 0.13em; color: var(--text-dim);
  background: color-mix(in srgb, var(--accent) 9%, transparent); border: 1px solid var(--border-gold);
  padding: 6px 13px 6px 11px; border-radius: 999px;
}
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); position: relative; box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 70%, transparent); }
@media (prefers-reduced-motion: no-preference) { .live-dot { animation: live-pulse 2s ease-out infinite; } }
@keyframes live-pulse { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 70%, transparent); } 70% { box-shadow: 0 0 0 7px transparent; } 100% { box-shadow: 0 0 0 0 transparent; } }
.hero-title {
  font: 700 clamp(1.85rem, 1rem + 2.9vw, 3rem)/1.04 var(--font-display);
  letter-spacing: -0.035em; margin: 16px 0 0; max-width: 16ch;
}
.hero-title span { background: var(--drizzle); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero-sub { color: var(--text-dim); font-size: clamp(0.92rem, 0.86rem + 0.3vw, 1.06rem); margin-top: 14px; max-width: 56ch; line-height: 1.55; }
.hero-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.chip {
  display: inline-flex; align-items: center; gap: 7px; font: 600 0.78rem var(--font-body); color: var(--text-dim);
  background: color-mix(in srgb, var(--surface) 80%, transparent); border: 1px solid var(--border); border-radius: 999px; padding: 7px 13px;
}
.chip svg { width: 14px; height: 14px; color: var(--accent); flex: 0 0 auto; }
.chip b { color: var(--text); font-weight: 700; }

/* ---- tabs ---- */
.tabs {
  position: sticky; top: 0; z-index: 50; display: flex; gap: 4px;
  padding: 0 14px;
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--border);
  -webkit-backdrop-filter: blur(14px) saturate(1.4); backdrop-filter: blur(14px) saturate(1.4);
}
.tab-btn {
  position: relative; background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--text-dim); cursor: pointer; font: 600 0.95rem var(--font-body); padding: 12px 16px; transition: color 0.15s;
}
.tab-btn:hover { color: var(--text); }
.tab-btn.active { color: var(--text); }
.tab-btn.active::after { content:''; position:absolute; left:14px; right:14px; bottom:-1px; height:3px; border-radius:3px 3px 0 0; background: var(--drizzle); box-shadow: var(--glow-gold); }

main { flex: 0 0 auto; display: flex; flex-direction: column; width: 100%; min-height: calc(100dvh - 112px); padding: 9px 12px 6px; max-width: none; margin: 0; box-sizing: border-box; }
.tab-content { display: none; }
.tab-content.active { flex: 1; display: flex; flex-direction: column; width: 100%; min-width: 0; min-height: 0; }
@media (prefers-reduced-motion: no-preference) {
  .tab-content.active { animation: rise 0.28s cubic-bezier(.2,.7,.2,1); }
  @keyframes rise { from { opacity: 0; transform: translateY(6px); } }
}
.sec-intro { margin: 2px 0 16px; display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.sec-intro h2 { font: 700 1.4rem var(--font-display); letter-spacing: -0.025em; }
.sec-intro p { color: var(--text-dim); font-size: 0.9rem; margin-top: 4px; max-width: 62ch; }

/* ---- paywall banner ---- */
.paywall {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  background:
    radial-gradient(120% 200% at 0% 0%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 55%),
    linear-gradient(100deg, color-mix(in srgb, var(--surface2) 80%, transparent), color-mix(in srgb, var(--surface) 60%, transparent));
  border: 1px solid var(--border-gold); border-radius: var(--r-md); padding: 14px 16px; margin: 0 0 18px;
  box-shadow: var(--shadow-card);
}
.paywall[hidden] { display: none; }
.pw-txt { font-size: 0.9rem; color: var(--text); }
.pw-txt b { color: var(--accent); }
.pw-sub { color: var(--text-dim); }
.pw-btn {
  margin-left: auto; font: 800 0.84rem var(--font-body); color: var(--ink); background: var(--drizzle);
  border: 0; border-radius: 999px; padding: 10px 18px; cursor: pointer; box-shadow: var(--glow-gold); white-space: nowrap; transition: filter .15s, transform .15s;
}
.pw-btn:hover { filter: brightness(1.07); transform: translateY(-1px); }

/* ---- upsell modal ---- */
.modal { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 20px;
  background: color-mix(in srgb, #000 64%, transparent); -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px); }
.modal[hidden] { display: none; }
@media (prefers-reduced-motion: no-preference) { .modal:not([hidden]) .sheet { animation: sheet-in .26s cubic-bezier(.2,.7,.2,1); } @keyframes sheet-in { from { opacity:0; transform: translateY(12px) scale(.98); } } }
.sheet {
  width: min(444px, 100%); background: linear-gradient(180deg, var(--surface2), var(--surface)); border: 1px solid var(--border); border-radius: var(--r-xl);
  padding: 28px 26px; box-shadow: var(--shadow-pop); position: relative; overflow: hidden;
}
.sheet::before { content:''; position:absolute; inset:0 0 auto 0; height:120px; background: radial-gradient(120% 100% at 50% 0%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 70%); pointer-events:none; }
.sheet-close { position: absolute; top: 14px; right: 16px; background: none; border: 0; color: var(--na); font-size: 24px; cursor: pointer; line-height: 1; z-index: 2; }
.sheet-close:hover { color: var(--text); }
.sheet h2 { font: 700 1.45rem var(--font-display); letter-spacing: -0.02em; position: relative; }
.sheet .price { margin: 8px 0 18px; position: relative; }
.sheet .price b { font: 700 2.1rem var(--font-display); letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.sheet .price span { color: var(--text-dim); font-size: 0.9rem; }
.perks { list-style: none; display: grid; gap: 11px; margin: 0 0 22px; position: relative; }
.perks li { display: flex; gap: 11px; align-items: flex-start; font-size: 0.9rem; color: var(--text); }
.perks li::before { content: ''; width: 18px; height: 18px; flex: 0 0 auto; margin-top: 1px; border-radius: 50%;
  background: var(--accent);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='11' stroke-width='0' fill='%23fff' opacity='0.18'/%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='11' stroke-width='0' fill='%23fff' opacity='0.18'/%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/contain no-repeat; }
.sheet-cta { width: 100%; font: 800 0.98rem var(--font-body); color: var(--ink); background: var(--drizzle);
  border: 0; border-radius: var(--r-sm); padding: 14px; cursor: pointer; box-shadow: var(--glow-gold); position: relative; transition: filter .15s, transform .15s; }
.sheet-cta:hover { filter: brightness(1.07); transform: translateY(-1px); }
.sheet-cta:disabled { opacity: 0.6; cursor: default; transform: none; }
.sheet-alt { margin-top: 14px; text-align: center; font-size: 0.8rem; color: var(--text-dim); position: relative; }
.sheet-alt a { cursor: pointer; font-weight: 700; }
.sheet-fine { margin-top: 14px; text-align: center; font-size: 0.68rem; color: var(--na); line-height: 1.5; position: relative; }

/* ---- toast ---- */
.toast {
  position: fixed; left: 50%; bottom: 28px; transform: translate(-50%, 16px); z-index: 120;
  background: var(--surface2); border: 1px solid var(--border-gold); color: var(--text);
  padding: 12px 20px; border-radius: 999px; font: 600 0.84rem var(--font-body); box-shadow: var(--shadow-pop);
  opacity: 0; transition: opacity 0.3s, transform 0.3s; pointer-events: none; max-width: 90vw; text-align: center;
}
.toast.show { opacity: 1; transform: translate(-50%, 0); }
.toast[hidden] { display: none; }

/* ---- free-user lock chips on Pro-only controls ---- */
body.is-free .pro-lock { position: relative; }
body.is-free .pro-lock::after {
  content: 'PRO'; position: absolute; top: -7px; right: -7px; font: 800 8px var(--font-body);
  background: var(--drizzle); color: var(--ink); border-radius: 5px; padding: 1px 4px; letter-spacing: 0.04em;
}
body.is-pro .pro-lock::after { display: none; }

/* ---- bubble toolbar ---- */
.bubbles { flex: 1; display: flex; flex-direction: column; margin: 0; width: 100%; min-width: 0; min-height: 0; }
.bub-bar {
  flex: 0 0 auto;
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px 9px; margin-bottom: 8px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 60%, transparent), color-mix(in srgb, var(--surface) 30%, transparent));
  border: 1px solid var(--hairline); border-radius: var(--r-lg); padding: 9px 11px; box-shadow: var(--shadow-card);
}
.bub-seg { display: inline-flex; background: color-mix(in srgb, var(--bg) 55%, var(--surface)); border: 1px solid var(--border); border-radius: 999px; padding: 3px; gap: 2px; }
.bub-pill {
  appearance: none; border: 0; background: transparent; color: var(--text-dim);
  font: 600 12.5px/1 var(--font-body); letter-spacing: .01em; padding: 9.5px 14px; border-radius: 999px;
  cursor: pointer; transition: color .15s, background .15s, box-shadow .15s; white-space: nowrap;
}
.bub-pill:hover { color: var(--text); }
.bub-pill.active { color: var(--ink); background: var(--drizzle); box-shadow: var(--glow-gold); }
.bub-search {
  flex: 1 1 150px; min-width: 130px; max-width: 230px; background: color-mix(in srgb, var(--bg) 55%, var(--surface)); color: var(--text);
  border: 1px solid var(--border); border-radius: 999px; padding: 9px 15px; font: 500 13px var(--font-body);
  outline: none; transition: border-color .15s, box-shadow .15s;
}
.bub-search::placeholder { color: var(--na); }
.bub-search:focus { border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent); }
.bub-mood {
  margin-left: auto; display: flex; align-items: baseline; gap: 8px; font: 500 12px var(--font-body); color: var(--text-dim);
  background: color-mix(in srgb, var(--bg) 50%, var(--surface)); border: 1px solid var(--border); border-radius: 999px; padding: 7px 14px;
}
.bub-mood-val { font: 800 15px var(--font-display); letter-spacing: -.01em; font-variant-numeric: tabular-nums; }
.bub-mood-sub { font-size: 11.5px; font-variant-numeric: tabular-nums; }

/* ---- Pin & Peek mobile filter bar. On desktop the wrappers are display:contents + explicit order, so the bar
   renders exactly as before; the "More" button + active-filter chips only appear on the mobile breakpoint. ---- */
.bub-morebtn, .bub-chips { display: none; }
.bub-mstrip, .bub-morepanel { display: contents; }
.bub-bar > .bub-view { order: 1; }
.bub-morepanel > .bub-group { order: 2; }
.bub-bar > .bub-tf { order: 3; }
.bub-morepanel > .bub-scope { order: 4; }
.bub-morepanel > .bub-dir { order: 5; }
.bub-morepanel > .bub-min { order: 6; }
.bub-morepanel > .bub-size { order: 7; }
.bub-morepanel > .bub-rank, .bub-morepanel > .bub-list { order: 8; }
.bub-bar > .bub-search { order: 9; }
.bub-mstrip > .bub-mood { order: 10; }

/* ---- bubble stage ---- */
.bub-stage {
  position: relative; width: 100%; flex: 1 1 auto; min-height: 300px;
  border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden;
  background:
    radial-gradient(120% 90% at 50% -12%, var(--mk-stage-glow), transparent 60%),
    radial-gradient(100% 80% at 50% 120%, color-mix(in srgb, var(--accent2) 6%, transparent), transparent 60%),
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 22%, var(--bg)), var(--bg));
  touch-action: none; /* canvas owns gestures */
}
.bub-stage::after { content:''; position:absolute; inset:0; pointer-events:none; border-radius: inherit; box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 5%, transparent); }
/* absolutely positioned so the canvas backing-store size can't feed back into the content-sized
   flex stage — that feedback was a ResizeObserver limit-cycle that shimmered the static Hive view. */
.bub-canvas { display: block; position: absolute; inset: 0; width: 100%; height: 100%; cursor: grab; z-index: 1; }
.bub-canvas.grabbing { cursor: grabbing; }
.bub-state {
  position: absolute; inset: 0; z-index: 3; display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 12px; color: var(--text-dim); font: 500 14px var(--font-body);
  background: var(--mk-stage-veil); backdrop-filter: blur(2px); transition: opacity .35s; text-align: center; padding: 24px;
}
.bub-state[hidden] { display: none; }
.bub-state.err { color: var(--maple); }
.bub-state .bub-spin {
  width: 28px; height: 28px; border-radius: 50%; border: 3px solid var(--mk-spin-track);
  border-top-color: var(--accent);
}
@media (prefers-reduced-motion: no-preference) { .bub-state .bub-spin { animation: bub-spin .8s linear infinite; } }
@keyframes bub-spin { to { transform: rotate(360deg); } }

.bub-legend { flex: 0 0 auto; margin-top: 7px; font: 500 11.5px var(--font-body); color: var(--na); letter-spacing: .01em; text-align: center; }
.bub-legend b { color: var(--text-dim); font-weight: 700; }
.bub-stamp { color: var(--accent); font-weight: 600; }

/* hover tooltip */
.bub-tip {
  position: absolute; z-index: 6; pointer-events: none; transform: translate(-50%, -130%);
  background: var(--surface); border: 1px solid var(--border-gold); border-radius: 10px;
  padding: 7px 10px; font: 600 11.5px var(--font-body); color: var(--text); white-space: nowrap;
  box-shadow: var(--shadow-pop);
}
.bub-tip .t-sym { color: var(--accent); }
.bub-tip[hidden] { display: none; }

/* click detail panel */
.bub-detail {
  position: absolute; z-index: 8; width: 238px; max-width: calc(100% - 24px);
  background: linear-gradient(180deg, var(--surface2), var(--surface));
  border: 1px solid var(--border-gold); border-radius: var(--r-lg); padding: 15px 16px;
  box-shadow: var(--shadow-pop);
  color: var(--text);
}
@media (prefers-reduced-motion: no-preference) { .bub-detail { animation: bub-pop .18s ease; } }
@keyframes bub-pop { from { opacity: 0; transform: scale(.94); } to { opacity: 1; transform: scale(1); } }
.bub-detail[hidden] { display: none; }
.bd-head { display: flex; align-items: center; gap: 10px; margin-bottom: 11px; }
.bd-logo { width: 32px; height: 32px; border-radius: 50%; flex: 0 0 auto; display: grid; place-items: center;
  font: 800 12px var(--font-body); color: #fff; overflow: hidden; box-shadow: 0 4px 12px -4px rgba(0,0,0,.6); }
.bd-logo img { width: 100%; height: 100%; object-fit: cover; }
.bd-sym { font: 800 15px var(--font-display); letter-spacing: -.01em; line-height: 1.1; }
.bd-name { font: 500 11px var(--font-body); color: var(--text-dim); line-height: 1.2; margin-top: 1px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 150px; }
.bd-close { margin-left: auto; cursor: pointer; color: var(--na); background: 0; border: 0; font-size: 18px; line-height: 1; padding: 2px 4px; }
.bd-close:hover { color: var(--text); }
.bd-price { font: 800 20px var(--font-display); letter-spacing: -.02em; margin-bottom: 10px; font-variant-numeric: tabular-nums; }
.bd-price small { font: 600 11px var(--font-body); color: var(--na); margin-left: 4px; }
.bd-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(0, 1fr)); gap: 5px; margin-bottom: 11px; }
.bd-cell { background: color-mix(in srgb, var(--text) 4%, transparent); border: 1px solid var(--hairline); border-radius: 9px; padding: 6px 2px; text-align: center; }
.bd-cell .l { display: block; font: 700 9px var(--font-body); color: var(--na); text-transform: uppercase; letter-spacing: .05em; }
.bd-cell .v { display: block; font: 800 12px var(--font-body); margin-top: 2px; font-variant-numeric: tabular-nums; }
.bd-spark { width: 100%; height: 40px; display: block; margin-bottom: 11px; }
.bd-meta { font: 500 11px var(--font-body); color: var(--text-dim); margin-bottom: 12px; }
.bd-meta b { color: var(--text); font-weight: 700; }
.bd-acts { display: flex; gap: 8px; }
.bd-btn { flex: 1; text-align: center; text-decoration: none; cursor: pointer; font: 700 11.5px var(--font-body);
  padding: 9px 6px; border-radius: var(--r-xs); border: 1px solid var(--border-gold); color: var(--text-dim); background: var(--surface); transition: .15s; }
.bd-btn:hover { color: var(--ink); background: var(--drizzle); border-color: transparent; }
.bd-est { color: var(--warn); }
.bd-links { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.bd-link { text-decoration: none; font: 600 10.5px var(--font-body); color: var(--text-dim); white-space: nowrap;
  padding: 5px 9px; border-radius: 999px; border: 1px solid var(--border); background: color-mix(in srgb, var(--bg) 50%, var(--surface)); transition: .15s; }
.bd-link:hover { color: var(--accent); border-color: var(--border-gold); }

/* ---- toolbar selects: rank pager + watchlist filter ---- */
.bub-rank, .bub-list {
  appearance: none; -webkit-appearance: none;
  background: color-mix(in srgb, var(--bg) 55%, var(--surface));
  color: var(--text); border: 1px solid var(--border); border-radius: 999px;
  font: 600 12.5px var(--font-body); padding: 9px 30px 9px 14px; cursor: pointer; outline: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23889' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
}
.bub-rank:hover, .bub-list:hover { border-color: var(--na); }
.bub-list { color: var(--accent); font-weight: 700; }

/* ---- detail: save-to-watchlist star ---- */
.bd-star { margin-left: auto; background: none; border: 0; color: var(--na); font-size: 19px; line-height: 1; cursor: pointer; padding: 0 2px; }
.bd-star:hover { color: var(--accent); transform: scale(1.12); }
.bd-head .bd-close { margin-left: 6px; }

/* ---- list / table view (alternative to the map) ---- */
.bub-listv { position: absolute; inset: 0; overflow: auto; z-index: 2; }
.bub-listv[hidden] { display: none; }


.lv-table { width: 100%; border-collapse: collapse; font: 500 12.5px var(--font-body); }
.lv-table thead th {
  position: sticky; top: 0; z-index: 1; text-align: right; white-space: nowrap;
  background: color-mix(in srgb, var(--surface) 94%, var(--bg)); color: var(--text-dim);
  font: 700 10.5px var(--font-body); text-transform: uppercase; letter-spacing: 0.05em;
  padding: 11px 12px; border-bottom: 1px solid var(--border); cursor: pointer;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); user-select: none;
}
.lv-table th.l, .lv-table td.l { text-align: left; }
.lv-table thead th:hover { color: var(--text); }
.lv-table tbody td { padding: 9px 12px; text-align: right; border-bottom: 1px solid var(--hairline); font-variant-numeric: tabular-nums; }
.lv-table tbody tr { cursor: pointer; transition: background .12s; }
.lv-table tbody tr:hover { background: color-mix(in srgb, var(--accent) 9%, transparent); }
.lv-rank { color: var(--na); width: 38px; }
.lv-asset { display: inline-flex; align-items: center; gap: 9px; }
.lv-logo { width: 22px; height: 22px; border-radius: 50%; overflow: hidden; flex: 0 0 auto; display: grid; place-items: center; background: color-mix(in srgb, var(--text) 8%, transparent); }
.lv-logo img { width: 100%; height: 100%; object-fit: cover; }
.lv-mono { font: 800 9px var(--font-body); color: var(--text-dim); }
.lv-sym { font-weight: 800; color: var(--text); }
.lv-name { color: var(--text-dim); max-width: 230px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lv-more { padding: 14px; text-align: center; color: var(--na); font-size: 12px; }
.lv-tools { display: flex; justify-content: flex-end; padding: 8px 12px 6px; }
.lv-export { cursor: pointer; font: 700 11px var(--font-body); color: var(--text-dim);
  padding: 7px 13px; border-radius: 999px; border: 1px solid var(--border-gold); background: var(--surface); transition: .15s; }
.lv-export:hover { color: var(--ink); background: var(--drizzle); border-color: transparent; }
@media (max-width: 620px) { .lv-name { display: none; } .lv-table tbody td, .lv-table thead th { padding: 9px 8px; } }

/* ---- footer ---- */
.site-foot { border-top: 1px solid var(--border); margin-top: 8px; padding: 40px var(--pad-x) 36px;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--surface) 45%, transparent)); }
.foot-wrap { max-width: var(--maxw); margin: 0 auto; }
.foot-top { display: flex; flex-wrap: wrap; gap: 24px 40px; justify-content: space-between; align-items: flex-start; }
.foot-brand { max-width: 360px; }
.foot-brand .brand { margin-bottom: 10px; }
.foot-tag { color: var(--text-dim); font-size: 0.84rem; line-height: 1.55; }
.foot-links { display: flex; flex-wrap: wrap; gap: 30px; }
.foot-col h5 { font: 700 0.68rem var(--font-body); text-transform: uppercase; letter-spacing: 0.1em; color: var(--na); margin-bottom: 11px; }
.foot-col a, .foot-col span { display: block; color: var(--text-dim); font-size: 0.84rem; padding: 4px 0; cursor: pointer; transition: color .15s; }
.foot-col a:hover, .foot-col span:hover { color: var(--text); }
.foot-rule { height: 1px; background: var(--border); margin: 26px 0 18px; }
.foot-bottom { display: flex; flex-wrap: wrap; gap: 12px 20px; justify-content: space-between; align-items: center; }
.foot-disclaimer { color: var(--na); font-size: 0.72rem; line-height: 1.5; max-width: 70ch; }
.foot-disclaimer b { color: var(--text-dim); }
.foot-copy { color: var(--na); font-size: 0.74rem; white-space: nowrap; }

@media (max-width: 620px) {
  .brand-name { font-size: 1.1rem; }
  .hd-wrap { gap: 10px; }
  .hd-acct { gap: 6px; }
  .acct-up, .acct-link, .acct-pro { padding: 7px 12px; font-size: 0.76rem; }
  .theme-btn { width: 36px; height: 36px; }
  .theme-pop { right: 12px; }
  .hero { padding: 28px var(--pad-x) 22px; }
  .hero-title { margin-top: 14px; }
  /* tabs share the row equally and shrink so all four (incl. "Commodities") fit without overflowing the phone */
  .tabs { padding: 0 8px; }
  .tab-btn { flex: 1 1 0; text-align: center; white-space: nowrap; padding: 12px 6px; font-size: 0.85rem; }
}
@media (max-width: 560px) {
  .bub-mood { margin-left: 0; order: 5; width: 100%; justify-content: center; }
  .bub-search { max-width: none; order: 4; }
  .bub-stage { min-height: 300px; }
  .sec-intro { margin-bottom: 12px; }
  .hero-chips { margin-top: 14px; }
}
@media (max-width: 480px) {
  .bub-bar { padding: 9px 9px; gap: 8px; }
  .bub-pill { padding: 9px 11px; font-size: 12px; }
  .bub-seg { padding: 2px; }
  .hero-sub { font-size: 0.94rem; }
  /* header: collapse the "✦ All access" label to just the icon and tighten everything so it never overflows the phone */
  header { padding: 11px 12px; }
  .hd-wrap { gap: 8px; }
  .hd-acct { gap: 5px; }
  .theme-btn { width: 34px; height: 34px; }
  .acct-pro { padding: 7px 10px; }
  .acct-lbl { display: none; }
}
@media (max-width: 380px) {
  .brand-name { font-size: 1rem; }
  .acct-up, .acct-link { padding: 7px 10px; font-size: 0.78rem; }
  .bub-pill { padding: 8px 9px; font-size: 11.5px; }
}
@media (max-width: 360px) {
  /* very small phones: drop the ".com" suffix and tighten the brand + tools so the header still fits */
  .brand-name i { display: none; }
  .brand-name { font-size: 0.88rem; }
  .brand { gap: 8px; }
  .theme-btn { width: 31px; height: 31px; }
  .hd-acct { gap: 4px; }
  .tab-btn { padding: 12px 3px; font-size: 0.78rem; }
}
/* ---- Pin & Peek: collapse the filter wall on phones into View + Timeframe rows + a "More" sheet ---- */
@media (max-width: 700px) {
  .bub-bar { flex-direction: column; align-items: stretch; gap: 7px; }
  .bub-bar > .bub-view { order: 1; }
  .bub-bar > .bub-tf { order: 2; }
  .bub-bar > .bub-mstrip { order: 3; }
  .bub-bar > .bub-chips { order: 4; }
  .bub-bar > .bub-search { order: 5; }
  .bub-bar > .bub-morepanel { order: 6; }
  .bub-view, .bub-tf { width: 100%; }
  .bub-view .bub-pill, .bub-tf .bub-pill { flex: 1 1 0; padding-left: 4px; padding-right: 4px; text-align: center; }
  .bub-mstrip { display: flex; flex-direction: row; align-items: center; gap: 8px; }
  .bub-morebtn { display: inline-flex; align-items: center; gap: 7px; flex: 1 1 auto;
    background: color-mix(in srgb, var(--bg) 55%, var(--surface)); color: var(--text);
    border: 1px solid var(--border); border-radius: 999px; padding: 10px 14px; font: 600 12.5px var(--font-body); cursor: pointer; }
  .bub-bar.has-filters .bub-morebtn { border-color: var(--accent); }
  .bub-morebtn .mb-ico { font-size: 13px; opacity: .85; }
  .bub-morecount { background: var(--drizzle); color: var(--ink); border-radius: 999px; font: 700 11px var(--font-body); padding: 1px 8px; margin-left: auto; }
  .bub-morebtn .mb-chev { transition: transform .2s; opacity: .7; }
  .bub-bar.more-open .bub-morebtn .mb-chev { transform: rotate(90deg); }
  .bub-mstrip > .bub-mood { order: 0; margin-left: 0; width: auto; }
  .bub-chips { display: flex; flex-wrap: wrap; gap: 6px; }
  .bub-bar:not(.has-filters) .bub-chips { display: none; }
  .bub-chip { display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
    background: color-mix(in srgb, var(--accent) 16%, transparent); color: var(--text);
    border: 1px solid color-mix(in srgb, var(--accent) 40%, var(--border)); border-radius: 999px; padding: 5px 11px; font: 600 12px var(--font-body); }
  .bub-chip .cx { opacity: .6; font-size: 14px; line-height: 1; }
  .bub-search { display: block; width: 100%; max-width: none; flex: 0 0 auto; }
  .bub-morepanel { display: flex; flex-direction: column; gap: 7px; overflow: hidden; max-height: 0; opacity: 0; transition: max-height .28s ease, opacity .18s; }
  .bub-bar.more-open .bub-morepanel { max-height: 78vh; opacity: 1; overflow-y: auto; }
  .bub-morepanel .bub-seg { width: 100%; }
  .bub-morepanel .bub-seg .bub-pill { flex: 1 1 0; padding-left: 4px; padding-right: 4px; text-align: center; }
  .bub-morepanel .bub-rank, .bub-morepanel .bub-list { width: 100%; max-width: none; }
}

/* ---- embed / widget mode (?embed=…): chromeless single map ---- */
body.embed::after { display: none; }
body.embed header, body.embed .hero, body.embed .tabs, body.embed .site-foot,
body.embed .sec-intro, body.embed .paywall, body.embed .bub-legend, body.embed .theme-pop, body.embed .settings-pop { display: none !important; }
body.embed main { padding: 10px; max-width: none; margin: 0; min-height: 100dvh; }
body.embed .bubbles { margin: 0; }
body.embed .bub-bar { margin-bottom: 10px; }
body.embed .bub-stage { min-height: 300px; }

/* ===================== price alerts (Pro) ===================== */
.bd-alert { background: none; border: 0; color: var(--na); font-size: 16px; line-height: 1; cursor: pointer; padding: 0 2px; }
.bd-alert:hover { color: var(--accent); transform: scale(1.12); }
.al-ctx { margin: 6px 0 14px; color: var(--text-dim); font-size: 0.86rem; position: relative; }
.al-form { position: relative; display: grid; gap: 10px; }
.al-row { display: flex; align-items: center; gap: 8px; }
.al-row[hidden] { display: none; }
.al-sel, .al-in { font: 600 0.92rem var(--font-body); color: var(--text); background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r-xs, 9px); padding: 10px 12px; }
.al-sel { width: 100%; cursor: pointer; }
.al-row .al-in { flex: 1; min-width: 0; }
.al-sel:focus, .al-in:focus { border-color: var(--accent); outline: none; }
.al-pre, .al-suf { color: var(--text-dim); font: 700 0.95rem var(--font-body); flex: 0 0 auto; }
.al-note { min-height: 1.1em; margin: 2px 0 0; font-size: 0.78rem; color: var(--text-dim); }
.al-list-wrap { margin-top: 18px; border-top: 1px solid var(--border); padding-top: 14px; }
.al-list-h { font: 700 0.82rem var(--font-body); letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-dim); margin: 0 0 10px; }
.al-list { display: grid; gap: 7px; max-height: 188px; overflow: auto; }
.al-item { display: flex; align-items: center; gap: 10px; justify-content: space-between; background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r-xs, 9px); padding: 9px 12px; font-size: 0.86rem; color: var(--text); }
.al-del { background: none; border: 0; color: var(--na); font-size: 18px; line-height: 1; cursor: pointer; padding: 0 2px; flex: 0 0 auto; }
.al-del:hover { color: var(--maple, #eb5f55); }
.al-empty { color: var(--na); font-size: 0.84rem; margin: 0; }
