/* Location Reveal — vertical mask layout */

.location-reveal {
  --lr-bg: #f3efe6;
  --lr-bg-soft: #1a1916;
  --lr-text: #f3efe6;
  --lr-muted: rgba(243, 239, 230, 0.72);
  --lr-gold: #c9a96e;
  --lr-gold-light: #e4d4b0;
  --lr-line: rgba(201, 169, 110, 0.28);
  --lr-font: var(--font-primary, "Open Sans", Arial, sans-serif);

  position: relative;
  width: 100%;
  background: var(--lr-bg);
  color: var(--lr-text);
  overflow: hidden;
}

.location-reveal__layout {
  position: relative;
  min-height: clamp(44rem, 100vh, 58rem);
  height: clamp(44rem, 100vh, 58rem);
  direction: ltr;
  isolation: isolate;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.location-reveal__logo-intro {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.location-reveal__logo-intro-mark {
  display: block;
  width: clamp(4.25rem, 7.5vw, 6.25rem);
  height: auto;
  transform-origin: center center;
  will-change: transform, opacity;
  filter: brightness(0) saturate(100%) invert(14%) sepia(16%) saturate(920%)
    hue-rotate(38deg) brightness(0.5) contrast(1.08)
    drop-shadow(0 6px 20px rgba(43, 46, 29, 0.18));
}

/* Visual — left half, full-bleed background */
.location-reveal__visual {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 50%;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background-color: #1a1916;
  background-image: url("../assets/location-reveal-aerial.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  transform-origin: left center;
  will-change: transform;
}

.location-reveal__visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent 55%,
    rgba(16, 16, 14, 0.35) 78%,
    rgba(16, 16, 14, 0.65) 100%
  );
  pointer-events: none;
}

/* Panel — right half, same height as visual */
.location-reveal__panel {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: clamp(2rem, 4vh, 3rem);
  width: 50%;
  height: 100%;
  margin: 0;
  padding: clamp(3rem, 6vh, 5rem) clamp(2.5rem, 4.5vw, 4rem)
    clamp(3rem, 6vh, 5rem) clamp(1.5rem, 3vw, 2.5rem);
  background-color: rgba(80, 79, 68, 1);
  direction: rtl;
  will-change: transform;
  box-sizing: border-box;
  overflow: hidden;
}

.location-reveal__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.75rem, 1.5vh, 1rem);
  width: 100%;
  max-width: none;
  text-align: center;
}

.location-reveal__header > .mask-reveal:not(.mask-reveal--inline) {
  width: 100%;
}

.location-reveal__title {
  margin: 0;
  font-family: var(--lr-font);
  font-size: clamp(2.65rem, 4.8vw, 4.25rem);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: 0.04em;
  text-align: center;
  background-image: none;
  -webkit-background-clip: unset;
  background-clip: unset;
  color: rgba(172, 138, 101, 1);
}

.location-reveal__rule {
  display: block;
  width: clamp(3.5rem, 8vw, 5rem);
  height: 1px;
  margin-inline: auto;
  background: rgba(172, 138, 101, 1);
}

.location-reveal__intro {
  margin: 0;
  font-size: clamp(1rem, 1.25vw, 1.15rem);
  font-weight: 300;
  line-height: 1.8;
  color: rgba(255, 255, 255, 1);
  width: 100%;
  max-width: none;
  text-align: right;
}

/* Feature grid — icon + label side by side (RTL: text left of icon, right-aligned) */
.location-reveal__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 0;
  padding: 0;
  list-style: none;
  gap: clamp(1rem, 2vw, 1.75rem) clamp(0.75rem, 1.5vw, 1.25rem);
}

.location-reveal__feature {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(0.65rem, 1.2vw, 0.9rem);
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  text-align: right;
}

.location-reveal__feature:hover {
  background: transparent;
  border-color: transparent;
}

.location-reveal__feature-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(3.25rem, 5vw, 4rem);
  height: clamp(3.25rem, 5vw, 4rem);
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 1);
  background-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.14);
  transition: border-color 0.3s ease, background-color 0.3s ease;
  will-change: transform, opacity;
}

.location-reveal__feature:hover .location-reveal__feature-icon {
  border-color: rgba(172, 138, 101, 1);
  background-color: rgba(172, 138, 101, 0.18);
}

.location-reveal__feature-icon img {
  display: block;
  width: 50%;
  height: 50%;
  object-fit: contain;
  color: rgba(255, 255, 255, 1);
  filter: brightness(0) invert(1);
  transition: filter 0.3s ease;
}

.location-reveal__feature:hover .location-reveal__feature-icon img {
  filter: brightness(0) saturate(100%) invert(68%) sepia(18%) saturate(742%)
    hue-rotate(358deg) brightness(92%) contrast(88%);
}

.location-reveal__feature-label {
  flex: 1;
  min-width: 0;
  font-size: clamp(0.78rem, 0.95vw, 0.9rem);
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 1);
  text-align: right;
  transition: color 0.3s ease;
  will-change: clip-path, opacity;
}

.location-reveal__feature:hover .location-reveal__feature-label {
  color: rgba(172, 138, 101, 1);
}

/* Scroll reveal */
.location-reveal__title,
.location-reveal__rule,
.location-reveal__intro,
.location-reveal__feature-icon,
.location-reveal__feature-label {
  will-change: transform, opacity, filter, clip-path;
}

@media (max-width: 1024px) {
  .location-reveal__layout {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    min-height: 0;
    height: auto;
  }

  .location-reveal__visual {
    position: relative;
    width: 100%;
    height: clamp(20rem, 48vw, 28rem);
    min-height: clamp(20rem, 48vw, 28rem);
  }

  .location-reveal__panel {
    position: relative;
    width: 100%;
    height: auto;
    min-height: 0;
    padding: clamp(2rem, 5vh, 2.75rem) clamp(1.25rem, 4vw, 2rem);
  }

  .location-reveal__header {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .location-reveal__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.1rem, 4vw, 1.5rem) clamp(0.5rem, 3vw, 0.85rem);
  }

  .location-reveal__title {
    font-size: clamp(2rem, 9vw, 2.65rem);
  }

  .location-reveal__intro {
    font-size: clamp(0.9rem, 3.6vw, 1rem);
  }

  .location-reveal__feature-label {
    font-size: clamp(0.72rem, 3.1vw, 0.84rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .location-reveal.is-init .location-reveal__title,
  .location-reveal.is-init .location-reveal__rule,
  .location-reveal.is-init .location-reveal__intro,
  .location-reveal.is-init .location-reveal__feature {
    opacity: 1;
  }

  .location-reveal__visual,
  .location-reveal__panel {
    clip-path: none !important;
    transform: none !important;
  }

  .location-reveal__logo-intro {
    display: none !important;
  }
}
