.elementor-224 .elementor-element.elementor-element-91c9c35{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:120px;--padding-bottom:96px;--padding-left:0px;--padding-right:0px;}.elementor-224 .elementor-element.elementor-element-91c9c35:not(.elementor-motion-effects-element-type-background), .elementor-224 .elementor-element.elementor-element-91c9c35 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-text );}.elementor-224 .elementor-element.elementor-element-e178d14{--spacer-size:20px;}.elementor-224 .elementor-element.elementor-element-70f3144{--display:flex;--margin-top:0px;--margin-bottom:45px;--margin-left:0px;--margin-right:0px;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-224 .elementor-element.elementor-element-eb529a8{text-align:center;}.elementor-224 .elementor-element.elementor-element-eb529a8 .elementor-heading-title{font-family:"Inter", Sans-serif;font-weight:600;color:var( --e-global-color-96fd2d0 );}.elementor-224 .elementor-element.elementor-element-fe406ef{background-color:var( --e-global-color-secondary );padding:14px 48px 14px 48px;text-align:center;}.elementor-224 .elementor-element.elementor-element-fe406ef.elementor-element{--align-self:center;}.elementor-224 .elementor-element.elementor-element-fe406ef .elementor-heading-title{color:var( --e-global-color-text );}.elementor-224 .elementor-element.elementor-element-b66e3ac{text-align:center;}.elementor-224 .elementor-element.elementor-element-b66e3ac .elementor-heading-title{color:var( --e-global-color-96fd2d0 );}.elementor-224 .elementor-element.elementor-element-4827f1d{background-color:var( --e-global-color-primary );padding:14px 48px 14px 48px;text-align:center;}.elementor-224 .elementor-element.elementor-element-4827f1d.elementor-element{--align-self:center;}.elementor-224 .elementor-element.elementor-element-4827f1d .elementor-heading-title{color:var( --e-global-color-text );}.elementor-224 .elementor-element.elementor-element-640ea8c{--display:flex;--margin-top:35px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:60px;--padding-bottom:60px;--padding-left:60px;--padding-right:60px;}.elementor-224 .elementor-element.elementor-element-640ea8c:not(.elementor-motion-effects-element-type-background), .elementor-224 .elementor-element.elementor-element-640ea8c > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-96fd2d0 );}.elementor-224 .elementor-element.elementor-element-67b67dd{--display:flex;--padding-top:35px;--padding-bottom:35px;--padding-left:35px;--padding-right:35px;}.elementor-224 .elementor-element.elementor-element-67b67dd:not(.elementor-motion-effects-element-type-background), .elementor-224 .elementor-element.elementor-element-67b67dd > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#21B3FD26;}.elementor-224 .elementor-element.elementor-element-9c03521{--display:flex;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:space-between;--align-items:center;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-224 .elementor-element.elementor-element-3b16d42{padding:0px 15px 0px 15px;border-style:solid;border-width:1px 1px 1px 1px;border-color:var( --e-global-color-text );text-align:start;}.elementor-224 .elementor-element.elementor-element-3b16d42 .elementor-heading-title{font-family:"Inter", Sans-serif;font-weight:400;letter-spacing:2px;color:var( --e-global-color-text );}.elementor-224 .elementor-element.elementor-element-3316991{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;--flex-wrap:nowrap;}.elementor-224 .elementor-element.elementor-element-3316991:not(.elementor-motion-effects-element-type-background), .elementor-224 .elementor-element.elementor-element-3316991 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-96fd2d0 );}.elementor-224 .elementor-element.elementor-element-7453682 .elementor-heading-title{font-family:"Inter", Sans-serif;font-weight:400;line-height:21px;color:var( --e-global-color-text );}.elementor-224 .elementor-element.elementor-element-22390a2 .elementor-heading-title{font-family:"Inter", Sans-serif;font-weight:400;line-height:21px;color:var( --e-global-color-text );}.elementor-224 .elementor-element.elementor-element-a763496{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:60px;--padding-right:60px;}.elementor-224 .elementor-element.elementor-element-1b710e2{--display:flex;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-224 .elementor-element.elementor-element-496805d{--display:grid;--e-con-grid-template-columns:repeat(2, 1fr);--e-con-grid-template-rows:repeat(1, 1fr);--grid-auto-flow:row;}.elementor-224 .elementor-element.elementor-element-3c951d9{--display:flex;}.elementor-224 .elementor-element.elementor-element-3c951d9.e-con{--flex-grow:1;--flex-shrink:0;}.elementor-224 .elementor-element.elementor-element-7d850c3{--display:flex;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-224 .elementor-element.elementor-element-05011cc{color:var( --e-global-color-96fd2d0 );}.elementor-224 .elementor-element.elementor-element-1cb1cf9{--n-accordion-title-font-size:18px;--n-accordion-title-justify-content:space-between;--n-accordion-title-flex-grow:1;--n-accordion-title-icon-order:initial;--n-accordion-item-title-space-between:0px;--n-accordion-item-title-distance-from-content:0px;--n-accordion-title-normal-color:var( --e-global-color-96fd2d0 );--n-accordion-title-hover-color:var( --e-global-color-primary );--n-accordion-title-active-color:var( --e-global-color-primary );--n-accordion-icon-size:15px;}.elementor-224 .elementor-element.elementor-element-1cb1cf9 > .e-n-accordion > .e-n-accordion-item > .e-n-accordion-item-title{border-style:none;}.elementor-224 .elementor-element.elementor-element-1cb1cf9 {--n-accordion-padding:0px 0px 0px 0px;}:where( .elementor-224 .elementor-element.elementor-element-1cb1cf9 > .e-n-accordion > .e-n-accordion-item > .e-n-accordion-item-title > .e-n-accordion-item-title-header ) > .e-n-accordion-item-title-text{font-family:"Inter", Sans-serif;font-weight:400;}.elementor-224 .elementor-element.elementor-element-a90f47c{--display:flex;}.elementor-224 .elementor-element.elementor-element-4211588{--display:flex;}.elementor-224 .elementor-element.elementor-element-1192461{color:var( --e-global-color-96fd2d0 );}.elementor-224 .elementor-element.elementor-element-26bcbf0{--n-accordion-title-font-size:18px;--n-accordion-title-justify-content:space-between;--n-accordion-title-flex-grow:1;--n-accordion-title-icon-order:initial;--n-accordion-item-title-space-between:0px;--n-accordion-item-title-distance-from-content:0px;--n-accordion-title-normal-color:var( --e-global-color-96fd2d0 );--n-accordion-title-hover-color:var( --e-global-color-primary );--n-accordion-title-active-color:var( --e-global-color-primary );--n-accordion-icon-size:15px;}.elementor-224 .elementor-element.elementor-element-26bcbf0 > .e-n-accordion > .e-n-accordion-item > .e-n-accordion-item-title{border-style:none;}.elementor-224 .elementor-element.elementor-element-26bcbf0 {--n-accordion-padding:0px 0px 0px 0px;}:where( .elementor-224 .elementor-element.elementor-element-26bcbf0 > .e-n-accordion > .e-n-accordion-item > .e-n-accordion-item-title > .e-n-accordion-item-title-header ) > .e-n-accordion-item-title-text{font-family:"Inter", Sans-serif;font-weight:400;}.elementor-224 .elementor-element.elementor-element-34ae78b{--display:grid;--e-con-grid-template-columns:repeat(2, 1fr);--e-con-grid-template-rows:repeat(1, 1fr);--grid-auto-flow:row;}.elementor-224 .elementor-element.elementor-element-d31a235{--display:flex;}.elementor-224 .elementor-element.elementor-element-47a1a5b{--display:flex;}.elementor-224 .elementor-element.elementor-element-507b2bf{font-family:"Inter", Sans-serif;font-size:14px;font-weight:400;color:var( --e-global-color-96fd2d0 );}.elementor-224 .elementor-element.elementor-element-f15b70a{--n-accordion-title-font-size:18px;--n-accordion-title-justify-content:space-between;--n-accordion-title-flex-grow:1;--n-accordion-title-icon-order:initial;--n-accordion-item-title-space-between:0px;--n-accordion-item-title-distance-from-content:0px;--n-accordion-title-normal-color:var( --e-global-color-96fd2d0 );--n-accordion-title-hover-color:var( --e-global-color-primary );--n-accordion-title-active-color:var( --e-global-color-primary );--n-accordion-icon-size:15px;}.elementor-224 .elementor-element.elementor-element-f15b70a > .e-n-accordion > .e-n-accordion-item > .e-n-accordion-item-title{border-style:none;}.elementor-224 .elementor-element.elementor-element-f15b70a {--n-accordion-padding:0px 0px 0px 0px;}:where( .elementor-224 .elementor-element.elementor-element-f15b70a > .e-n-accordion > .e-n-accordion-item > .e-n-accordion-item-title > .e-n-accordion-item-title-header ) > .e-n-accordion-item-title-text{font-family:"Inter", Sans-serif;font-weight:400;}.elementor-224 .elementor-element.elementor-element-cc7b0b7{--display:flex;}.elementor-224 .elementor-element.elementor-element-e57446f{--display:flex;}.elementor-224 .elementor-element.elementor-element-b9a85b3{font-family:"Inter", Sans-serif;font-size:14px;font-weight:400;color:var( --e-global-color-96fd2d0 );}.elementor-224 .elementor-element.elementor-element-a466447{--n-accordion-title-font-size:18px;--n-accordion-title-justify-content:space-between;--n-accordion-title-flex-grow:1;--n-accordion-title-icon-order:initial;--n-accordion-item-title-space-between:0px;--n-accordion-item-title-distance-from-content:0px;--n-accordion-title-normal-color:var( --e-global-color-96fd2d0 );--n-accordion-title-hover-color:var( --e-global-color-primary );--n-accordion-title-active-color:var( --e-global-color-primary );--n-accordion-icon-size:15px;}.elementor-224 .elementor-element.elementor-element-a466447 > .e-n-accordion > .e-n-accordion-item > .e-n-accordion-item-title{border-style:none;}.elementor-224 .elementor-element.elementor-element-a466447 {--n-accordion-padding:0px 0px 0px 0px;}:where( .elementor-224 .elementor-element.elementor-element-a466447 > .e-n-accordion > .e-n-accordion-item > .e-n-accordion-item-title > .e-n-accordion-item-title-header ) > .e-n-accordion-item-title-text{font-family:"Inter", Sans-serif;font-weight:400;}@media(max-width:1440px){.elementor-224 .elementor-element.elementor-element-496805d{--grid-auto-flow:row;}.elementor-224 .elementor-element.elementor-element-34ae78b{--grid-auto-flow:row;}}@media(max-width:1024px){.elementor-224 .elementor-element.elementor-element-91c9c35{--padding-top:120px;--padding-bottom:96px;--padding-left:20px;--padding-right:20px;}.elementor-224 .elementor-element.elementor-element-640ea8c{--padding-top:10px;--padding-bottom:10px;--padding-left:10px;--padding-right:10px;}.elementor-224 .elementor-element.elementor-element-496805d{--grid-auto-flow:row;}.elementor-224 .elementor-element.elementor-element-34ae78b{--grid-auto-flow:row;}}@media(max-width:767px){.elementor-224 .elementor-element.elementor-element-91c9c35{--padding-top:80px;--padding-bottom:96px;--padding-left:20px;--padding-right:20px;}.elementor-224 .elementor-element.elementor-element-e178d14{--spacer-size:20px;}.elementor-224 .elementor-element.elementor-element-fe406ef{padding:14px 15px 14px 15px;}.elementor-224 .elementor-element.elementor-element-4827f1d{padding:14px 15px 14px 15px;}.elementor-224 .elementor-element.elementor-element-640ea8c{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-224 .elementor-element.elementor-element-67b67dd{--padding-top:20px;--padding-bottom:20px;--padding-left:20px;--padding-right:20px;}.elementor-224 .elementor-element.elementor-element-a763496{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-224 .elementor-element.elementor-element-496805d{--e-con-grid-template-columns:repeat(1, 1fr);--grid-auto-flow:row;}.elementor-224 .elementor-element.elementor-element-3c951d9.e-con{--flex-grow:1;--flex-shrink:0;}.elementor-224 .elementor-element.elementor-element-34ae78b{--e-con-grid-template-columns:repeat(1, 1fr);--grid-auto-flow:row;}}@media(min-width:768px){.elementor-224 .elementor-element.elementor-element-3316991{--width:50%;}.elementor-224 .elementor-element.elementor-element-1b710e2{--width:100%;}}/* Start custom CSS for html, class: .elementor-element-df555a3 */:root {
  --gra-dark: #07005D;
  --gra-primary: #0498FF;
  --gra-light: rgba(33, 179, 253, 0.15);
  --gra-accent: #21B3FD;
  --gra-bg: #ffffff;
  --gra-surface: #f8fbff;
  --gra-border: rgba(4, 152, 255, 0.15);
  --gra-text: #07005D;
  --gra-text-dim: rgba(7, 0, 93, 0.65);
  --gra-card: #ffffff;
  --gra-glow: 0 10px 30px rgba(4, 152, 255, 0.08);
  --radius: 16px;
  --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}


