/* Shared coverage-map module (el-footprint dark / el-licensing-map light).
   Class names keep the fp2- prefix they were born with. */
.elcov { /* wrapper only — themes hang off .elcov-light */ }

/* Map */
.fp2-map-wrap { position: relative; max-width: 720px; margin: 0 auto 30px; }
.el-usmap { width: 100%; height: auto; display: block; overflow: visible; }
.el-usmap path[data-state] {
  fill: #3c5168;
  transition: fill 0.18s ease, filter 0.18s ease;
  cursor: default;
}
.el-usmap path[data-state].is-active { cursor: pointer; }
.el-usmap path[data-state].is-active:hover { filter: brightness(1.18); }
.el-usmap .borders { stroke: rgba(255,255,255,0.55); stroke-width: 1; }
.el-usmap .separator1 { stroke: rgba(255,255,255,0.3); }
/* Tooltip */
.fp2-map-tip {
  position: absolute; pointer-events: none; z-index: 6;
  transform: translate(-50%, calc(-100% - 12px));
  background: #16283a; border: 1px solid rgba(255,255,255,0.12);
  border-radius: 9px; padding: 9px 14px; text-align: center; line-height: 1.25;
  opacity: 0; transition: opacity 0.12s ease;
  white-space: nowrap; box-shadow: 0 10px 28px rgba(0,0,0,0.5);
}
.fp2-map-tip.is-on { opacity: 1; }
.fp2-map-tip .fp2-tip-name {
  display: block; font-size: 13px; font-weight: 800; color: #fff;
  letter-spacing: 0.01em; margin-bottom: 4px;
}
.fp2-map-tip .fp2-tip-prod { display: block; font-size: 11px; font-weight: 700; color: #8fd06a; letter-spacing: 0.02em; }
.fp2-map-tip .fp2-tip-none { display: block; font-weight: 600; color: rgba(255,255,255,0.5); }
/* Legend */
.fp2-legend { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px 20px; margin-bottom: 44px; }
.fp2-legend-item { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; color: rgba(255,255,255,0.72); }
.fp2-legend-swatch { width: 14px; height: 14px; border-radius: 4px; flex: none; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18); }
.fp2-legend-none .fp2-legend-swatch { background: #3c5168; }
/* Coverage list — tap-to-expand touch module (hidden on desktop) */
.fp2-coverage { display: none; max-width: 480px; margin: 0 auto 40px; text-align: left; }
.fp2-cov-row { border: 1px solid rgba(255,255,255,0.10); border-radius: 10px; background: rgba(255,255,255,0.03); margin-bottom: 10px; overflow: hidden; }
.fp2-cov-head {
  display: flex; align-items: center; gap: 12px; width: 100%;
  background: none; border: 0; cursor: pointer; text-align: left;
  padding: 14px 16px; min-height: 52px; color: #fff;
  font-family: inherit; font-size: 14px; font-weight: 700; letter-spacing: -0.01em;
}
.fp2-cov-head-static { cursor: default; }
.fp2-cov-dot { width: 14px; height: 14px; border-radius: 4px; flex: none; background: #3c5168; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18); }
.fp2-cov-name { flex: 1 1 auto; }
.fp2-cov-count { font-size: 12px; font-weight: 700; color: rgba(255,255,255,0.6); background: rgba(255,255,255,0.07); border-radius: 20px; padding: 2px 10px; flex: none; }
.fp2-cov-chev { width: 9px; height: 9px; flex: none; margin-left: 2px; border-right: 2px solid rgba(255,255,255,0.5); border-bottom: 2px solid rgba(255,255,255,0.5); transform: rotate(45deg); transition: transform 0.22s ease; }
.fp2-cov-row.is-open .fp2-cov-chev { transform: rotate(225deg); }
.fp2-cov-panel { max-height: 0; overflow: hidden; transition: max-height 0.28s ease; }
.fp2-cov-row.is-open .fp2-cov-panel { max-height: 640px; }
.fp2-cov-states { display: flex; flex-wrap: wrap; gap: 6px; padding: 2px 16px 16px; }
.fp2-cov-state {
  font-size: 11.5px; font-weight: 600; color: rgba(255,255,255,0.72);
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.09);
  border-radius: 6px; padding: 4px 9px; line-height: 1.25; white-space: nowrap;
}
.fp2-cov-none { background: none; border-color: rgba(255,255,255,0.07); }
.fp2-cov-none .fp2-cov-name { color: rgba(255,255,255,0.55); font-weight: 600; }

/* ---- Light theme (licensing page) ---- */
.elcov-light .el-usmap path[data-state] { fill: #dfe5ea; }
.elcov-light .el-usmap .borders { stroke: rgba(22,40,58,0.35); }
.elcov-light .el-usmap .separator1 { stroke: rgba(22,40,58,0.2); }
/* tooltip stays dark — it reads fine on a light page */
.elcov-light .fp2-legend-item { color: rgba(22,40,58,0.78); }
.elcov-light .fp2-legend-swatch { box-shadow: inset 0 0 0 1px rgba(22,40,58,0.15); }
.elcov-light .fp2-legend-none .fp2-legend-swatch { background: #dfe5ea; }
.elcov-light .fp2-cov-row { border-color: rgba(22,40,58,0.12); background: rgba(22,40,58,0.03); }
.elcov-light .fp2-cov-head { color: #16283a; }
.elcov-light .fp2-cov-dot { background: #dfe5ea; box-shadow: inset 0 0 0 1px rgba(22,40,58,0.15); }
.elcov-light .fp2-cov-count { color: rgba(22,40,58,0.6); background: rgba(22,40,58,0.07); }
.elcov-light .fp2-cov-chev { border-right-color: rgba(22,40,58,0.45); border-bottom-color: rgba(22,40,58,0.45); }
.elcov-light .fp2-cov-state { color: rgba(22,40,58,0.75); background: rgba(22,40,58,0.05); border-color: rgba(22,40,58,0.1); }
.elcov-light .fp2-cov-none .fp2-cov-name { color: rgba(22,40,58,0.55); }

/* On touch the map is a static visual — don't show a misleading pointer cursor */
@media (hover: none) { .el-usmap path[data-state].is-active { cursor: default; } }
/* Tablet + phone: reveal the tap list (map stays as a static visual on tablet) */
@media (max-width: 1024px) { .fp2-coverage { display: block; } }
/* Phone: list only */
@media (max-width: 640px) { .fp2-map-wrap { display: none; } }
