:root{
  --bg:#05070b;
  --panel:#0b0f16;
  --panel2:#0a0d13;
  --stroke:rgba(156,180,255,.14);
  --stroke2:rgba(156,180,255,.08);
  --text:rgba(240,245,255,.92);
  --muted:rgba(255,255,255,.92);
  --cyan:#44f1ff;
  --cyan2:#18a5ff;
  --amber:#ffcc66;
  --danger:#ff4d6d;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--mono);
  background:radial-gradient(1000px 800px at 20% 10%, rgba(24,165,255,.12), transparent 55%),
             radial-gradient(800px 650px at 70% 20%, rgba(68,241,255,.08), transparent 55%),
             linear-gradient(180deg, #04060a 0%, #060914 45%, #04060a 100%);
  color:var(--text);
  overflow:hidden;
}

.gw2{height:100%;display:flex;flex-direction:column}

/* ── Ticker tape bar ─────────────────────────────────────────────── */
.gw2-tickerBar{
  position:relative;
  z-index:35;
  width:100%;
  height:64px;
  flex-shrink:0;
  background:#131722;
  overflow:hidden;
  margin-top:-1px;
}
.gw2-liveTicker{
  position:relative;
  display:flex;
  align-items:center;
  width:100%;
  height:100%;
  background:#131722;
  overflow:hidden;
}
.gw2-liveTicker-pill{
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  height:100%;
  padding:0 14px;
  font-family:var(--mono);
  font-size:.62rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--cyan);
  background:linear-gradient(90deg, rgba(68,241,255,.16), rgba(68,241,255,0));
  border-right:1px solid rgba(68,241,255,.22);
}
.gw2-liveTicker-viewport{
  flex:1;
  min-width:0;
  position:relative;
  mask-image:linear-gradient(90deg, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
}
.gw2-liveTicker-track{
  display:inline-flex;
  align-items:center;
  gap:0;
  white-space:nowrap;
  will-change:transform;
  animation:gw2TickerScroll 110s linear infinite;
}
.gw2-liveTicker-track.is-paused,
.gw2-liveTicker:hover .gw2-liveTicker-track{
  animation-play-state:paused;
}
@keyframes gw2TickerScroll{
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}
.gw2-liveTicker-empty{
  padding:0 16px;
  font-family:var(--mono);
  font-size:.66rem;
  color:var(--muted);
  letter-spacing:.06em;
}
.gw2-liveTicker-item{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:0 16px;
  height:64px;
  font-family:var(--mono);
  font-size:.92rem;
  font-weight:700;
  color:var(--text);
  text-decoration:none;
  border-right:1px solid rgba(156,180,255,.06);
  transition:background .12s;
}
.gw2-liveTicker-item:hover{background:rgba(68,241,255,.04)}
.gw2-liveTicker-sym{color:#fff;letter-spacing:.04em;font-weight:800}
.gw2-liveTicker-price{color:rgba(240,245,255,.82)}
.gw2-liveTicker-chg{
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-weight:800;
}
.gw2-liveTicker-chg.up{color:#22c55e}
.gw2-liveTicker-chg.dn{color:#ef4444}
.gw2-liveTicker-chg.neu{color:var(--muted)}
.gw2-liveTicker-arrow{font-size:.58rem;opacity:.88}
.gw2-liveTicker-item[data-market-id]{cursor:pointer}
.gw2-liveTicker-item[data-market-id]:focus-visible,
.gw2-liveTicker-item[href]:focus-visible{
  outline:1px solid rgba(68,241,255,.45);
  outline-offset:-1px;
}
@media(max-width:768px){
  .gw2-tickerBar{height:80px}
  .gw2-liveTicker-pill{padding:0 12px}
  .gw2-liveTicker-item{
    height:80px;
    padding:0 12px;
    font-size:.85rem;
    gap:5px;
  }
  .gw2-liveTicker-track{animation-duration:80s}
}

.gw2-topbar{
  height:64px;
  position:relative;
  z-index:40; /* keep topbar + search dropdown above panels */
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 16px;
  background:#131722;
  backdrop-filter: blur(10px);
  box-shadow:0 2px 0 0 #131722;
}
.gw2-brand{display:flex;align-items:center;gap:12px;min-width:240px}
.gw2-brandLink{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:8px 12px;
  border:1px solid rgba(68,241,255,.12);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(10,16,29,.9), rgba(6,10,20,.78));
  box-shadow:0 10px 30px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.02);
}
.gw2-brandLink:hover{border-color:rgba(68,241,255,.28)}
.gw2-brandLogo{
  display:block;
  width:auto;
  height:26px;
  filter:drop-shadow(0 0 14px rgba(68,241,255,.08));
}

.gw2-actions{display:flex;align-items:center;gap:10px}
.gw2-tabs{display:flex;align-items:center;gap:8px}
.gw2-tab{
  display:inline-flex;
  align-items:center;
  height:34px;
  padding:0 10px;
  border-radius:12px;
  border:1px solid var(--stroke2);
  background:rgba(6,8,12,.45);
  color:var(--muted);
  text-decoration:none;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.gw2-tab:hover{border-color:rgba(68,241,255,.26);color:rgba(240,245,255,.92)}
.gw2-tab.is-active{
  border-color:rgba(68,241,255,.32);
  color:rgba(68,241,255,.95);
  background:linear-gradient(180deg, rgba(68,241,255,.12), rgba(24,165,255,.06));
}

/* Premium CTA */
.gw2-btn-premium{
  border:1px solid rgba(201,162,39,.42);
  background:rgba(201,162,39,.12);
  color:rgba(255,235,195,.95);
  text-decoration:none;
}
.gw2-btn-premium:hover{
  border-color:rgba(201,162,39,.62);
  background:rgba(201,162,39,.18);
  color:#fff;
}
/* ── Hamburger button ───────────────────────────────────────────────── */
.gw2-hamburger{
  appearance:none;
  background:none;
  border:1px solid var(--stroke2);
  border-radius:8px;
  width:36px;height:36px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:5px;
  padding:0;
  cursor:pointer;
  flex-shrink:0;
  transition:border-color .18s;
}
.gw2-hamburger:hover{border-color:rgba(68,241,255,.35)}
.gw2-hamburger span{
  display:block;
  width:16px;height:1.5px;
  background:var(--text);
  border-radius:2px;
  transition:transform .22s ease, opacity .18s, width .18s;
}
/* Animated X when open */
.gw2-hamburger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.gw2-hamburger.is-open span:nth-child(2){opacity:0;width:0}
.gw2-hamburger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── Menu overlay (backdrop) ───────────────────────────────────────── */
.gw2-menuOverlay{
  position:fixed;inset:0;
  z-index:199;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(3px);
  opacity:0;pointer-events:none;
  transition:opacity .25s;
}
.gw2-menuOverlay.is-open{opacity:1;pointer-events:all}

/* ── Slide-in menu panel ────────────────────────────────────────────── */
.gw2-menu{
  position:fixed;
  top:0;left:0;
  height:100%;
  width:280px;
  z-index:200;
  background:linear-gradient(160deg, rgba(10,14,22,.98) 0%, rgba(7,10,18,.99) 100%);
  border-right:1px solid var(--stroke);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:flex;flex-direction:column;
  transform:translateX(-100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  /* override hidden — animation handles visibility */
}
.gw2-menu:not([hidden]){transform:translateX(0)}
/* keep layout while hidden (avoids flash on first open) */
.gw2-menu[hidden]{display:flex!important;visibility:hidden}
.gw2-menu:not([hidden]){visibility:visible}

.gw2-menuHeader{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 18px 14px;
  border-bottom:1px solid var(--stroke2);
  flex-shrink:0;
}
.gw2-menuBrand{display:flex;align-items:center}
.gw2-menuBrandLogo{
  display:block;
  width:auto;
  height:22px;
  opacity:.96;
}
.gw2-menuClose{
  appearance:none;background:none;border:1px solid var(--stroke2);
  border-radius:6px;width:28px;height:28px;
  color:var(--muted);font-size:16px;cursor:pointer;
  display:grid;place-items:center;padding:0;
  transition:border-color .15s,color .15s;
}
.gw2-menuClose:hover{border-color:rgba(68,241,255,.35);color:var(--text)}

.gw2-menuList{
  list-style:none;margin:0;padding:10px 0;
  flex:1;overflow-y:auto;
}
.gw2-menuItem{display:block}

.gw2-menuLink{
  display:flex;align-items:center;gap:12px;
  width:100%;
  padding:12px 20px;
  background:none;border:none;
  color:rgba(220,230,255,.82);
  font-family:var(--sans);font-size:13px;font-weight:400;
  text-decoration:none;cursor:pointer;
  transition:background .15s,color .15s;
  text-align:left;
}
.gw2-menuLink:hover{
  background:rgba(68,241,255,.06);
  color:rgba(68,241,255,.95);
}
.gw2-menuAction{justify-content:flex-start}
.gw2-menuAction .gw2-notifCount{margin-left:auto}
.gw2-menuLink.is-active{
  color:var(--cyan);
  background:rgba(68,241,255,.08);
  border-left:2px solid var(--cyan);
  padding-left:18px;
}
.gw2-menuIcon{
  width:16px;height:16px;flex-shrink:0;opacity:.7;
}
.gw2-menuChevron{
  width:12px;height:12px;
  margin-left:auto;flex-shrink:0;opacity:.55;
  transition:transform .2s;
}
.gw2-menuToggle[aria-expanded="true"] .gw2-menuChevron{transform:rotate(180deg)}

/* Submenu */
.gw2-subMenu{
  list-style:none;margin:0;padding:0 0 6px;
  background:rgba(0,0,0,.18);
  overflow:hidden;
}
.gw2-subMenu[hidden]{display:none}
.gw2-subLink{
  display:block;width:100%;
  padding:9px 20px 9px 48px;
  background:none;border:none;
  color:rgba(205,220,255,.65);
  font-family:var(--sans);font-size:12px;
  text-align:left;cursor:pointer;
  transition:color .15s,background .15s;
}
.gw2-subLink:hover{color:var(--cyan);background:rgba(68,241,255,.05)}
.gw2-subLink.is-active{color:var(--cyan);font-weight:500}

/* Divider between groups */
.gw2-menuItem + .gw2-menuItem.gw2-menuDivider{
  border-top:1px solid var(--stroke2);
  margin-top:8px;padding-top:8px;
}

.gw2-btn[hidden]{display:none!important}
.gw2-btn{
  appearance:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--stroke);
  background:linear-gradient(180deg, rgba(14,18,28,.9), rgba(9,12,18,.8));
  color:var(--text);
  padding:9px 12px;
  border-radius:12px;
  font-family:var(--mono);
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  font-size:11px;
  cursor:pointer;
}
.gw2-btn:hover{border-color:rgba(68,241,255,.32)}
.gw2-btn.is-active{
  border-color:rgba(68,241,255,.55);
  box-shadow:0 0 0 1px rgba(68,241,255,.16) inset;
}
.gw2-btn:active{transform:translateY(1px)}
.gw2-btn-ghost{background:transparent;border-color:var(--stroke2)}
.gw2-authLinkBtn{
  border-color:rgba(68,241,255,.28);
  color:rgba(220,252,255,.95);
}

.gw2-searchWrap{
  position:relative;
  width:min(420px, 38vw);
}
.gw2-searchInput{
  width:100%;
  height:34px;
  border-radius:12px;
  border:1px solid var(--stroke2);
  background:rgba(6,8,12,.45);
  color:rgba(240,245,255,.92);
  padding:0 10px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.02em;
  outline:none;
}
.gw2-searchInput:focus{
  border-color:rgba(68,241,255,.34);
  box-shadow:0 0 0 3px rgba(68,241,255,.10);
}
.gw2-searchResults{
  position:absolute;
  top:40px;
  left:0;
  right:0;
  z-index:45;
  border:1px solid var(--stroke);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(10,13,20,.96), rgba(8,10,16,.90));
  box-shadow:0 25px 80px rgba(0,0,0,.60);
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height:52vh;
  overflow:auto;
}
.gw2-searchResults[hidden]{display:none}
.gw2-searchItem{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  border:1px solid var(--stroke2);
  background:rgba(6,8,12,.45);
  border-radius:14px;
  padding:10px 10px;
  cursor:pointer;
}
.gw2-searchItem:hover{border-color:rgba(68,241,255,.28)}
.gw2-searchItem.is-active{border-color:rgba(68,241,255,.40);box-shadow:0 0 0 3px rgba(68,241,255,.08)}
.gw2-searchItem .l{min-width:0}
.gw2-searchItem .t{font-family:var(--mono);font-size:12px;letter-spacing:.06em}
.gw2-searchItem .n{margin-top:3px;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gw2-searchItem .r{font-family:var(--mono);font-size:10px;color:rgba(68,241,255,.85);letter-spacing:.12em;text-transform:uppercase}

/* Desktop: 4-column layout — alerts | globe | intel brief | live news */
.gw2-main{flex:1;min-height:0;display:flex;flex-direction:row}
.gw2-globe{flex:1;min-width:180px;position:relative;overflow:hidden}
.gw2-side{
  width:340px;
  flex-shrink:0;
  border-left:1px solid var(--stroke2);
  background:linear-gradient(180deg, rgba(10,13,20,.92), rgba(7,9,14,.88));
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
/* ── Live news channels panel ────────────────────────────────────── */
.gw2-newspanel{
  width:420px;
  flex-shrink:0;
  border-left:1px solid var(--stroke2);
  background:linear-gradient(180deg, rgba(10,13,20,.92), rgba(7,9,14,.88));
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
/* Ad banner — right panel default state */
.gw2-adBanner{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px;
  min-height:0;
  overflow:hidden;
}
.gw2-adBannerLink{
  display:flex;
  flex-direction:column;
  width:300px;
  height:250px;
  flex-shrink:0;
  text-decoration:none;
  border:1px solid rgba(68,241,255,.16);
  border-radius:14px;
  background:linear-gradient(160deg,rgba(68,241,255,.04) 0%,rgba(10,13,20,.85) 60%);
  overflow:hidden;
  transition:border-color .22s,background .22s;
  /* Scale down on narrow screens without changing the 300×250 slot */
  max-width:min(300px, calc(100% - 24px));
}
.gw2-adBannerLink:hover{
  border-color:rgba(68,241,255,.34);
  background:linear-gradient(160deg,rgba(68,241,255,.09) 0%,rgba(10,13,20,.88) 60%);
}
.gw2-adBannerImg{width:100%;height:100%;object-fit:cover;display:block;border-radius:13px}
.gw2-adBannerInner{
  padding:20px 16px 18px;
  display:flex;
  flex-direction:column;
  gap:10px;
  height:100%;
  box-sizing:border-box;
}
.gw2-adBannerLabel{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  opacity:.55;
}
.gw2-adBannerVisual{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px 0 4px;
}
.gw2-adBannerTitle{
  font-size:1.15rem;
  font-weight:700;
  color:var(--cyan);
  letter-spacing:.03em;
  line-height:1.2;
}
.gw2-adBannerBody{
  font-size:12px;
  color:rgba(205,220,255,.65);
  line-height:1.65;
  flex:1;
}
.gw2-adBannerCta{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.1em;
  color:var(--cyan);
  opacity:.82;
  padding-top:4px;
  border-top:1px solid rgba(68,241,255,.1);
}

/* Play overlay inside each channel card */
.gw2-newsPlayOverlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(6,8,12,.72);
  z-index:5;
  transition:background .18s;
}
.gw2-newsPlayOverlay:hover{
  background:rgba(6,8,12,.5);
}
.gw2-newsPlayBtn{
  background:none;
  border:2px solid rgba(68,241,255,.45);
  border-radius:50%;
  width:48px;
  height:48px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 0 0 3px;
  transition:border-color .18s,background .18s;
}
.gw2-newsPlayBtn:hover{
  border-color:rgba(68,241,255,.9);
  background:rgba(68,241,255,.1);
}

.gw2-newsChannels{
  flex:1;
  min-height:0;
  overflow-y:auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  padding:10px;
  -webkit-overflow-scrolling:touch;
}
.gw2-newsCard{
  display:flex;
  flex-direction:column;
  gap:5px;
}
/* Centre the last card when it sits alone on a row in the 2-column grid */
.gw2-newsCard--centred{
  grid-column:1 / -1;
  width:50%;
  margin:0 auto;
}
.gw2-newsLabel{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  padding:0 2px;
}
.gw2-newsEmbed{
  position:relative;
  width:100%;
  padding-top:100%; /* square */
  background:#000;
  border-radius:6px;
  overflow:hidden;
  border:1px solid var(--stroke2);
}
/* Fullscreen expand button — appears on card hover */
.gw2-fsBtn{
  position:absolute;
  top:6px;right:6px;
  z-index:10;
  width:26px;height:26px;
  border:1px solid rgba(156,180,255,.28);
  border-radius:6px;
  background:rgba(6,8,12,.78);
  color:var(--cyan);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  padding:0;
  opacity:0;
  transition:opacity .18s, background .18s;
}
.gw2-newsCard:hover .gw2-fsBtn,
.gw2-newsEmbed:fullscreen .gw2-fsBtn,
.gw2-newsEmbed:-webkit-full-screen .gw2-fsBtn{opacity:1}
.gw2-fsBtn:hover{background:rgba(68,241,255,.18)}

/* Fullscreen state — fill the screen */
.gw2-newsEmbed:fullscreen,
.gw2-newsEmbed:-webkit-full-screen{
  padding-top:0;
  width:100vw;
  height:100vh;
  border-radius:0;
  background:#000;
}
.gw2-newsEmbed:fullscreen iframe,
.gw2-newsEmbed:-webkit-full-screen iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

.gw2-newsEmbed iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:none;
  display:block;
}

.gw2-sideScroll{flex:1;min-height:0;overflow-y:auto;padding-bottom:14px;-webkit-overflow-scrolling:touch}
.gw2-sideHeader{padding:18px 18px 12px;border-bottom:1px solid var(--stroke2)}
.gw2-sideTitle h1{
  margin:8px 0 0;
  font-size:20px;
  letter-spacing:.02em;
}
.gw2-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:11px;
  letter-spacing:.16em;
  font-family:var(--mono);
  text-transform:uppercase;
  color:rgba(68,241,255,.92);
}
.gw2-muted{color:var(--muted);font-size:12px}

.gw2-card{
  margin:14px 14px 0;
  border:1px solid var(--stroke2);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(8,10,16,.92), rgba(8,10,16,.65));
  padding:14px;
  box-shadow: 0 0 0 1px rgba(0,0,0,.35) inset;
}
.gw2-cardTitle{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(240,245,255,.86);
  margin-bottom:10px;
}
.gw2-kpis{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:10px}
.gw2-kpis .kpi{
  padding:10px 10px 9px;
  border-radius:14px;
  border:1px solid var(--stroke2);
  background:rgba(6,8,12,.55);
}
.gw2-kpis .kpi label{
  display:block;
  font-size:10px;
  font-family:var(--mono);
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:6px;
}
.gw2-kpis .kpi strong{font-family:var(--mono);font-size:12px}

.gw2-lines{display:grid;grid-template-columns:1fr;gap:8px}
.gw2-line{
  display:flex;justify-content:space-between;gap:10px;
  padding:9px 10px;
  border-radius:14px;
  border:1px solid var(--stroke2);
  background:rgba(6,8,12,.45);
}
.gw2-line .k{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.gw2-line .v{font-family:var(--mono);font-size:11px;color:rgba(240,245,255,.88);text-align:right}
.gw2-body{line-height:1.5;color:rgba(240,245,255,.86);font-size:13px}
.gw2-divider{height:1px;background:var(--stroke2);margin:12px 0}

.gw2-marketTop{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:10px;margin-bottom:10px}
.gw2-quote{font-family:var(--mono);font-size:16px;margin-top:4px;color:rgba(68,241,255,.92)}
.gw2-quoteSub{font-family:var(--mono);font-size:12px;margin-top:4px}
.gw2-tvWrap{border-radius:16px;overflow:hidden;border:1px solid var(--stroke2);background:#ffffff}
.gw2-tv{height:240px}

.gw2-spacer{flex:1}
.gw2-footer{padding:10px 14px 14px}

/* ── Left alerts panel ──────────────────────────────────────────────── */
.gw2-leftside{
  width:280px;
  flex-shrink:0;
  border-right:1px solid var(--stroke2);
  background:linear-gradient(180deg, rgba(10,13,20,.92), rgba(7,9,14,.88));
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.gw2-alertTabs{display:flex;gap:6px}
.gw2-alertTab{
  appearance:none;
  border:1px solid var(--stroke2);
  background:rgba(6,8,12,.45);
  color:var(--muted);
  padding:5px 10px;
  border-radius:10px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
}
.gw2-alertTab:hover:not(:disabled){border-color:rgba(68,241,255,.26);color:rgba(240,245,255,.92)}
.gw2-alertTab.is-active{
  border-color:rgba(68,241,255,.32);
  color:rgba(68,241,255,.95);
  background:linear-gradient(180deg, rgba(68,241,255,.12), rgba(24,165,255,.06));
}
.gw2-alertTab.is-locked{
  opacity:.45;
  cursor:not-allowed;
}

/* Alert search bar */
.gw2-alertSearchBar{
  display:flex;
  align-items:center;
  gap:6px;
  padding:6px 14px 8px;
  border-bottom:1px solid var(--stroke2);
}
.gw2-alertSearchWrap{
  flex:1;
  position:relative;
  display:flex;
  align-items:center;
}
.gw2-alertSearchIcon{
  position:absolute;
  left:9px;
  color:var(--muted);
  pointer-events:none;
  flex-shrink:0;
}
.gw2-alertSearchInput{
  width:100%;
  background:rgba(255,255,255,.04);
  border:1px solid var(--stroke2);
  border-radius:8px;
  color:rgba(240,245,255,.9);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.04em;
  padding:6px 28px 6px 28px;
  outline:none;
  transition:border-color .18s;
}
.gw2-alertSearchInput::placeholder{color:var(--muted);opacity:.7}
.gw2-alertSearchInput:focus{border-color:rgba(68,241,255,.32);background:rgba(68,241,255,.03)}
.gw2-alertSearchClear{
  position:absolute;
  right:7px;
  background:none;
  border:none;
  color:var(--muted);
  cursor:pointer;
  font-size:14px;
  line-height:1;
  padding:2px 4px;
}
.gw2-alertSearchClear:hover{color:rgba(240,245,255,.9)}
.gw2-alertArchiveBtn{
  flex-shrink:0;
  background:rgba(68,241,255,.06);
  border:1px solid rgba(68,241,255,.2);
  border-radius:7px;
  color:rgba(68,241,255,.8);
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:5px 8px;
  cursor:pointer;
  white-space:nowrap;
  transition:background .18s,border-color .18s;
}
.gw2-alertArchiveBtn:hover{background:rgba(68,241,255,.12);border-color:rgba(68,241,255,.38)}
.gw2-alertArchiveBtn.is-loading{opacity:.6;cursor:wait}
/* Alert cards */
.gw2-alertCard{
  border:1px solid var(--stroke2);
  border-radius:14px;
  background:rgba(6,8,12,.45);
  padding:11px 12px;
  margin:0 14px 10px;
  transition:border-color .2s, box-shadow .2s;
}
.gw2-alertCard.is-green{
  border-color:rgba(34,197,94,.45);
  box-shadow:0 0 14px rgba(34,197,94,.18), inset 0 0 14px rgba(34,197,94,.05);
}
.gw2-alertCard.is-amber{
  border-color:rgba(251,191,36,.45);
  box-shadow:0 0 14px rgba(251,191,36,.18), inset 0 0 14px rgba(251,191,36,.05);
}
.gw2-alertCard.is-red{
  border-color:rgba(239,68,68,.32);
  box-shadow:0 0 10px rgba(239,68,68,.12), inset 0 0 10px rgba(239,68,68,.04);
}
.gw2-alertMeta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:6px;
}
.gw2-alertType{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:2px 7px;
  border-radius:6px;
  border:1px solid currentColor;
  opacity:.85;
}
.gw2-alertCard.is-green .gw2-alertType{color:rgba(34,197,94,.9)}
.gw2-alertCard.is-amber .gw2-alertType{color:rgba(251,191,36,.9)}
.gw2-alertCard.is-red   .gw2-alertType{color:rgba(239,68,68,.85)}
.gw2-alertTime{font-family:var(--mono);font-size:10px;color:var(--muted);white-space:nowrap}
.gw2-alertMsg{font-size:12px;color:rgba(240,245,255,.88);line-height:1.5;text-transform:uppercase}
.gw2-alertWhy{
  margin-top:6px;
  font-size:11px;
  color:rgba(205,220,255,.72);
  line-height:1.4;
}
.gw2-alertTicker{
  display:inline-block;
  margin-top:6px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(68,241,255,.85);
  text-decoration:none;
}
.gw2-alertTicker:hover{color:rgba(68,241,255,1)}
.gw2-alertSource{
  font-family:var(--mono);
  font-size:9px;
  font-weight:600;
  letter-spacing:.08em;
  color:rgba(205,220,255,.5);
  background:rgba(156,180,255,.08);
  border:1px solid rgba(156,180,255,.14);
  border-radius:4px;
  padding:1px 5px;
  text-transform:uppercase;
  white-space:nowrap;
}
.gw2-alertShare{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:none;
  border:1px solid rgba(156,180,255,.15);
  border-radius:5px;
  color:rgba(205,220,255,.35);
  cursor:pointer;
  padding:3px 5px;
  line-height:1;
  transition:color .15s, border-color .15s, background .15s;
  flex-shrink:0;
}
.gw2-alertShare:hover{
  color:rgba(68,241,255,.85);
  border-color:rgba(68,241,255,.28);
  background:rgba(68,241,255,.05);
}
.gw2-alertShare.is-copied{
  color:rgba(34,197,94,.9);
  border-color:rgba(34,197,94,.4);
  background:rgba(34,197,94,.08);
}
/* Geopolitical alert — amber glow accent */
.gw2-alertCard.is-geo{
  border-color:rgba(251,191,36,.4);
  box-shadow:0 0 12px rgba(251,191,36,.14), inset 0 0 12px rgba(251,191,36,.04);
}
.gw2-alertCard.is-geo .gw2-alertType{color:rgba(251,191,36,.9)}
.gw2-alertEmpty{
  padding:24px 14px;
  text-align:center;
  color:var(--muted);
  font-size:12px;
  font-family:var(--mono);
  letter-spacing:.08em;
}

/* Live pulse dot next to ALERTS pill */
.gw2-liveDot{
  display:inline-block;
  width:6px;height:6px;
  border-radius:50%;
  background:var(--cyan);
  vertical-align:middle;
  margin-left:2px;
  animation:gw2LivePulse 1.6s ease-in-out infinite;
}
@keyframes gw2LivePulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.3;transform:scale(.65)}
}

/* New-alert slide-in animation */
@keyframes gw2AlertSlideIn{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:translateY(0)}
}
.gw2-alertCard.is-new{
  animation:gw2AlertSlideIn .3s ease forwards;
}

