/* OptionGap - Global Markets tab */

.gm-root { display: flex; flex-direction: column; gap: 22px; padding-bottom: 40px; }

.gm-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 24px;
  flex-wrap: wrap;
}
.gm-head > div:first-child { flex: 1 1 420px; min-width: 0; }
.gm-kicker {
  font-size: 11.5px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 6px;
}
.gm-title { font-size: var(--t-3xl); font-weight: 700; letter-spacing: -0.02em; color: var(--fg-0); margin: 0 0 8px; }
.gm-sub { font-size: 14px; color: var(--fg-1); max-width: 560px; margin: 0; line-height: 1.55; }
.gm-breadth {
  display: flex; flex-direction: column; align-items: flex-end; gap: 8px;
  flex: 0 0 auto;
}
.gm-breadth-row { display: flex; gap: 10px; }
.gm-breadth-pill {
  font-size: 12.5px; padding: 6px 12px; border-radius: 999px; border: 1px solid var(--bd-2);
  background: rgba(255,255,255,0.02); color: var(--fg-1); white-space: nowrap;
}
.gm-breadth-pill b { font-family: var(--font-mono); margin-right: 3px; }
.gm-breadth-pill.up b { color: var(--pos); }
.gm-breadth-pill.dn b { color: var(--neg); }
.gm-asof { font-size: 11px; color: var(--fg-3); text-align: right; }
.gm-refresh {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12.5px; font-weight: 600; padding: 6px 12px; border-radius: 999px;
  background: var(--accent-soft); border: 1px solid var(--accent-bd); color: var(--accent);
  cursor: pointer; transition: filter var(--ani-fast), background var(--ani-fast);
}
.gm-refresh:hover:not(:disabled) { filter: brightness(1.12); }
.gm-refresh:disabled { opacity: 0.7; cursor: default; }
.gm-refresh.spinning svg { animation: gmSpin 0.8s linear infinite; }
@keyframes gmSpin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .gm-refresh.spinning svg { animation: none; } }

.gm-grid { display: grid; grid-template-columns: minmax(0, 1.45fr) minmax(300px, 1fr); gap: 24px; align-items: stretch; }

/* globe */
.gm-globe-wrap {
  position: relative; background: var(--bg-card); border: 1px solid var(--bd-2);
  border-radius: var(--radius-xl); padding: 14px; box-shadow: var(--shadow-1);
  min-height: 540px; min-width: 0; overflow: hidden;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
}
.gm-globe-wrap .home-globe-stage { max-width: 100%; }
.gm-globe-fallback { padding: 40px; text-align: center; color: var(--fg-3); }
.gm-globe-legend {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
  margin-top: 6px; font-size: 11px; color: var(--fg-2);
}
.gm-globe-legend span { display: inline-flex; align-items: center; gap: 5px; }
.gm-globe-legend i { width: 12px; height: 12px; border-radius: 3px; display: inline-block; }
.gm-globe-legend .dn3 { background: hsl(2 78% 52%); }
.gm-globe-legend .dn1 { background: hsl(2 78% 52% / 0.4); }
.gm-globe-legend .flat { background: rgba(120,130,150,0.3); }
.gm-globe-legend .up1 { background: hsl(150 72% 48% / 0.4); }
.gm-globe-legend .up3 { background: hsl(150 72% 48%); }