/* ===== DIRECTORY CARDS ===== */
.directory { padding: 0 2rem 3rem; max-width: 1100px; margin: 0 auto; }
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.25rem;
}
.area-card {
  background: #ffffff;
  border: 1px solid var(--gra-border);
  border-radius: var(--radius);
  padding: 1.75rem;
  cursor: pointer;
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.04);
}
.area-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(4,152,255,0.03), transparent);
  opacity: 0; transition: opacity var(--transition);
}
.area-card:hover {
  transform: translateY(-4px);
  border-color: rgba(4, 152, 255, 0.4);
  box-shadow: 0 12px 30px rgba(4, 152, 255, 0.12);
}
.area-card:hover::before { opacity: 1; }
.card-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: linear-gradient(135deg, rgba(4,152,255,0.15), rgba(33,179,253,0.08));
  border: 1px solid var(--gra-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; margin-bottom: 1rem;
}
.area-card h3 { font-size: 1.05rem; font-weight: 600; margin-bottom: 0.4rem; letter-spacing: -0.01em; }
.area-card p { color: var(--gra-text-dim); font-size: 1.85rem; line-height: 1.5; margin-bottom: 1rem; }
.card-action {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--gra-primary); font-size: 0.82rem; font-weight: 500;
}
.card-action .arrow { transition: transform var(--transition); }
.area-card:hover .card-action .arrow { transform: translateX(4px); }