/* ── Video cards (Stockertim Special) ───────────────────────────────────── */
.gw2-videoCard{
  display:flex;
  flex-direction:column;
  border:1px solid var(--stroke2);
  border-radius:14px;
  background:rgba(6,8,12,.45);
  margin:0 14px 10px;
  overflow:hidden;
  cursor:pointer;
  transition:border-color .2s, box-shadow .2s;
}
.gw2-videoCard:hover{
  border-color:rgba(68,241,255,.5);
  box-shadow:0 0 14px rgba(68,241,255,.14), inset 0 0 12px rgba(68,241,255,.04);
}
.gw2-videoThumbWrap{
  position:relative;
  width:100%;
  padding-top:56.25%; /* 16:9 */
  background:#0a0d18;
  flex-shrink:0;
}
.gw2-videoThumb{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.gw2-videoPlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.32);
  transition:background .18s;
}
.gw2-videoCard:hover .gw2-videoPlay{background:rgba(0,0,0,.18)}
.gw2-videoPlayIcon{
  width:38px;height:38px;
  border-radius:50%;
  background:rgba(255,0,0,.82);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(0,0,0,.5);
  transition:transform .18s;
}
.gw2-videoCard:hover .gw2-videoPlayIcon{transform:scale(1.1)}
.gw2-videoPlayIcon::after{
  content:'';
  display:block;
  width:0;height:0;
  border-top:8px solid transparent;
  border-bottom:8px solid transparent;
  border-left:14px solid #fff;
  margin-left:3px;
}
.gw2-videoBody{padding:9px 11px 10px}
.gw2-videoTitle{
  font-size:12px;
  color:rgba(240,245,255,.92);
  line-height:1.45;
  margin-bottom:6px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.gw2-videoMeta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:6px;
}
.gw2-videoLabel{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.16em;
  text-transform:uppercase;
  padding:2px 7px;
  border-radius:6px;
  border:1px solid rgba(255,0,0,.45);
  color:rgba(255,80,80,.9);
}
.gw2-videoTime{font-family:var(--mono);font-size:10px;color:var(--muted);white-space:nowrap}
.gw2-videoTickers{margin-top:5px;display:flex;flex-wrap:wrap;gap:4px}
.gw2-videoTicker{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.1em;
  color:rgba(68,241,255,.8);
  background:rgba(68,241,255,.07);
  border:1px solid rgba(68,241,255,.18);
  border-radius:4px;
  padding:1px 5px;
}
/* Search result row for videos */
.gw2-searchItem.is-video .t{color:rgba(255,80,80,.9)}

.gw2-videoModalOverlay{
  position:fixed;
  inset:0;
  z-index:320;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  background:rgba(2,6,16,.82);
  backdrop-filter:blur(6px);
}
.gw2-videoModalOverlay[hidden]{display:none}
.gw2-videoModal{
  width:min(1180px, calc(100vw - 32px));
  border:1px solid rgba(68,241,255,.18);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(9,14,27,.98), rgba(5,8,16,.98));
  box-shadow:0 30px 80px rgba(0,0,0,.42), 0 0 0 1px rgba(68,241,255,.05) inset;
  overflow:hidden;
}
.gw2-videoModalHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 18px 10px;
}
.gw2-videoModalKicker{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(68,241,255,.82);
}
.gw2-videoModalClose{
  appearance:none;
  border:1px solid rgba(68,241,255,.18);
  background:rgba(255,255,255,.03);
  color:rgba(240,245,255,.92);
  width:34px;
  height:34px;
  border-radius:10px;
  cursor:pointer;
  font-size:20px;
  line-height:1;
}
.gw2-videoModalClose:hover{border-color:rgba(68,241,255,.35);color:#fff}
.gw2-videoModalTitle{
  padding:0 18px 14px;
  font-size:15px;
  line-height:1.45;
  color:rgba(240,245,255,.96);
}
.gw2-videoModalFrameWrap{
  position:relative;
  width:100%;
  padding-top:56.25%;
  background:#000;
}
.gw2-videoModalFrame{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  display:block;
}

/* ── Video modal: share button ─────────────────────────────────────────── */
.gw2-videoModalActions{display:flex;align-items:center;gap:8px}
.gw2-videoShareBtn{
  appearance:none;
  border:1px solid rgba(68,241,255,.22);
  background:rgba(68,241,255,.06);
  color:rgba(68,241,255,.9);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.06em;
  padding:0 12px;
  height:34px;
  border-radius:10px;
  cursor:pointer;
  white-space:nowrap;
  transition:border-color .18s, background .18s, color .18s;
}
.gw2-videoShareBtn:hover{border-color:rgba(68,241,255,.5);background:rgba(68,241,255,.12);color:#fff}

/* ── Videos section overlay (reached from the sub-nav VIDEOS button) ────── */
.gw2-videosOverlay{
  position:fixed;
  inset:0;
  z-index:315;
  display:flex;
  align-items:stretch;
  justify-content:center;
  padding:24px;
  background:rgba(2,6,16,.86);
  backdrop-filter:blur(6px);
}
.gw2-videosOverlay[hidden]{display:none}
.gw2-videosPanel{
  width:min(1240px, 100%);
  display:flex;
  flex-direction:column;
  border:1px solid rgba(68,241,255,.16);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(9,14,27,.98), rgba(5,8,16,.98));
  box-shadow:0 30px 80px rgba(0,0,0,.45), 0 0 0 1px rgba(68,241,255,.05) inset;
  overflow:hidden;
}
.gw2-videosHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:18px 22px 16px;
  border-bottom:1px solid var(--stroke2);
}
.gw2-videosKicker{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.22em;
  color:rgba(68,241,255,.7);
}
.gw2-videosHeadTitle{
  font-size:22px;
  font-weight:600;
  color:rgba(240,245,255,.96);
  margin-top:2px;
}
.gw2-videosHeadRight{display:flex;align-items:center;gap:10px}
.gw2-videosSearchWrap{position:relative}
.gw2-videosSearch{
  appearance:none;
  width:230px;
  max-width:42vw;
  height:36px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.03);
  color:var(--text);
  border-radius:10px;
  padding:0 12px;
  font-size:13px;
  outline:none;
}
.gw2-videosSearch:focus{border-color:rgba(68,241,255,.4)}
.gw2-videosSearch::placeholder{color:var(--muted)}
.gw2-videosClose{
  appearance:none;
  border:1px solid rgba(68,241,255,.18);
  background:rgba(255,255,255,.03);
  color:rgba(240,245,255,.92);
  width:36px;height:36px;
  border-radius:10px;
  cursor:pointer;
  font-size:22px;
  line-height:1;
  flex-shrink:0;
}
.gw2-videosClose:hover{border-color:rgba(68,241,255,.35);color:#fff}
/* Free / Premium toggle bar above the scroll area */
.gw2-videosTabs{
  display:flex;align-items:center;gap:8px;
  padding:0 22px 14px;
  border-bottom:1px solid var(--stroke);
  flex-shrink:0;
}
.gw2-videosTab{
  appearance:none;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;height:34px;
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.03);
  color:rgba(220,230,250,.78);
  border-radius:8px;
  font-family:inherit;font-size:13px;font-weight:600;letter-spacing:.04em;
  cursor:pointer;
  transition:border-color .14s,background .14s,color .14s;
}
.gw2-videosTab:hover{
  border-color:rgba(68,241,255,.35);
  color:#fff;
}
.gw2-videosTab.is-active{
  border-color:rgba(68,241,255,.55);
  background:rgba(68,241,255,.10);
  color:#fff;
}
.gw2-videosTab[data-tab="premium"].is-active{
  border-color:rgba(255,204,102,.55);
  background:rgba(255,204,102,.10);
  color:#ffe7a8;
}
.gw2-videosTabCount{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:18px;padding:0 6px;
  border-radius:9px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  font-family:var(--mono);font-size:10px;font-weight:700;
  color:rgba(220,230,250,.80);
}
.gw2-videosTab.is-active .gw2-videosTabCount{
  background:rgba(68,241,255,.12);
  border-color:rgba(68,241,255,.35);
  color:#9ff3ff;
}
.gw2-videosTab[data-tab="premium"].is-active .gw2-videosTabCount{
  background:rgba(255,204,102,.14);
  border-color:rgba(255,204,102,.40);
  color:#ffe9a3;
}
@media (max-width: 700px){
  .gw2-videosTabs{padding:0 16px 12px;gap:6px}
  .gw2-videosTab{padding:7px 12px;height:32px;font-size:12px}
}

.gw2-videosScroll{
  flex:1;
  overflow-y:auto;
  padding:18px 22px 26px;
}
.gw2-videosGroup{margin-bottom:26px}
.gw2-videosGroup[hidden]{display:none}
.gw2-videosGroupTitle{
  display:flex;
  align-items:baseline;
  gap:10px;
  font-size:15px;
  font-weight:600;
  color:rgba(240,245,255,.94);
  margin:4px 0 14px;
  padding-bottom:8px;
  border-bottom:1px solid var(--stroke2);
}
.gw2-videosGroupHint{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.gw2-videosGrid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(248px, 1fr));
  gap:16px;
}
.gw2-videosEmpty{
  text-align:center;
  color:var(--muted);
  font-size:14px;
  padding:60px 20px;
}
/* Grid card overrides the alert-list card's side margins */
.gw2-videoCard--grid{margin:0}
.gw2-videoDesc{
  font-size:11px;
  color:var(--muted);
  line-height:1.5;
  margin-bottom:7px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.gw2-videoLabel.is-premium{
  border-color:rgba(255,204,102,.5);
  color:var(--amber);
}
.gw2-videoThumb.is-blurred{filter:blur(7px) brightness(.55);transform:scale(1.06)}
.gw2-videoCard.is-locked{cursor:pointer}
.gw2-videoLockBadge{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.34);
}
.gw2-videoLockBadgeIcon{
  width:44px;height:44px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:19px;
  background:rgba(255,204,102,.16);
  border:1px solid rgba(255,204,102,.5);
  box-shadow:0 2px 14px rgba(0,0,0,.45);
}

