/* ═══════════════════════════
   SEC 2 — NEXUS GLOBE
═══════════════════════════ */
#s2{
  background:radial-gradient(ellipse at 60% 50%,rgba(0,70,150,.07) 0%,transparent 65%),var(--obs);
  position:relative;
  overflow:visible;
}

#globe-wrap{position:relative;width:min(580px,88vw);height:min(580px,88vw);margin:0 auto;cursor:grab;flex-shrink:0}
#globe-wrap:active{cursor:grabbing}
#globeCanvas{width:100%;height:100%}

.globe-hint{font-size:9px;color:rgba(0,242,255,.3);letter-spacing:.2em;text-transform:uppercase;margin-top:12px;text-align:center}

/* ── Tour HUD ── */
#globe-tour-hud{
  position:absolute;top:12px;left:50%;transform:translateX(-50%);
  z-index:10;display:flex;align-items:center;gap:10px;
  padding:6px 16px;background:rgba(0,4,18,.88);
  border:1px solid rgba(0,242,255,.18);
  clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
  opacity:0;transition:opacity .5s;pointer-events:none;white-space:nowrap
}
#globe-tour-hud.on{opacity:1}
.hud-dot{width:5px;height:5px;border-radius:50%;background:var(--nm);box-shadow:0 0 6px var(--nm);animation:pulse 1s infinite}
.hud-label{font-family:var(--fd);font-size:7px;letter-spacing:.3em;color:var(--cb);text-transform:uppercase}
.hud-progress{font-family:var(--fd);font-size:7px;letter-spacing:.2em;color:rgba(0,242,255,.5)}
.hud-skip{
  font-family:var(--fd);font-size:7px;letter-spacing:.2em;color:rgba(184,204,238,.28);
  cursor:pointer;pointer-events:all;margin-left:6px;
  border-left:1px solid rgba(0,242,255,.1);padding-left:10px;transition:color .2s;
  touch-action:manipulation;
  padding-top:8px;padding-bottom:8px; /* enlarge tap target vertically */
}
.hud-skip:hover{color:var(--cb)}

/* ═══════════════════════════
   CITY NAMES PANEL
═══════════════════════════ */
#city-list-panel{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  width:min(620px,92vw);
  justify-content:center;
  padding:20px 0 10px;
  flex-shrink:0;
}

/* ─────────────────────────────────────────────
   CITY BUTTON — Tron edition
   Bigger, brighter, animated scan line + corners
───────────────────────────────────────────── */
.clist-btn{
  background:rgba(0,4,18,.80);
  border:1px solid rgba(0,242,255,.18);
  padding:11px 15px 11px 12px;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
  transition:border-color .28s, background .28s, transform .22s, box-shadow .28s;
  clip-path:polygon(7px 0,100% 0,calc(100% - 7px) 100%,0 100%);
  flex:1 1 160px;
  max-width:200px;
  text-align:left;
  position:relative;
  overflow:hidden;
  /* ── Mobile: remove tap delay and ensure finger-sized target ── */
  touch-action: manipulation;
  min-height: 52px;          /* Apple/Google recommended minimum tap target */
  -webkit-tap-highlight-color: transparent;
}

/* top gradient line */
.clist-btn::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--ccol,#00f2ff),transparent);
  opacity:.35;transition:opacity .28s;
  z-index:1;
}

/* Tron sweep — the scan-line that crosses on hover */
.clist-btn::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(
    108deg,
    transparent 38%,
    rgba(255,255,255,.055) 50%,
    transparent 62%
  );
  transform:translateX(-130%);
  pointer-events:none;
  z-index:2;
}