/* ===== STATS BAR ===== */
.stats-bar {
  display: flex; gap: 1rem; margin-top: 2rem;
  flex-wrap: wrap; justify-content: center;
}
.stat-item {
  background: var(--gra-card); border: 1px solid var(--gra-border);
  border-radius: 12px; padding: 1rem 1.5rem;
  text-align: center; flex: 1; min-width: 140px;
}
.stat-value { font-size: 1.5rem; font-weight: 700; color: var(--gra-accent); }
.stat-label { font-size: 1.75rem; color: var(--gra-text-dim); margin-top: 2px; }

/* ===== MAP VIEW ===== */
.map-view {
  display: flex !important;
  position: relative !important; /* Forza a que se quede en su sitio */
  width: 100% !important;

  margin: auto;
  height: 650px !important;
  inset: auto !important;       /* Anula el 'inset: 0' anterior */
  z-index: 1 !important;         /* Baja el nivel para que no tape menús */
  ...
}


.zoom-controls.floating {
  position: absolute;
  bottom: 2rem;
  right: 2rem;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 100;
}
.zoom-controls.floating .zoom-btn {
  width: 44px !important; height: 44px !important;
  background: #ffffff;
  border: 1px solid var(--gra-border);
  border-radius: 12px;
  color: #07005D;
  font-size: 1.4rem !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
  display: flex; align-items: center; justify-content: center;
  transition: all var(--transition);
}
.zoom-controls.floating .zoom-btn:hover {
  background: #f8fbff !important;
  border-color: var(--gra-primary);
  transform: translateY(-2px);
}