/* ── Premium lock dialog ───────────────────────────────────────────────── */
.gw2-videoLockBox{
  position:relative;
  width:min(420px, 100%);
  text-align:center;
  padding:34px 30px 28px;
  border:1px solid rgba(255,204,102,.22);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(20,17,9,.98), rgba(7,8,14,.98));
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.gw2-videoLockClose{position:absolute;top:14px;right:14px}
.gw2-videoLockIcon{font-size:34px;margin-bottom:8px}
.gw2-videoLockKicker{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--amber);
}
.gw2-videoLockTitle{
  font-size:17px;
  font-weight:600;
  color:rgba(240,245,255,.96);
  margin:8px 0 10px;
  line-height:1.4;
}
.gw2-videoLockMsg{
  font-size:13px;
  color:var(--muted);
  line-height:1.6;
  margin:0 0 22px;
}
.gw2-videoLockBtns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.gw2-videoLockGo{
  text-decoration:none;
  font-weight:600;
  font-size:13px;
  padding:11px 22px;
  border-radius:11px;
  color:#1a1407;
  background:linear-gradient(180deg,#ffd97a,#f0b840);
  border:1px solid rgba(255,204,102,.6);
}
.gw2-videoLockGo:hover{filter:brightness(1.06)}
.gw2-videoLockDismiss{
  appearance:none;
  font-size:13px;
  padding:11px 18px;
  border-radius:11px;
  cursor:pointer;
  color:var(--text);
  background:rgba(255,255,255,.04);
  border:1px solid var(--stroke);
}
.gw2-videoLockDismiss:hover{border-color:rgba(156,180,255,.3)}

@media (max-width:720px){
  .gw2-videosOverlay{padding:0}
  .gw2-videosPanel{border-radius:0;border:0}
  .gw2-videosHead{padding:14px 16px}
  .gw2-videosHeadTitle{font-size:18px}
  .gw2-videosSearch{width:150px}
  .gw2-videosScroll{padding:14px 16px 22px}
  .gw2-videosGrid{grid-template-columns:repeat(auto-fill, minmax(150px, 1fr));gap:12px}
}

.gw2-globeHost{position:absolute;inset:0}

/* ── 2D flat-map background — lightweight, near-zero-GPU alternative to the
 * 3D WebGL globe. Equirectangular night-earth image + absolutely-positioned
 * markers; no canvas, no continuous animation. ───────────────────────────── */
.gw2-flatMap{
  position:absolute;inset:0;
  background:#05070e url("https://unpkg.com/three-globe/example/img/earth-night.jpg") center/100% 100% no-repeat;
}
.gw2-flatMap[hidden]{display:none}
.gw2-flatMap::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at center, rgba(5,7,14,.12) 0%, rgba(5,7,14,.6) 100%);
}
.gw2-flatMapMarkers{position:absolute;inset:0}
.gw2-mapDot{
  position:absolute;width:10px;height:10px;padding:0;margin:0;
  border:none;border-radius:50%;cursor:pointer;
  transform:translate(-50%,-50%);
  background:var(--dot,#44f1ff);
  box-shadow:0 0 7px 1px var(--dot,#44f1ff), 0 0 0 1px rgba(0,0,0,.55);
  transition:width .1s ease,height .1s ease;
}
.gw2-mapDot:hover,.gw2-mapDot:focus-visible{width:15px;height:15px;outline:none;z-index:3}
.gw2-mapTip{
  position:absolute;z-index:12;pointer-events:none;
  padding:5px 9px;border-radius:7px;
  background:rgba(6,9,16,.96);border:1px solid var(--stroke2);
  font-family:var(--mono);font-size:10px;line-height:1.35;color:var(--text);
  white-space:nowrap;transform:translate(-50%,-128%);
  box-shadow:0 6px 18px rgba(0,0,0,.55);
}
.gw2-mapTip[hidden]{display:none}

/* Background-style toggle — sits just below the globe mode bar. */
.gw2-bgToggle{
  position:absolute;top:52px;left:50%;transform:translateX(-50%);
  display:flex;gap:2px;z-index:10;
  background:rgba(6,8,12,.65);border:1px solid var(--stroke);
  border-radius:16px;padding:3px;
}
.gw2-bgToggleBtn{
  padding:3px 13px;border:none;border-radius:13px;cursor:pointer;
  background:transparent;color:var(--muted);
  font-family:var(--mono);font-size:9px;font-weight:700;
  letter-spacing:.09em;text-transform:uppercase;
  transition:background .15s ease,color .15s ease;
}
.gw2-bgToggleBtn:hover{color:var(--text)}
.gw2-bgToggleBtn.is-active{background:rgba(68,241,255,.16);color:#9ff3ff}
/* "Grid" navigates to the Global Grid dashboard rather than toggling the
   background, so it uses its own class (the bg-toggle JS only binds
   .gw2-bgToggleBtn) and a thin divider to set it apart from Map / 3D. */
.gw2-bgGridLink{
  padding:3px 13px;border:none;border-radius:13px;cursor:pointer;
  background:transparent;color:var(--muted);text-decoration:none;
  display:inline-flex;align-items:center;
  font-family:var(--mono);font-size:9px;font-weight:700;
  letter-spacing:.09em;text-transform:uppercase;
  border-left:1px solid var(--stroke);margin-left:2px;
  transition:background .15s ease,color .15s ease;
}
.gw2-bgGridLink:hover{background:rgba(68,241,255,.16);color:#9ff3ff}
@media(max-width:600px){ .gw2-bgToggle{top:44px} }

/* Floating marker labels on the 3-D globe.
 *
 * CSS2DRenderer sets an inline style.transform that places the element's CENTER
 * at the globe point. We add padding-bottom so the visible content sits above
 * the dot without needing overflow or fighting the inline transform.
 *
 * Total height H = content (~28px) + padding-bottom (52px) ≈ 80px.
 * CSS2DRenderer translates by -50% of H ≈ -40px, centering the 80px box at the
 * dot. The visible content occupies the top 28px → bottom edge of content is at
 * dot_y - 40 + 28 = dot_y - 12px (just above the dot).
 */
.gw2-ptLabel{
  pointer-events:none;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:3px;
  padding-bottom:52px;
  white-space:nowrap;
}
.gw2-ptLabel__ticker{
  font-family:var(--mono,monospace);
  font-size:.95rem;
  font-weight:800;
  letter-spacing:.06em;
  color:#e2eaff;
  text-shadow:0 1px 6px #000,0 0 10px #000;
  line-height:1;
}
.gw2-ptLabel__chg{
  font-family:var(--mono,monospace);
  font-size:.68rem;
  font-weight:700;
  padding:2px 5px;
  border-radius:3px;
  background:rgba(8,12,28,.84);
  border:1px solid rgba(255,255,255,.12);
  line-height:1.3;
  min-width:3.4rem;
  text-align:center;
}
.gw2-ptLabel__chg--up  { color:#22c55e; }
.gw2-ptLabel__chg--dn  { color:#ef4444; }
.gw2-ptLabel__chg--neu { color:rgba(205,220,255,.55); }

.gw2-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(156,180,255,.08) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(156,180,255,.08) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image: radial-gradient(closest-side at 50% 45%, rgba(0,0,0,.95), transparent 72%);
  opacity:.55;
  pointer-events:none;
}
/* ── Markets dashboard overlay ──────────────────────────────────────────── */
.gw2-mkDash{
  position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:20;
  width:min(780px, calc(100% - 24px));
  pointer-events:auto;
  animation:popupIn .22s cubic-bezier(.22,1,.36,1);
}
.gw2-mkDash[hidden]{display:none}
.gw2-mkDashGrid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  justify-items:stretch;
}
/* Center lone last card when it falls in col 1 of its row (e.g. 7th of 3-col) */
.gw2-mkDashGrid .gw2-mkCard:last-child:nth-child(3n+1){
  grid-column:2;
}
.gw2-mkCard{
  background:linear-gradient(150deg,rgba(8,11,22,.92),rgba(5,7,14,.90));
  border:1px solid var(--stroke);
  border-radius:12px;
  padding:9px 11px 8px;
  cursor:pointer;
  transition:border-color .15s,background .15s;
  backdrop-filter:blur(6px);
  min-width:0;
}
.gw2-mkCard:hover{border-color:rgba(68,241,255,.35);background:rgba(12,18,34,.95)}
.gw2-mkCard-head{display:flex;align-items:baseline;justify-content:space-between;gap:6px;margin-bottom:3px}
.gw2-mkCard-label{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gw2-mkCard-cat{font-family:var(--mono);font-size:8px;letter-spacing:.1em;color:rgba(205,220,255,.4);text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.gw2-mkCard-price{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--text);letter-spacing:.02em;line-height:1}
.gw2-mkCard-chg{font-family:var(--mono);font-size:10px;margin-top:2px}
.gw2-mkCard-bar{height:4px;border-radius:2px;overflow:hidden;display:flex;margin-top:7px;gap:1px}
.gw2-mkCard-seg{height:100%;flex:0 0 auto;border-radius:1px}
.gw2-mkCard-seg.is-pos{background:rgba(34,197,94,.9)}
.gw2-mkCard-seg.is-neu{background:rgba(148,163,184,.6)}
.gw2-mkCard-seg.is-neg{background:rgba(239,68,68,.9)}
.gw2-mkCard-sentMeta{font-family:var(--mono);font-size:8px;color:rgba(205,220,255,.38);margin-top:3px}
.gw2-mkCard-nbBtn{
  margin-top:8px;width:100%;
  display:inline-flex;align-items:center;justify-content:center;gap:5px;
  padding:5px 8px;border-radius:6px;
  border:1px solid rgba(68,241,255,.30);
  background:rgba(68,241,255,.08);color:#9ff3ff;
  font-family:inherit;font-size:9px;font-weight:700;letter-spacing:.06em;
  cursor:pointer;transition:border-color .14s,background .14s,color .14s;
}
.gw2-mkCard-nbBtn:hover{border-color:rgba(68,241,255,.55);background:rgba(68,241,255,.14);color:#fff}
.gw2-mkCard-nbBtn svg{width:11px;height:11px}

/* ── Alpha View — super admin portfolio dashboard ───────────────────────── */
.gw2-alphaDash{
  width:min(1120px, calc(100% - 24px));
  max-height:min(86vh, 880px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border:1px solid rgba(68,241,255,.22);
  border-radius:14px;
  background:linear-gradient(150deg,rgba(8,11,22,.96),rgba(5,7,14,.94));
  box-shadow:0 22px 70px rgba(0,0,0,.58);
  backdrop-filter:blur(6px);
}
.gw2-alphaHead{
  flex:0 0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:12px 16px 10px;
  border-bottom:1px solid rgba(156,180,255,.10);
}
.gw2-alphaKicker{font-family:var(--mono);font-size:9px;letter-spacing:.16em;color:rgba(68,241,255,.82)}
.gw2-alphaTitle{margin-top:3px;font-family:var(--mono);font-size:17px;font-weight:700;color:#ffffff}
.gw2-alphaNav{display:flex;flex-wrap:wrap;justify-content:center;gap:3px}
.gw2-alphaNav .gw2-modeBtn{font-size:10px;padding:5px 9px}
.gw2-alphaNav .gw2-modeBtn[disabled]{cursor:default;opacity:1}
/* SUPERINVESTORS button — extension of Alpha View, gold accent to match the
   ALPHA VIEW pill on the destination page so users see the visual continuity. */
.gw2-alphaNav .gw2-modeBtn--si{
  background:rgba(200,155,60,.10);
  border-color:rgba(200,155,60,.32);
  color:#c89b3c;
}
.gw2-alphaNav .gw2-modeBtn--si:hover{
  background:rgba(200,155,60,.20);
  border-color:rgba(200,155,60,.55);
  color:#e2b758;
}
.gw2-alphaToggles{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px}
.gw2-alphaEye{
  appearance:none;border:1px solid rgba(68,241,255,.25);border-radius:8px;
  background:rgba(68,241,255,.08);color:rgba(220,252,255,.95);
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;padding:6px 9px;cursor:pointer;
}
.gw2-alphaEye[aria-pressed="true"]{background:rgba(255,209,102,.16);border-color:rgba(255,209,102,.45);color:#ffe7b3}
.gw2-alphaEye:disabled{opacity:.5;cursor:default}
.gw2-alphaMeta{
  flex:0 0 auto;
  padding:7px 16px;font-family:var(--mono);font-size:10px;line-height:1.5;
  color:#ffffff;border-bottom:1px solid rgba(156,180,255,.06);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.gw2-alphaBody{flex:1 1 auto;min-height:0;overflow:auto;padding:14px 16px 18px}

.gw2-alphaKpis,.gw2-alphaKpis2{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
/* Financial strip holds 7 cards (USD, NGN, FX G/L, Cost, P/L, Today, YTD). A
   7-col grid keeps them on ONE row on wide screens; drop to 4 cols (4+3, no
   orphan) at mid widths, then 2 on phones. Tiles are a touch tighter so seven
   fit comfortably. */
.gw2-alphaKpis{grid-template-columns:repeat(7,1fr)}
.gw2-alphaKpis2{margin-top:10px}
@media (max-width:1400px){.gw2-alphaKpis{grid-template-columns:repeat(4,1fr)}}
@media (max-width:1100px){.gw2-alphaKpis2{grid-template-columns:repeat(3,1fr)}}
@media (max-width:620px){.gw2-alphaKpis,.gw2-alphaKpis2{grid-template-columns:repeat(2,1fr)}}
.gw2-alphaKpi{
  border:1px solid rgba(156,180,255,.12);border-radius:11px;padding:10px 11px;min-width:0;
  background:linear-gradient(160deg,rgba(255,255,255,.035),rgba(255,255,255,.012));
}
.gw2-alphaKpiLbl{font-family:var(--mono);font-size:8.5px;letter-spacing:.11em;text-transform:uppercase;color:#ffffff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gw2-alphaKpiVal{margin-top:6px;font-family:var(--mono);font-size:17px;font-weight:700;color:#ffffff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gw2-alphaKpiSub{margin-top:4px;font-family:var(--mono);font-size:10px;color:#ffffff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* The leading % change in a KPI sub-line is the headline metric — make it pop
   (larger + bolder) so it reads at a glance instead of hiding in the caption. */
.gw2-alphaKpiSub > span.is-pos:first-child,
.gw2-alphaKpiSub > span.is-neg:first-child{
  font-size:14px;font-weight:800;letter-spacing:.01em;
}
.gw2-alphaKpiVal.is-pos,.gw2-alphaKpiSub.is-pos,.gw2-alphaTable td.is-pos,.is-pos{color:#5be4a5}
.gw2-alphaKpiVal.is-neg,.gw2-alphaKpiSub.is-neg,.gw2-alphaTable td.is-neg,.is-neg{color:#ff6b8b}

.gw2-alphaCharts{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:10px}
.gw2-alphaChartSpan2{grid-column:span 2}
@media (max-width:1240px){
  .gw2-alphaCharts{grid-template-columns:repeat(2,1fr)}
  .gw2-alphaChartSpan2{grid-column:1/-1}
}
@media (max-width:760px){
  .gw2-alphaCharts{grid-template-columns:1fr}
  .gw2-alphaChartSpan2{grid-column:auto}
}
.gw2-alphaChartCard{
  border:1px solid rgba(156,180,255,.12);border-radius:11px;padding:10px 12px;
  background:rgba(255,255,255,.02);
}
.gw2-alphaChartHd{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(68,241,255,.78);margin-bottom:6px}
.gw2-alphaChartHint{font-size:8px;letter-spacing:.04em;text-transform:none;color:#ffffff;margin-left:6px}
.gw2-alphaChartBox{position:relative;height:172px}
/* Canvas is taken out of flow so its size can never feed back into the CSS
   grid column width — that feedback caused a Chart.js resize loop (flicker). */
.gw2-alphaChartBox>canvas{position:absolute;top:0;left:0}
.gw2-alphaChartWide{grid-column:1/-1}
.gw2-alphaChartBox--bar{height:230px}
.gw2-alphaChartBox--bench{height:470px}
@media (max-width:760px){.gw2-alphaChartBox--bench{height:400px}}

/* ── Alpha View — benchmark comparison table ──────────────────────────────── */
.gw2-alphaTable tr.gw2-alphaBenchYou td{background:rgba(255,209,102,.13);font-weight:700}
.gw2-alphaTable tr.gw2-alphaBenchYou td:first-child{box-shadow:inset 2px 0 0 #ffd166}
.gw2-alphaBenchFlag{margin-right:7px;font-size:13px}
.gw2-alphaBenchCountry{display:block;font-weight:400;font-size:9px;color:#ffffff;opacity:.85}

.gw2-alphaSubHd{
  margin:16px 0 8px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:rgba(68,241,255,.82);
  display:flex;align-items:baseline;gap:10px;
}
.gw2-alphaCurNote{font-size:10px;letter-spacing:.06em;text-transform:none;color:#ffffff}
.gw2-alphaTableWrap{
  overflow:auto;border:1px solid rgba(156,180,255,.10);border-radius:10px;
  background:linear-gradient(180deg,rgba(8,12,22,.56),rgba(8,12,22,.36));
}
.gw2-alphaTable{
  width:100%;border-collapse:separate;border-spacing:0;min-width:720px;
  font-family:var(--mono);font-size:10.5px;line-height:1.35;
}
.gw2-alphaTable th,.gw2-alphaTable td{
  border-bottom:1px solid rgba(156,180,255,.07);padding:6px 8px;text-align:left;white-space:nowrap
}
.gw2-alphaTable th{
  position:sticky;top:0;z-index:1;background:rgba(10,14,24,.985);color:rgba(68,241,255,.88);
  font-size:8px;letter-spacing:.12em;text-transform:uppercase
}
.gw2-alphaTable td{color:#ffffff}
/* Click-to-sort headers (all AlphaView tables). */
.gw2-alphaTable th.gw2-sortable{cursor:pointer;user-select:none;-webkit-user-select:none;white-space:nowrap}
.gw2-alphaTable th.gw2-sortable:hover{color:#fff;background:rgba(68,241,255,.12)}
.gw2-alphaTable th.gw2-sortable::after{content:"\2195";opacity:.28;margin-left:4px;font-size:.85em}
.gw2-alphaTable th.is-sortAsc::after{content:"\25B2";opacity:.95;color:#44f1ff}
.gw2-alphaTable th.is-sortDesc::after{content:"\25BC";opacity:.95;color:#44f1ff}
.gw2-alphaTable tbody tr:hover td{background:rgba(68,241,255,.045)}
.gw2-alphaTable .gw2-r{text-align:right;font-variant-numeric:tabular-nums}
.gw2-alphaTable td.is-money{color:rgba(255,235,195,.95);font-weight:700}
.gw2-alphaTk{color:#ffffff;font-weight:800;font-size:13px;letter-spacing:.03em;min-width:0}

/* ── Pulse — valuation + momentum snapshot table ──────────────────────────── */
.gw2-pulseWrap{margin-bottom:4px}
.gw2-pulseLoading{padding:22px 14px;text-align:center;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.55)}
.gw2-pulseTable{min-width:760px}
.gw2-pulseTable .gw2-pulseR{text-align:right;font-variant-numeric:tabular-nums}
.gw2-pulseTable th.gw2-pulseR{text-align:right}
.gw2-pulseTk{color:#fff;font-weight:800;font-size:12px;letter-spacing:.03em}
.gw2-pulseNm{color:rgba(240,245,255,.92);max-width:230px;overflow:hidden;text-overflow:ellipsis}
.gw2-pulseSec{display:block;font-size:9px;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:1px}
.gw2-pulseMuted{color:rgba(255,255,255,.4)}
.gw2-pulseMuted2{color:rgba(255,255,255,.62)}
.gw2-pulseCap{color:rgba(255,235,195,.95);font-weight:700}
.gw2-pulseEmailBtn{cursor:pointer}
@media (max-width:640px){ .gw2-pulseTable{font-size:10px} }

/* ── Pulse — LEFT slide-in panel + LEFT launcher (mirrors Search/Alerts) ──── */
.gw2-pulsePanelRoot{position:fixed;inset:0;z-index:1196;visibility:hidden;pointer-events:none;
  font-family:var(--sans,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif)}
.gw2-pulsePanelRoot[data-open="true"]{visibility:visible;pointer-events:auto}
.gw2-pulseOverlay{position:absolute;inset:0;background:rgba(3,5,10,.46);
  backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);opacity:0;transition:opacity .26s ease}
.gw2-pulsePanelRoot[data-open="true"] .gw2-pulseOverlay{opacity:1}
.gw2-pulseSlide{
  position:absolute;top:0;left:0;bottom:0;width:54vw;max-width:820px;min-width:340px;
  display:flex;flex-direction:column;
  background:linear-gradient(168deg,rgba(12,16,26,.99),rgba(7,10,18,.995));
  border-right:1px solid rgba(156,180,255,.16);box-shadow:24px 0 60px rgba(0,0,0,.55);
  transform:translate3d(-102%,0,0);transition:transform .26s cubic-bezier(.22,.8,.2,1);will-change:transform}
.gw2-pulsePanelRoot[data-open="true"] .gw2-pulseSlide{transform:translate3d(0,0,0)}
@media (max-width:900px){ .gw2-pulseSlide{width:92vw;max-width:none} }
.gw2-pulseHead{display:flex;align-items:center;gap:11px;padding:15px 15px 13px;
  border-bottom:1px solid rgba(156,180,255,.08)}
.gw2-pulseHead-icon{font-size:18px;flex:0 0 auto}
.gw2-pulseHead-titles{display:flex;flex-direction:column;line-height:1.25;flex:1 1 auto;min-width:0}
.gw2-pulseHead-title{font-size:14px;font-weight:800;letter-spacing:.04em;color:#fff}
.gw2-pulseHead-sub{font-size:10.5px;color:rgba(255,255,255,.55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gw2-pulseHead .gw2-pulseEmailBtn{flex:0 0 auto}
.gw2-pulseClose{flex:0 0 auto;width:30px;height:30px;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;border:1px solid rgba(156,180,255,.14);
  background:rgba(8,12,22,.7);color:rgba(255,255,255,.6);transition:color .14s,border-color .14s,background .14s}
.gw2-pulseClose:hover{color:#fff;border-color:rgba(68,241,255,.5);background:rgba(68,241,255,.1)}
.gw2-pulseBody{flex:1 1 auto;overflow:auto;padding:12px 13px 16px}
.gw2-pulseBody .gw2-pulseWrap{margin:0}

/* LEFT launcher tab — orange, like the Search/Alerts launchers. */
.gw2-pulseFab{
  position:fixed;top:50%;left:0;transform:translateY(-50%);z-index:1188;
  display:flex;flex-direction:column;align-items:center;gap:7px;padding:13px 9px;cursor:pointer;
  border:1px solid rgba(255,255,255,.22);border-left:none;border-radius:0 12px 12px 0;
  background:linear-gradient(160deg,#e8761f,#c25910);color:#fff;
  box-shadow:6px 0 22px rgba(0,0,0,.4);transition:transform .16s ease,background .16s ease}
.gw2-pulseFab:hover{transform:translateY(-50%) translateX(3px);background:linear-gradient(160deg,#f4831f,#cf6311)}
.gw2-pulseFab svg{width:18px;height:18px}
.gw2-pulseFab-label{font-family:var(--mono,ui-monospace,Menlo,monospace);font-size:9px;font-weight:700;
  letter-spacing:.14em;writing-mode:vertical-rl;text-orientation:mixed;color:#fff}
.gw2-pulsePanelRoot[data-open="true"] ~ .gw2-pulseFab{opacity:0;pointer-events:none}
@media (max-width:640px){ .gw2-pulseFab{padding:11px 7px} .gw2-pulseFab-label{display:none} }
.gw2-alphaNm{
  display:block;font-weight:400;font-size:9px;line-height:1.25;color:#ffffff;
  max-width:180px;overflow:hidden;text-overflow:ellipsis
}
.gw2-alphaTable--dense{
  min-width:640px;font-size:11.5px;table-layout:fixed;
}
.gw2-alphaTable--dense th,
.gw2-alphaTable--dense td{padding:5px 7px}
.gw2-alphaTable--dense th:first-child,
.gw2-alphaTable--dense td:first-child{width:34%}
.gw2-alphaTable--dense .gw2-alphaTk,
.gw2-alphaTable--dense .gw2-alphaNm{
  display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.gw2-alphaTable--dense td{
  overflow:hidden;text-overflow:ellipsis;
}
.gw2-alphaTable--dense .gw2-r{
  letter-spacing:.01em;
}
.gw2-alphaTableWrap--dense{
  border-color:rgba(68,241,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}
.gw2-alphaSrc{margin-left:5px;font-size:8px;letter-spacing:.05em;color:rgba(255,209,102,.8);border:1px solid rgba(255,209,102,.3);border-radius:4px;padding:1px 3px}
.gw2-alphaSrc--bad{color:rgba(255,107,139,.95);border-color:rgba(255,107,139,.45)}
.gw2-alphaTable tr.gw2-alphaUnpriced td{opacity:.5}

.gw2-alphaWarn{
  margin-top:12px;border:1px solid rgba(255,209,102,.22);border-radius:10px;
  background:rgba(255,209,102,.05);padding:9px 13px;
  font-family:var(--mono);font-size:10px;color:rgba(255,225,170,.85);
}
.gw2-alphaWarn strong{display:block;letter-spacing:.12em;text-transform:uppercase;font-size:9px;margin-bottom:4px;color:rgba(255,209,102,.85)}
.gw2-alphaWarn ul{margin:0;padding-left:16px}
.gw2-alphaWarn li{margin:2px 0}

/* Privacy: blur every monetary span when armed */
/* Discreet soft-focus privacy screen (default on) — a light blur that reads as
   a stylistic dim, not a redaction bar. Hover a value to reveal it briefly. */
/* Privacy mask: heavy blur + low opacity + normalised width so the smudge
   reveals neither the digits nor the magnitude. A $200 figure and a $9M
   figure produce identically-sized smudges. Hover briefly clears it. */
.gw2-alphaDash.is-priv .gw2-amt{
  display:inline-block;
  min-width:140px;
  filter:blur(12px);opacity:.55;
  user-select:none;cursor:default;
  transition:filter .15s,opacity .15s,min-width .15s;
}
/* Sub-text amounts (smaller font) get a narrower fixed mask so they still
   fit on the line, but stay uniform across cards regardless of value. */
.gw2-alphaDash.is-priv .gw2-alphaKpiSub .gw2-amt,
.gw2-alphaDash.is-priv .gw2-alphaTable .gw2-amt{min-width:80px}
/* Hover/clear: snap back to natural width so the real number aligns nicely. */
.gw2-alphaDash.is-priv .gw2-amt:hover{filter:blur(0);opacity:1;min-width:0}

.gw2-alphaError{padding:18px 14px 24px;color:rgba(255,150,170,.92);font-family:var(--mono);font-size:12px}
.gw2-alphaModeBtn{border:1px solid rgba(201,162,39,.24);color:rgba(255,235,195,.9)}

/* ── Alpha View — Top Movers heatmap (gainers vs losers, sized by P/L %) ──
   Two squarified treemaps; reuses the same algorithm as the NGX Top Movers
   view. Each tile is sized by |unrealised P/L %| so the strongest mover is
   the biggest square. */
.gw2-alphaMovers{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gw2-alphaMoversCol{
  display:flex;flex-direction:column;
  border:1px solid rgba(156,180,255,.12);border-radius:11px;
  overflow:hidden;background:rgba(255,255,255,.02);
}
.gw2-alphaMoversHd{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;
  font-family:var(--mono);font-size:10px;font-weight:700;
  letter-spacing:.10em;text-transform:uppercase;
  border-bottom:1px solid rgba(156,180,255,.10);
  background:rgba(10,14,24,.55);
}
.gw2-alphaMoversHd--up{color:#5be4a5}
.gw2-alphaMoversHd--dn{color:#ff6b8b}
.gw2-alphaMoversCount{margin-left:auto;font-size:9px;color:#ffffff;letter-spacing:.06em}
.gw2-alphaHeatBox{
  position:relative;width:100%;height:300px;
  background:rgba(4,6,12,.55);
}
.gw2-alphaHeatBox--tall{height:440px}
@media (max-width:760px){.gw2-alphaHeatBox--tall{height:340px}}
.gw2-alphaHeatEmpty{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:10px;letter-spacing:.05em;color:#ffffff;
  text-align:center;padding:0 14px;
}
.gw2-alphaHeatTile{
  position:absolute;box-sizing:border-box;
  border:1px solid rgba(4,6,12,.7);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;text-align:center;
  transition:filter .1s,outline-color .1s;
  outline:1px solid transparent;outline-offset:-2px;
}
.gw2-alphaHeatTile:hover{filter:brightness(1.18);outline-color:rgba(255,255,255,.65);z-index:3}
.gw2-alphaHeatSym{font-weight:800;color:#fff;line-height:1.05;text-shadow:0 1px 2px rgba(0,0,0,.6)}
.gw2-alphaHeatPct{font-weight:700;color:#ffffff;line-height:1.1;text-shadow:0 1px 2px rgba(0,0,0,.6)}

/* ── Alpha View — copy-as-image button on every chart / card ──────────────── */
.gw2-alphaChartCard,.gw2-alphaKpi,.gw2-alphaMoversCol{position:relative;min-width:0}
.gw2-alphaCopyBtn{
  position:absolute;top:7px;right:7px;z-index:5;
  width:25px;height:25px;padding:0;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(68,241,255,.30);border-radius:7px;
  background:rgba(8,14,26,.92);color:#fff;cursor:pointer;
  opacity:0;transition:opacity .14s ease,background .14s ease,transform .1s ease;
}
.gw2-alphaCopyBtn svg{width:13px;height:13px}
.gw2-alphaCopyBtn:hover{background:rgba(68,241,255,.20);border-color:rgba(68,241,255,.55)}
.gw2-alphaCopyBtn:active{transform:scale(.92)}
.gw2-alphaChartCard:hover .gw2-alphaCopyBtn,
.gw2-alphaKpi:hover .gw2-alphaCopyBtn,
.gw2-alphaMoversCol:hover .gw2-alphaCopyBtn,
.gw2-alphaCopyBtn:focus-visible{opacity:1}
@media (hover:none){.gw2-alphaCopyBtn{opacity:.85}}

/* ── Alpha View — Portfolio Value range selector (1D…ALL) ─────────────────── */
.gw2-alphaRange{display:flex;flex-wrap:wrap;gap:4px;margin:2px 0 8px}
.gw2-alphaRangeBtn{
  appearance:none;cursor:pointer;
  font-family:var(--mono);font-size:9px;letter-spacing:.06em;
  padding:4px 9px;border-radius:6px;
  border:1px solid rgba(156,180,255,.18);
  background:rgba(255,255,255,.03);color:#ffffff;
  transition:background .12s ease,border-color .12s ease;
}
.gw2-alphaRangeBtn:hover{background:rgba(68,241,255,.10);border-color:rgba(68,241,255,.35)}
.gw2-alphaRangeBtn.is-active{
  background:rgba(68,241,255,.16);border-color:rgba(68,241,255,.6);
  color:#ffffff;font-weight:700;
}

/* ── Alpha View — Day Movers heatmap (top 5 gainers / losers) ──────────────────
 * Compact square-tile grid above the Performance section. Mirrors the NGX
 * indices heatmap: uniform tiles, coloured by the 1-day move. */
/* Two stacked rows — gainers group above losers group — each a card. */
.gw2-alphaDayHeatWrap{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.gw2-alphaDayHeatGroup{padding:0}
.gw2-alphaDayHeatGroup .gw2-alphaDayHeat{padding:8px;margin-bottom:0}
.gw2-alphaDayHeat{
  position:relative;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(148px,1fr));
  gap:6px;
  margin-bottom:18px;
}
.gw2-alphaDayHeatEmpty{
  grid-column:1/-1;padding:14px 4px;
  font-family:var(--mono);font-size:.62rem;color:var(--muted);
}
.gw2-alphaDayHeatTile{
  position:relative;
  display:flex;flex-direction:column;justify-content:space-between;gap:6px;
  min-height:124px;padding:11px 12px;
  border:1px solid rgba(4,6,12,.55);border-radius:9px;
  cursor:pointer;overflow:hidden;
  outline:1px solid transparent;outline-offset:-2px;
  transition:filter .12s ease,outline-color .12s ease;
}
.gw2-alphaDayHeatTile:hover{filter:brightness(1.15);outline-color:rgba(255,255,255,.5)}
/* Live P/E pinned top-right; fades out on hover so the copy button owns the corner. */
.gw2-alphaDayHeatTile-pe{
  position:absolute;top:9px;right:11px;z-index:3;
  font-family:var(--mono);font-size:.62rem;font-weight:700;
  font-variant-numeric:tabular-nums;letter-spacing:.02em;
  color:rgba(255,255,255,.92);text-shadow:0 1px 2px rgba(0,0,0,.55);
  transition:opacity .14s ease;pointer-events:none;
}
.gw2-alphaDayHeatTile-pe span{font-size:.5rem;font-weight:700;letter-spacing:.06em;opacity:.6;margin-right:2px}
.gw2-alphaDayHeatTile:hover .gw2-alphaDayHeatTile-pe{opacity:0}
/* Per-tile copy-as-image button — same cyan branding as .gw2-alphaCopyBtn. */
.gw2-alphaTileCopy{
  position:absolute;top:6px;right:6px;z-index:4;
  width:20px;height:20px;padding:0;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(68,241,255,.30);border-radius:6px;
  background:rgba(8,14,26,.82);color:#fff;cursor:pointer;
  opacity:0;transition:opacity .14s ease,background .14s ease,transform .1s ease;
}
.gw2-alphaTileCopy svg{width:11px;height:11px}
.gw2-alphaTileCopy:hover{background:rgba(68,241,255,.22);border-color:rgba(68,241,255,.55)}
.gw2-alphaTileCopy:active{transform:scale(.9)}
.gw2-alphaDayHeatTile:hover .gw2-alphaTileCopy,
.gw2-alphaTileCopy:focus-visible{opacity:1}
@media (hover:none){.gw2-alphaTileCopy{opacity:.8}}
.gw2-alphaDayHeatTile-sym{
  font-family:var(--mono);font-size:1rem;font-weight:800;letter-spacing:.04em;
  color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.55);
}
.gw2-alphaDayHeatTile-name{
  font-size:.58rem;font-weight:600;margin-top:3px;
  color:rgba(255,255,255,.82);text-shadow:0 1px 2px rgba(0,0,0,.45);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
/* Real-time position chip above each tile — today's P/L (USD) + day % for the
   actual holding. Dark translucent pill so it reads on green/red tiles. */
.gw2-alphaTileChip{
  display:inline-flex;align-items:center;gap:5px;margin-bottom:4px;
  padding:2px 7px;border-radius:999px;
  /* reserve the top-right corner for the P/E badge so the two never overlap */
  max-width:calc(100% - 40px);overflow:hidden;
  font-family:var(--mono);font-size:.54rem;font-weight:700;line-height:1.3;
  font-variant-numeric:tabular-nums;letter-spacing:.02em;white-space:nowrap;
  color:#fff;background:rgba(4,8,16,.5);border:1px solid rgba(255,255,255,.20);
  text-shadow:0 1px 2px rgba(0,0,0,.5);
}
.gw2-alphaTileChip-amt{font-weight:800}
.gw2-alphaTileChip-pct{opacity:.85}
.gw2-alphaTileChip.is-pos{border-color:rgba(91,228,165,.55);background:rgba(13,66,46,.5)}
.gw2-alphaTileChip.is-pos .gw2-alphaTileChip-amt{color:#bff3da}
.gw2-alphaTileChip.is-neg{border-color:rgba(255,120,140,.5);background:rgba(78,18,28,.5)}
.gw2-alphaTileChip.is-neg .gw2-alphaTileChip-amt{color:#ffc9d2}
/* Narrow privacy mask for the tiny chip amount (the default 140px mask is far
   too wide for a tile). Blurs under AMOUNTS privacy; clears on hover. */
.gw2-alphaDash.is-priv .gw2-alphaTileChip .gw2-amt{min-width:42px;filter:blur(6px)}
.gw2-alphaDash.is-priv .gw2-alphaTileChip .gw2-amt:hover{min-width:0;filter:blur(0)}
/* Price is the hero figure (Yahoo/Google quote convention); the % change is
   the smaller secondary line. Tabular numerals keep columns aligned. */
.gw2-alphaDayHeatTile-px{
  font-family:var(--mono);font-size:1.2rem;font-weight:700;line-height:1.12;
  font-variant-numeric:tabular-nums;letter-spacing:.01em;
  color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.55);
}
.gw2-alphaDayHeatTile-pct{
  font-family:var(--mono);font-size:.82rem;font-weight:700;margin-top:2px;
  font-variant-numeric:tabular-nums;
  color:rgba(255,255,255,.92);text-shadow:0 1px 2px rgba(0,0,0,.5);
}
.gw2-alphaDayHeatTile-cap{
  font-family:var(--mono);font-size:.64rem;font-weight:700;margin-top:4px;
  font-variant-numeric:tabular-nums;letter-spacing:.02em;
  color:rgba(255,255,255,.9);text-shadow:0 1px 2px rgba(0,0,0,.5);
}
.gw2-alphaDayHeatTile-cap span{
  font-size:.52rem;font-weight:700;letter-spacing:.08em;
  opacity:.62;margin-right:3px;
}

/* ── Alpha View — Day Movers (1D price change) ────────────────────────────── */
.gw2-alphaDayMovers{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:760px){.gw2-alphaDayMovers{grid-template-columns:1fr}}
.gw2-alphaChartHd.gw2-alphaDayHd--up{color:#5be4a5}
.gw2-alphaChartHd.gw2-alphaDayHd--dn{color:#ff6b8b}
.gw2-alphaDayList{display:flex;flex-direction:column;gap:1px;margin-top:2px}
.gw2-alphaDayHead{
  display:flex;align-items:center;gap:9px;
  padding:5px 7px;margin-bottom:2px;
  border-bottom:1px solid rgba(156,180,255,.16);
}
.gw2-alphaDayHead span{
  font-family:var(--mono);font-size:8px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:#ffffff;
}
.gw2-alphaDayRow{
  display:flex;align-items:center;gap:9px;
  padding:6px 7px;border-radius:7px;cursor:pointer;
  font-family:var(--mono);
}
.gw2-alphaDayRow:hover{background:rgba(68,241,255,.07)}
.gw2-alphaDayRank{flex:0 0 auto;width:16px;text-align:right;font-size:10px;color:#ffffff}
.gw2-alphaDayTk{flex:1 1 auto;min-width:0;font-size:14px;font-weight:700;color:#ffffff}
.gw2-alphaDayNm{display:block;font-weight:400;font-size:9px;color:#ffffff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gw2-alphaDayPx{flex:0 0 auto;width:78px;text-align:right;font-size:11px;color:#ffffff;font-variant-numeric:tabular-nums}
.gw2-alphaDayUsd{flex:0 0 auto;width:86px;text-align:right;font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;color:#ffffff}
.gw2-alphaDayUsd.is-pos{color:#5be4a5}
.gw2-alphaDayUsd.is-neg{color:#ff6b8b}
.gw2-alphaDayHead .gw2-alphaDayUsd{color:rgba(68,241,255,.78);font-weight:600}
.gw2-alphaDash.is-priv .gw2-alphaDayUsd .gw2-amt{min-width:54px;filter:blur(7px)}
.gw2-alphaDash.is-priv .gw2-alphaDayUsd .gw2-amt:hover{min-width:0;filter:blur(0)}
.gw2-alphaDayPct{flex:0 0 auto;width:72px;text-align:right;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums}
.gw2-alphaDayEmpty{padding:22px 12px;text-align:center;font-family:var(--mono);font-size:10px;color:#ffffff}

/* ── Alpha View — full-width dashboard mode ───────────────────────────────
   While Alpha View is open the Intel Brief + Advertisement/News panels are
   hidden and the dashboard fills the content area (Alerts panel stays). */
.gw2--alphaView .gw2-side,
.gw2--alphaView .gw2-newspanel{display:none}
.gw2--alphaView .gw2-grid,
.gw2--alphaView .gw2-globeHost,
.gw2--alphaView .gw2-modeBar,
.gw2--alphaView .gw2-hud,
.gw2--alphaView .gw2-fallback{display:none}
.gw2--alphaView #alphaViewDashboard{
  position:absolute;inset:10px;transform:none;animation:none;
  width:auto;height:auto;max-width:none;max-height:none;
}
@media (max-width:980px){
  .gw2--alphaView .gw2-globe{height:auto;min-height:86vh;flex:1 1 auto}
  .gw2--alphaView #alphaViewDashboard{inset:6px}
}

/* ── Alpha View — mobile responsiveness pass ──────────────────────────────
   The dashboard already collapses KPIs (4→2) and charts (2→1) at 760px.
   These rules tighten the header, table and heatmap for real phone widths. */
@media (max-width:760px){
  .gw2-alphaMovers{grid-template-columns:1fr}      /* gainers above losers */
  .gw2-alphaHeatBox{height:260px}
  .gw2-alphaDash{
    width:calc(100% - 12px);
    max-height:92vh;
    border-radius:12px;
  }
  .gw2-alphaHead{
    flex-wrap:wrap;gap:8px;padding:10px 12px 8px;
  }
  .gw2-alphaNav{width:100%;order:3;justify-content:flex-start}
  .gw2-alphaToggles{order:2}
  .gw2-alphaBody{padding:12px 10px 16px}
  .gw2-alphaChartBox{height:158px}
  .gw2-alphaChartBox--bar{height:210px}
  /* Holdings table keeps its dense layout but scrolls smoothly with momentum. */
  .gw2-alphaTableWrap{-webkit-overflow-scrolling:touch}
}
@media (max-width:440px){
  .gw2-alphaKpis{grid-template-columns:1fr}        /* one KPI per row on small phones */
  .gw2-alphaKpiVal{font-size:18px}
  .gw2-alphaTitle{font-size:15px}
  .gw2-alphaNav .gw2-modeBtn{font-size:9px;padding:4px 7px}
  .gw2-alphaHeatBox{height:230px}
}

/* ── Globe mode toggle bar ─────────────────────────────────────────────── */
.gw2-modeBar{
  position:absolute;
  top:12px;left:50%;transform:translateX(-50%);
  display:flex;gap:2px;
  background:rgba(6,8,12,.65);
  border:1px solid var(--stroke);
  border-radius:20px;
  padding:3px;
  backdrop-filter:blur(10px);
  z-index:10;
}
.gw2-modeBtn{
  padding:5px 14px;
  border-radius:16px;
  border:none;
  background:transparent;
  color:var(--muted);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background .15s,color .15s;
}
.gw2-modeBtn:hover{color:var(--text);background:rgba(68,241,255,.08)}
.gw2-modeBtn.is-active{background:rgba(68,241,255,.18);color:var(--cyan)}
.gw2-navBtn{
  padding:5px 10px;
  border-radius:16px;
  border:none;
  background:transparent;
  color:var(--muted);
  font-size:13px;
  line-height:1;
  cursor:pointer;
  transition:background .15s,color .15s;
}
.gw2-navBtn:hover{color:var(--text);background:rgba(68,241,255,.08)}
.gw2-navBtn:disabled{opacity:.28;cursor:default}

.gw2-hud{
  position:absolute;
  left:14px;bottom:14px;
  border:1px solid var(--stroke2);
  border-radius:16px;
  background:rgba(6,8,12,.55);
  padding:10px 12px;
  width:min(420px, calc(100% - 28px));
  backdrop-filter: blur(10px);
}
.gw2-hudRow{display:flex;gap:12px;align-items:baseline}
.gw2-hudRow + .gw2-hudRow{margin-top:6px}
.gw2-hudKey{width:54px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.gw2-hudVal{font-family:var(--mono);font-size:11px;color:rgba(240,245,255,.88)}
.gw2-kbd{
  display:inline-flex;
  padding:2px 6px;
  border-radius:8px;
  border:1px solid var(--stroke2);
  background:rgba(0,0,0,.25);
  font-family:var(--mono);
  font-size:11px;
}

/* ── Persistent marker popup ─────────────────────────────────────────────── */
.gw2-markerPopup{
  position:absolute;
  z-index:30;
  width:360px;
  background:linear-gradient(160deg, rgba(8,11,20,.97), rgba(6,8,15,.95));
  border:1px solid rgba(68,241,255,.3);
  border-radius:20px;
  padding:20px;
  box-shadow:0 28px 80px rgba(0,0,0,.75), 0 0 0 1px rgba(0,0,0,.4) inset;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  pointer-events:auto;
  /* Animate in */
  animation:popupIn .18s cubic-bezier(.22,1,.36,1);
}
.gw2-markerPopup[hidden]{display:none}
@keyframes popupIn{
  from{opacity:0;transform:scale(.92) translateY(6px)}
  to  {opacity:1;transform:scale(1)   translateY(0)}
}
.gw2-markerClose{
  position:absolute;top:12px;right:12px;
  appearance:none;
  border:1px solid rgba(156,180,255,.2);
  background:rgba(255,255,255,.06);
  color:rgba(205,220,255,.7);
  width:28px;height:28px;
  border-radius:50%;
  font-size:16px;line-height:1;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.gw2-markerClose:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(68,241,255,.4)}
.gw2-markerInner{display:flex;align-items:center;gap:18px}
.gw2-markerAvatar{
  flex-shrink:0;
  width:80px;height:80px;
  border-radius:50%;
  border:2px solid rgba(68,241,255,.35);
  background:rgba(68,241,255,.06);
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:18px;color:rgba(68,241,255,.6);
}
.gw2-markerAvatar img{width:100%;height:100%;object-fit:cover;display:block}
.gw2-markerInfo{flex:1;min-width:0}
.gw2-markerTicker{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(68,241,255,.9);margin-bottom:4px;
}
.gw2-markerName{
  font-size:15px;color:rgba(240,245,255,.95);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:12px;font-weight:500;
}
.gw2-markerPrice{
  font-family:var(--mono);font-size:26px;
  color:#fff;letter-spacing:-.01em;margin-bottom:5px;
}
.gw2-markerChange{font-family:var(--mono);font-size:13px}
.gw2-markerSentiment{
  margin-top:14px;
  padding:12px 12px 10px;
  border-radius:14px;
  border:1px solid rgba(156,180,255,.12);
  background:rgba(255,255,255,.03);
}
#sectorSentimentBlock{border-color:rgba(68,241,255,.18);background:rgba(68,241,255,.04)}
#marketSentimentBlock{border-color:rgba(250,204,21,.18);background:rgba(250,204,21,.04)}
.gw2-sentimentHead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.gw2-sentimentTitle{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(205,220,255,.72);
}
.gw2-sentimentMeta{font-family:var(--mono);font-size:10px;color:rgba(205,220,255,.55)}
.gw2-sentimentBar{
  height:10px;
  border-radius:999px;
  overflow:hidden;
  display:flex;
  background:rgba(156,180,255,.08);
  border:1px solid rgba(156,180,255,.10);
}
.gw2-sentimentSeg{height:100%;flex:0 0 auto}
.gw2-sentimentSeg.is-pos{background:rgba(34,197,94,.85)}
.gw2-sentimentSeg.is-neu{background:rgba(148,163,184,.70)}
.gw2-sentimentSeg.is-neg{background:rgba(239,68,68,.85)}
.gw2-sentimentLegend{
  margin-top:8px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  font-family:var(--mono);
  font-size:10px;
  color:rgba(205,220,255,.70);
}
.gw2-sentimentLeg{display:flex;align-items:center;gap:6px;white-space:nowrap}
.gw2-sentimentLeg .sw{width:8px;height:8px;border-radius:3px;display:inline-block}
.gw2-sentimentLeg.is-pos .sw{background:rgba(34,197,94,.9)}
.gw2-sentimentLeg.is-neu .sw{background:rgba(148,163,184,.85)}
.gw2-sentimentLeg.is-neg .sw{background:rgba(239,68,68,.9)}
.gw2-markerFooter{
  margin-top:16px;
  padding-top:12px;
  border-top:1px solid rgba(156,180,255,.1);
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.gw2-markerFooterNote{font-size:11px;color:var(--muted);font-family:var(--mono)}
.gw2-markerBtn{
  appearance:none;
  border:1px solid rgba(68,241,255,.28);
  background:rgba(68,241,255,.08);
  color:rgba(68,241,255,.95);
  padding:6px 14px;border-radius:10px;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;cursor:pointer;
}
.gw2-markerBtn:hover{background:rgba(68,241,255,.16)}

@media(max-width:640px){
  .gw2-markerPopup{width:calc(100% - 28px);left:14px!important;right:14px;transform:none!important}
  .gw2-modeBar{
    top:8px;
    z-index:35;
    max-width:calc(100% - 16px);
    overflow-x:auto;
    border-radius:14px;
    padding:2px;
    scrollbar-width:none;
  }
  .gw2-modeBar::-webkit-scrollbar{display:none}
  .gw2-modeBtn{
    padding:5px 8px;
    border-radius:12px;
    font-size:9px;
    letter-spacing:.08em;
    flex-shrink:0;
  }
  .gw2-navBtn{
    padding:5px 8px;
    border-radius:12px;
    flex-shrink:0;
  }
  .gw2-mkDash{
    top:48px;
    bottom:10px;
    transform:translateX(-50%);
    width:min(360px, calc(100% - 20px));
    max-height:calc(100% - 58px);
    overflow-y:auto;
    padding-right:2px;
  }
  .gw2-mkDashGrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:5px;
  }
  .gw2-mkDashGrid .gw2-mkCard:last-child:nth-child(3n+1){
    grid-column:auto;
  }
  .gw2-mkDashGrid .gw2-mkCard:last-child:nth-child(odd){
    grid-column:1 / -1;
    justify-self:center;
    width:calc((100% - 5px) / 2);
  }
  .gw2-mkCard{
    border-radius:8px;
    padding:6px 7px 5px;
  }
  .gw2-mkCard-head{gap:4px;margin-bottom:2px}
  .gw2-mkCard-label{font-size:7.5px;letter-spacing:.08em}
  .gw2-mkCard-cat{font-size:7px;letter-spacing:.06em}
  .gw2-mkCard-price{font-size:11px}
  .gw2-mkCard-chg{font-size:8.5px;margin-top:1px}
  .gw2-mkCard-bar{height:3px;margin-top:5px}
  .gw2-mkCard-sentMeta{font-size:7px;margin-top:2px}
  .gw2-alphaDash{
    width:calc(100% - 20px);
    max-height:calc(100% - 58px);
  }
  .gw2-alphaHead{
    align-items:flex-start;
    flex-direction:column;
    gap:8px;
    padding:9px 10px 8px;
  }
  .gw2-alphaTitle{font-size:13px}
  .gw2-alphaToggles{
    width:100%;
    justify-content:flex-start;
    gap:5px;
  }
  .gw2-alphaEye{
    font-size:9px;
    padding:5px 7px;
  }
  .gw2-alphaMeta{
    padding:7px 10px;
    font-size:9px;
  }
  .gw2-alphaTableWrap{
    max-height:calc(100% - 92px);
    padding:0 6px 8px;
  }
  .gw2-alphaTable{
    min-width:680px;
    font-size:10px;
  }
  .gw2-alphaTable th,
  .gw2-alphaTable td{
    padding:6px 7px;
  }
}

.gw2-fallback{
  position:absolute;left:14px;top:14px;right:14px;
  border:1px solid rgba(255,77,109,.25);
  background:rgba(24,8,12,.55);
  border-radius:16px;
  padding:12px 14px;
  display:none;
}
.gw2-fallbackTitle{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;font-size:11px;color:rgba(255,77,109,.95)}
.gw2-fallbackBody{margin-top:6px;color:rgba(240,245,255,.86);font-size:13px}

/* Command palette */
.gw2-cmdk{position:fixed;inset:0;z-index:50}
.gw2-cmdk[hidden]{display:none}
.gw2-cmdkOverlay{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.gw2-cmdkPanel{
  position:relative;
  margin:10vh auto 0;
  width:min(720px, calc(100% - 24px));
  border:1px solid var(--stroke);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(10,13,20,.95), rgba(8,10,16,.88));
  box-shadow: 0 25px 80px rgba(0,0,0,.65);
  padding:12px;
}
.gw2-cmdkHeader{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.gw2-cmdkTitle{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;font-size:11px;color:rgba(240,245,255,.86)}
.gw2-input{
  width:100%;
  border-radius:14px;
  border:1px solid var(--stroke2);
  background:rgba(6,8,12,.55);
  padding:12px 12px;
  color:var(--text);
  font-family:var(--mono);
  letter-spacing:.02em;
  outline:none;
}
.gw2-input:focus{border-color:rgba(68,241,255,.36);box-shadow:0 0 0 3px rgba(68,241,255,.12)}
.gw2-cmdkList{
  margin-top:10px;
  max-height:42vh;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-right:4px;
}
.gw2-result{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  border:1px solid var(--stroke2);
  background:rgba(6,8,12,.45);
  border-radius:14px;
  padding:10px 10px;
  cursor:pointer;
}
.gw2-result:hover{border-color:rgba(68,241,255,.28)}
.gw2-result .l{min-width:0}
.gw2-result .t{font-family:var(--mono);font-size:12px;letter-spacing:.06em}
.gw2-result .n{margin-top:3px;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gw2-result .r{font-family:var(--mono);font-size:10px;color:rgba(68,241,255,.85);letter-spacing:.12em;text-transform:uppercase}
.gw2-cmdkHint{margin-top:10px;font-family:var(--mono);font-size:11px;letter-spacing:.02em}

/* ── Tablet / small laptop (≤ 980px) ────────────────────────────── */
@media (max-width: 980px){
  body{overflow:auto}
  html,body{height:auto;min-height:100%}
  .gw2{height:auto;min-height:100vh}

  /* Switch to vertical stack */
  .gw2-main{flex-direction:column}

  /* Globe first — centred hero */
  .gw2-globe{
    flex:none;
    height:62vh;
    min-height:300px;
    order:1;
  }

  /* Alerts panel below globe */
  .gw2-leftside{
    width:100%;
    border-right:none;
    border-top:1px solid var(--stroke2);
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    order:2;
  }
  .gw2-leftside .gw2-sideScroll{max-height:420px}

  /* Intel brief panel last */
  .gw2-side{
    width:100%;
    border-left:none;
    border-top:1px solid var(--stroke2);
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    order:3;
  }
  .gw2-side .gw2-sideScroll{max-height:600px}

  /* News panel: keep the desktop 2-column card grid on smaller screens */
  .gw2-newspanel{
    width:100%;
    border-left:none;
    border-top:1px solid var(--stroke2);
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    order:4;
  }
  .gw2-adBanner{min-height:274px}
  .gw2-newsChannels{
    grid-template-columns:repeat(2,minmax(0,1fr));
    overflow:visible;
    padding:12px;
  }
  .gw2-newsEmbed{
    padding-top:100%;
  }

  /* HUD overlaps globe on narrow screens — hide it */
  .gw2-hud{display:none}

  .gw2-searchWrap{width:min(480px, 42vw)}
  /* iOS Safari auto-zoom prevention — search input font-size must be ≥ 16px */
  .gw2-searchInput{font-size:16px}
}

/* ── Mobile phones (≤ 640px) ─────────────────────────────────────── */
@media (max-width: 640px){
  /* Topbar: two-row layout — logo row + navlinks row */
  .gw2-topbar{
    height:auto;
    flex-wrap:wrap;
    padding:10px 12px 8px;
    gap:0;
    align-items:center;
    justify-content:flex-start;
  }
  /* Brand row: hamburger stays left, logo absolutely centred in the full width */
  .gw2-brand{
    min-width:0;
    flex:0 0 100%;
    position:relative;
    display:flex;
    align-items:center;
    gap:8px;
    padding-bottom:10px;
    border-bottom:1px solid rgba(255,255,255,.06);
    margin-bottom:10px;
  }
  .gw2-brandLink{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    padding:7px 10px;
    border-radius:12px;
  }
  .gw2-brandLogo{height:22px}
  /* Menu panel fills full width on mobile */
  .gw2-menu{width:100%;max-width:300px}

  /* Actions row — centred and scrolls horizontally on very small screens */
  .gw2-actions{
    width:100%;
    gap:6px;
    justify-content:center;
    overflow-x:auto;
    overflow-y:visible;
    padding-bottom:2px;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }
  .gw2-actions::-webkit-scrollbar{display:none}
  .gw2-tabs{flex-shrink:0;gap:4px}
  .gw2-tab{height:28px;padding:0 8px;font-size:10px;border-radius:10px}

  /* Hide inline search bar — Search button opens palette */
  .gw2-searchWrap{display:none}
  .gw2-btn{padding:6px 10px;font-size:10px;flex-shrink:0}
  /* Alert search — full width, slightly larger touch targets */
  .gw2-alertSearchInput{font-size:16px} /* prevent iOS auto-zoom */
  .gw2-alertSearchBar{padding:6px 10px 8px}

  /* Shorter globe on phones */
  .gw2-globe{height:38vh;min-height:200px}

  /* Tighter panel padding */
  .gw2-sideHeader{padding:14px 14px 10px}
  .gw2-alertCard{margin:0 10px 8px}
  .gw2-card{margin:10px 10px 0}

  /* Hide inline alert tabs on mobile — use hamburger menu instead */
  .gw2-alertTabs{display:none}

  .gw2-leftside .gw2-sideScroll{max-height:340px}
  .gw2-side .gw2-sideScroll{max-height:480px}
  .gw2-newsChannels{gap:8px;padding:10px}
  .gw2-newsLabel{font-size:9px}

  /* TV chart smaller on phones */
  .gw2-tv{height:180px}

  .gw2-wlDash{
    padding:6px 6px 8px;
  }
  .gw2-wlSignIn{
    padding:18px 12px;
  }
  .gw2-wlSignInTitle{
    font-size:.8rem;
    margin-bottom:6px;
  }
  .gw2-wlSignInBody{
    font-size:.7rem;
    line-height:1.4;
    margin-bottom:12px;
  }
  .gw2-wlSignInBtns{
    gap:6px;
  }
  .gw2-wlSignInBtn{
    font-size:.68rem;
    padding:6px 10px;
  }
  .gw2-wlGrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:5px;
    margin-bottom:6px;
  }
  .gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+1),
  .gw2-wlGrid > .gw2-wlCard:nth-last-child(2):nth-child(4n+1),
  .gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+2),
  .gw2-wlGrid > .gw2-wlCard:nth-last-child(3):nth-child(4n+1),
  .gw2-wlGrid > .gw2-wlCard:nth-last-child(2):nth-child(4n+2),
  .gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+3){
    grid-column:auto;
  }
  .gw2-wlGrid > .gw2-wlCard:last-child:nth-child(odd){
    grid-column:1 / -1;
    justify-self:center;
    width:calc((100% - 5px) / 2);
  }
  .gw2-wlCard{
    border-radius:6px;
    padding:7px 8px;
  }
  .gw2-wlCardTop{
    margin-bottom:4px;
  }
  .gw2-wlTicker{font-size:.95rem}
  .gw2-wlName{font-size:.58rem;line-height:1.2}
  .gw2-wlRemove{font-size:.9rem;padding:1px 3px}
  .gw2-wlPrice{font-size:.78rem;margin-bottom:4px}
  .gw2-wlLabel{font-size:.56rem}
  .gw2-wlVal{font-size:.64rem}
  .gw2-wlAddRow{
    padding:6px 8px 8px;
    gap:6px;
  }
  .gw2-wlAddBtn{
    font-size:.65rem;
    padding:5px 9px;
  }
  .gw2-wlCount,
  .gw2-wlFull{
    font-size:.62rem;
  }

  /* iOS Safari auto-zoom prevention — any focused input < 16px triggers zoom */
  .gw2-authInput,
  .gw2-wlAddInput,
  .gw2-input{font-size:16px}
}

/* ═══════════════════════════════════════════════════════════════════════════
   AUTH GATE — full-screen entry wall, shown until user authenticates
   ═══════════════════════════════════════════════════════════════════════════ */
.gw2-authGate{
  position:fixed;inset:0;
  z-index:9000;
  display:flex;
  background:#05080f;
  overflow:hidden;
}
.gw2-authGate[hidden]{display:none!important}

/* Left branding panel */
.gw2-gateLeft{
  flex:0 0 42%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  padding:56px 40px;
  background:linear-gradient(160deg,#060c1e 0%,#08122a 60%,#030710 100%);
  border-right:1px solid rgba(68,241,255,.08);
  position:relative;
  overflow:hidden;
}
/* Subtle grid overlay on left panel */
.gw2-gateLeft::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(68,241,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(68,241,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
  pointer-events:none;
}
/* Cyan radial glow centred */
.gw2-gateLeft::after{
  content:'';
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:560px;height:560px;
  background:radial-gradient(circle,rgba(68,241,255,.07) 0%,transparent 68%);
  pointer-events:none;
}

.gw2-gateBrand{
  display:flex;align-items:center;justify-content:center;
  margin-bottom:44px;
  position:relative;z-index:1;
}
.gw2-gateLogo{
  display:block;
  width:auto;
  height:48px;
  max-width:min(100%, 260px);
  padding:10px 16px;
  border:1px solid rgba(68,241,255,.12);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(8,14,27,.82), rgba(5,10,18,.68));
  box-shadow:0 18px 50px rgba(0,0,0,.22), 0 0 0 1px rgba(68,241,255,.04) inset;
}

.gw2-gateTagline{
  margin-bottom:32px;
  position:relative;z-index:1;
  max-width:360px;
}
.gw2-gateTaglineHead{
  font-size:1.85rem;font-weight:800;
  line-height:1.18;
  color:#e2eaff;
  letter-spacing:-.01em;
  margin-bottom:14px;
}
.gw2-gateTaglineBody{
  font-size:.82rem;color:rgba(180,190,220,.65);line-height:1.65;
  max-width:340px;
}

.gw2-gateFeatures{
  list-style:none;padding:0;margin:0 0 32px;
  position:relative;z-index:1;
  width:100%;max-width:320px;
}
.gw2-gateFeatures li{
  display:flex;align-items:center;gap:10px;
  font-size:.78rem;color:rgba(180,190,220,.7);
  padding:7px 0;
  border-bottom:1px solid rgba(68,241,255,.05);
}
.gw2-gateFeatures li:last-child{border-bottom:none}
.gw2-gateDot{
  width:6px;height:6px;border-radius:50%;
  background:var(--cyan);flex-shrink:0;
  box-shadow:0 0 6px rgba(68,241,255,.6);
}
.gw2-gateFree{
  font-size:.72rem;letter-spacing:.08em;
  color:rgba(68,241,255,.45);
  font-family:var(--mono);
  position:relative;z-index:1;
}

/* Right form panel */
.gw2-gateRight{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  padding:48px 40px;
  background:#06090f;
  overflow-y:auto;
}

.gw2-gateCard{
  width:100%;
  max-width:400px;
  background:#0b1020;
  border:1px solid rgba(68,241,255,.13);
  border-radius:12px;
  padding:32px 30px 28px;
  box-shadow:0 24px 64px rgba(0,0,0,.55);
}

.gw2-gateDisclaimer{
  margin-top:20px;
  font-size:.67rem;color:rgba(120,135,165,.45);
  text-align:center;line-height:1.6;
  max-width:380px;
}

/* ── Shared auth form pieces (used inside gate card) ────────────────────── */

/* Tabs */
.gw2-authTabs{
  display:flex;gap:4px;
  margin-bottom:24px;
  border-bottom:1px solid rgba(68,241,255,.1);
  padding-bottom:14px;
}
.gw2-authTabBtn{
  background:none;border:none;cursor:pointer;
  font-size:.8rem;font-weight:700;letter-spacing:.06em;
  color:rgba(180,190,220,.45);padding:7px 18px;border-radius:5px;
  transition:color .15s,background .15s;
}
.gw2-authTabBtn:hover{color:#e2eaff;background:rgba(255,255,255,.05)}
.gw2-authTabBtn.is-active{
  color:var(--cyan);
  background:rgba(68,241,255,.1);
  border:1px solid rgba(68,241,255,.18);
}

/* Fields */
.gw2-authField{margin-bottom:16px}
.gw2-authLabel{
  display:block;margin-bottom:6px;
  font-size:.71rem;letter-spacing:.07em;color:rgba(180,190,220,.6);
  font-family:var(--mono);text-transform:uppercase;
}
.gw2-authHint{
  font-size:.67rem;color:rgba(180,190,220,.35);
  text-transform:none;letter-spacing:0;
}
.gw2-authInput{
  width:100%;box-sizing:border-box;
  background:#060a18;
  border:1px solid rgba(68,241,255,.15);
  border-radius:6px;
  color:#e2eaff;
  font-size:.86rem;
  padding:10px 13px;
  outline:none;
  transition:border-color .18s,box-shadow .18s;
}
.gw2-authInput:focus{
  border-color:rgba(68,241,255,.45);
  box-shadow:0 0 0 3px rgba(68,241,255,.07);
}
.gw2-authInput::placeholder{color:rgba(180,190,220,.25)}

/* Captcha row */
.gw2-captchaRow{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.gw2-captchaImg{
  border:1px solid rgba(68,241,255,.18);
  border-radius:5px;height:46px;width:160px;flex-shrink:0;
}
.gw2-captchaRefresh{
  background:rgba(68,241,255,.1);border:1px solid rgba(68,241,255,.2);
  color:var(--cyan);border-radius:5px;cursor:pointer;
  font-size:1.1rem;padding:5px 10px;transition:background .15s;flex-shrink:0;
}
.gw2-captchaRefresh:hover{background:rgba(68,241,255,.22)}
.gw2-captchaInput{flex:1;min-width:80px}

/* Error banner */
.gw2-authError{
  background:rgba(239,68,68,.1);
  border:1px solid rgba(239,68,68,.28);
  border-radius:5px;
  color:#fca5a5;
  font-size:.78rem;line-height:1.5;
  padding:9px 12px;
  margin-bottom:14px;
}

/* Submit button */
.gw2-authSubmit{
  width:100%;padding:11px;
  background:linear-gradient(135deg,rgba(68,241,255,.2),rgba(68,241,255,.08));
  border:1px solid rgba(68,241,255,.38);
  border-radius:6px;
  color:var(--cyan);
  font-size:.84rem;font-weight:800;letter-spacing:.08em;
  cursor:pointer;
  transition:background .15s,color .15s,box-shadow .15s;
  margin-top:4px;
}
.gw2-authSubmit:hover{
  background:rgba(68,241,255,.26);
  color:#fff;
  box-shadow:0 0 18px rgba(68,241,255,.18);
}
.gw2-authSubmit:disabled{opacity:.4;cursor:default;box-shadow:none}

/* Note / cross-link line below form */
.gw2-authNote{
  margin-top:14px;
  font-size:.72rem;color:rgba(180,190,220,.45);
  text-align:center;line-height:1.5;
}
.gw2-authLink{
  background:none;border:none;cursor:pointer;
  color:var(--cyan);font-size:.72rem;text-decoration:underline;
  padding:0;transition:color .15s;
}
.gw2-authLink:hover{color:#fff}

/* Gateway ID input */
.gw2-gwIdInput{
  font-family:monospace;letter-spacing:.08em;font-size:1.05rem;text-align:center;
  text-transform:uppercase;
}

/* Gateway ID reveal panel. The success block shown ONLY after a brand-new
   account is created via the signup form. JS toggles its `hidden` attribute
   from switchAuthTab('reveal'). The [hidden]{display:none!important} guard
   below matters because the `display:flex` rule on the bare selector would
   otherwise outrank the user-agent stylesheet's `[hidden]{display:none}`,
   leaving the panel visible on the login + signup tabs and on every modal
   open — exactly the bug users reported. Same pattern as .gw2-authGate
   above (line ~2421). */
.gw2-gwIdReveal{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:8px 0 4px;text-align:center;
}
.gw2-gwIdReveal[hidden]{display:none!important}
/* Belt and braces — apply the same guard to every auth form (login,
   signup, forgot, quick-login) so a future stylesheet change doesn't
   re-introduce the same bug. */
.gw2-authForm[hidden]{display:none!important}
.gw2-gwIdRevealIcon{
  width:52px;height:52px;border-radius:50%;
  background:rgba(34,197,94,.12);border:1.5px solid rgba(34,197,94,.4);
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;color:#22c55e;
}
.gw2-gwIdRevealTitle{
  font-size:1.1rem;font-weight:700;color:#e2e8f0;
}
.gw2-gwIdRevealBody{
  font-size:.78rem;color:rgba(180,190,220,.6);line-height:1.6;
  max-width:280px;
}
.gw2-gwIdBox{
  font-family:monospace;letter-spacing:.14em;font-size:1.5rem;font-weight:700;
  color:var(--cyan);background:rgba(68,241,255,.06);
  border:1.5px solid rgba(68,241,255,.25);border-radius:10px;
  padding:14px 28px;width:100%;box-sizing:border-box;text-align:center;
}
.gw2-gwIdCopy{
  background:rgba(68,241,255,.08);border:1px solid rgba(68,241,255,.25);
  color:var(--cyan);font-size:.8rem;font-weight:600;letter-spacing:.04em;
  padding:8px 20px;border-radius:8px;cursor:pointer;transition:background .15s;
  width:100%;
}
.gw2-gwIdCopy:hover{background:rgba(68,241,255,.15)}

/* Quick sign-in panel (remembered Gateway ID from last session) */
.gw2-quickLogin{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:4px;padding:12px 0 8px;
}
.gw2-quickLoginId{
  font-family:var(--mono);
  font-size:1.5rem;font-weight:700;letter-spacing:.14em;
  color:var(--cyan);
  background:rgba(68,241,255,.06);
  border:1.5px solid rgba(68,241,255,.22);
  border-radius:10px;
  padding:14px 28px;
  width:100%;box-sizing:border-box;
  margin-bottom:4px;
}

/* Auth success message */
.gw2-authSuccess{
  background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.25);
  color:#4ade80;font-size:.8rem;text-align:center;
  padding:10px 14px;border-radius:8px;line-height:1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
   AUTH BUTTON (topbar — account / sign-out button once authenticated)
   ═══════════════════════════════════════════════════════════════════════════ */
.gw2-authBtn{
  background:rgba(34,197,94,.1);
  border:1px solid rgba(34,197,94,.35);
  color:#4ade80;
  font-size:.72rem;letter-spacing:.06em;
  padding:5px 12px;border-radius:4px;cursor:pointer;
  transition:background .15s,color .15s,border-color .15s;
  white-space:nowrap;max-width:150px;
  overflow:hidden;text-overflow:ellipsis;
  /* Hidden until user is authenticated */
  display:none;
}
.gw2-authBtn.is-signed-in{display:inline-flex;align-items:center;}
.gw2-authBtn:hover{background:rgba(68,241,255,.08);border-color:rgba(68,241,255,.3);color:#e2e8f0}

/* Topbar logout button — shown only when signed in */
.gw2-logoutBtn{
  background:rgba(239,68,68,.08);
  border:1px solid rgba(239,68,68,.3);
  color:#fca5a5;
  font-size:.72rem;letter-spacing:.06em;
  padding:5px 12px;border-radius:4px;cursor:pointer;
  transition:background .15s,border-color .15s;
  white-space:nowrap;
}
.gw2-logoutBtn:hover{background:rgba(239,68,68,.18);border-color:rgba(239,68,68,.5);color:#fff}
.gw2-logoutBtn[hidden]{display:none!important}

/* Bell notification button */
.gw2-bellBtn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:transparent;color:rgba(255,255,255,.55);cursor:pointer;transition:color .15s,border-color .15s,background .15s;flex-shrink:0}
.gw2-bellBtn:hover{color:#e2e8f0;border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.06)}
.gw2-bellBtn.is-active{color:#44f1ff;border-color:rgba(68,241,255,.4);background:rgba(68,241,255,.08)}
.gw2-bellBtn.is-active svg{filter:drop-shadow(0 0 4px rgba(68,241,255,.5))}

/* ═══════════════════════════════════════════════════════════════════════════
   PROFILE MODAL
   ═══════════════════════════════════════════════════════════════════════════ */
.gw2-profileOverlay{
  position:fixed;inset:0;z-index:9100;
  background:rgba(0,0,0,.6);backdrop-filter:blur(2px);
}
.gw2-profileOverlay[hidden]{display:none}
.gw2-profileModal{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:9101;
  width:min(460px,92vw);
  background:#0b1020;
  border:1px solid rgba(68,241,255,.18);
  border-radius:12px;
  padding:0;
  overflow:hidden;
}
.gw2-profileModal[hidden]{display:none}
.gw2-profileHeader{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px 16px;
  border-bottom:1px solid rgba(68,241,255,.1);
}
.gw2-profileTitle{
  font-size:.85rem;font-weight:700;letter-spacing:.08em;
  color:var(--cyan);text-transform:uppercase;
}
.gw2-profileClose{
  background:none;border:none;color:var(--muted);cursor:pointer;
  font-size:1.3rem;line-height:1;padding:2px 6px;border-radius:4px;
  transition:color .15s;
}
.gw2-profileClose:hover{color:var(--fg)}
.gw2-profileSection{padding:20px 22px}
.gw2-profileSectionTitle{
  font-size:.72rem;font-weight:700;letter-spacing:.07em;
  color:var(--muted);text-transform:uppercase;margin-bottom:12px;
}
.gw2-profileRow{display:flex;gap:10px;align-items:center}
.gw2-profileRow .gw2-authInput{flex:1}
.gw2-profileDivider{height:1px;background:rgba(68,241,255,.07);margin:0 22px}
.gw2-profileMsg{
  font-size:.78rem;margin-top:8px;padding:6px 10px;border-radius:4px;
}
.gw2-profileMsg.is-ok{background:rgba(34,197,94,.1);color:#4ade80;border:1px solid rgba(34,197,94,.25)}
.gw2-profileMsg.is-err{background:rgba(239,68,68,.1);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}
.gw2-profileMsg[hidden]{display:none}
.gw2-profileFooter{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 22px 20px;
}
.gw2-profileEmail{font-size:.78rem;color:var(--muted)}
.gw2-profileSignOut{
  background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);
  color:#fca5a5;font-size:.75rem;letter-spacing:.05em;
  padding:6px 14px;border-radius:4px;cursor:pointer;
  transition:background .15s;
}
.gw2-profileSignOut:hover{background:rgba(239,68,68,.22)}

/* ═══════════════════════════════════════════════════════════════════════════
   WATCHLIST DASHBOARD OVERLAY
   ═══════════════════════════════════════════════════════════════════════════ */
.gw2-wlDash{
  padding:12px 10px 10px;
  overflow-y:auto;
}
.gw2-wlSignIn{
  display:flex;flex-direction:column;align-items:center;
  padding:32px 20px;text-align:center;
}
.gw2-wlSignInTitle{
  font-size:.92rem;font-weight:700;letter-spacing:.08em;color:var(--cyan);margin-bottom:10px;
}
.gw2-wlSignInBody{
  font-size:.78rem;color:var(--muted);max-width:280px;line-height:1.5;margin-bottom:20px;
}
.gw2-wlSignInBtns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.gw2-wlSignInBtn{
  background:rgba(68,241,255,.12);border:1px solid rgba(68,241,255,.3);
  border-radius:5px;color:var(--cyan);font-size:.78rem;font-weight:700;
  letter-spacing:.06em;padding:8px 18px;cursor:pointer;transition:background .15s;
}
.gw2-wlSignInBtn:hover{background:rgba(68,241,255,.22);color:#fff}
.gw2-wlSignInBtnAlt{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.3);color:#4ade80;}
.gw2-wlSignInBtnAlt:hover{background:rgba(34,197,94,.2);color:#fff}

/* Watchlist grid — 4 cols; orphaned last items centred */
.gw2-wlGrid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;margin-bottom:10px;
}
/* 1 orphan (e.g. 9 cards): card is at col 1 of new row → centre in cols 2–3 */
.gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+1){
  grid-column:2 / 4;
}
/* 2 orphans (e.g. 10 cards): cards land in cols 1–2 → shift to cols 2–3 */
.gw2-wlGrid > .gw2-wlCard:nth-last-child(2):nth-child(4n+1){ grid-column:2; }
.gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+2)       { grid-column:3; }
/* 3 orphans (e.g. 7 cards): cards land in cols 1–3 → centre the trio */
.gw2-wlGrid > .gw2-wlCard:nth-last-child(3):nth-child(4n+1){ grid-column:1; }
.gw2-wlGrid > .gw2-wlCard:nth-last-child(2):nth-child(4n+2){ grid-column:2; }
.gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+3)       { grid-column:3; }
.gw2-wlCard{
  background:rgba(13,18,36,.9);border:1px solid rgba(68,241,255,.12);
  border-radius:7px;padding:10px 11px;cursor:pointer;
  transition:border-color .15s,background .15s;position:relative;
}
.gw2-wlCard:hover{border-color:rgba(68,241,255,.35);background:rgba(68,241,255,.05)}
.gw2-wlCardTop{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.gw2-wlTicker{font-size:1.05rem;font-weight:800;color:var(--cyan);letter-spacing:.06em}
.gw2-wlName{font-size:.68rem;color:var(--muted);margin-top:2px;line-height:1.3}
.gw2-wlRemove{
  background:none;border:none;cursor:pointer;
  color:rgba(180,190,220,.35);font-size:1rem;line-height:1;
  padding:2px 4px;border-radius:3px;transition:color .15s,background .15s;flex-shrink:0;
}
.gw2-wlRemove:hover{color:#ef4444;background:rgba(239,68,68,.1)}
.gw2-wlPrice{font-size:.9rem;font-weight:700;color:#e2eaff;margin-bottom:6px;font-family:var(--mono)}
.gw2-wlRow{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.gw2-wlLabel{font-size:.66rem;color:var(--muted);letter-spacing:.05em;font-family:var(--mono)}
.gw2-wlVal{font-size:.74rem;font-weight:700;font-family:var(--mono)}
.gw2-wlVal--up{color:#22c55e}
.gw2-wlVal--dn{color:#ef4444}
.gw2-wlVal--{color:var(--muted)}

/* ─────────────────────────────────────────────────────────────────────────
 * Extended-hours strip — used by every stock-card surface (Mag 7 dashboard,
 * watchlist, globe marker popup, notebook chart header). Shows the latest
 * premarket / after-hours print under the regular session change.
 *
 * Empty / null when the quote has no extended print (NGX, FX, crypto, etc.) —
 * the helper returns "" and no element is emitted.
 * ───────────────────────────────────────────────────────────────────────── */
.gw2-extHours{
  display:inline-flex;align-items:center;gap:6px;flex-wrap:nowrap;
  margin-top:4px;
  font-family:var(--mono);font-size:.72rem;font-weight:600;
  letter-spacing:.02em;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
}
.gw2-extHours.is-compact{font-size:9px;margin-top:2px;gap:4px}

.gw2-extHours-badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:1px 6px;border-radius:4px;
  font-size:.58rem;font-weight:700;letter-spacing:.10em;text-transform:uppercase;
  background:rgba(68,241,255,.10);border:1px solid rgba(68,241,255,.30);color:#9ff3ff;
  transition:background .12s ease, border-color .12s ease;
}
.gw2-extHours.is-compact .gw2-extHours-badge{font-size:7.5px;padding:0 4px;letter-spacing:.08em}
.gw2-extHours-badge[data-ext-session="PREMARKET"]   {background:rgba(255,204,102,.10);border-color:rgba(255,204,102,.35);color:#ffe7a8}
.gw2-extHours-badge[data-ext-session="AFTER_HOURS"] {background:rgba(180,150,255,.10);border-color:rgba(180,150,255,.35);color:#cdb4ff}
.gw2-extHours-badge[data-ext-session="REGULAR"]     {background:rgba(34,197,94,.10);border-color:rgba(34,197,94,.30);color:#22c55e}

.gw2-extHours-price{color:inherit}
.gw2-extHours-chg{opacity:.92}

/* No entry animation. The strip is re-rendered on every ~15 s quote poll, and
 * an animation here re-fires each cycle across every strip on the page (markets
 * cards, brief panel, popup, AlphaView rows) — a synchronized opacity flash +
 * 2 px translate that reads as page-wide flicker / shake. Strips now update
 * silently in place (see setExtStrip_ in app.js, which also skips no-op writes).
 * Only the badge colour keeps its short transition. */

/* Dashboard card slot — sits between change-% line and the sentiment bar. */
.gw2-mkCard-ext{min-height:14px}
.gw2-mkCard-ext:empty{display:none}

/* Globe marker popup variant — slightly larger and right-aligned with the
 * regular price/change lines that sit immediately above it. */
.gw2-markerExtHours{margin-top:4px;font-size:.72rem;font-family:var(--mono)}
.gw2-markerExtHours:empty{display:none}
.gw2-markerExtHours .gw2-extHours{margin-top:0}

/* Market Feed brief card — extended-hours strip under the price/change row,
 * with breathing room above (price row) and below (TradingView chart). */
.gw2-quoteExtHours{margin-top:8px;margin-bottom:14px}
.gw2-quoteExtHours:empty{display:none}

/* AlphaView holdings table — ext-hours strip below the price within its cell. */
.gw2-alphaExt{margin-top:3px;display:flex;justify-content:flex-end}
.gw2-alphaExt:empty{display:none}
.gw2-alphaExt .gw2-extHours{margin-top:0}

/* ─────────────────────────────────────────────────────────────────────────
 * Alpha View — institutional analytics layer (Phase 1 + Phase 2).
 * Visual language reuses the existing gw2-alpha* palette: cyan accent
 * (#44f1ff), red for loss (#ff6b8b), green for gain (#5be4a5), white text on
 * the dark slate panel. All blocks are additive — no existing rule is touched.
 * ───────────────────────────────────────────────────────────────────────── */

/* Goal tracker + drawdown alert banner */
.gw2-alphaAlertBar{
  margin-top:10px;padding:9px 12px;border-radius:8px;
  font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:#ffd166;
  background:rgba(255,107,139,.12);border:1px solid rgba(255,107,139,.45);
}
.gw2-alphaAlertBar strong{color:#ff6b8b;letter-spacing:.16em;margin-right:8px}
.gw2-alphaGoal{
  margin-top:10px;padding:10px 12px;border-radius:10px;
  background:rgba(68,241,255,.05);border:1px solid rgba(68,241,255,.18);
}
.gw2-alphaGoalHd{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:rgba(68,241,255,.85)}
.gw2-alphaGoalBar{margin-top:7px;height:8px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.gw2-alphaGoalBarFill{display:block;height:100%;background:linear-gradient(90deg,#44f1ff,#5be4a5)}
.gw2-alphaGoalSub{margin-top:6px;font-family:var(--mono);font-size:10px;color:#ffffff}

/* Concentration & mandate bars */
.gw2-alphaConcList{display:flex;flex-direction:column;gap:4px;margin-top:4px}
.gw2-alphaConcRow{
  display:grid;grid-template-columns:64px 1fr 64px auto;gap:8px;align-items:center;
  padding:4px 8px;border-radius:6px;background:rgba(255,255,255,.02);
}
.gw2-alphaConcRow--breach{background:rgba(255,107,139,.10)}
.gw2-alphaConcTk{font-family:var(--mono);font-size:11px;font-weight:700;color:#ffffff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gw2-alphaConcBar{position:relative;height:8px;background:rgba(255,255,255,.05);border-radius:4px;overflow:hidden}
.gw2-alphaConcBarFill{display:block;height:100%;background:#44f1ff;border-radius:4px;transition:width .35s ease}
.gw2-alphaConcLimit{position:absolute;top:-2px;bottom:-2px;width:2px;background:#ffd166;opacity:.85}
.gw2-alphaConcPct{font-family:var(--mono);font-size:11px;color:#ffffff;text-align:right;font-variant-numeric:tabular-nums}
.gw2-alphaConcFlag{
  font-family:var(--mono);font-size:8px;letter-spacing:.06em;color:#ff6b8b;
  border:1px solid rgba(255,107,139,.45);border-radius:4px;padding:1px 4px;
}
.gw2-alphaConcRule{
  margin-top:8px;font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;
  color:rgba(255,255,255,.62);
}

/* Monthly returns heatmap — table cell tint comes from inline style */
.gw2-alphaMonthlyTbl td,.gw2-alphaMonthlyTbl th{font-size:10.5px;padding:4px 6px}
.gw2-alphaMonthlyTbl th{background:rgba(10,14,24,.98)}
.gw2-alphaRollSub{display:block;font-size:9px;color:rgba(255,255,255,.7);margin-top:2px}

/* Style box — 3 × 3 grid */
.gw2-alphaStyleBoxWrap{display:flex;flex-direction:column;gap:2px;padding:6px 4px 2px}
.gw2-alphaSbHdRow,.gw2-alphaSbRow{display:grid;grid-template-columns:60px repeat(3,1fr);gap:2px}
.gw2-alphaSbHd{font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:rgba(68,241,255,.7);text-align:center}
.gw2-alphaSbRowHd{font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:rgba(68,241,255,.7);align-self:center}
.gw2-alphaSbCell{
  min-height:36px;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:12px;font-weight:700;color:#0a0e18;
  border-radius:4px;border:1px solid rgba(68,241,255,.18);
}

/* Scenarios */
.gw2-alphaScn{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.gw2-alphaScnRow{padding:6px 8px;border-radius:6px;background:rgba(255,255,255,.02)}
.gw2-alphaScnHd{font-family:var(--mono);font-size:11px;color:#ffffff}
.gw2-alphaScnHd strong{color:#ffd166;margin-right:8px}
.gw2-alphaScnHd span{color:rgba(255,255,255,.65);font-size:9.5px}
.gw2-alphaScnBar{margin:5px 0;height:7px;background:rgba(255,255,255,.05);border-radius:4px;overflow:hidden}
.gw2-alphaScnBarFill{display:block;height:100%;border-radius:4px}
.gw2-alphaScnBarFill.is-pos{background:#5be4a5}
.gw2-alphaScnBarFill.is-neg{background:#ff6b8b}
.gw2-alphaScnVals{font-family:var(--mono);font-size:11px;color:#ffffff;text-align:right;font-variant-numeric:tabular-nums}

/* Correlation matrix */
.gw2-alphaCorrTbl td,.gw2-alphaCorrTbl th{font-size:10px;padding:5px 7px}
.gw2-alphaCorrTbl th{background:rgba(10,14,24,.98)}
.gw2-alphaCorrCell{font-weight:700;color:#0a0e18}

/* IBRG / Stockertim footer */
.gw2-alphaFooter{
  margin-top:18px;padding:10px 4px 0;
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.5);text-align:center;
  border-top:1px solid rgba(156,180,255,.10);
}

/* Print — Alpha View only, no app chrome */
@media print{
  body.gw2-alphaPrinting > *:not(.gw2){display:none!important}
  body.gw2-alphaPrinting .gw2{background:#ffffff!important;color:#000!important}
  body.gw2-alphaPrinting .gw2 *:not(#alphaViewDashboard):not(#alphaViewDashboard *){display:none!important}
  body.gw2-alphaPrinting #alphaViewDashboard{
    position:static!important;display:block!important;width:100%!important;height:auto!important;
    overflow:visible!important;background:#ffffff!important;color:#0a0e18!important;
    border:none!important;border-radius:0!important;hidden:false!important;
  }
  body.gw2-alphaPrinting #alphaViewDashboard[hidden]{display:block!important}
  body.gw2-alphaPrinting .gw2-alphaBody{overflow:visible!important;padding:0!important}
  body.gw2-alphaPrinting .gw2-alphaToggles,
  body.gw2-alphaPrinting .gw2-alphaNav,
  body.gw2-alphaPrinting .gw2-alphaCopyBtn,
  body.gw2-alphaPrinting .gw2-alphaRange{display:none!important}
  body.gw2-alphaPrinting .gw2-alphaDash.is-priv .gw2-amt{filter:none!important;opacity:1!important}
  body.gw2-alphaPrinting .gw2-alphaKpi,
  body.gw2-alphaPrinting .gw2-alphaChartCard,
  body.gw2-alphaPrinting .gw2-alphaTable{
    background:#ffffff!important;color:#0a0e18!important;border-color:#cbd2e0!important;
    page-break-inside:avoid;
  }
  body.gw2-alphaPrinting .gw2-alphaKpiLbl,
  body.gw2-alphaPrinting .gw2-alphaKpiVal,
  body.gw2-alphaPrinting .gw2-alphaKpiSub,
  body.gw2-alphaPrinting .gw2-alphaChartHd,
  body.gw2-alphaPrinting .gw2-alphaTable th,
  body.gw2-alphaPrinting .gw2-alphaTable td{color:#0a0e18!important}
  body.gw2-alphaPrinting .gw2-alphaSubHd{
    color:#0a0e18!important;border-color:#cbd2e0!important;page-break-after:avoid;
  }
  body.gw2-alphaPrinting .gw2-alphaFooter{color:#3a4456!important;border-top:1px solid #cbd2e0!important}
}

/* Watchlist card — ext-hours strip slot (hidden when the ticker has none). */
.gw2-wlExt:empty{display:none}

/* Mobile compact — keep the strip on a single line without overflow. */
@media(max-width:600px){
  .gw2-extHours          {font-size:9.5px;gap:4px}
  .gw2-extHours-badge    {font-size:7px;padding:0 4px}
  .gw2-extHours.is-compact{font-size:8px}
}

/* Add row */
.gw2-wlAddRow{
  display:flex;align-items:center;gap:7px;
  padding:8px 12px 12px;border-top:1px solid rgba(68,241,255,.08);
}
.gw2-wlAddInput{
  flex:1;min-width:0;background:#060a18;
  border:1px solid rgba(68,241,255,.18);border-radius:4px;
  color:#e2eaff;font-size:.78rem;padding:6px 9px;outline:none;
  transition:border-color .15s;text-transform:uppercase;
}
.gw2-wlAddInput:focus{border-color:rgba(68,241,255,.45)}
.gw2-wlAddInput::placeholder{text-transform:none;color:rgba(180,190,220,.3)}
.gw2-wlAddBtn{
  background:rgba(68,241,255,.12);border:1px solid rgba(68,241,255,.3);
  border-radius:4px;color:var(--cyan);font-size:.74rem;font-weight:700;
  letter-spacing:.05em;padding:6px 12px;cursor:pointer;white-space:nowrap;transition:background .15s;
}
.gw2-wlAddBtn:hover{background:rgba(68,241,255,.22);color:#fff}
.gw2-wlCount{font-size:.68rem;color:var(--muted);font-family:var(--mono);white-space:nowrap}
.gw2-wlFull{font-size:.72rem;color:var(--muted);font-style:italic}

/* ═══════════════════════════════════════════════════════════════════════════
   WATCH BUTTON IN MARKER POPUP
   ═══════════════════════════════════════════════════════════════════════════ */
.gw2-markerWatchRow{padding:8px 14px 4px;display:flex;gap:6px}
.gw2-wlWatchBtn{
  flex:1;padding:7px 0;
  background:rgba(68,241,255,.1);border:1px solid rgba(68,241,255,.28);
  border-radius:5px;color:var(--cyan);
  font-size:.76rem;font-weight:700;letter-spacing:.07em;
  cursor:pointer;transition:background .15s,color .15s;
}
.gw2-wlWatchBtn:hover{background:rgba(68,241,255,.22);color:#fff}
.gw2-wlWatchBtn.is-watching{
  background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.35);color:#22c55e;
}
.gw2-wlWatchBtn.is-watching:hover{
  background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:#ef4444;
}
.gw2-copyCardBtn{
  flex:0 0 34px;width:34px;padding:0;
  background:rgba(68,241,255,.08);border:1px solid rgba(68,241,255,.28);
  border-radius:5px;color:var(--cyan);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .15s,color .15s;
}
.gw2-copyCardBtn:hover{background:rgba(68,241,255,.22);color:#fff}
.gw2-copyToast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(12px);
  background:#1a2233;border:1px solid rgba(68,241,255,.35);border-radius:8px;
  color:#44f1ff;font-size:.78rem;font-weight:600;letter-spacing:.04em;
  padding:8px 18px;pointer-events:none;
  opacity:0;transition:opacity .2s,transform .2s;z-index:9999;white-space:nowrap;
}
.gw2-copyToast.is-visible{opacity:1;transform:translateX(-50%) translateY(0)}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media(max-width:860px){
  .gw2-authGate{flex-direction:column}
  .gw2-gateLeft{
    flex:0 0 auto;padding:32px 28px 28px;
    border-right:none;border-bottom:1px solid rgba(68,241,255,.08);
    align-items:center;
  }
  .gw2-gateTaglineHead{font-size:1.35rem}
  .gw2-gateFeatures{display:none}
  .gw2-gateBrand{margin-bottom:20px}
  .gw2-gateLogo{height:42px;padding:8px 14px}
  .gw2-gateTagline{margin-bottom:0}
  .gw2-gateTaglineBody{display:none}
  .gw2-gateFree{display:none}
  .gw2-gateRight{padding:28px 20px 40px;justify-content:flex-start}
  .gw2-gateCard{padding:24px 20px 20px}
}
@media(max-width:480px){
  .gw2-authGate{font-size:14px}
  .gw2-gateLeft{padding:22px 18px 18px}
  .gw2-gateLogo{height:36px;padding:8px 12px;border-radius:14px}
  .gw2-gateTaglineHead{font-size:1.1rem}
  .gw2-gateRight{padding:20px 14px 32px}
  .gw2-gateCard{padding:20px 16px 16px;border-radius:8px}
  .gw2-wlGrid{grid-template-columns:1fr 1fr}
  .gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+1),
  .gw2-wlGrid > .gw2-wlCard:nth-last-child(2):nth-child(4n+1),
  .gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+2),
  .gw2-wlGrid > .gw2-wlCard:nth-last-child(3):nth-child(4n+1),
  .gw2-wlGrid > .gw2-wlCard:nth-last-child(2):nth-child(4n+2),
  .gw2-wlGrid > .gw2-wlCard:last-child:nth-child(4n+3){ grid-column:auto; }
  .gw2-wlGrid > .gw2-wlCard:last-child:nth-child(odd){
    grid-column:1 / -1;
    justify-self:center;
    width:calc((100% - 5px) / 2);
  }
  .gw2-captchaRow{flex-wrap:wrap}
  .gw2-captchaImg{width:140px}
}

/* ── Intel Center (Notifications / Rules / Delivery) ─────────────────── */
.gw2-notifBtn{position:relative}
.gw2-notifCount{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 6px;margin-left:8px;
  border-radius:999px;
  background:rgba(255,77,109,.18);
  border:1px solid rgba(255,77,109,.35);
  color:rgba(255,182,196,.95);
  font-size:11px;font-weight:700;
}

.gw2-notifDrawer{
  position:fixed;inset:0;z-index:230;
  display:flex;justify-content:flex-end;
}
.gw2-notifDrawer[hidden]{display:none}
.gw2-notifOverlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(3px);
}
.gw2-notifPanel{
  position:relative;
  width:min(520px, 96vw);
  height:100%;
  background:linear-gradient(160deg, rgba(10,14,22,.98) 0%, rgba(7,10,18,.99) 100%);
  border-left:1px solid var(--stroke);
  box-shadow:-24px 0 60px rgba(0,0,0,.55);
  display:flex;flex-direction:column;
}
.gw2-notifHeader{
  padding:16px 16px 12px;
  border-bottom:1px solid rgba(156,180,255,.10);
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
}
.gw2-notifTitle{
  font-family:var(--mono);
  font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(68,241,255,.95);
}
.gw2-notifSub{font-size:12px;margin-top:4px}
.gw2-notifHeaderBtns{display:flex;gap:10px;align-items:center}
.gw2-notifTabs{
  display:flex;gap:8px;padding:10px 12px;
  border-bottom:1px solid rgba(156,180,255,.08);
  background:rgba(6,8,12,.35);
}
.gw2-notifTab{
  height:30px;padding:0 10px;border-radius:10px;
  border:1px solid rgba(156,180,255,.10);
  background:rgba(6,8,12,.25);
  color:var(--muted);
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;
}
.gw2-notifTab.is-active{
  border-color:rgba(68,241,255,.28);
  color:rgba(68,241,255,.95);
  background:linear-gradient(180deg, rgba(68,241,255,.10), rgba(24,165,255,.05));
}
.gw2-notifBody{flex:1;overflow:hidden}
.gw2-notifPane{height:100%;display:flex;flex-direction:column}
.gw2-notifStatus{
  padding:12px 14px;
  color:var(--muted);
  border-bottom:1px dashed rgba(156,180,255,.10);
  font-size:12px;
}
.gw2-notifList{
  flex:1;overflow:auto;padding:12px;
  display:flex;flex-direction:column;gap:10px;
}
.gw2-notifCard{
  border:1px solid rgba(156,180,255,.12);
  border-radius:14px;
  background:rgba(6,8,12,.35);
  padding:12px 12px 10px;
  cursor:pointer;
  transition:border-color .15s, transform .12s;
}
.gw2-notifCard:hover{border-color:rgba(68,241,255,.22);transform:translateY(-1px)}
.gw2-notifCard.is-unread{border-color:rgba(68,241,255,.28);box-shadow:0 0 0 1px rgba(68,241,255,.08) inset}
.gw2-notifMeta{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:8px}
.gw2-notifPill{
  display:inline-flex;align-items:center;gap:6px;
  height:18px;padding:0 8px;border-radius:999px;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  border:1px solid rgba(156,180,255,.14);
  color:rgba(220,230,255,.82);
  background:rgba(6,8,12,.25);
}
.gw2-notifPill.is-low{border-color:rgba(156,180,255,.14)}
.gw2-notifPill.is-medium{border-color:rgba(68,241,255,.18)}
.gw2-notifPill.is-high{border-color:rgba(255,204,102,.28);color:rgba(255,226,180,.95)}
.gw2-notifPill.is-critical{border-color:rgba(255,77,109,.35);color:rgba(255,182,196,.95)}
.gw2-notifHeadline{font-family:var(--sans);font-size:13px;line-height:1.25;color:rgba(240,245,255,.92)}
.gw2-notifWhy{margin-top:8px;font-size:12px;color:rgba(205,220,255,.70)}
.gw2-notifLinks{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap}
.gw2-notifLink{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(68,241,255,.90);
  text-decoration:none;
  border:1px solid rgba(68,241,255,.18);
  background:rgba(68,241,255,.06);
  padding:6px 8px;border-radius:10px;
}
.gw2-notifLink:hover{border-color:rgba(68,241,255,.30)}

/* Rules */
.gw2-ruleTop{padding:12px 12px 10px;border-bottom:1px solid rgba(156,180,255,.08);display:flex;align-items:center;gap:12px;justify-content:space-between}
.gw2-ruleList{flex:1;overflow:auto;padding:12px;display:flex;flex-direction:column;gap:10px}
.gw2-ruleCard{
  border:1px solid rgba(156,180,255,.12);
  border-radius:14px;
  background:rgba(6,8,12,.35);
  padding:12px;
}
.gw2-ruleRow{display:flex;align-items:center;justify-content:space-between;gap:10px}
.gw2-ruleName{font-family:var(--sans);font-size:13px;color:rgba(240,245,255,.92)}
.gw2-ruleDesc{margin-top:6px;font-size:12px;color:rgba(205,220,255,.70)}
.gw2-ruleBtns{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.gw2-ruleEditor{
  padding:12px;border-top:1px solid rgba(156,180,255,.08);
  background:rgba(6,8,12,.35);
}
.gw2-field{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.gw2-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(205,220,255,.70);font-family:var(--mono)}
.gw2-notifDrawer .gw2-input,
.gw2-notifDrawer .gw2-select,
.gw2-notifDrawer .gw2-textarea{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(156,180,255,.12);
  background:rgba(6,8,12,.25);
  color:rgba(240,245,255,.92);
  padding:10px 10px;
  outline:none;
  font-family:var(--sans);
}
.gw2-notifDrawer .gw2-textarea{min-height:68px;resize:vertical}
.gw2-notifDrawer .gw2-input:focus,
.gw2-notifDrawer .gw2-select:focus,
.gw2-notifDrawer .gw2-textarea:focus{border-color:rgba(68,241,255,.28)}
.gw2-formRow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gw2-checkRow{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.gw2-check{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:rgba(220,230,255,.84)}
.gw2-check input{accent-color:#44f1ff}

/* Delivery */
.gw2-deliveryCard{
  margin:12px;
  border:1px solid rgba(156,180,255,.12);
  border-radius:14px;
  background:rgba(6,8,12,.35);
  padding:12px;
}
.gw2-deliveryTitle{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(240,245,255,.92);
  margin-bottom:10px;
}
.gw2-deliveryRow{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.gw2-deliveryLabel{font-size:12px;color:rgba(205,220,255,.70)}
.gw2-deliveryHint{font-size:12px;margin-top:4px}

/* Toggle */
.gw2-toggle{display:flex;gap:10px;align-items:center;cursor:pointer;user-select:none}
.gw2-toggle input{display:none}
.gw2-toggleUi{
  width:42px;height:24px;border-radius:999px;
  border:1px solid rgba(156,180,255,.16);
  background:rgba(6,8,12,.25);
  position:relative;
}
.gw2-toggleUi:before{
  content:"";
  width:18px;height:18px;border-radius:50%;
  background:rgba(240,245,255,.90);
  position:absolute;left:3px;top:50%;transform:translateY(-50%);
  transition:transform .18s ease, background .18s;
}
.gw2-toggle input:checked + .gw2-toggleUi{
  border-color:rgba(68,241,255,.35);
  background:rgba(68,241,255,.10);
}
.gw2-toggle input:checked + .gw2-toggleUi:before{transform:translate(18px, -50%);background:rgba(68,241,255,.95)}
.gw2-toggleLabel{font-size:12px;color:rgba(220,230,255,.84)}

@media(max-width:520px){
  .gw2-formRow{grid-template-columns:1fr}
  /* iOS zoom fix for notification drawer inputs */
  .gw2-notifDrawer .gw2-input,
  .gw2-notifDrawer .gw2-select,
  .gw2-notifDrawer .gw2-textarea{font-size:16px}
}

/* ── Auth gate: landscape / short-viewport fix ─────────────────────────── */
/* On phones held sideways the viewport can be as short as 375px.
   Allow the entire gate to scroll so the form is never clipped.           */
@media(max-width:900px) and (max-height:500px){
  .gw2-authGate{overflow-y:auto;flex-direction:column}
  .gw2-gateLeft{
    flex:none;
    padding:16px 20px;
    min-height:0;
  }
  .gw2-gateTagline{margin-bottom:10px}
  .gw2-gateRight{flex:none;padding:16px 14px 28px}
}

/* ── Smart Money Overlay (Phase 3 — Superinvestor × Alpha View) ──────── */
/* All classes are additive to the existing gw2-alpha* family. Built on
   the same dark/glass conventions, monospace numerics, palette tokens. */

.gw2-alphaSmartHd{
  /* lifts the Smart-Money heading a touch so it visually breaks from
     the Risk Lab section above it without needing extra DOM */
  margin-top:30px;
}
.gw2-alphaSmartUnav{
  padding:14px 16px;
  border:1px dashed rgba(156,180,255,.20);
  border-radius:10px;
  font-family:var(--mono);
  font-size:11px;
  color:rgba(255,255,255,.65);
  background:rgba(20,28,48,.30);
}
.gw2-alphaSmartUnavDetail{
  margin-top:6px;
  font-size:10px;
  color:rgba(220,230,255,.50);
  letter-spacing:.04em;
}

/* 1. Alignment strip */
.gw2-alphaSmartAlignWrap{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) minmax(0, 2.4fr);
  gap:12px;
  margin:10px 0 8px;
}
.gw2-alphaSmartScoreCard{
  border:1px solid rgba(156,180,255,.14);
  background:linear-gradient(180deg, rgba(20,28,48,.40), rgba(10,16,30,.55));
  border-radius:12px;
  padding:14px 16px;
  position:relative;
  display:flex;flex-direction:column;justify-content:center;
}
.gw2-alphaSmartScoreLbl{
  font-family:var(--mono);font-size:9px;letter-spacing:.13em;
  text-transform:uppercase;color:#ffffff;opacity:.85;
}
.gw2-alphaSmartScoreVal{
  margin-top:6px;
  font-family:var(--mono);font-size:46px;font-weight:700;line-height:1;
  color:#44f1ff;
}
.gw2-alphaSmartScoreSub{
  margin-top:8px;
  font-family:var(--mono);font-size:11px;color:rgba(220,230,255,.80);
}
.gw2-alphaSmartScoreBar{
  margin-top:12px;height:6px;border-radius:3px;
  background:rgba(156,180,255,.10);
  overflow:hidden;
}
.gw2-alphaSmartScoreFill{
  height:100%;width:0%;
  background:linear-gradient(90deg, #44f1ff, #7c9cff 50%, #5be4a5);
  transition:width .35s ease;
}
.gw2-alphaSmartMatchGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
.gw2-alphaSmartMatch{
  border:1px solid var(--mc, rgba(156,180,255,.20));
  background:linear-gradient(180deg, rgba(20,28,48,.45), rgba(10,16,30,.55));
  border-radius:12px;
  padding:12px 14px;
  display:flex;flex-direction:column;gap:4px;
  position:relative;
  overflow:hidden;
}
.gw2-alphaSmartMatch::before{
  content:"";position:absolute;top:0;left:0;width:4px;height:100%;
  /* Lift the raw brand colour towards white so dark-navy brands (e.g.
     BlackRock #1a1a2e) still read against the card's dark gradient. The
     stripe stays unmistakably brand-coloured for bright palettes — the
     mix is only ~25% white, so vibrant blues/greens/golds keep their hue.
     The first declaration is a fallback for browsers without color-mix(). */
  background:var(--mc, #7c9cff);
  background:color-mix(in oklab, var(--mc, #7c9cff) 75%, #ffffff 25%);
}
.gw2-alphaSmartMatchRank{
  font-family:var(--mono);font-size:9px;letter-spacing:.16em;
  text-transform:uppercase;color:rgba(220,230,255,.65);
}
.gw2-alphaSmartMatchMgr{
  font-family:var(--mono);font-size:14px;font-weight:700;color:#ffffff;
  line-height:1.2;
}
.gw2-alphaSmartMatchFirm{
  font-family:var(--mono);font-size:10px;color:rgba(220,230,255,.70);
}
.gw2-alphaSmartMatchStats{
  margin-top:auto;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;
}
.gw2-alphaSmartMatchPct{
  font-family:var(--mono);font-size:20px;font-weight:700;
  /* Brand-tinted but contrast-floored: mix the raw brand colour with ~40%
     white so dark identities (BlackRock's #1a1a2e was rendering invisible
     against the card's dark background) still pass minimum contrast. Bright
     palettes keep most of their character because the white blend is partial.
     `text-shadow` provides a faint additional separation for any colour.
     The first `color:` declaration is the fallback for browsers without
     color-mix() — they at least keep the existing tint. */
  color:var(--mc, #44f1ff);
  color:color-mix(in oklab, var(--mc, #44f1ff) 60%, #ffffff 40%);
  text-shadow:0 1px 0 rgba(0,0,0,.45);
}
.gw2-alphaSmartMatchHint{
  font-family:var(--mono);font-size:9px;letter-spacing:.06em;
  color:rgba(220,230,255,.60);
}

/* 2. Crowding treemap */
.gw2-alphaSmartTreemap{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:10px 6px;
}
.gw2-alphaSmartTile{
  flex:1 1 16%;min-width:90px;
  min-height:72px;
  border:1px solid rgba(156,180,255,.18);
  border-radius:10px;
  padding:10px 12px;
  display:flex;flex-direction:column;justify-content:center;
  transition:transform .15s ease, border-color .15s ease;
}
.gw2-alphaSmartTile:hover{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.50);
}
.gw2-alphaSmartTileSym{
  font-family:var(--mono);font-size:14px;font-weight:700;color:#ffffff;
}
.gw2-alphaSmartTileMeta{
  font-family:var(--mono);font-size:10px;color:rgba(220,230,255,.85);
  margin-top:3px;
}
.gw2-alphaSmartTileScore{
  font-family:var(--mono);font-size:9px;letter-spacing:.06em;
  color:rgba(220,230,255,.65);margin-top:5px;
}

/* Privacy mask — when the dashboard is in masked mode, hide raw value
   labels in smart-money tiles & scores. Mirrors .is-priv on the parent. */
.gw2-alphaDash.is-priv .gw2-alphaSmartTileMeta,
.gw2-alphaDash.is-priv .gw2-alphaSmartScoreVal,
.gw2-alphaDash.is-priv .gw2-alphaSmartMatchPct{
  filter:blur(6px);
}
.gw2-alphaDash.is-priv .gw2-alphaSmartTile:hover .gw2-alphaSmartTileMeta,
.gw2-alphaDash.is-priv .gw2-alphaSmartScoreCard:hover .gw2-alphaSmartScoreVal,
.gw2-alphaDash.is-priv .gw2-alphaSmartMatch:hover .gw2-alphaSmartMatchPct{
  filter:none;
}

/* Smaller viewports — stack the alignment strip and shrink match grid */
@media(max-width:980px){
  .gw2-alphaSmartAlignWrap{grid-template-columns:1fr}
  .gw2-alphaSmartMatchGrid{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .gw2-alphaSmartTile{flex-basis:30% !important}
}
@media(max-width:600px){
  .gw2-alphaSmartMatchGrid{grid-template-columns:1fr}
  .gw2-alphaSmartScoreVal{font-size:38px}
  .gw2-alphaSmartTile{flex-basis:46% !important}
}


/* ── Stock Deep-Dive Module (Phase 6 — Alpha View intelligence platform) ── */

/* Header DEEP DIVE button — same toggle look as the privacy / sound buttons. */
.gw2-alphaDdBtn{ /* inherits .gw2-alphaEye visuals */ }
.gw2-alphaDdBtn[aria-pressed="true"]{
  background:linear-gradient(180deg, rgba(68,241,255,.20), rgba(68,241,255,.08));
  border-color:rgba(68,241,255,.45);
}

/* ── Portfolio Intelligence overlay (lives inside the Alpha View body) ── */
.gw2-alphaPortIntelHd{
  /* same .gw2-alphaSubHd register; add a thin accent stripe */
  border-left:3px solid rgba(68,241,255,.55);
  padding-left:10px;
}
.gw2-alphaPortIntelCov{
  margin-left:8px; font-style:italic;
}
.gw2-alphaPortIntelCalendar{
  display:flex; flex-wrap:wrap; gap:6px; padding:10px 6px;
}
.gw2-alphaPortIntelCalChip{
  display:inline-flex; flex-direction:column; align-items:center;
  padding:6px 10px; border:1px solid rgba(156,180,255,.20);
  border-radius:10px; min-width:64px; cursor:pointer;
  background:linear-gradient(180deg, rgba(20,28,48,.45), rgba(10,16,30,.55));
  transition:transform .15s ease, border-color .15s ease;
}
.gw2-alphaPortIntelCalChip:hover{ transform:translateY(-1px); border-color:rgba(68,241,255,.5); }
.gw2-alphaPortIntelCalChip .d{ font-family:var(--mono); font-size:9px; color:rgba(220,230,255,.7); letter-spacing:.06em; text-transform:uppercase; }
.gw2-alphaPortIntelCalChip .t{ font-family:var(--mono); font-size:13px; font-weight:700; color:#fff; }
.gw2-alphaPortIntelCalChip .lbl{ font-family:var(--mono); font-size:8px; color:rgba(220,230,255,.6); margin-top:2px; }
.gw2-alphaPortIntelCalChip.is-soon{ border-color:rgba(255,107,139,.55); background:rgba(255,107,139,.10); }

.gw2-alphaFocusCard{
  margin-top:10px;
  border-color:rgba(68,241,255,.26);
  background:linear-gradient(180deg,rgba(8,14,26,.98),rgba(7,11,22,.95));
}
.gw2-alphaFocusHead{
  display:flex; align-items:flex-start; justify-content:space-between; gap:14px;
}
.gw2-alphaFocusHeadMain{flex:1 1 auto; min-width:0}
.gw2-alphaFocusKicker{
  font-family:var(--mono); font-size:9px; letter-spacing:.14em;
  text-transform:uppercase; color:rgba(68,241,255,.8);
}
.gw2-alphaFocusTicker{
  margin-top:4px; font-family:var(--mono); font-size:24px; font-weight:800; color:#fff;
}
.gw2-alphaFocusName{
  margin-top:4px; font-family:var(--mono); font-size:12px; color:rgba(220,230,255,.78);
}
.gw2-alphaFocusActions{
  display:flex; flex-wrap:wrap; justify-content:flex-end; gap:6px;
}
.gw2-alphaFocusBody{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; margin-top:12px;
}
.gw2-alphaFocusPane{
  border:1px solid rgba(156,180,255,.12); border-radius:11px; padding:11px 12px;
  background:rgba(255,255,255,.02);
}
.gw2-alphaFocusPane.is-span-2{grid-column:1 / -1}
.gw2-alphaFocusPaneHd{
  font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  color:rgba(68,241,255,.78); margin-bottom:8px;
}
.gw2-alphaFocusGrid{
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:8px;
}
.gw2-alphaFocusMini{
  border:1px solid rgba(156,180,255,.1); border-radius:9px; padding:8px 9px;
  background:rgba(255,255,255,.02);
}
.gw2-alphaFocusMini .l{
  font-family:var(--mono); font-size:9px; letter-spacing:.08em; color:rgba(220,230,255,.62);
}
.gw2-alphaFocusMini .v{
  margin-top:5px; font-family:var(--mono); font-size:15px; font-weight:700; color:#fff;
}
.gw2-alphaFocusText{
  font-size:12px; line-height:1.6; color:rgba(232,239,255,.84);
}
.gw2-alphaFocusList{
  display:flex; flex-direction:column; gap:7px;
}
.gw2-alphaFocusListRow{
  display:flex; justify-content:space-between; gap:10px; font-size:11px; color:rgba(232,239,255,.84);
}
.gw2-alphaFocusListRow strong{
  flex:1 1 46%; min-width:0;
  font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:rgba(220,230,255,.62);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.gw2-alphaFocusListRow span{
  flex:0 1 54%; min-width:0; text-align:right;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  font-variant-numeric:tabular-nums;
}
.gw2-alphaFocusFlagList{
  display:flex; flex-wrap:wrap; gap:6px;
}
.gw2-alphaFocusLinks{
  display:flex; flex-wrap:wrap; gap:10px; margin-top:6px;
}
.gw2-alphaFocusLinks a{
  font-family:var(--mono); font-size:11px; color:#9fefff; text-decoration:none;
}
.gw2-alphaFocusLinks a:hover{text-decoration:underline}

.gw2-alphaPortIntelSync{
  display:flex; gap:14px; padding:12px 14px; margin-top:10px;
  font-family:var(--mono); font-size:11px; color:rgba(220,230,255,.85);
  background:rgba(10,16,30,.45); border:1px solid rgba(156,180,255,.15);
  border-radius:10px;
}
.gw2-alphaPortIntelSync .dot{
  display:inline-block; width:8px; height:8px; border-radius:50%;
  background:rgba(160,170,200,.50); margin-right:6px; vertical-align:middle;
}
.gw2-alphaPortIntelSync .dot.is-green { background:#5be4a5; box-shadow:0 0 6px rgba(91,228,165,.45); }
.gw2-alphaPortIntelSync .dot.is-amber { background:#ffcc66; }
.gw2-alphaPortIntelSync .dot.is-grey  { background:rgba(160,170,200,.45); }

/* ── Stock Deep-Dive panel ─────────────────────────────────────────────── */
.gw2-alphaDdPanel{
  margin-top:24px;
  border:1px solid rgba(68,241,255,.35);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(10,18,34,.85), rgba(6,10,20,.92));
  padding:16px 18px;
}
.gw2-alphaDdHead{
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  padding-bottom:12px; border-bottom:1px solid rgba(156,180,255,.18); margin-bottom:14px;
}
.gw2-alphaDdBack{
  background:transparent; border:1px solid rgba(156,180,255,.25);
  color:#fff; padding:4px 10px; border-radius:8px; cursor:pointer;
  font-family:var(--mono); font-size:14px;
}
.gw2-alphaDdBack:hover{ border-color:rgba(68,241,255,.55); }
.gw2-alphaDdHeadL{ flex:1 1 280px; }
.gw2-alphaDdTicker{
  font-family:var(--mono); font-size:24px; font-weight:800; color:#44f1ff; letter-spacing:.04em;
}
.gw2-alphaDdName{
  font-family:var(--mono); font-size:13px; color:rgba(220,230,255,.85); margin-top:2px;
}
.gw2-alphaDdChips{ display:flex; gap:6px; flex-wrap:wrap; margin-top:6px; }
.gw2-alphaDdChip{
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 9px; border-radius:999px; font-family:var(--mono);
  font-size:9px; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(68,241,255,.10); border:1px solid rgba(68,241,255,.35); color:#a8efff;
}
.gw2-alphaDdChip.is-pos{ background:rgba(91,228,165,.10); border-color:rgba(91,228,165,.45); color:#9af0c9; }
.gw2-alphaDdChip.is-neu{ background:rgba(200,210,230,.05); border-color:rgba(200,210,230,.25); color:rgba(220,230,255,.85); }
.gw2-alphaDdChip.is-link{ cursor:pointer; }
.gw2-alphaDdChip.is-link:hover{ filter:brightness(1.15); }
.gw2-alphaDdHeadR{ display:flex; flex-direction:column; align-items:flex-end; gap:2px; min-width:160px; }
.gw2-alphaDdPrice{ font-family:var(--mono); font-size:24px; font-weight:800; color:#fff; }
.gw2-alphaDdChg  { font-family:var(--mono); font-size:13px; color:rgba(220,230,255,.85); }
.gw2-alphaDdExt  { /* ext-hours strip — reuses .gw2-extHours markup */ }

.gw2-alphaDdActions{ display:flex; gap:10px; align-items:center; }
.gw2-alphaDdPicker{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--mono); font-size:10px; color:rgba(220,230,255,.7); letter-spacing:.08em;
}
.gw2-alphaDdInput{
  background:rgba(10,16,30,.7); border:1px solid rgba(156,180,255,.25);
  color:#fff; padding:5px 8px; border-radius:6px; font-family:var(--mono); font-size:13px;
  width:90px; text-transform:uppercase;
}
.gw2-alphaDdInput:focus{ border-color:rgba(68,241,255,.65); outline:none; }

.gw2-alphaDdMeta{
  font-family:var(--mono); font-size:11px; color:rgba(220,230,255,.65);
  margin-bottom:10px;
}
.gw2-alphaDdBody{ display:flex; flex-direction:column; gap:14px; }

@media (max-width:980px){
  .gw2-alphaFocusBody{grid-template-columns:1fr}
  .gw2-alphaFocusPane.is-span-2{grid-column:auto}
  .gw2-alphaFocusGrid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:620px){
  .gw2-alphaFocusHead{flex-direction:column}
  .gw2-alphaFocusActions{justify-content:flex-start}
  .gw2-alphaFocusGrid{grid-template-columns:1fr}
}

.gw2-alphaDdCardGrid{
  display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:14px;
}
@media (max-width: 980px){
  .gw2-alphaDdCardGrid{ grid-template-columns:1fr; }
}
.gw2-alphaDdCard{
  background:linear-gradient(180deg, rgba(20,28,48,.50), rgba(10,16,30,.62));
  border:1px solid rgba(156,180,255,.18);
  border-radius:12px; padding:14px 16px;
}
.gw2-alphaDdCard:hover{ border-color:rgba(156,180,255,.30); }
.gw2-alphaDdCardHd{
  font-family:var(--mono); font-size:12px; font-weight:700; color:#fff;
  letter-spacing:.08em; text-transform:uppercase; margin-bottom:10px;
}

.gw2-alphaDdOverviewGrid{
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.6fr); gap:14px;
}
.gw2-alphaDdOverviewSide dl{ display:grid; grid-template-columns:auto 1fr; gap:6px 12px; margin:0; font-family:var(--mono); font-size:11px; }
.gw2-alphaDdOverviewSide dt{ color:rgba(220,230,255,.6); }
.gw2-alphaDdOverviewSide dd{ margin:0; color:#fff; }
.gw2-alphaDdOverviewDesc{
  font-family:ui-sans-serif, system-ui, sans-serif; font-size:13px;
  line-height:1.5; color:rgba(220,230,255,.88);
}
.gw2-alphaDdCompetitors{ display:flex; gap:6px; flex-wrap:wrap; margin-top:8px; }
.gw2-alphaDdCompetitor{
  cursor:pointer; padding:3px 8px; border-radius:999px;
  font-family:var(--mono); font-size:9px; letter-spacing:.06em;
  background:rgba(156,180,255,.10); border:1px solid rgba(156,180,255,.30); color:#cdd6f4;
}
.gw2-alphaDdCompetitor:hover{ background:rgba(68,241,255,.15); border-color:rgba(68,241,255,.55); color:#fff; }

.gw2-alphaDdCeoGrid{ display:flex; gap:14px; }
.gw2-alphaDdCeoPhoto{
  width:96px; height:96px; border-radius:50%; overflow:hidden;
  background:linear-gradient(135deg, rgba(68,241,255,.20), rgba(150,200,255,.05));
  border:2px solid rgba(68,241,255,.35);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  font-family:var(--mono); font-size:28px; font-weight:800; color:#fff;
}
.gw2-alphaDdCeoPhoto img{ width:100%; height:100%; object-fit:cover; }
.gw2-alphaDdCeoBody{ flex:1; min-width:0; }
.gw2-alphaDdCeoName{ font-family:var(--mono); font-size:15px; font-weight:700; color:#fff; }
.gw2-alphaDdCeoTitle{ font-family:var(--mono); font-size:11px; color:rgba(220,230,255,.75); margin-top:2px; }
.gw2-alphaDdCeoFacts{ display:grid; grid-template-columns:auto 1fr; gap:4px 12px; font-family:var(--mono); font-size:11px; margin-top:10px; }
.gw2-alphaDdCeoFacts dt{ color:rgba(220,230,255,.6); }
.gw2-alphaDdCeoFacts dd{ margin:0; color:#fff; }
.gw2-alphaDdCeoBio{ font-family:ui-sans-serif, system-ui, sans-serif; font-size:12px; line-height:1.5; color:rgba(220,230,255,.85); margin-top:8px; }

.gw2-alphaDdChartCard{ /* uses default card */ }
.gw2-alphaDdChart{ width:100%; min-height:420px; border-radius:8px; overflow:hidden; }
.gw2-alphaDdMiniKpis{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(110px,1fr)); gap:8px; margin-bottom:10px;
}
.gw2-alphaDdMiniKpi{
  padding:6px 10px; border-radius:8px; background:rgba(10,16,30,.45);
  border:1px solid rgba(156,180,255,.15); text-align:center;
}
.gw2-alphaDdMiniKpi .l{ font-family:var(--mono); font-size:9px; color:rgba(220,230,255,.6); letter-spacing:.08em; text-transform:uppercase; }
.gw2-alphaDdMiniKpi .v{ font-family:var(--mono); font-size:14px; font-weight:700; color:#fff; margin-top:3px; }

.gw2-alphaDdFinCharts{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:10px; margin-bottom:12px;
}
.gw2-alphaDdFinChart{ height:180px; }
@media (max-width: 820px){ .gw2-alphaDdFinCharts{ grid-template-columns:1fr; } }

.gw2-alphaDdFilingTabs{ display:flex; gap:6px; margin-bottom:10px; flex-wrap:wrap; }
.gw2-alphaDdFilingTab{
  padding:4px 10px; border-radius:999px; cursor:pointer;
  font-family:var(--mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(156,180,255,.06); border:1px solid rgba(156,180,255,.25); color:rgba(220,230,255,.8);
}
.gw2-alphaDdFilingTab.is-active{ background:rgba(68,241,255,.15); border-color:rgba(68,241,255,.55); color:#fff; }
.gw2-alphaDdFilingTab:hover{ border-color:rgba(68,241,255,.45); }

.gw2-alphaDdTargets{ padding:10px 4px; }
.gw2-alphaDdTargetsBar{
  position:relative; height:38px; border-radius:8px;
  background:linear-gradient(90deg, rgba(255,107,139,.10), rgba(255,204,102,.10), rgba(91,228,165,.10));
  border:1px solid rgba(156,180,255,.20);
}
.gw2-alphaDdTargetsTick{
  position:absolute; top:-6px; bottom:-6px; width:2px; background:#fff;
  transform:translateX(-1px);
}
.gw2-alphaDdTargetsTick.is-mean{ background:#44f1ff; box-shadow:0 0 6px rgba(68,241,255,.65); }
.gw2-alphaDdTargetsLabels{ display:flex; justify-content:space-between; font-family:var(--mono); font-size:10px; color:rgba(220,230,255,.7); margin-top:6px; }
.gw2-alphaDdTargetsStats{ display:flex; gap:10px; flex-wrap:wrap; margin-top:10px; font-family:var(--mono); font-size:11px; color:#fff; }

/* Intelligence Signal tiles */
.gw2-alphaDdIntelCard{ background:linear-gradient(180deg, rgba(28,38,60,.55), rgba(10,16,30,.70)); }
.gw2-alphaDdIntelGrid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(150px,1fr)); gap:10px; }
.gw2-alphaDdIntelTile{
  padding:10px 12px; border-radius:10px;
  background:rgba(10,16,30,.55); border:1px solid rgba(156,180,255,.18);
  border-top:3px solid rgba(160,170,200,.50);
  min-height:88px; display:flex; flex-direction:column; gap:3px;
}
.gw2-alphaDdIntelTile.is-pos{ border-top-color:#5be4a5; }
.gw2-alphaDdIntelTile.is-neu{ border-top-color:#ffcc66; }
.gw2-alphaDdIntelTile.is-neg{ border-top-color:#ff6b8b; }
.gw2-alphaDdIntelTile .lbl{ font-family:var(--mono); font-size:9px; letter-spacing:.10em; text-transform:uppercase; color:rgba(220,230,255,.65); }
.gw2-alphaDdIntelTile .val{ font-family:var(--mono); font-size:22px; font-weight:800; color:#fff; }
.gw2-alphaDdIntelTile .sub{ font-family:var(--mono); font-size:10px; color:rgba(220,230,255,.65); }
.gw2-alphaDdIntelTile.is-pos .val{ color:#9af0c9; }
.gw2-alphaDdIntelTile.is-neg .val{ color:#ffb3c4; }
.gw2-alphaDdIntelTile .val .small{ font-size:14px; font-weight:600; color:rgba(220,230,255,.7); margin-left:4px; }

.gw2-alphaDdIntelGroupHd{
  grid-column: 1 / -1;
  font-family:var(--mono); font-size:10px; color:rgba(220,230,255,.55);
  letter-spacing:.10em; text-transform:uppercase; padding:8px 2px 0;
  border-top:1px dashed rgba(156,180,255,.12); margin-top:6px;
}
.gw2-alphaDdIntelGroupHd:first-of-type{ border-top:none; margin-top:0; padding-top:0; }

.gw2-alphaDdSources{
  margin-top:8px; font-family:var(--mono); font-size:10px;
  color:rgba(220,230,255,.55); padding:8px 4px;
}
.gw2-alphaDdSources a{ color:rgba(68,241,255,.75); text-decoration:none; }
.gw2-alphaDdSources a:hover{ text-decoration:underline; }

/* Privacy mask: dollar values inside the deep-dive should blur in is-priv mode */
.gw2-alphaDash.is-priv .gw2-alphaDdPrice,
.gw2-alphaDash.is-priv .gw2-alphaDdMiniKpi .v.is-money,
.gw2-alphaDash.is-priv .gw2-alphaDd-amt{
  filter:blur(6px);
}


/* ── Alpha View · Cash Holdings block ──────────────────────────────────── */
.gw2-alphaCashHd{
  border-left:3px solid rgba(91,228,165,.55);
  padding-left:10px;
}
.gw2-alphaCashRows{
  margin-top:10px;
  display:flex; flex-direction:column; gap:4px;
}
.gw2-alphaCashRow{
  display:flex; justify-content:space-between; gap:10px;
  font-family:var(--mono); font-size:11px;
  padding:5px 8px; border-radius:6px;
  background:rgba(91,228,165,.05); border:1px solid rgba(91,228,165,.15);
  color:rgba(220,230,255,.85);
}
.gw2-alphaCashRow .is-money{ color:#fff; }
.gw2-alphaCashNote{
  color:rgba(220,230,255,.55); font-style:italic; margin-left:6px;
}
.gw2-alphaCashStale{
  display:inline-block; margin-left:6px; padding:1px 6px;
  font-family:var(--mono); font-size:9px; letter-spacing:.06em;
  text-transform:uppercase; border-radius:999px;
  background:rgba(255,204,102,.15); border:1px solid rgba(255,204,102,.45); color:#ffcc66;
}
