.ma-map{
  position:relative;
  width:100%;
  max-width:1200px;
  margin:0 auto;
  border-radius:16px;
  overflow:hidden;
  background:#0b1220;
}

.ma-map__img{
  display:block;
  width:100%;
  height:auto;
}



/* Hotpoint */
.ma-hotpoint{
  position:absolute;
  left:0; top:0;
  transform:translate(-50%,-50%);
  width:44px; height:44px;            /* touch target AA */
  border:0;
  border-radius:999px;
  cursor:pointer;
  background:rgba(255,255,255,.10);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow:0 10px 30px rgba(0,0,0,.25);
  display:grid;
  place-items:center;
  z-index:3;
}

.ma-hotpoint:focus-visible{
  outline:3px solid rgba(11,92,255,.85);
  outline-offset:3px;
}

/* Círculo latido (ring) */
.ma-hotpoint::before{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.55);
  opacity:.0;
  transform:scale(.7);
  animation: maPulse 1.6s ease-out infinite;
}

@keyframes maPulse{
  0%   { opacity:.0; transform:scale(.75); }
  20%  { opacity:.55; }
  100% { opacity:0; transform:scale(1.35); }
}

/* Respeta reduced motion */
@media (prefers-reduced-motion: reduce){
  .ma-hotpoint::before{ animation:none; }
}

/* Icono SVG */
.ma-hotpoint svg{
  width:30px;
  height:30px;
  display:block;
  color:#fff;
}

/* Variantes por tipo (ajusta a tu paleta si quieres) */
.ma-hotpoint[data-type="metro"]{ background:rgba(11,92,255,.8); }
.ma-hotpoint[data-type="bus"]{ background:rgba(239,68,68,1); }
.ma-hotpoint[data-type="parking"]{ background:rgba(2,45,103,1); }
.ma-hotpoint[data-type="shop"]{ background:rgba(255,184,0,.8); }
.ma-hotpoint[data-type="eci"]{ background:rgba(255,255,255,.8); }
.ma-hotpoint[data-type="consigna"]{ background:rgba(255,184,0,1); }

/* Popover dentro del contenedor */
.ma-popover{
  position:absolute;
  z-index:4;
  width:min(320px, calc(100vw - 32px));
  background:rgba(10,14,22,.92);
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  box-shadow:0 18px 60px rgba(0,0,0,.45);
  padding:12px 12px 10px;
}

.ma-popover[hidden]{ display:none; }

.ma-popover__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:0px;
}

.ma-popover__title{
  font-size:14px;
  line-height:1.2;
  margin:0;
  font-weight:700;
}

.ma-popover__close{
  width:32px; height:32px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
  cursor:pointer;
}

.ma-popover__body{
  font-size:13px;
  line-height:1.35;
  opacity:.95;
}



/* Label badge */
.ma-label{
  position:absolute;
  transform: translate(-50%, -50%);
  z-index:2; /* debajo de hotpoints (3) y popover (4) */
  pointer-events:none; /* no molesta al click */
  max-width: min(220px, calc(100% - 16px));
}

.ma-label__badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  font-size:12px;
  line-height:1;
  font-weight:700;
  letter-spacing:.2px;
  color:#fff;

  background: rgba(38,33,35,1);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* Alineación (ajusta el translate) */
.ma-label[data-align="left"]   { transform: translate(0%, -50%); }
.ma-label[data-align="center"] { transform: translate(-50%, -50%); }
.ma-label[data-align="right"]  { transform: translate(-100%, -50%); }



/* Mobile: reducir un poco */
@media (max-width: 420px){
  .ma-label__badge{ font-size:11px; padding:6px 9px; }
}


/* =========================
   ACCESOS (clicables + popover)
   ========================= */
.ma-access{
  position:absolute;
  z-index:3;
  transform: translate(-50%, -50%);
  border:0;
  background:none;
  padding:0;
  pointer-events:auto;
}

.ma-access[data-align="left"]   { transform: translate(0%, -50%); }
.ma-access[data-align="center"] { transform: translate(-50%, -50%); }
.ma-access[data-align="right"]  { transform: translate(-100%, -50%); }

.ma-access__badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 11px;
  border-radius:999px;
  font-size:12px;
  line-height:1;
  font-weight:800;
  color:#fff;
  cursor:pointer;

  background: rgba(var(--ma-blue-rgb),0.5); /* tono “acceso” */
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 12px 34px rgba(0,0,0,.28);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.ma-access__badge svg{
  width:16px; height:16px;
  color:#fff;
}

.ma-access:focus-visible{
  outline:3px solid rgba(11,92,255,.85);
  outline-offset:3px;
}

/* =========================
   MAP FULLSCREEN
   ========================= */

/* Botón expandir */
.ma-map__fs-btn{
  position:absolute;
  top:12px;
  right:12px;
  z-index:6; /* por encima de todo */
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(10,14,22,.75);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color:#fff;
  cursor:pointer;
  display:grid;
  place-items:center;
  box-shadow:0 12px 34px rgba(0,0,0,.35);
}

.ma-map__fs-btn svg{
  width:20px;
  height:20px;
}

/* Estado fullscreen */
.ma-map.is-fullscreen{
  position:fixed;
  inset:0;
  width:100vw;
  height:100vh;
  max-width:none;
  margin:0;
  border-radius:0;
  z-index:999;
  background:#0b1220;
}

/* Imagen escala completa */
.ma-map.is-fullscreen .ma-map__img{
  width:100%;
  height:100%;
  object-fit:contain; /* respeta proporción */
}

/* En fullscreen, mejora popover */
.ma-map.is-fullscreen .ma-popover{
  max-width:360px;
}

/* Evita scroll del body */
body.ma-noscroll{
  overflow:hidden;
}

h5.accesos {
	font-size:20px;
	margin: 0px;
}

p.accesos.dcha-izq {
	margin: 0px;
}


/* =========================
   FULLSCREEN MAP (contain)
   ========================= */

.ma-map.is-fullscreen{
  position: fixed;
  inset: 0;
  z-index: 1000;
}

/* Capa blanca de fondo */
.ma-map.is-fullscreen::before{
  content:"";
  position: absolute;
  inset: 0;
  background: #fff;
  z-index: 0;
}

/* Imagen del plano */
.ma-map__img{
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: contain;     /* 👈 CLAVE */
  object-position: center;
  display: block;
}

/* Capas interactivas por encima */
.ma-hotpoint,
.ma-label,
.ma-access,
.ma-popover,
.ma-map__fs-btn{
  position: absolute;
  z-index: 2;
}


.ma-popover{
  position: absolute;
  z-index: 3000;
}

/* Bloqueo scroll + ocultar header */
body.ma-map-fullscreen{
  overflow: hidden;
}

body.ma-map-fullscreen .site-header{
  opacity: 0;
  pointer-events: none;
}