.zoom-btn {
  padding: 0;
}

.zoom-btn svg {
  width: 40%;   /* ocupa todo el ancho del botón */
  height: 40%;  /* ocupa todo el alto del botón */
}




.map-body { display: flex; flex: 1; overflow: hidden; }

/* ===== SIDEBAR ===== */
.map-sidebar {
  width: 260px; flex-shrink: 0;
  background: #21B3FD26; /* Requested sidebar background */
  border-right: 1px solid var(--gra-border);
  padding: 1rem; overflow-y: auto;
}
.sidebar-title {
  font-size: 2rem !important; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.08em; color: #0498FF;
  margin-bottom: 0.75rem; padding: 0 0.5rem;
}
.zone-btn {
  width: 100%; font-size: 16px !important; text-align: left;
  background: transparent !important; /* Removed default background */
  border: 1px solid transparent;
  border-radius: 10px !important; padding: 10px 12px;
  color: #07005D; /* Requested text color */
  cursor: pointer;
  font-family: inherit; 
  display: flex; align-items: center; gap: 10px;
  transition: all var(--transition); margin-bottom: 6px;
}
.zone-btn:hover, .zone-btn.active { 
  background: #fff !important; 
  border-color: var(--gra-primary); 
  box-shadow: 0 4px 12px rgba(4, 152, 255, 0.1); 
}
.zone-btn.active {
  color: #07005D;
}

.zone-btn .zone-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  box-shadow: 0 0 8px rgba(0,0,0,0.1);
}
.zone-btn .zone-label { 
  font-weight: 700; 
  color: #0498FF; /* Requested title color */
}

.zone-btn .zone-sub { font-size: 16px !important; color: #07005D; display: block; font-weight: 500; opacity: 0.8; }

/* Legend */
.legend-section { margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--gra-border); }
.legend-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 0.5rem; font-size: 16px !important; color: #07005D;
  border-radius: 8px;
  transition: all var(--transition);
}
.legend-item.clickable {
  cursor: pointer;
}
.legend-item.clickable:hover {
  background: var(--gra-light);
  color: var(--gra-primary);
}
.legend-item.active {
  background: #fff;
  color: var(--gra-primary);
  box-shadow: 0 4px 12px rgba(4, 152, 255, 0.1);
  border: 1px solid var(--gra-primary);
}
.legend-icon { width: 16px; text-align: center; font-size: 1.85rem; }

