/* ═══════════════════════════════════════════════════════
   Forge Site Selector — Plugin Styles
   All selectors scoped under .fss-wrap to prevent
   conflicts with WordPress / Elementor / theme styles.
   ═══════════════════════════════════════════════════════ */

.fss-wrap {
  --fss-bg:     #060911;
  --fss-bg2:    #0b1018;
  --fss-panel:  rgba(9,14,23,0.96);
  --fss-card:   rgba(14,20,32,0.88);
  --fss-border: rgba(56,189,248,0.11);
  --fss-bhi:    rgba(56,189,248,0.36);
  --fss-orange: #F97316;
  --fss-od:     rgba(249,115,22,0.13);
  --fss-blue:   #38BDF8;
  --fss-txt:    #DCE8F4;
  --fss-txt2:   #7A90A8;
  --fss-txt3:   #354D65;
  --fss-green:  #34D399;
  --fss-yellow: #FBBF24;
  --fss-red:    #F87171;
  --fss-purple: #A78BFA;
  --fss-grid:   rgba(56,189,248,0.028);

  font-family: 'Barlow', sans-serif;
  background: var(--fss-bg);
  background-image:
    linear-gradient(var(--fss-grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--fss-grid) 1px, transparent 1px);
  background-size: 32px 32px;
  color: var(--fss-txt);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-sizing: border-box;
  position: relative;
}

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

/* ── HEADER ────────────────────────────────────────────── */
.fss-wrap .fss-header {
  height: 50px;
  background: var(--fss-bg2);
  border-bottom: 1px solid var(--fss-border);
  display: flex;
  align-items: center;
  padding: 0 18px;
  gap: 14px;
  flex-shrink: 0;
  z-index: 900;
}
.fss-wrap .fss-logo {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 3px;
  color: var(--fss-orange);
  text-transform: uppercase;
  white-space: nowrap;
}
.fss-wrap .fss-logo span { color: var(--fss-txt2); font-weight: 400; }
.fss-wrap .fss-hd  { width: 1px; height: 22px; background: var(--fss-border); flex-shrink: 0; }
.fss-wrap .fss-htag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 2.5px;
  color: var(--fss-blue); opacity: .65; text-transform: uppercase;
}
.fss-wrap .fss-hright { margin-left: auto; display: flex; align-items: center; gap: 10px; }

/* Status chip */
.fss-wrap .fss-dchip {
  display: flex; align-items: center; gap: 7px;
  padding: 4px 10px; border-radius: 3px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase;
  border: 1px solid var(--fss-border); background: var(--fss-card);
  transition: all .4s; white-space: nowrap;
}
.fss-wrap .fss-dd { width: 5px; height: 5px; border-radius: 50%; }
.fss-wrap .fss-dchip.fss-loading { color: var(--fss-yellow); border-color: rgba(251,191,36,.28); }
.fss-wrap .fss-dchip.fss-loading .fss-dd { background: var(--fss-yellow); box-shadow: 0 0 6px var(--fss-yellow); animation: fss-blink 1s infinite; }
.fss-wrap .fss-dchip.fss-live    { color: var(--fss-green);  border-color: rgba(52,211,153,.28); }
.fss-wrap .fss-dchip.fss-live .fss-dd    { background: var(--fss-green); box-shadow: 0 0 8px var(--fss-green); }
.fss-wrap .fss-dchip.fss-sim     { color: var(--fss-txt2);   border-color: var(--fss-border); }
.fss-wrap .fss-dchip.fss-sim .fss-dd     { background: var(--fss-txt3); }

@keyframes fss-blink { 0%,100%{opacity:1} 50%{opacity:.25} }

/* ── APP LAYOUT ────────────────────────────────────────── */
.fss-wrap .fss-app { display: flex; flex: 1; overflow: hidden; min-height: 0; }

/* ── SIDEBAR ───────────────────────────────────────────── */
.fss-wrap .fss-sb {
  width: 252px; flex-shrink: 0;
  background: var(--fss-panel);
  border-right: 1px solid var(--fss-border);
  display: flex; flex-direction: column;
  overflow-y: auto;
  backdrop-filter: blur(18px);
}
.fss-wrap .fss-sb::-webkit-scrollbar { width: 3px; }
.fss-wrap .fss-sb::-webkit-scrollbar-thumb { background: var(--fss-border); }
.fss-wrap .fss-sbl { padding: 14px 16px; border-bottom: 1px solid var(--fss-border); }
.fss-wrap .fss-sblabel {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px; letter-spacing: 3px; color: var(--fss-txt3);
  text-transform: uppercase; margin-bottom: 11px;
}

