/* ============================================
   Interactive Map Page Styles
   ============================================ */

.interactive-map-page {
  min-height: 100dvh;
}

.interactive-map-page .map-main-container {
  width: 100%;
  min-height: 100dvh;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
}

/* Map Hero Section */
.interactive-map-page .map-hero {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* Map SVG and Background */
.interactive-map-page #map {
  display: block;
  width: 100%;
  height: 100dvh;
  background: #f6f0e6;
  cursor: grab;
  z-index: 10;
}

.interactive-map-page #map:active {
  cursor: grabbing;
}

.interactive-map-page .map-background {
  pointer-events: all;
  fill: none;
}

/* Map Overlay */
.interactive-map-page .map-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

/* Country Map Feature */
.interactive-map-page .country {
  fill: rgba(210, 180, 140, 0.8);
  stroke: brown;
}

/* Star Animations */
@keyframes twinkle {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.8; }
}

.interactive-map-page .star {
  transition: transform 1.3s ease;
  pointer-events: bounding-box;
  z-index: 15;
  animation: twinkle 2s infinite ease-in-out;
  cursor: pointer;
}

/* Title and Overlay Text */
.interactive-map-page .title-div {
  position: fixed;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  color: #111111;
  white-space: nowrap;
  pointer-events: none;
  z-index: 5;
}

.interactive-map-page .title-div h1 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 1.05;
  font-weight: bold;
  color: #000000;
  text-align: left;
}

.interactive-map-page .title-div p {
  margin: 0.75rem 0 0;
  font-size: clamp(1rem, 1.6vw, 1.5rem);
  line-height: 1.35;
  color: #000000;
  text-align: left;
}

.interactive-map-page .title-div .map-cta-button {
  margin-top: 1rem;
  margin-left: 0;
  margin-right: auto;
  display: inline-block;
  pointer-events: auto;
  background: #8d4f3f;
  color: #ffffff;
  text-decoration: none;
  font-weight: 700;
  border-radius: 0.5rem;
  padding: 0.65rem 1rem;
  transition: background 0.2s ease;
  border: none;
  cursor: pointer;
}

.interactive-map-page .title-div .map-cta-button:hover {
  background: #ddb15c;
}

/* Arrow Container and Animations */
.interactive-map-page .arrowContainer {
  margin-top: 1rem;
  height: 280px;
  color: #8d4f3f;
  letter-spacing: 0.08em;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: relative;
  margin-left: auto;
  margin-right: auto;
}

.interactive-map-page .arrowContainer svg {
  position: absolute;
  height: 50px;
  width: 50px;
  stroke: #ccc;
  transform-origin: center;
}

.interactive-map-page .arrow-left {
  animation: pointLeft 1s ease-in-out infinite alternate;
}

.interactive-map-page .arrow-right {
  animation: pointRight 1s ease-in-out infinite alternate;
}

.interactive-map-page .arrow-up {
  animation: pointOut 1s ease-in-out infinite alternate;
  transform: translate(-50%, -50%);
}

.interactive-map-page .arrow-down {
  animation: pointDown 1s ease-in-out infinite alternate;
}

@keyframes pointOut {
  0% { transform: translate(0%, -75%); }
  100% { transform: translate(0%, -100%); }
}

@keyframes pointRight {
  0% { transform: translate(150%, 0%); }
  100% { transform: translate(200%, 0%); }
}

@keyframes pointDown {
  0% { transform: translate(0%, 75%); }
  100% { transform: translate(0%, 100%); }
}

@keyframes pointLeft {
  0% { transform: translate(-150%, 0%); }
  100% { transform: translate(-200%, 0%); }
}

.interactive-map-page .animate-point-out {
  animation: pointOut 1s ease-in-out infinite alternate;
}

.interactive-map-page .animate-point-right {
  animation: pointRight 1s ease-in-out infinite alternate;
}

.interactive-map-page .animate-point-down {
  animation: pointDown 1s ease-in-out infinite alternate;
}

.interactive-map-page .animate-point-left {
  animation: pointLeft 1s ease-in-out infinite alternate;
}