/* ===== MAP CANVAS ===== */
.map-canvas {
  flex: 1; position: relative; overflow: hidden;
  background: #f8fbff;
  cursor: grab;
}
.map-canvas:active { cursor: grabbing; }
.map-canvas-inner {
  transform-origin: 0 0;
  /* will-change: transform; Removed to prevent pixelation at high zoom */
  position: absolute;
  top: 0; left: 0;
}
.map-canvas-inner svg {
  display: block;
  width: 1200px;
  height: auto;
  shape-rendering: geometricPrecision;
}

/* SVG Light Theme - Resetting to original or soft dark */
.map-canvas-inner svg line,
.map-canvas-inner svg polyline,
.map-canvas-inner svg polygon,
.map-canvas-inner svg path {
  stroke: rgba(7, 0, 93, 0.4) !important; /* Soft dark blue for lines */
}
.map-canvas-inner svg text {
  fill: #07005D !important;
}
.map-canvas-inner svg polyline[class],
.map-canvas-inner svg polygon[class] {
  fill: none !important;
}

/* Zone Overlays */
.zone-overlay {
  position: absolute;
  border: 2px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.3s ease;
  pointer-events: all;
}
.zone-overlay:hover, .zone-overlay.highlighted {
  background: rgba(4, 152, 255, 0.12);
  border-color: var(--gra-primary);
  box-shadow: inset 0 0 30px rgba(4, 152, 255, 0.08);
}
.zone-overlay .zone-tag {
  position: absolute; top: 8px; left: 8px;
  background: rgba(4, 0, 56, 0.85);
  backdrop-filter: blur(8px);
  border: 1px solid var(--gra-border);
  border-radius: 6px; padding: 4px 10px;
  font-size: 1.7rem; font-weight: 600;
  color: var(--gra-accent); white-space: nowrap;
  opacity: 0; transform: translateY(-4px);
  transition: all 0.3s ease;
  pointer-events: none;
}
.zone-overlay:hover .zone-tag,
.zone-overlay.highlighted .zone-tag {
  opacity: 1; transform: translateY(0);
}

/* Amenity Markers */
.amenity-marker {
  position: absolute;
  width: 12px; height: 12px;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0.5);
  opacity: 0;
  pointer-events: none;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  z-index: 50;
}
.amenity-marker.visible {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  pointer-events: auto;
  cursor: pointer;
}

.amenity-pulse-ring {
  content: '';
  position: absolute;
  left: -8px; top: -8px; right: -8px; bottom: -8px;
  border: 2px solid;
  border-radius: 50%;
  animation: pulse-ring 2s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}

.amenity-tooltip {
  position: absolute;
  bottom: 100%; left: 50%;
  transform: translate(-50%, -8px);
  background: rgba(4, 0, 56, 0.9);
  backdrop-filter: blur(8px);
  border: 1px solid var(--gra-border);
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 0.7rem; font-weight: 500;
  color: #fff; white-space: nowrap;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.amenity-marker:hover .amenity-tooltip {
  opacity: 1; transform: translate(-50%, -12px);
}

/* ===== TOOLTIP ===== */
.tooltip {
  position: fixed; z-index: 1000;
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(16px);
  border: 1px solid var(--gra-border);
  border-radius: 10px; padding: 10px 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
  pointer-events: none; opacity: 0;
  transition: opacity 0.2s ease;
  max-width: 220px;
}
.tooltip.visible { opacity: 1; }
.tooltip h4 { font-size: 0.85rem; font-weight: 600; margin-bottom: 2px; }
.tooltip p { font-size: 0.75rem; color: var(--gra-text-dim); }