/* Layer toggles */
.fss-wrap .fss-ltog {
  display: flex; align-items: center; gap: 9px;
  padding: 7px 0; cursor: pointer; user-select: none;
}
.fss-wrap .fss-ltog:hover .fss-ln { color: var(--fss-txt); }
.fss-wrap .fss-tt {
  width: 30px; height: 15px; border-radius: 8px;
  background: var(--fss-card); border: 1px solid var(--fss-border);
  position: relative; flex-shrink: 0; transition: border-color .25s;
}
.fss-wrap .fss-tb {
  position: absolute; width: 9px; height: 9px;
  border-radius: 50%; background: var(--fss-txt3);
  top: 2px; left: 2px; transition: left .25s, background .25s;
}
.fss-wrap .fss-ltog.fss-on .fss-tt { border-color: rgba(56,189,248,.45); }
.fss-wrap .fss-ltog.fss-on .fss-tb { left: 18px; background: var(--fss-blue); }
.fss-wrap .fss-ld  { width: 7px; height: 7px; border-radius: 2px; flex-shrink: 0; }
.fss-wrap .fss-ln  { font-size: 12px; color: var(--fss-txt2); font-weight: 500; transition: color .2s; }
.fss-wrap .fss-ltog.fss-on .fss-ln { color: var(--fss-txt); }
.fss-wrap .fss-lbadge {
  margin-left: auto; font-family: 'JetBrains Mono', monospace;
  font-size: 7.5px; letter-spacing: 1px; padding: 2px 5px; border-radius: 2px;
}
.fss-wrap .fss-lbadge.fss-real { background: rgba(52,211,153,.08); color: var(--fss-green); border: 1px solid rgba(52,211,153,.2); }
.fss-wrap .fss-lbadge.fss-sim  { background: rgba(255,255,255,.03); color: var(--fss-txt3);  border: 1px solid rgba(255,255,255,.07); }

/* Branch list */
.fss-wrap .fss-bi  { display: flex; align-items: center; gap: 8px; padding: 6px 0; cursor: pointer; transition: opacity .15s; }
.fss-wrap .fss-bi:hover { opacity: .75; }
.fss-wrap .fss-bcode { font-family: 'JetBrains Mono', monospace; font-size: 9.5px; color: var(--fss-orange); width: 34px; flex-shrink: 0; }
.fss-wrap .fss-bcity { font-size: 11px; color: var(--fss-txt2); }
.fss-wrap .fss-bst   { font-size: 10px; color: var(--fss-txt3); margin-left: auto; }

/* Score guide */
.fss-wrap .fss-grow { display: flex; align-items: center; gap: 8px; padding: 3px 0; font-size: 11px; color: var(--fss-txt2); }
.fss-wrap .fss-gd   { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }

/* Data sources */
.fss-wrap .fss-srcrow { padding: 3px 0; font-size: 10px; color: var(--fss-txt3); line-height: 1.7; }
.fss-wrap .fss-srclive { color: var(--fss-green); }

/* ── MAP ───────────────────────────────────────────────── */
.fss-wrap .fss-mw   { flex: 1; position: relative; min-width: 0; }
.fss-wrap #fss-map  { width: 100%; height: 100%; }
.fss-wrap .fss-mhint {
  position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%);
  z-index: 500; background: rgba(9,14,23,.9);
  border: 1px solid rgba(56,189,248,.2); border-radius: 6px;
  padding: 9px 18px; font-family: 'JetBrains Mono', monospace;
  font-size: 10px; color: var(--fss-blue); letter-spacing: 2px;
  backdrop-filter: blur(8px); pointer-events: none;
  transition: opacity .5s; white-space: nowrap;
}
.fss-wrap .fss-mhint.fss-gone { opacity: 0; }

/* ── SCORE PANEL ───────────────────────────────────────── */
.fss-wrap .fss-sp {
  width: 318px; flex-shrink: 0;
  background: var(--fss-panel); border-left: 1px solid var(--fss-border);
  backdrop-filter: blur(18px);
  display: flex; flex-direction: column; overflow-y: auto;
  transform: translateX(100%);
  transition: transform .42s cubic-bezier(.22,1,.36,1);
}
.fss-wrap .fss-sp.fss-open { transform: translateX(0); }
.fss-wrap .fss-sp::-webkit-scrollbar { width: 3px; }
.fss-wrap .fss-sp::-webkit-scrollbar-thumb { background: var(--fss-border); }