.clist-btn:hover{
  background:rgba(0,8,32,.96);
  border-color:var(--ccol,#00f2ff);
  transform:translateY(-4px) scale(1.018);
  box-shadow:
    0 10px 28px rgba(0,0,0,.55),
    0 0 0 1px var(--ccol,#00f2ff),
    0 0 18px rgba(0,242,255,.12),
    inset 0 0 16px rgba(0,242,255,.04);
}
.clist-btn:hover::before{opacity:1}
.clist-btn:hover::after{
  animation:tron-sweep .6s ease-in-out forwards;
}

/* ── Touch active state: show Tron effect on tap ── */
.clist-btn:active{
  background:rgba(0,12,40,.98);
  border-color:var(--ccol,#00f2ff);
  transform:scale(.97);
  box-shadow:
    0 0 0 2px var(--ccol,#00f2ff),
    0 0 20px rgba(0,242,255,.25),
    inset 0 0 16px rgba(0,242,255,.1);
}
.clist-btn:active::before{opacity:1}
.clist-btn:active::after{
  animation:tron-sweep .4s ease-out forwards;
}
.clist-btn:active .clist-corner{opacity:1}
.clist-btn:active .clist-name{color:#fff;text-shadow:0 0 10px var(--ccol,#00f2ff)}

/* ── JS-driven press (touchstart → .btn-pressing, touchend removes it)
   Reliable on all mobile browsers — CSS :active is not guaranteed on iOS  ── */
.clist-btn.btn-pressing{
  background:rgba(0,12,40,.98) !important;
  border-color:var(--ccol,#00f2ff) !important;
  transform:scale(.97) !important;
  box-shadow:
    0 0 0 2px var(--ccol,#00f2ff),
    0 0 24px rgba(0,242,255,.32),
    inset 0 0 18px rgba(0,242,255,.14) !important;
  transition:transform .08s ease, box-shadow .08s ease, background .08s ease !important;
}
.clist-btn.btn-pressing::before{opacity:1 !important}
.clist-btn.btn-pressing::after{
  animation:tron-sweep .4s ease-out forwards !important;
}
.clist-btn.btn-pressing .clist-corner{opacity:1 !important}
.clist-btn.btn-pressing .clist-name{
  color:#fff !important;
  text-shadow:0 0 12px var(--ccol,#00f2ff) !important;
}

/* On touch devices: reset sticky :hover states after tap */
@media(hover:none){
  .clist-btn:hover{
    transform:none;
    background:rgba(0,4,18,.80);
    border-color:rgba(0,242,255,.18);
    box-shadow:none;
  }
  .clist-btn:hover::before{opacity:.35}
  .clist-btn:hover::after{animation:none}
  .clist-btn:hover .clist-name{color:#e8f0ff;text-shadow:none}
  .clist-btn:hover .clist-corner{opacity:0}
}

@keyframes tron-sweep{
  from{transform:translateX(-130%)}
  to  {transform:translateX(160%)}
}

/* ── Click / fire animation ── */
.clist-btn.btn-firing{
  animation:tron-fire .65s cubic-bezier(.22,1,.36,1) forwards;
}
@keyframes tron-fire{
  0%  {
    box-shadow:
      0 0 0 0   var(--ccol,#00f2ff),
      0 0 0 0   rgba(0,242,255,.0),
      inset 0 0 0 0 rgba(0,242,255,.18);
  }
  20% {
    box-shadow:
      0 0 0 3px var(--ccol,#00f2ff),
      0 0 24px 6px rgba(0,242,255,.28),
      inset 0 0 18px 2px rgba(0,242,255,.14);
    background:rgba(0,16,50,.98);
    border-color:var(--ccol,#00f2ff);
    transform:translateY(-5px) scale(1.03);
  }
  55% {
    box-shadow:
      0 0 0 5px rgba(0,242,255,.15),
      0 0 40px 10px rgba(0,242,255,.08),
      inset 0 0 24px 4px rgba(0,242,255,.06);
    transform:translateY(-3px) scale(1.015);
  }
  100%{
    box-shadow:
      0 10px 28px rgba(0,0,0,.55),
      0 0 0 1px var(--ccol,#00f2ff),
      0 0 18px rgba(0,242,255,.12);
    transform:translateY(-4px) scale(1.018);
    background:rgba(0,8,32,.96);
    border-color:var(--ccol,#00f2ff);
  }
}

/* ── Tron corner bracket accents ── */
.clist-corner{
  position:absolute;
  width:7px;height:7px;
  pointer-events:none;
  z-index:3;
  opacity:0;
  transition:opacity .25s;
}
.clist-btn:hover .clist-corner,
.clist-btn.tour-active .clist-corner,
.clist-btn.btn-firing .clist-corner{opacity:1}

.clist-corner-tl{
  top:2px;left:4px;
  border-top:1.5px solid var(--ccol,#00f2ff);
  border-left:1.5px solid var(--ccol,#00f2ff);
}
.clist-corner-br{
  bottom:2px;right:4px;
  border-bottom:1.5px solid var(--ccol,#00f2ff);
  border-right:1.5px solid var(--ccol,#00f2ff);
}

/* ── Icon ── */
.clist-icon{font-size:19px;flex-shrink:0;line-height:1;position:relative;z-index:4}

/* ── Text block ── */
.clist-text{display:flex;flex-direction:column;gap:3px;min-width:0;overflow:hidden;position:relative;z-index:4}

.clist-name{
  font-family:var(--fd);font-size:8.5px;letter-spacing:.18em;
  color:#e8f0ff;text-transform:uppercase;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;
  transition:color .22s;
}
.clist-btn:hover .clist-name,
.clist-btn.tour-active .clist-name{color:#fff;text-shadow:0 0 10px var(--ccol,#00f2ff)}

.clist-role{
  font-size:7.5px;letter-spacing:.07em;
  color:rgba(184,204,238,.50);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:color .22s;
}
.clist-btn:hover .clist-role{color:rgba(200,220,255,.72)}

/* ── Tour-active state ── */
.clist-btn.tour-active{
  border-color:var(--ccol,#00f2ff) !important;
  background:rgba(0,10,32,.98) !important;
  animation:clist-pulse 1.1s ease-in-out infinite;
}
.clist-btn.tour-active::before{opacity:1}

@keyframes clist-pulse{
  0%,100%{box-shadow:0 0 8px rgba(0,242,255,.12),0 4px 14px rgba(0,0,0,.35)}
  50%    {box-shadow:0 0 22px rgba(0,242,255,.5),0 8px 24px rgba(0,0,0,.45)}
}

/* ── Rotating-to label ── */
.clist-btn.btn-rotating .clist-role::after{
  content:' · LOCKING…';
  color:var(--ccol,#00f2ff);
  animation:blink-dot .7s steps(1) infinite;
}
@keyframes blink-dot{0%,100%{opacity:1}50%{opacity:0}}

/* ── Mobile ── */
@media(max-width:480px){
  #city-list-panel{
    gap:7px;
    width:min(580px,96vw);
    /* Make the panel scrollable horizontally if buttons overflow */
    padding-left: 4px;
    padding-right: 4px;
  }
  .clist-btn{
    flex:1 1 140px;
    max-width:172px;
    padding:10px 12px 10px 10px;
    min-height:54px;
    /* Remove clip-path on mobile — it clips the hit area and looks rough on small screens */
    clip-path: none;
    border-radius: 2px;
    gap:8px;
  }
  .clist-icon{font-size:18px}
  .clist-name{font-size:8px;letter-spacing:.12em}
  .clist-role{font-size:7px}
}

/* Very small phones — squeeze to single row of wider buttons */
@media(max-width:340px){
  .clist-btn{flex:1 1 100%;max-width:100%;min-height:50px}
}

/* ═══════════════════════════
   CITY MODAL (Rich Company Card)
═══════════════════════════ */
#city-overlay{position:absolute;inset:0;z-index:20;pointer-events:none;display:flex;align-items:center;justify-content:center}
/* pointer-events:none by default — only becomes interactive when .on is added */
.city-modal{background:rgba(0,4,18,.96);border:1px solid rgba(0,242,255,.22);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);width:420px;max-width:calc(100vw - 32px);max-height:90vh;overflow-y:auto;clip-path:polygon(0 0,calc(100% - 22px) 0,100% 22px,100% 100%,22px 100%,0 calc(100% - 22px));transform:scale(.86) translateY(14px);opacity:0;transition:all .45s cubic-bezier(.16,1,.3,1);pointer-events:none;position:relative;scrollbar-width:none}
.city-modal::-webkit-scrollbar{display:none}
.city-modal.on{transform:scale(1) translateY(0);opacity:1;pointer-events:all}
.city-modal::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cb) 40%,var(--nm) 60%,transparent);z-index:1}
.city-modal::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(0,242,255,.18),transparent)}

.cm-header{padding:20px 24px 16px;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid rgba(0,242,255,.07)}
.cm-location-row{display:flex;align-items:center;gap:7px}
.cm-pin{font-size:11px}
.cm-city{font-family:var(--fd);font-size:8px;letter-spacing:.32em;color:var(--cb);opacity:.7;text-transform:uppercase}
.cm-close{font-size:8px;color:rgba(184,204,238,.3);cursor:pointer;letter-spacing:.2em;font-family:var(--fd);background:none;border:1px solid rgba(0,242,255,.1);transition:all .2s;padding:8px 12px;clip-path:polygon(6px 0,100% 0,calc(100% - 6px) 100%,0 100%);white-space:nowrap;touch-action:manipulation;min-height:40px}
.cm-close:hover{color:var(--cb);border-color:rgba(0,242,255,.4);background:rgba(0,242,255,.06)}

.cm-identity{padding:20px 24px 16px;display:flex;align-items:center;gap:16px;border-bottom:1px solid rgba(0,242,255,.06)}
.cm-logo{width:54px;height:54px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;position:relative;border:1px solid rgba(255,255,255,.07)}
.cm-logo::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.04),transparent)}
.cm-company-name{font-family:var(--fd);font-size:15px;font-weight:700;color:#fff;letter-spacing:.1em;line-height:1.2;margin-bottom:5px}
.cm-industry-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cm-industry{font-size:8px;padding:2px 9px;border:1px solid;letter-spacing:.12em;text-transform:uppercase;opacity:.85}
.cm-status-dot{width:6px;height:6px;border-radius:50%;background:var(--nm);box-shadow:0 0 6px var(--nm);flex-shrink:0;animation:pulse 2.2s infinite}
.cm-status-text{font-size:8px;color:var(--nm);letter-spacing:.15em;text-transform:uppercase}

.cm-role-block{padding:14px 24px;border-bottom:1px solid rgba(0,242,255,.06)}
.cm-role-label{font-size:7px;letter-spacing:.35em;color:rgba(0,242,255,.4);text-transform:uppercase;margin-bottom:4px}
.cm-role{font-family:var(--fd);font-size:17px;font-weight:700;color:#fff;letter-spacing:.06em;line-height:1.2}

.cm-metrics{padding:14px 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;border-bottom:1px solid rgba(0,242,255,.06)}
.cm-metric{background:rgba(0,242,255,.03);border:1px solid rgba(0,242,255,.08);padding:10px 10px 8px;text-align:center;clip-path:polygon(4px 0,100% 0,calc(100% - 4px) 100%,0 100%)}
.cm-metric-val{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--cb);line-height:1;margin-bottom:4px;text-shadow:0 0 12px rgba(0,242,255,.4)}
.cm-metric-lbl{font-size:7px;color:rgba(184,204,238,.35);letter-spacing:.14em;text-transform:uppercase}

.cm-impact-block{padding:14px 24px;border-bottom:1px solid rgba(0,242,255,.06)}
.cm-section-label{font-size:7px;letter-spacing:.35em;color:rgba(0,242,255,.4);text-transform:uppercase;margin-bottom:8px}
.cm-impact-list{display:flex;flex-direction:column;gap:5px}
.cm-impact-item{display:flex;align-items:flex-start;gap:8px;font-size:9.5px;color:rgba(184,204,238,.65);line-height:1.55;letter-spacing:.03em}
.cm-impact-arrow{color:var(--nm);flex-shrink:0;font-size:8px;margin-top:2px}

.cm-detail-block{padding:14px 24px;border-bottom:1px solid rgba(0,242,255,.06)}
.cm-detail{font-size:9.5px;color:rgba(184,204,238,.5);line-height:1.85;letter-spacing:.03em}

.cm-tags-block{padding:14px 24px;border-bottom:1px solid rgba(0,242,255,.06)}
.cm-tags{display:flex;flex-wrap:wrap;gap:5px}
.cm-tag{font-size:7px;padding:3px 9px;background:rgba(0,242,255,.04);border:1px solid rgba(0,242,255,.14);color:var(--cb);letter-spacing:.12em;text-transform:uppercase;transition:all .18s;cursor:default}
.cm-tag:hover{background:rgba(0,242,255,.09);border-color:rgba(0,242,255,.32)}

.cm-footer{padding:14px 24px 20px;display:flex;gap:10px}
.cm-btn{flex:1;padding:12px;font-family:var(--fd);font-size:8px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:all .25s;border:1px solid;clip-path:polygon(7px 0,100% 0,calc(100% - 7px) 100%,0 100%);background:transparent;text-align:center;touch-action:manipulation;min-height:44px}
.cm-btn-primary{color:var(--cb);border-color:rgba(0,242,255,.35)}
.cm-btn-primary:hover{background:rgba(0,242,255,.08);border-color:var(--cb);box-shadow:0 0 16px rgba(0,242,255,.12)}
.cm-btn-secondary{color:rgba(184,204,238,.4);border-color:rgba(184,204,238,.12)}
.cm-btn-secondary:hover{color:var(--dim);border-color:rgba(184,204,238,.25)}

/* ── Tour Pin Label ── */
#globe-pin-label {
  position: absolute;
  pointer-events: none;
  z-index: 15;
  /* offset right of the pin centre */
  transform: translate(18px, -50%);
  opacity: 0;
  transition: opacity .38s ease;
  display: flex;
  align-items: center;
  gap: 9px;
  background: rgba(0,4,20,.88);
  border: 1px solid rgba(0,242,255,.28);
  backdrop-filter: blur(10px);
  padding: 8px 14px 8px 10px;
  clip-path: polygon(6px 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
  white-space: nowrap;
  /* connecting line from label back to pin */
}
#globe-pin-label::before {
  content: '';
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,242,255,.5));
}
#globe-pin-label.on {
  opacity: 1;
}

.pnl-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  animation: pulse 1.1s infinite;
}
.pnl-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pnl-name {
  font-family: var(--fd);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  line-height: 1.2;
}
.pnl-country {
  font-family: var(--fd);
  font-size: 7px;
  letter-spacing: .28em;
  color: rgba(0,242,255,.42);
  text-transform: uppercase;
}
.pnl-role {
  font-size: 7.5px;
  letter-spacing: .06em;
  color: rgba(184,204,238,.55);
  margin-top: 1px;
}

@media(max-width:480px){
  #globe-pin-label { padding: 6px 10px 6px 8px; gap: 7px; }
  .pnl-name  { font-size: 8.5px; }
  .pnl-role  { font-size: 7px; }
}