/* board */
.gm-board {
  background: var(--bg-card); border: 1px solid var(--bd-2);
  border-radius: var(--radius-xl); padding: 14px; box-shadow: var(--shadow-1);
  display: flex; flex-direction: column; gap: 12px;
}
.gm-search {
  width: 100%; height: 38px; padding: 0 12px; border-radius: var(--radius);
  background: var(--bg-2); border: 1px solid var(--bd-2); color: var(--fg-0);
  font-size: 13px; font-family: var(--font-sans); outline: none;
}
.gm-search:focus { border-color: var(--accent-bd); box-shadow: 0 0 0 3px var(--accent-soft); }
.gm-board-scroll { max-height: 520px; overflow-y: auto; display: flex; flex-direction: column; gap: 16px; padding-right: 4px; }
.gm-region-h {
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--fg-2); margin-bottom: 6px; position: sticky; top: 0;
  background: var(--bg-card); padding: 4px 0; z-index: 1;
}
.gm-row {
  display: grid; grid-template-columns: 24px 1fr auto auto; align-items: center; gap: 10px;
  width: 100%; text-align: left; padding: 8px 10px; border: 1px solid transparent;
  border-radius: var(--radius); background: transparent; cursor: pointer;
  transition: background var(--ani-fast), border-color var(--ani-fast);
}
.gm-row:hover { background: rgba(255,255,255,0.03); border-color: var(--bd-2); }
.gm-row-flag { font-size: 17px; }
.gm-row-name { display: flex; flex-direction: column; min-width: 0; }
.gm-row-country { font-size: 13px; color: var(--fg-0); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gm-row-index { font-size: 10.5px; color: var(--fg-3); }
.gm-row-last { font-size: 12.5px; color: var(--fg-1); text-align: right; }
.gm-row-chg { font-size: 12.5px; font-weight: 600; text-align: right; min-width: 60px; }
.gm-row-chg.up { color: var(--pos); }
.gm-row-chg.dn { color: var(--neg); }
.gm-row-chg.na { color: var(--fg-3); font-weight: 400; }

/* chart modal */
.gm-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(5,6,9,0.72); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center; padding: 24px;
  animation: gmFade 0.18s ease;
}
@keyframes gmFade { from { opacity: 0; } to { opacity: 1; } }
.gm-modal {
  width: min(820px, 100%); background: var(--bg-1); border: 1px solid var(--bd-3);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-2); overflow: hidden;
  animation: gmRise 0.2s cubic-bezier(.2,.8,.2,1);
}
@keyframes gmRise { from { transform: translateY(12px); opacity: 0; } to { transform: none; opacity: 1; } }
.gm-modal-hd {
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
  padding: 16px 18px; border-bottom: 1px solid var(--bd-1);
}
.gm-modal-ttl { display: flex; align-items: center; gap: 12px; }
.gm-modal-flag { font-size: 28px; }
.gm-modal-country { font-size: 17px; font-weight: 700; color: var(--fg-0); }
.gm-modal-index { font-size: 11.5px; color: var(--fg-2); font-family: var(--font-mono); }
.gm-modal-hd-r { display: flex; align-items: center; gap: 16px; }
.gm-modal-quote { display: flex; flex-direction: column; align-items: flex-end; gap: 1px; }
.gm-modal-last { font-size: 16px; font-weight: 700; color: var(--fg-0); }
.gm-modal-chg { font-size: 13px; font-weight: 600; }
.gm-modal-chg.up { color: var(--pos); }
.gm-modal-chg.dn { color: var(--neg); }
.gm-modal-close {
  width: 34px; height: 34px; border-radius: 8px; display: grid; place-items: center;
  background: rgba(255,255,255,0.04); border: 1px solid var(--bd-2); color: var(--fg-1); cursor: pointer;
}
.gm-modal-close:hover { background: rgba(255,255,255,0.08); color: var(--fg-0); }
.gm-modal-ranges { display: flex; gap: 4px; margin: 10px 18px 0; width: fit-content; }
.gm-modal-ranges button { min-width: 44px; }
.gm-modal-body { padding: 8px; min-height: 320px; }
.gm-modal-chart { width: 100%; height: 360px; }
.gm-modal-state {
  display: flex; align-items: center; justify-content: center; text-align: center;
  height: 320px; padding: 30px; color: var(--fg-2); font-size: 14px; line-height: 1.6; max-width: 460px; margin: 0 auto;
}
.gm-modal-foot {
  padding: 10px 18px; border-top: 1px solid var(--bd-1);
  font-size: 11px; color: var(--fg-3); text-align: center;
}

@media (max-width: 980px) {
  .gm-grid { grid-template-columns: 1fr; }
  .gm-globe-wrap { min-height: 420px; }
}