.fss-wrap .fss-ph {
  padding: 13px 15px; border-bottom: 1px solid var(--fss-border);
  display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.fss-wrap .fss-pt {
  font-family: 'Rajdhani', sans-serif; font-size: 13px; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase; color: var(--fss-blue);
}
.fss-wrap .fss-px {
  width: 24px; height: 24px; background: var(--fss-card);
  border: 1px solid var(--fss-border); border-radius: 4px; cursor: pointer;
  display: grid; place-items: center; color: var(--fss-txt2);
  font-size: 12px; transition: all .18s;
}
.fss-wrap .fss-px:hover { border-color: var(--fss-bhi); color: var(--fss-txt); }

.fss-wrap .fss-pcoords {
  padding: 9px 15px; border-bottom: 1px solid var(--fss-border);
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px;
  color: var(--fss-txt3); letter-spacing: .5px; flex-shrink: 0;
}

/* County stats */
.fss-wrap .fss-pcounty { padding: 12px 15px; border-bottom: 1px solid var(--fss-border); flex-shrink: 0; }
.fss-wrap .fss-cname {
  font-family: 'Rajdhani', sans-serif; font-size: 16px; font-weight: 600;
  letter-spacing: 1px; color: var(--fss-txt); margin-bottom: 8px;
}
.fss-wrap .fss-cname small { font-size: 11px; font-weight: 400; color: var(--fss-txt2); letter-spacing: 0; font-family: 'Barlow', sans-serif; }
.fss-wrap .fss-cstats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.fss-wrap .fss-cstat { background: var(--fss-card); border: 1px solid var(--fss-border); border-radius: 4px; padding: 6px 9px; }
.fss-wrap .fss-cstat-val { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--fss-txt); font-weight: 500; }
.fss-wrap .fss-cstat-lbl { font-size: 9.5px; color: var(--fss-txt3); margin-top: 1px; }
.fss-wrap .fss-cstat-src { font-size: 8px; color: var(--fss-green); letter-spacing: .5px; margin-top: 2px; font-family: 'JetBrains Mono', monospace; }
.fss-wrap .fss-pcounty-sim { font-size: 9.5px; color: var(--fss-txt3); font-family: 'JetBrains Mono', monospace; letter-spacing: 1px; padding: 4px 0; line-height: 1.6; }

/* Loading */
.fss-wrap .fss-pload { padding: 44px 16px; display: flex; flex-direction: column; align-items: center; gap: 14px; }
.fss-wrap .fss-sring {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid var(--fss-border); border-top-color: var(--fss-blue);
  animation: fss-spin .75s linear infinite;
}
@keyframes fss-spin { to { transform: rotate(360deg); } }
.fss-wrap .fss-ltxt {
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px;
  color: var(--fss-txt3); letter-spacing: 2px; text-align: center; line-height: 1.8; white-space: pre-line;
}

/* Score circle */
.fss-wrap .fss-scw { padding: 20px 16px 16px; border-bottom: 1px solid var(--fss-border); display: flex; flex-direction: column; align-items: center; gap: 10px; }
.fss-wrap .fss-scirc { position: relative; width: 116px; height: 116px; }
.fss-wrap .fss-scirc svg { transform: rotate(-90deg); }
.fss-wrap .fss-arc-bg  { fill: none; stroke: var(--fss-border); stroke-width: 6; }
.fss-wrap .fss-arc-fill {
  fill: none; stroke-width: 6; stroke-linecap: round;
  stroke-dasharray: 315; stroke-dashoffset: 315;
  transition: stroke-dashoffset 1.1s cubic-bezier(.22,1,.36,1), stroke .4s;
}
.fss-wrap .fss-snum {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Rajdhani', sans-serif; font-size: 38px; font-weight: 700;
}
.fss-wrap .fss-vb { padding: 3px 13px; border-radius: 3px; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 2.5px; font-weight: 500; text-transform: uppercase; }
.fss-wrap .fss-go  { background: rgba(52,211,153,.09);  color: var(--fss-green);  border: 1px solid rgba(52,211,153,.28); }
.fss-wrap .fss-cau { background: rgba(251,191,36,.09);  color: var(--fss-yellow); border: 1px solid rgba(251,191,36,.28); }
.fss-wrap .fss-ng  { background: rgba(248,113,113,.09); color: var(--fss-red);    border: 1px solid rgba(248,113,113,.28); }