/* ===== LOADING ===== */
.loading-overlay {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 1rem; z-index: 10;
}
.spinner {
  width: 40px; height: 40px;
  border: 3px solid var(--gra-border);
  border-top-color: var(--gra-primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
.loading-text { font-size: 0.85rem; color: var(--gra-text-dim); }

/* ===== ANIMATIONS ===== */
@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}
@keyframes pulse-ring {
  0% { transform: scale(0.5); opacity: 0; }
  50% { opacity: 1; }
  100% { transform: scale(1.5); opacity: 0; }
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
@keyframes fade-in {
  from { opacity: 0; transform: translateY(12px); }
  to { opaczone-btnity: 1; transform: translateY(0); }
}
.area-card { animation: fade-in 0.5s ease backwards; }
.area-card:nth-child(1) { animation-delay: 0.05s; }
.area-card:nth-child(2) { animation-delay: 0.1s; }
.area-card:nth-child(3) { animation-delay: 0.15s; }
.area-card:nth-child(4) { animation-delay: 0.2s; }
.area-card:nth-child(5) { animation-delay: 0.25s; }

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .hero { padding: 3rem 1.5rem 1.5rem; }
  .hero h2 { font-size: 1.6rem; }
  .directory { padding: 0 1rem 2rem; }
  .cards-grid { grid-template-columns: 1fr; }
  
  /* Responsive Map Embed */
  .map-view { height: 750px !important; }
  .map-body { flex-direction: column; }
  .map-sidebar { 
    display: flex !important;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: flex-start;
    width: 100% !important;
    max-height: 240px;
    border-right: none;
    border-bottom: 1px solid var(--gra-border);
    padding: 0.75rem;
  }
  .sidebar-title { width: 100%; margin-bottom: 4px; }
  .zone-btn { 
    width: calc(50% - 4px); 
    margin-right: 4px; 
    margin-bottom: 4px; 
    padding: 6px 8px; 
  }
  .legend-section { 
    width: 100%; 
    margin-top: 0.5rem; 
    padding-top: 0.5rem; 
    display: flex; 
    flex-wrap: wrap; 
  }
  .legend-item { 
    width: calc(50% - 4px); 
    margin-right: 4px; 
    margin-bottom: 2px; 
    padding: 4px; 
  }
  
  .map-toolbar .toolbar-title { display: none; }
  .header { padding: 0 1rem; }
  .header-brand h1 { font-size: 0.95rem; }
}
@media (max-width: 480px) {
  .stats-bar { flex-direction: column; }
  .stat-item { min-width: unset; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ec05220 */:root {
  --gra-dark: #07005D;
  --gra-primary: #0498FF;
  --gra-light: rgba(33, 179, 253, 0.15);
  --gra-accent: #21B3FD;
  --gra-bg: #ffffff;
  --gra-surface: #f8fbff;
  --gra-border: rgba(4, 152, 255, 0.15);
  --gra-text: #07005D;
  --gra-text-dim: rgba(7, 0, 93, 0.65);
  --gra-card: #ffffff;
  --gra-glow: 0 10px 30px rgba(4, 152, 255, 0.08);
  --radius: 16px;
  --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ===== HERO ===== */
.hero {
  margin-top: 64px;
  padding: 4rem 2rem 2rem;
  text-align: center;
  background: linear-gradient(180deg, rgba(4,152,255,0.08) 0%, transparent 100%);
  position: relative;
}
.hero::before {
  content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(4,152,255,0.1) 0%, transparent 70%);
  pointer-events: none;
}
.hero h2 {
  font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 800;
  letter-spacing: -0.03em; margin-bottom: 0.5rem;
  background: linear-gradient(135deg, #fff 30%, var(--gra-accent));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.hero p { color: var(--gra-text-dim); font-size: 1rem; max-width: 500px; margin: 0 auto; }
.hero .badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--gra-card); border: 1px solid var(--gra-border);
  border-radius: 100px; padding: 6px 16px; font-size: 0.8rem;
  color: var(--gra-accent); margin-bottom: 1rem;
}
.hero .badge .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #00e676; animation: pulse-dot 2s infinite;
}

/* ===== DIRECTORY CARDS ===== */
.directory { padding: 0 2rem 3rem; max-width: 1100px; margin: 0 auto; }
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.25rem;
}
.area-card {
  background: #ffffff;
  border: 1px solid var(--gra-border);
  border-radius: var(--radius);
  padding: 1.75rem;
  cursor: pointer;
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.04);
}
.area-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(4,152,255,0.03), transparent);
  opacity: 0; transition: opacity var(--transition);
}
.area-card:hover {
  transform: translateY(-4px);
  border-color: rgba(4, 152, 255, 0.4);
  box-shadow: 0 12px 30px rgba(4, 152, 255, 0.12);
}
.area-card:hover::before { opacity: 1; }
.card-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: linear-gradient(135deg, rgba(4,152,255,0.15), rgba(33,179,253,0.08));
  border: 1px solid var(--gra-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; margin-bottom: 1rem;
}
.area-card h3 { font-size: 1.05rem; font-weight: 600; margin-bottom: 0.4rem; letter-spacing: -0.01em; }
.area-card p { color: var(--gra-text-dim); font-size: 0.85rem; line-height: 1.5; margin-bottom: 1rem; }
.card-action {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--gra-primary); font-size: 0.82rem; font-weight: 500;
}
.card-action .arrow { transition: transform var(--transition); }
.area-card:hover .card-action .arrow { transform: translateX(4px); }

/* ===== STATS BAR ===== */
.stats-bar {
  display: flex; gap: 1rem; margin-top: 2rem;
  flex-wrap: wrap; justify-content: center;
}
.stat-item {
  background: var(--gra-card); border: 1px solid var(--gra-border);
  border-radius: 12px; padding: 1rem 1.5rem;
  text-align: center; flex: 1; min-width: 140px;
}
.stat-value { font-size: 1.5rem; font-weight: 700; color: var(--gra-accent); }
.stat-label { font-size: 0.75rem; color: var(--gra-text-dim); margin-top: 2px; }