/* Tooltip Styles */
.interactive-map-page #tooltip {
  position: absolute;
  opacity: 0;
  display: block;
  z-index: 20;
  max-width: min(38rem, 92vw);
  max-height: 50vh;
  overflow: auto;
  background-color: #15151E;
  color: #f7f3e8;
  border-radius: 5px;
  padding: 10px;
  pointer-events: auto;
  transition: opacity 0.3s ease-in-out;
  white-space: normal;
}

.interactive-map-page #tooltip a {
  color: #e6be6b;
}

.interactive-map-page #tooltip.wide {
  width: 600px;
  column-count: 2;
  column-gap: 20px;
}

/* Tooltip arrow tail */
.interactive-map-page #tooltip::after {
  content: "";
  position: absolute;
  bottom: -16px;
  left: 50%;
  transform: translateX(-50%);
  border-width: 8px;
  border-style: solid;
  border-color: #15151E transparent transparent transparent;
}

.interactive-map-page #tooltip::before {
  content: "";
  position: absolute;
  bottom: -17px;
  left: 50%;
  transform: translateX(-50%);
  border-width: 9px;
  border-style: solid;
  border-color: #15151E transparent transparent transparent;
}

/* Color Utilities */
.interactive-map-page .fill-softwhite {
  fill: #f6f0e6;
}

.interactive-map-page .fill-mustard {
  fill: #ddb15c;
}

.interactive-map-page .text-softwhite {
  color: #f7f3e8;
}

.interactive-map-page .text-mustard {
  color: #e6be6b;
}

.interactive-map-page .growing-region-polygon {
  pointer-events: none;
}

.interactive-map-page .growing-region-label {
  pointer-events: none;
  letter-spacing: 0.01em;
}

/* Sticky Filter Overlay */
.interactive-map-page .map-filter-overlay {
  position: fixed;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 40;
  pointer-events: auto;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.15);
  background: linear-gradient(140deg, rgba(23, 18, 16, 0.92), rgba(47, 35, 28, 0.86));
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(8px);
  color: #f7f3e8;
  padding: 0.85rem 1rem 1rem;
}

.interactive-map-page .map-filter-overlay-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.7rem;
}

.interactive-map-page .map-filter-overlay-header h2 {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.interactive-map-page .map-filter-reset {
  border: 1px solid rgba(230, 190, 107, 0.45);
  background: rgba(230, 190, 107, 0.12);
  color: #f7f3e8;
  border-radius: 999px;
  padding: 0.35rem 0.75rem;
  font-weight: 700;
  font-size: 0.78rem;
  cursor: pointer;
}

.interactive-map-page .map-filter-reset:hover {
  background: rgba(230, 190, 107, 0.24);
}

.interactive-map-page .map-filter-slider {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0.3rem;
  scrollbar-width: thin;
}

.interactive-map-page .map-filter-group {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: nowrap;
  min-width: max-content;
}

.interactive-map-page .map-filter-group-label {
  color: rgba(247, 243, 232, 0.76);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}

.interactive-map-page .map-filter-chip {
  border: 1px solid rgba(247, 243, 232, 0.35);
  background: rgba(255, 255, 255, 0.08);
  color: #f7f3e8;
  border-radius: 999px;
  padding: 0.3rem 0.62rem;
  font-size: 0.76rem;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  white-space: nowrap;
}

.interactive-map-page .map-filter-chip.is-active {
  border-color: #ddb15c;
  background: #ddb15c;
  color: #1c1411;
}

/* Responsive */
@media (max-width: 900px) {
  .interactive-map-page .title-div {
    white-space: normal;
    max-width: min(88vw, 24rem);
  }

  .interactive-map-page #tooltip.wide {
    width: 90vw;
    column-count: 1;
  }

  .interactive-map-page .map-filter-overlay {
    left: 0.5rem;
    right: 0.5rem;
    bottom: 0.5rem;
    padding: 0.75rem;
  }

  .interactive-map-page .map-filter-overlay-header h2 {
    font-size: 0.8rem;
  }
}