/* Sub-scores */
.fss-wrap .fss-subs { padding: 14px 15px; border-bottom: 1px solid var(--fss-border); display: flex; flex-direction: column; gap: 10px; }
.fss-wrap .fss-subr { display: flex; flex-direction: column; gap: 5px; }
.fss-wrap .fss-subh { display: flex; justify-content: space-between; align-items: center; }
.fss-wrap .fss-subn { font-size: 11px; color: var(--fss-txt2); font-weight: 500; display: flex; align-items: center; gap: 5px; }
.fss-wrap .fss-subv { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--fss-txt); }
.fss-wrap .fss-subv small { font-size: 8.5px; color: var(--fss-txt3); }
.fss-wrap .fss-datasrc { font-family: 'JetBrains Mono', monospace; font-size: 7px; padding: 1px 4px; border-radius: 2px; letter-spacing: .5px; text-transform: uppercase; }
.fss-wrap .fss-datasrc.fss-real { background: rgba(52,211,153,.08); color: rgba(52,211,153,.75); border: 1px solid rgba(52,211,153,.15); }
.fss-wrap .fss-datasrc.fss-sim  { background: rgba(255,255,255,.03); color: var(--fss-txt3); border: 1px solid rgba(255,255,255,.07); }
.fss-wrap .fss-btrack { height: 3px; background: rgba(255,255,255,.05); border-radius: 2px; overflow: hidden; }
.fss-wrap .fss-bfill  { height: 100%; border-radius: 2px; width: 0%; transition: width .9s cubic-bezier(.22,1,.36,1); }

/* Intel bullets */
.fss-wrap .fss-ib   { padding: 13px 15px; border-bottom: 1px solid var(--fss-border); }
.fss-wrap .fss-ilbl { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; letter-spacing: 3px; color: var(--fss-txt3); text-transform: uppercase; margin-bottom: 8px; }
.fss-wrap .fss-irow { display: flex; align-items: flex-start; gap: 8px; padding: 4px 0; font-size: 11px; color: var(--fss-txt2); line-height: 1.55; }
.fss-wrap .fss-ico  { flex-shrink: 0; margin-top: 2px; font-size: 9px; }

/* Footer */
.fss-wrap .fss-pfoot { padding: 13px 15px; margin-top: auto; }
.fss-wrap .fss-sbtn {
  width: 100%; padding: 10px; background: var(--fss-od);
  border: 1px solid rgba(249,115,22,.28); border-radius: 6px;
  color: var(--fss-orange); font-family: 'Rajdhani', sans-serif;
  font-size: 12px; font-weight: 600; letter-spacing: 2.5px;
  text-transform: uppercase; cursor: pointer; transition: all .2s;
}
.fss-wrap .fss-sbtn:hover { background: rgba(249,115,22,.21); border-color: rgba(249,115,22,.52); }

.fss-wrap .fss-pcontent          { display: none; flex-direction: column; }
.fss-wrap .fss-pcontent.fss-vis  { display: flex; }

/* ── LEAFLET OVERRIDES (scoped to .fss-mw) ─────────────── */
.fss-wrap .fss-mw .leaflet-container { background: #060911; }
.fss-wrap .fss-mw .leaflet-control-zoom a {
  background: rgba(9,14,23,.92) !important;
  color: #7A90A8 !important;
  border-color: rgba(56,189,248,.16) !important;
}
.fss-wrap .fss-mw .leaflet-control-zoom a:hover {
  background: rgba(14,20,32,.95) !important;
  color: #38BDF8 !important;
}
.fss-wrap .fss-mw .leaflet-control-attribution { display: none !important; }

/* Custom markers */
.fss-bmk {
  width: 11px; height: 11px; border-radius: 50%;
  background: #F97316; border: 2.5px solid rgba(249,115,22,.33);
  box-shadow: 0 0 14px rgba(249,115,22,.6);
}
.fss-pmk {
  width: 14px; height: 14px; border-radius: 50%;
  background: #38BDF8; border: 3px solid rgba(56,189,248,.28);
  box-shadow: 0 0 22px rgba(56,189,248,.88);
  animation: fss-ppulse 2s ease-in-out infinite;
}
@keyframes fss-ppulse {
  0%,100% { box-shadow: 0 0 22px rgba(56,189,248,.88); }
  50%      { box-shadow: 0 0 36px rgba(56,189,248,1), 0 0 64px rgba(56,189,248,.3); }
}

/* Tooltip */
.fss-ftip {
  background: rgba(9,14,23,.96) !important;
  border: 1px solid rgba(56,189,248,.26) !important;
  color: #DCE8F4 !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10.5px !important;
  padding: 5px 11px !important;
  border-radius: 4px !important;
  box-shadow: 0 4px 18px rgba(0,0,0,.5) !important;
}
.fss-ftip::before { border-top-color: rgba(56,189,248,.26) !important; }