/* ===== MAP VIEW ===== */
.map-view {
  display: flex; position: fixed; inset: 0;
  background: var(--gra-bg); z-index: 200;
  flex-direction: column;
}

.zoom-controls.floating {
  position: absolute;
  bottom: 2rem;
  right: 2rem;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 100;
}
.zoom-controls.floating .zoom-btn {
  width: 44px; height: 44px;
  background: #ffffff;
  border: 1px solid var(--gra-border);
  border-radius: 12px;
  color: #07005D;
  font-size: 1.4rem;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
  display: flex; align-items: center; justify-content: center;
  transition: all var(--transition);
}
.zoom-controls.floating .zoom-btn:hover {
  background: #f8fbff;
  border-color: var(--gra-primary);
  transform: translateY(-2px);
}

.map-body { display: flex; flex: 1; overflow: hidden; }

/* ===== SIDEBAR ===== */
.map-sidebar {
  width: 260px; flex-shrink: 0;
  background: #21B3FD26; /* Requested sidebar background */
  border-right: 1px solid var(--gra-border);
  padding: 1rem; overflow-y: auto;
}
.sidebar-title {
  font-size: 0.7rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.08em; color: #0498FF;
  margin-bottom: 0.75rem; padding: 0 0.5rem;
}
.zone-btn {
  width: 100%; text-align: left;
  background: transparent; /* Removed default background */
  border: 1px solid transparent;
  border-radius: 10px; padding: 10px 12px;
  color: #07005D; /* Requested text color */
  cursor: pointer;
  font-family: inherit; font-size: 0.85rem;
  display: flex; align-items: center; gap: 10px;
  transition: all var(--transition); margin-bottom: 6px;
}
.zone-btn:hover, .zone-btn.active { 
  background: #fff; 
  border-color: var(--gra-primary); 
  box-shadow: 0 4px 12px rgba(4, 152, 255, 0.1); 
}
.zone-btn.active {
  color: #07005D;
}

.zone-btn .zone-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  box-shadow: 0 0 8px rgba(0,0,0,0.1);
}
.zone-btn .zone-label { 
  font-weight: 700; 
  color: #0498FF; /* Requested title color */
}

.zone-btn .zone-sub { font-size: 0.72rem; color: #07005D; display: block; font-weight: 500; opacity: 0.8; }

/* Legend */
.legend-section { margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--gra-border); }
.legend-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 0.5rem; font-size: 0.75rem; color: #07005D;
  border-radius: 8px;
  transition: all var(--transition);
}
.legend-item.clickable {
  cursor: pointer;
}
.legend-item.clickable:hover {
  background: var(--gra-light);
  color: var(--gra-primary);
}
.legend-item.active {
  background: #fff;
  color: var(--gra-primary);
  box-shadow: 0 4px 12px rgba(4, 152, 255, 0.1);
  border: 1px solid var(--gra-primary);
}
.legend-icon { width: 16px; text-align: center; font-size: 0.85rem; }

/* ===== MAP CANVAS ===== */
.map-canvas {
  flex: 1; position: relative; overflow: hidden;
  background: #f8fbff;
  cursor: grab;
}
.map-canvas:active { cursor: grabbing; }
.map-canvas-inner {
  transform-origin: 0 0;
  /* will-change: transform; Removed to prevent pixelation at high zoom */
  position: absolute;
  top: 0; left: 0;
}
.map-canvas-inner svg {
  display: block;
  width: 1200px;
  height: auto;
  shape-rendering: geometricPrecision;
}

/* SVG Light Theme - Resetting to original or soft dark */
.map-canvas-inner svg line,
.map-canvas-inner svg polyline,
.map-canvas-inner svg polygon,
.map-canvas-inner svg path {
  stroke: rgba(7, 0, 93, 0.4) !important; /* Soft dark blue for lines */
}
.map-canvas-inner svg text {
  fill: #07005D !important;
}
.map-canvas-inner svg polyline[class],
.map-canvas-inner svg polygon[class] {
  fill: none !important;
}

/* Zone Overlays */
.zone-overlay {
  position: absolute;
  border: 2px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.3s ease;
  pointer-events: all;
}
.zone-overlay:hover, .zone-overlay.highlighted {
  background: rgba(4, 152, 255, 0.12);
  border-color: var(--gra-primary);
  box-shadow: inset 0 0 30px rgba(4, 152, 255, 0.08);
}
.zone-overlay .zone-tag {
  position: absolute; top: 8px; left: 8px;
  background: rgba(4, 0, 56, 0.85);
  backdrop-filter: blur(8px);
  border: 1px solid var(--gra-border);
  border-radius: 6px; padding: 4px 10px;
  font-size: 0.7rem; font-weight: 600;
  color: var(--gra-accent); white-space: nowrap;
  opacity: 0; transform: translateY(-4px);
  transition: all 0.3s ease;
  pointer-events: none;
}
.zone-overlay:hover .zone-tag,
.zone-overlay.highlighted .zone-tag {
  opacity: 1; transform: translateY(0);
}

/* Amenity Markers */
.amenity-marker {
  position: absolute;
  width: 12px; height: 12px;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0.5);
  opacity: 0;
  pointer-events: none;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  z-index: 50;
}
.amenity-marker.visible {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  pointer-events: auto;
  cursor: pointer;
}

.amenity-pulse-ring {
  content: '';
  position: absolute;
  left: -8px; top: -8px; right: -8px; bottom: -8px;
  border: 2px solid;
  border-radius: 50%;
  animation: pulse-ring 2s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}

.amenity-tooltip {
  position: absolute;
  bottom: 100%; left: 50%;
  transform: translate(-50%, -8px);
  background: rgba(4, 0, 56, 0.9);
  backdrop-filter: blur(8px);
  border: 1px solid var(--gra-border);
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 0.7rem; font-weight: 500;
  color: #fff; white-space: nowrap;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.amenity-marker:hover .amenity-tooltip {
  opacity: 1; transform: translate(-50%, -12px);
}

/* ===== TOOLTIP ===== */
.tooltip {
  position: fixed; z-index: 1000;
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(16px);
  border: 1px solid var(--gra-border);
  border-radius: 10px; padding: 10px 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
  pointer-events: none; opacity: 0;
  transition: opacity 0.2s ease;
  max-width: 220px;
}
.tooltip.visible { opacity: 1; }
.tooltip h4 { font-size: 0.85rem; font-weight: 600; margin-bottom: 2px; }
.tooltip p { font-size: 0.75rem; color: var(--gra-text-dim); }

/* ===== FOOTER ===== */
.footer {
  text-align: center; padding: 2rem;
  border-top: 1px solid var(--gra-border);
  color: var(--gra-text-dim); font-size: 0.8rem;
}
.footer a { color: var(--gra-primary); text-decoration: none; }
.footer a:hover { text-decoration: underline; }

/* ===== LOADING ===== */
.loading-overlay {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 1rem; z-index: 10;
}
.spinner {
  width: 40px; height: 40px;
  border: 3px solid var(--gra-border);
  border-top-color: var(--gra-primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
.loading-text { font-size: 0.85rem; color: var(--gra-text-dim); }

/* ===== ANIMATIONS ===== */
@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}
@keyframes pulse-ring {
  0% { transform: scale(0.5); opacity: 0; }
  50% { opacity: 1; }
  100% { transform: scale(1.5); opacity: 0; }
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
@keyframes fade-in {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
.area-card { animation: fade-in 0.5s ease backwards; }
.area-card:nth-child(1) { animation-delay: 0.05s; }
.area-card:nth-child(2) { animation-delay: 0.1s; }
.area-card:nth-child(3) { animation-delay: 0.15s; }
.area-card:nth-child(4) { animation-delay: 0.2s; }
.area-card:nth-child(5) { animation-delay: 0.25s; }

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .hero { padding: 3rem 1.5rem 1.5rem; }
  .hero h2 { font-size: 1.6rem; }
  .directory { padding: 0 1rem 2rem; }
  .cards-grid { grid-template-columns: 1fr; }
  .map-sidebar { display: none; }
  .map-toolbar .toolbar-title { display: none; }
  .header { padding: 0 1rem; }
  .header-brand h1 { font-size: 0.95rem; }
}
@media (max-width: 480px) {
  .stats-bar { flex-direction: column; }
  .stat-item { min-width: unset; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-c81f755 */.table-container {
  width: 100%;
  overflow-x: auto;   /* activa scroll horizontal */
  -webkit-overflow-scrolling: touch; /* scroll suave en móviles */
}
.custom-table table, thead, tbody, tfoot, tr, th, td {
  background-color: transparent !important; /* fuerza sin fondo */
}

.custom-table {
  border-collapse: collapse;
  width: 100%;
  background-color: transparent; /* sin fondo */
}

.custom-table th,
.custom-table td {
  text-align: left;
  padding: 8px;
  background-color: transparent; /* fuerza sin fondo */
  border-bottom: 1px solid #07005D; /* solo línea inferior */
}

.custom-table tfoot {
  text-align: left;
  padding: 8px;
  background-color: transparent; /* fuerza sin fondo */
  border-top: 1px solid #07005D; /* solo línea inferior */
}/* End custom CSS */