
/*
╔══════════════════════════════════════════════════════════════╗
║  EPE HOMEPAGE CSS STRUCTURE — DO NOT DELETE SECTIONS        ║
╠══════════════════════════════════════════════════════════════╣
║  CORE:        ── SCROLLBAR through ── ANIMATIONS            ║
║  LPD-DETAIL:  ▼▼▼ BEGIN:LPD-DETAIL  ...  END:LPD-DETAIL    ║
║  ATLAS:       ▼▼▼ BEGIN:ATLAS-TEASER ... END:ATLAS-TEASER   ║
╚══════════════════════════════════════════════════════════════╝
*/

:root {
  --gold: #C9A96E;
  --gold-light: #E8D5A3;
  --gold-dark: #A07840;
  --navy: #2C3556;
  --navy-dark: #2a4070;
  --navy-deeper: #1e3260;
  --cream: #F8F5EF;
  --white: #FFFFFF;
  --text-light: rgba(255,255,255,0.7);
  --text-muted: rgba(255,255,255,0.4);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Montserrat', sans-serif;
  background: var(--navy-deeper);
  color: var(--white);
  overflow-x: hidden;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--navy-deeper); }
::-webkit-scrollbar-thumb { background: var(--gold-dark); border-radius: 2px; }

/* ── NAV ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 24px 60px;
  display: flex; align-items: center; justify-content: space-between;
  transition: all 0.4s ease;
}
nav.scrolled {
  background: rgba(15,21,37,0.95);
  backdrop-filter: blur(12px);
  padding: 16px 60px;
  border-bottom: 1px solid rgba(201,169,110,0.15);
}
.nav-logo {
  display: flex; align-items: center; gap: 14px;
  text-decoration: none;
}
.nav-logo-epe {
  font-family: 'Cormorant Garamond', serif;
  font-size: 32px; font-weight: 300; letter-spacing: 6px;
  color: var(--gold); line-height: 1;
}
.nav-logo-sub {
  font-size: 9px; letter-spacing: 3px; text-transform: uppercase;
  color: var(--text-light); font-weight: 300; line-height: 1.6;
  border-left: 1px solid rgba(201,169,110,0.3);
  padding-left: 14px;
}
.nav-links { display: flex; gap: 40px; align-items: center; }
.nav-links a {
  text-decoration: none; color: var(--text-light);
  font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  font-weight: 400; transition: color 0.3s;
  position: relative;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -4px; left: 0; right: 0;
  height: 1px; background: var(--gold); transform: scaleX(0);
  transition: transform 0.3s; transform-origin: left;
}
.nav-links a:hover { color: var(--gold); }
.nav-links a:hover::after { transform: scaleX(1); }
.nav-lang {
  display: flex; gap: 6px;
}
.nav-lang button {
  background: none; border: none; color: var(--text-muted);
  font-size: 10px; letter-spacing: 1px; cursor: pointer;
  font-family: 'Montserrat', sans-serif; padding: 4px 6px;
  transition: color 0.3s; text-transform: uppercase;
}
.nav-lang button.active { color: var(--gold); }

/* ── HERO ── */
.hero {
  position: relative; height: 92vh; min-height: 620px;
  display: flex; flex-direction: column; justify-content: center;
  overflow: hidden;
}
/* ── HERO BG WITH REAL IMAGE ── */
.hero-bg {
  position: absolute; inset: 0;
  background: url('../images/hero-bg.jpg') center/cover no-repeat;
}
.hero-bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(
    135deg,
    rgba(15,21,37,0.55) 0%,
    rgba(26,32,56,0.40) 40%,
    rgba(15,21,37,0.45) 100%
  );
}
/* Decorative geometric lines */
.hero-lines {
  position: absolute; inset: 0; overflow: hidden;
}
.hero-lines::before {
  content: '';
  position: absolute; right: -100px; top: -100px;
  width: 700px; height: 700px;
  border: 1px solid rgba(201,169,110,0.06);
  border-radius: 50%;
  animation: rotateSlow 40s linear infinite;
}
.hero-lines::after {
  content: '';
  position: absolute; right: 50px; top: 50px;
  width: 500px; height: 500px;
  border: 1px solid rgba(201,169,110,0.04);
  border-radius: 50%;
  animation: rotateSlow 30s linear infinite reverse;
}
@keyframes rotateSlow { to { transform: rotate(360deg); } }

.hero-content {
  position: relative; z-index: 2;
  padding: 100px 60px 40px;
  max-width: 800px;
  animation: heroFadeUp 1.2s ease forwards;
}
@keyframes heroFadeUp {
  from { opacity: 0; transform: translateY(40px); }
  to { opacity: 1; transform: translateY(0); }
}
.hero-eyebrow {
  font-size: 10px; letter-spacing: 5px; text-transform: uppercase;
  color: var(--gold); margin-bottom: 20px;
  display: flex; align-items: center; gap: 16px;
}
.hero-eyebrow::before {
  content: ''; display: block; width: 40px; height: 1px; background: var(--gold);
}
.hero-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(48px, 7vw, 88px);
  font-weight: 300; line-height: 1.05;
  margin-bottom: 28px;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}
.hero-title em {
  font-style: italic; color: var(--gold);
}
.hero-subtitle {
  font-size: 13px; letter-spacing: 1px; line-height: 1.8;
  color: var(--text-light); max-width: 480px; margin-bottom: 48px;
  font-weight: 300;
}
.hero-cta {
  display: flex; gap: 20px; flex-wrap: wrap;
}
.btn-primary {
  display: inline-block; padding: 16px 40px;
  background: var(--gold); color: var(--navy-deeper);
  text-decoration: none; font-size: 10px; letter-spacing: 3px;
  text-transform: uppercase; font-weight: 600;
  transition: all 0.3s; border: 1px solid var(--gold);
}
.btn-primary:hover {
  background: transparent; color: var(--gold);
}
.btn-outline {
  display: inline-block; padding: 16px 40px;
  background: transparent; color: var(--white);
  text-decoration: none; font-size: 10px; letter-spacing: 3px;
  text-transform: uppercase; font-weight: 400;
  border: 1px solid rgba(255,255,255,0.2);
  transition: all 0.3s;
}
.btn-outline:hover {
  border-color: var(--gold); color: var(--gold);
}
.hero-scroll {
  position: absolute; right: 60px; bottom: 80px; z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  animation: heroFadeUp 1.5s ease 0.3s both;
}
.hero-scroll span {
  font-size: 9px; letter-spacing: 3px; color: var(--text-muted);
  text-transform: uppercase; writing-mode: vertical-rl;
}
.scroll-line {
  width: 1px; height: 60px; background: linear-gradient(to bottom, var(--gold), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%,100% { opacity: 0.4; transform: scaleY(1); }
  50% { opacity: 1; transform: scaleY(1.1); }
}

/* ── STATS BAR ── */
.stats-bar {
  background: var(--navy);
  border-top: 1px solid rgba(201,169,110,0.15);
  border-bottom: 1px solid rgba(201,169,110,0.15);
  padding: 40px 60px;
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 40px;
}
.stat-item { text-align: center; }
.stat-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 42px; font-weight: 300; color: var(--gold);
  line-height: 1;
}
.stat-label {
  font-size: 9px; letter-spacing: 3px; text-transform: uppercase;
  color: var(--text-light); margin-top: 8px; font-weight: 400;
}

/* ── SECTION HEADER ── */
.section-header {
  text-align: center; margin-bottom: 64px;
}
.section-eyebrow {
  font-size: 9px; letter-spacing: 5px; text-transform: uppercase;
  color: var(--gold); margin-bottom: 16px;
  display: flex; align-items: center; justify-content: center; gap: 16px;
}
.section-eyebrow::before, .section-eyebrow::after {
  content: ''; display: block; width: 30px; height: 1px; background: var(--gold-dark);
}
.section-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(32px, 4vw, 52px); font-weight: 300;
  line-height: 1.1;
}
.section-title em { font-style: italic; color: var(--gold); }
.section-sub {
  font-size: 12px; color: var(--text-light); margin-top: 16px;
  letter-spacing: 0.5px; line-height: 1.8; max-width: 500px; margin-inline: auto;
  font-weight: 300;
}

/* ── SERVICES ── */
.services {
  padding: 100px 60px;
  background: #1e3260;
}
.services-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px;
}
.service-card {
  background: var(--navy);
  padding: 52px 40px;
  position: relative; overflow: hidden;
  transition: all 0.4s ease;
  cursor: default;
}
.service-card::before {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: var(--gold); transform: scaleX(0);
  transition: transform 0.4s ease; transform-origin: left;
}
.service-card:hover { background: #1e2a4a; }
.service-card:hover::before { transform: scaleX(1); }
.service-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 64px; font-weight: 300; color: rgba(201,169,110,0.45);
  position: absolute; top: 20px; right: 30px; line-height: 1;
  transition: color 0.4s;
}
.service-card:hover .service-num { color: rgba(201,169,110,0.65); }
.service-icon { font-size: 28px; margin-bottom: 24px; }
.service-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px; font-weight: 400; margin-bottom: 16px;
  color: var(--white);
}
.service-text {
  font-size: 12px; line-height: 1.9; color: var(--text-light);
  font-weight: 300;
}
.service-link {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 28px; color: var(--gold); font-size: 10px;
  letter-spacing: 2px; text-transform: uppercase; text-decoration: none;
  transition: gap 0.3s;
}
.service-link:hover { gap: 14px; }
.service-link::after { content: '→'; }

/* ── ABOUT ── */
.about {
  padding: 100px 60px;
  background: var(--navy);
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: center;
}
.about-visual {
  position: relative;
}
.about-photo-frame {
  width: 100%; aspect-ratio: 3/4;
  background: linear-gradient(135deg, var(--navy-dark) 0%, #2C3556 100%);
  position: relative; overflow: hidden;
}
.about-photo-frame::before {
  content: 'R.E.';
  font-family: 'Cormorant Garamond', serif;
  font-size: 120px; font-weight: 300; color: rgba(201,169,110,0.06);
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  white-space: nowrap;
}
.about-photo-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 16px;
}
.about-photo-placeholder .icon { font-size: 64px; opacity: 0.3; }
.about-photo-placeholder p {
  font-size: 11px; letter-spacing: 2px; color: rgba(255,255,255,0.2);
  text-transform: uppercase;
}
.about-frame-deco {
  position: absolute; top: -20px; left: -20px; right: 20px; bottom: 20px;
  border: 1px solid rgba(201,169,110,0.2); pointer-events: none;
  z-index: -1;
}
.about-badge {
  position: absolute; bottom: -20px; right: -20px;
  background: var(--gold); color: var(--navy-deeper);
  padding: 20px 24px; text-align: center;
}
.about-badge-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px; font-weight: 300; line-height: 1;
}
.about-badge-text {
  font-size: 9px; letter-spacing: 2px; text-transform: uppercase;
  font-weight: 600; margin-top: 4px;
}
.about-content {}
.about-intro {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px; font-weight: 300; font-style: italic;
  color: var(--gold-light); line-height: 1.6; margin-bottom: 32px;
}
.about-text {
  font-size: 12px; line-height: 2; color: var(--text-light);
  font-weight: 300; margin-bottom: 16px;
}
.about-values {
  margin-top: 40px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.about-value {
  padding: 20px;
  border: 1px solid rgba(201,169,110,0.15);
}
.about-value-title {
  font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--gold); margin-bottom: 8px; font-weight: 500;
}
.about-value-text {
  font-size: 11px; color: var(--text-light); line-height: 1.6; font-weight: 300;
}
.about-signature {
  margin-top: 40px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 32px; font-style: italic; color: var(--gold);
  border-top: 1px solid rgba(201,169,110,0.2);
  padding-top: 24px;
}
.about-signature span {
  display: block; font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-style: normal; letter-spacing: 2px;
  color: var(--text-muted); text-transform: uppercase; margin-top: 6px;
}

/* ── PROPERTY MANAGEMENT ── */
.pm-section {
  padding: 100px 60px;
  background: linear-gradient(135deg, var(--navy-deeper) 0%, #2a4070 100%);
  position: relative; overflow: hidden;
}
.pm-section::before {
  content: 'PM';
  font-family: 'Cormorant Garamond', serif;
  font-size: 300px; font-weight: 300;
  color: rgba(201,169,110,0.03);
  position: absolute; right: -40px; top: 50%;
  transform: translateY(-50%);
  line-height: 1; pointer-events: none;
}
.pm-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: center;
}
.pm-services {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
  margin-top: 40px;
}
.pm-service {
  padding: 24px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(201,169,110,0.1);
  transition: border-color 0.3s;
}
.pm-service:hover { border-color: rgba(201,169,110,0.3); }
.pm-service-icon { font-size: 24px; margin-bottom: 12px; }
.pm-service-title {
  font-size: 11px; letter-spacing: 1px; text-transform: uppercase;
  color: var(--gold); margin-bottom: 8px; font-weight: 500;
}
.pm-service-text {
  font-size: 11px; color: var(--text-light); line-height: 1.6; font-weight: 300;
}
.pm-visual {
  position: relative;
}
.pm-mockup {
  background: var(--navy);
  border: 1px solid rgba(201,169,110,0.2);
  border-radius: 2px; overflow: hidden;
}
.pm-mockup-header {
  background: var(--navy-dark);
  padding: 12px 16px;
  display: flex; align-items: center; gap: 8px;
  border-bottom: 1px solid rgba(201,169,110,0.1);
}
.pm-mockup-dot { width: 8px; height: 8px; border-radius: 50%; }
.pm-mockup-title {
  font-size: 10px; letter-spacing: 2px; color: var(--gold);
  text-transform: uppercase; margin-left: 8px;
}
.pm-mockup-body { padding: 24px; }
.pm-mockup-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.05);
  font-size: 11px;
}
.pm-mockup-row:last-child { border-bottom: none; }
.pm-mockup-label { color: var(--text-muted); }
.pm-mockup-val { color: var(--white); }
.pm-mockup-status {
  font-size: 9px; padding: 3px 8px; border-radius: 20px;
  letter-spacing: 1px; text-transform: uppercase;
}
.status-ok { background: rgba(90,138,106,0.2); color: #6aba8a; }
.status-pending { background: rgba(201,169,110,0.15); color: var(--gold); }

/* ── PROPERTIES PREVIEW ── */
.properties-section {
  padding: 100px 60px;
  background: var(--navy-deeper);
}
.properties-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px;
  margin-bottom: 48px;
}
.property-card {
  position: relative; overflow: hidden;
  aspect-ratio: 3/4; cursor: pointer;
  background: var(--navy);
}
.property-card-bg {
  width: 100%; height: 100%;
  background: linear-gradient(135deg, #2a4070, #2C3556);
  display: flex; align-items: center; justify-content: center;
  transition: transform 0.6s ease;
  font-size: 64px; opacity: 0.2;
}
.property-card:hover .property-card-bg { transform: scale(1.05); }
.property-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(15,21,37,0.45) 0%, transparent 40%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 28px;
}
.property-card-price {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px; color: var(--gold); font-weight: 400;
  margin-bottom: 6px;
}
.property-card-title {
  font-size: 14px; font-weight: 300; margin-bottom: 4px;
}
.property-card-location {
  font-size: 10px; letter-spacing: 1px; color: var(--text-muted); text-transform: uppercase;
}
.property-card-tags {
  display: flex; gap: 8px; margin-top: 12px;
}
.property-tag {
  font-size: 9px; padding: 3px 8px;
  border: 1px solid rgba(201,169,110,0.3); color: var(--gold-light);
  letter-spacing: 1px; text-transform: uppercase;
}
.property-card-num {
  position: absolute; top: 20px; right: 20px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 13px; color: rgba(255,255,255,0.3);
}

/* ── CONTACT ── */
.contact-section {
  padding: 100px 60px;
  background: var(--navy);
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
}
.contact-info {}
.contact-intro {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px; font-style: italic; color: var(--gold-light);
  line-height: 1.7; margin-bottom: 40px; font-weight: 300;
}
.contact-item {
  display: flex; gap: 20px; align-items: flex-start;
  margin-bottom: 28px; padding-bottom: 28px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.contact-item:last-child { border-bottom: none; }
.contact-item-icon { font-size: 18px; opacity: 0.7; flex-shrink: 0; margin-top: 2px; }
.contact-item-label {
  font-size: 9px; letter-spacing: 2px; color: var(--gold);
  text-transform: uppercase; margin-bottom: 5px;
}
.contact-item-val {
  font-size: 13px; color: var(--white); font-weight: 300;
}
.contact-item-val a {
  color: var(--white); text-decoration: none; transition: color 0.3s;
}
.contact-item-val a:hover { color: var(--gold); }
.contact-form {}
.form-group { margin-bottom: 20px; }
.form-group label {
  display: block; font-size: 9px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--gold); margin-bottom: 8px;
}
.form-group input, .form-group select, .form-group textarea {
  width: 100%; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1); color: var(--white);
  padding: 14px 16px; font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 300;
  outline: none; transition: border-color 0.3s;
  appearance: none; -webkit-appearance: none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--gold);
}
.form-group textarea { min-height: 100px; resize: vertical; }
.form-group select option { background: var(--navy-dark); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-submit {
  width: 100%; padding: 16px;
  background: var(--gold); color: var(--navy-deeper);
  border: none; font-family: 'Montserrat', sans-serif;
  font-size: 10px; letter-spacing: 3px; text-transform: uppercase;
  font-weight: 600; cursor: pointer; transition: all 0.3s;
  margin-top: 8px;
}
.form-submit:hover { background: var(--gold-dark); }

/* ── FOOTER ── */
footer {
  background: var(--navy-deeper);
  border-top: 1px solid rgba(201,169,110,0.1);
  padding: 40px 60px;
  display: flex; justify-content: space-between; align-items: center;
}
.footer-logo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px; font-weight: 300; letter-spacing: 4px; color: var(--gold);
}
.footer-copy {
  font-size: 10px; color: var(--text-muted); letter-spacing: 1px;
}
.footer-links { display: flex; gap: 24px; }
.footer-links a {
  font-size: 10px; letter-spacing: 1px; color: var(--text-muted);
  text-decoration: none; text-transform: uppercase; transition: color 0.3s;
}
.footer-links a:hover { color: var(--gold); }

/* ── DIVIDER ── */
.gold-divider {
  width: 60px; height: 1px; background: var(--gold); margin: 0 auto 20px;
}

/* ── MOBILE ── */
@media (max-width: 768px) {
  nav { padding: 20px 24px; }
  nav.scrolled { padding: 14px 24px; }
  .nav-links { display: none; }
  .hero-content { padding: 0 24px 60px; }
  .hero-scroll { display: none; }
  .stats-bar { grid-template-columns: repeat(2,1fr); padding: 40px 24px; gap: 24px; }
  .services { padding: 60px 24px; }
  .services-grid { grid-template-columns: 1fr; }
  .about { padding: 60px 24px; grid-template-columns: 1fr; gap: 40px; }
  .pm-section { padding: 60px 24px; }
  .pm-grid { grid-template-columns: 1fr; gap: 40px; }
  .pm-services { grid-template-columns: 1fr 1fr; }
  .properties-section { padding: 60px 24px; }
  .properties-grid { grid-template-columns: 1fr; }
  .contact-section { padding: 60px 24px; grid-template-columns: 1fr; gap: 40px; }
  footer { padding: 30px 24px; flex-direction: column; gap: 16px; text-align: center; }
  .footer-links { flex-wrap: wrap; justify-content: center; }
}

/* ── ANIMATIONS ── */
.fade-up {
  opacity: 0; transform: translateY(30px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}
.fade-up.visible { opacity: 1; transform: translateY(0); }
.fade-up-delay-1 { transition-delay: 0.1s; }
.fade-up-delay-2 { transition-delay: 0.2s; }
.fade-up-delay-3 { transition-delay: 0.3s; }

/* ── HERO HIGHLIGHTS ── */
.hero-highlights {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 3;
  display: grid; grid-template-columns: repeat(3,1fr);
  border-top: 1px solid rgba(201,169,110,0.4);
}
.hero-highlight {
  display: flex; align-items: center; gap: 20px;
  padding: 28px 40px;
  background: rgba(26,32,52,0.82);
  backdrop-filter: blur(12px);
  cursor: pointer; transition: background 0.3s;
  border-right: 1px solid rgba(201,169,110,0.1);
}
.hero-highlight:last-child { border-right: none; }
.hero-highlight:hover { background: rgba(36,44,68,0.95); }
.hero-highlight-img {
  width: 80px; height: 80px; border-radius: 4px;
  flex-shrink: 0; border: 1px solid rgba(201,169,110,0.25);
}
.hero-highlight-price {
  font-family: 'Cormorant Garamond',serif;
  font-size: 20px; color: var(--gold); font-weight: 400;
}
.hero-highlight-title {
  font-size: 13px; color: var(--white); margin: 4px 0; font-weight: 300;
}
.hero-highlight-loc {
  font-size: 11px; color: rgba(255,255,255,0.55); letter-spacing: 0.5px;
}
@media (max-width: 768px) {
  .hero-highlights {
    position: relative;
    display: flex; overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
  }
  .hero-highlights::-webkit-scrollbar { display: none; }
  .hero-highlight {
    min-width: 85vw; scroll-snap-align: start;
    border-right: 1px solid rgba(201,169,110,0.1);
    border-bottom: none; padding: 16px 20px;
  }
  .hero-highlight-img { width: 56px; height: 56px; }
  .hero-content { padding-bottom: 20px; }
}
.search-bar {
  background: var(--navy); border: 1px solid rgba(201,169,110,0.2);
  padding: 18px 24px; border-radius: 2px;
}
.search-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 14px; }
.search-field label { display:block; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.search-field input, .search-field select {
  width: 100%; background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12); color: var(--white);
  padding: 9px 12px; font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 300; outline: none;
  transition: border-color 0.2s; appearance: none; -webkit-appearance: none;
  border-radius: 0;
}
.search-field input:focus, .search-field select:focus { border-color: var(--gold); }
.search-field select option { background: var(--navy-dark); }
.search-field input::placeholder { color: rgba(255,255,255,0.25); }
.search-typ-tag { display:inline-block; padding:5px 12px; border-radius:20px; font-size:11px; border:1px solid rgba(255,255,255,0.15); color:rgba(255,255,255,0.6); cursor:pointer; transition:all 0.2s; background:transparent; user-select:none; }
.search-typ-tag.active { background:var(--gold); color:var(--navy-deeper); border-color:var(--gold); font-weight:500; }
.search-typ-tag:hover:not(.active) { border-color:rgba(201,169,110,0.5); color:var(--gold); }
.ort-suggest-item { padding:9px 14px; font-size:12px; color:rgba(255,255,255,0.8); cursor:pointer; border-bottom:1px solid rgba(255,255,255,0.05); }
.ort-suggest-item:hover { background:rgba(201,169,110,0.1); color:var(--gold); }
@media (max-width: 768px) {
  .search-grid { grid-template-columns: 1fr 1fr; }
}

/* ── PROPERTY DETAIL ── */
.pd-slider { position: relative; width: 100%; height: 320px; overflow: hidden; background: var(--navy-dark); border-radius: 2px; margin-bottom: 24px; }
.pd-slider img { width: 100%; height: 100%; object-fit: cover; }
.pd-info-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin: 24px 0; }
.pd-info-item { background: var(--navy); padding: 16px; text-align: center; border: 1px solid rgba(201,169,110,0.1); }
.pd-info-val { font-family: 'Cormorant Garamond',serif; font-size: 22px; color: var(--gold); }
.pd-info-lbl { font-size: 9px; letter-spacing: 1px; color: var(--text-muted); text-transform: uppercase; margin-top: 4px; }
.pd-features { display: flex; flex-wrap: wrap; gap: 8px; margin: 16px 0; }
.pd-feature { background: rgba(201,169,110,0.1); border: 1px solid rgba(201,169,110,0.2); color: var(--gold-light); padding: 5px 12px; font-size: 11px; }
.pd-section-title { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--text-muted); border-bottom: 1px solid rgba(255,255,255,0.05); padding-bottom: 8px; margin: 24px 0 12px; }
.property-card-bg {
  width: 100%; height: 100%;
  background-size: cover !important;
  background-position: center !important;
  transition: transform 0.6s ease;
  font-size: 64px; display: flex; align-items: center; justify-content: center;
}

/* ── ABOUT PHOTO ── */
.about-photo-frame {
  width: 100%; aspect-ratio: 3/4;
  background: url('https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?w=600&q=80') center/cover no-repeat;
  position: relative; overflow: hidden;
}
.about-photo-frame::before { display: none; }
.about-photo-placeholder { display: none; }

/* ── LIFESTYLE / INSIDER SECTION ── */
.lifestyle-section {
  padding: 100px 60px;
  background: var(--navy);
  position: relative; overflow: hidden;
}
.lifestyle-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 2px;
  margin-top: 48px;
}
.lifestyle-card {
  background: var(--navy-dark);
  overflow: hidden; cursor: pointer;
  transition: transform 0.3s ease;
  position: relative;
}
.lifestyle-card:hover { transform: translateY(-4px); }
.lifestyle-card-img {
  width: 100%; aspect-ratio: 4/3;
  object-fit: cover; display: block;
  transition: transform 0.5s ease;
  background: linear-gradient(135deg, #2a4070, #2C3556);
  display: flex; align-items: center; justify-content: center;
  font-size: 48px;
}
.lifestyle-card:hover .lifestyle-card-img { transform: scale(1.04); }
.lifestyle-card-body { padding: 24px; }
.lifestyle-card-cat {
  font-size: 9px; letter-spacing: 3px; text-transform: uppercase;
  color: var(--gold); margin-bottom: 10px; font-weight: 500;
}
.lifestyle-card-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px; font-weight: 400; line-height: 1.3;
  margin-bottom: 10px; color: var(--white);
}
.lifestyle-card-text {
  font-size: 11px; color: var(--text-light);
  line-height: 1.8; font-weight: 300; margin-bottom: 16px;
}
.lifestyle-card-link {
  font-size: 10px; letter-spacing: 2px; color: var(--gold);
  text-transform: uppercase; text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
  transition: gap 0.3s;
}
.lifestyle-card-link:hover { gap: 12px; }
.lifestyle-card-link::after { content: '→'; }
.lifestyle-coming {
  position: absolute; top: 16px; right: 16px;
  background: rgba(201,169,110,0.15); color: var(--gold);
  font-size: 9px; letter-spacing: 2px; padding: 4px 10px;
  text-transform: uppercase; border: 1px solid rgba(201,169,110,0.3);
}
@media (max-width: 768px) {
  .lifestyle-section { padding: 60px 24px; }
  .lifestyle-grid { grid-template-columns: 1fr; gap: 12px; }
}

/* ── YOUTUBE SECTION ── */
.youtube-section {
  padding: 100px 60px;
  background: var(--navy-deeper);
  position: relative; overflow: hidden;
}
.youtube-section::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 40% at 50% 50%, rgba(201,169,110,0.04) 0%, transparent 70%);
  pointer-events: none;
}
.youtube-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-top: 48px;
}
.youtube-card {
  position: relative; overflow: hidden; cursor: pointer;
  background: var(--navy);
  transition: transform 0.3s ease;
}
.youtube-card:hover { transform: translateY(-4px); }
.youtube-thumb {
  width: 100%; aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--navy-dark), #2C3556);
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.youtube-thumb img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.4s ease;
}
.youtube-card:hover .youtube-thumb img { transform: scale(1.05); }
.youtube-play {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.2);
  transition: background 0.3s;
}
.youtube-card:hover .youtube-play { background: rgba(0,0,0,0.4); }
.youtube-play-btn {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--gold); display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: var(--navy-deeper);
  box-shadow: 0 4px 20px rgba(201,169,110,0.4);
  transition: transform 0.3s;
}
.youtube-card:hover .youtube-play-btn { transform: scale(1.1); }
.youtube-info { padding: 16px; }
.youtube-label {
  font-size: 9px; letter-spacing: 2px; color: var(--gold);
  text-transform: uppercase; margin-bottom: 6px;
}
.youtube-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 16px; font-weight: 400; line-height: 1.4;
  margin-bottom: 6px;
}
.youtube-meta {
  font-size: 10px; color: var(--text-muted); letter-spacing: 0.5px;
}
.youtube-placeholder {
  width: 100%; aspect-ratio: 16/9;
  background: var(--navy-dark);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; border: 1px dashed rgba(201,169,110,0.2);
}
.youtube-placeholder p { font-size: 11px; color: var(--text-muted); letter-spacing: 1px; }
.youtube-channel {
  display: flex; align-items: center; justify-content: center; gap: 16px;
  margin-top: 40px;
}
.youtube-subscribe {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 32px; background: #FF0000; color: #fff;
  text-decoration: none; font-size: 11px; letter-spacing: 2px;
  text-transform: uppercase; font-weight: 600; transition: all 0.3s;
  font-family: 'Montserrat', sans-serif;
}
.youtube-subscribe:hover { background: #cc0000; }

/* ── SOCIAL SECTION ── */
.social-section {
  padding: 60px;
  background: var(--navy);
  display: flex; align-items: center; justify-content: space-between;
  gap: 40px; flex-wrap: wrap;
}
.social-left {}
.social-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px; font-weight: 300; margin-bottom: 6px;
}
.social-title em { font-style: italic; color: var(--gold); }
.social-sub { font-size: 11px; color: var(--text-light); letter-spacing: 0.5px; font-weight: 300; }
.social-links { display: flex; gap: 12px; }
.social-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 24px; text-decoration: none;
  font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  font-weight: 500; transition: all 0.3s; font-family: 'Montserrat', sans-serif;
  border: 1px solid;
}
.social-btn-insta {
  background: linear-gradient(135deg, #833ab4, #fd1d1d, #fcb045);
  color: #fff; border-color: transparent;
}
.social-btn-insta:hover { opacity: 0.85; }
.social-btn-wa {
  background: #25D366; color: #fff; border-color: transparent;
}
.social-btn-wa:hover { background: #1da851; }
.social-btn-yt {
  background: transparent; color: var(--gold); border-color: rgba(201,169,110,0.3);
}
.social-btn-yt:hover { border-color: var(--gold); background: rgba(201,169,110,0.05); }

/* ── PM SECTION IMAGE ── */
.pm-section {
  background: linear-gradient(135deg, rgba(15,21,37,0.97) 0%, rgba(26,32,56,0.97) 100%),
              url('https://images.unsplash.com/photo-1512917774080-9991f1c4c750?w=1200&q=80') center/cover no-repeat;
}

@media (max-width: 768px) {
  .youtube-grid { grid-template-columns: 1fr; }
  .social-section { padding: 40px 24px; flex-direction: column; align-items: flex-start; }
  .youtube-section { padding: 60px 24px; }
}

/* ── TESTIMONIALS ── */
.testimonials-section {
  padding: 100px 60px;
  background: linear-gradient(135deg, var(--navy-deeper) 0%, var(--navy) 100%);
  position: relative; overflow: hidden;
}
.testimonials-section::before {
  content: '"';
  font-family: 'Cormorant Garamond', serif;
  font-size: 400px; font-weight: 300; line-height: 1;
  color: rgba(201,169,110,0.04);
  position: absolute; top: -60px; left: 40px;
  pointer-events: none;
}
.testimonials-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px;
  margin-top: 48px;
}
.testimonial-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(201,169,110,0.12);
  border-radius: 2px; padding: 32px 28px;
  position: relative; transition: border-color 0.3s;
}
.testimonial-card:hover { border-color: rgba(201,169,110,0.3); }
.testimonial-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: 48px; color: var(--gold); line-height: 1;
  margin-bottom: 16px; opacity: 0.6;
}
.testimonial-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px; font-style: italic; font-weight: 300;
  line-height: 1.7; color: rgba(255,255,255,0.85);
  margin-bottom: 24px;
}
.testimonial-divider {
  width: 32px; height: 1px; background: var(--gold);
  margin-bottom: 16px; opacity: 0.5;
}
.testimonial-author {
  display: flex; align-items: center; gap: 12px;
}
.testimonial-avatar {
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(201,169,110,0.15);
  border: 1px solid rgba(201,169,110,0.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
}
.testimonial-name {
  font-size: 13px; font-weight: 500; color: var(--white);
}
.testimonial-origin {
  font-size: 11px; color: var(--text-muted); margin-top: 2px; letter-spacing: 0.5px;
}
.testimonial-stars {
  position: absolute; top: 28px; right: 28px;
  font-size: 11px; color: var(--gold); letter-spacing: 2px;
}
@media (max-width: 768px) {
  .testimonials-section { padding: 60px 24px; }
  .testimonials-grid { grid-template-columns: 1fr; gap: 16px; }
}
/* ── LANG CONTENT ── */
[data-lang] { display: none; }
[data-lang].active { display: block; }
[data-lang-inline] { display: none; }
[data-lang-inline].active { display: inline; }



/* ▼▼▼ BEGIN:LPD-DETAIL ▼▼▼ */
/* ═══ EPE EXPOSÉ PREMIUM BLUE v3 ═══ */
:root {
  --ex-navy:#0b1426; --ex-navy2:#111d34; --ex-blue:#203c70;
  --ex-panel:#2d3a61; --ex-panel2:#334269;
  --ex-gold:#c9a96e; --ex-gold2:#d8b978;
  --ex-white:#f7f3ea; --ex-muted:#b8bfd0;
  --ex-border:rgba(201,169,110,.35); --ex-line:rgba(255,255,255,.12);
  --ex-shadow:0 24px 70px rgba(0,0,0,.42);
}
#property-overlay { background: linear-gradient(135deg,#101b31 0%,#1f3b70 52%,#2c3a61 100%); overflow-y:auto; width:100%; height:100%; }
.epe-expose-page { font-family:'Jost','Montserrat',system-ui,sans-serif; color:var(--ex-white); font-weight:300; line-height:1.6; min-height:100vh; width:100%; }

/* HEADER */
.ex-header { height:68px; background:rgba(10,18,34,.96); border-bottom:1px solid rgba(201,169,110,.2); display:flex; align-items:center; justify-content:space-between; padding:0 32px; position:sticky; top:0; z-index:30; backdrop-filter:blur(14px); gap:16px; }
.ex-back-btn { background:none; border:1px solid rgba(201,169,110,.35); color:var(--ex-white); padding:9px 18px; font-size:10px; letter-spacing:.15em; cursor:pointer; font-family:'Montserrat',sans-serif; transition:.2s; white-space:nowrap; flex-shrink:0; }
.ex-back-btn:hover { background:rgba(201,169,110,.15); border-color:var(--ex-gold); }
.ex-expose-btn { background:linear-gradient(135deg,var(--ex-gold),var(--ex-gold2)); color:#09101d; border:none; padding:10px 24px; font-size:10px; letter-spacing:.18em; text-transform:uppercase; cursor:pointer; font-family:'Montserrat',sans-serif; font-weight:600; white-space:nowrap; transition:.2s; }
.ex-expose-btn:hover { opacity:.88; }
.ex-fav { cursor:pointer; color:var(--ex-gold); white-space:nowrap; font-size:12px; letter-spacing:.1em; font-family:'Montserrat',sans-serif; }

/* HERO */
.ex-hero { position:relative; min-height:580px; display:flex; align-items:flex-end; padding:100px 7vw 52px; overflow:hidden; border-bottom:1px solid var(--ex-border); }
.ex-hero::before { content:''; position:absolute; inset:0; background-image:var(--hero-img); background-size:cover; background-position:center; filter:saturate(.9); }
.ex-hero::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,rgba(4,10,19,.92) 0%,rgba(6,15,29,.78) 35%,rgba(6,15,29,.2) 78%), linear-gradient(0deg,rgba(4,10,19,.75),transparent 50%); }
.ex-hero-content { position:relative; z-index:2; max-width:720px; }
.ex-kicker { font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--ex-white); margin-bottom:12px; opacity:.9; }
.ex-title { font-family:'Cormorant Garamond',serif; font-size:clamp(36px,5vw,64px); font-weight:400; line-height:.98; letter-spacing:-.02em; margin-bottom:20px; }
.ex-price { font-family:'Cormorant Garamond',serif; font-size:clamp(28px,3.5vw,42px); color:var(--ex-gold); margin-bottom:22px; }
.ex-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; min-height:46px; padding:0 28px; border:1px solid var(--ex-border); background:rgba(6,12,24,.3); color:var(--ex-white); font-size:11px; letter-spacing:.2em; text-transform:uppercase; cursor:pointer; text-decoration:none; font-family:'Montserrat',sans-serif; transition:.2s; }
.ex-btn:hover { background:rgba(201,169,110,.15); }
.ex-btn-gold { background:linear-gradient(135deg,var(--ex-gold),var(--ex-gold2)); color:#09101d; border-color:transparent; font-weight:600; }
.ex-btn-gold:hover { opacity:.9; }

/* FACTS */
.ex-facts { background:rgba(25,43,78,.75); border-bottom:1px solid var(--ex-border); }
.ex-facts-inner { width:min(1180px,calc(100% - 64px)); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); }
.ex-fact { display:flex; align-items:center; justify-content:center; gap:20px; padding:28px 16px; border-right:1px solid var(--ex-line); }
.ex-fact:last-child { border-right:0; }
.ex-icon { width:32px; height:32px; color:var(--ex-gold); display:grid; place-items:center; flex-shrink:0; }
.ex-icon svg { width:30px; height:30px; stroke:currentColor; stroke-width:1.35; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.ex-fact strong { display:block; font-family:'Cormorant Garamond',serif; font-size:26px; font-weight:500; }
.ex-fact small { font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:rgba(247,243,234,.8); }

/* CONTAINER */
.ex-container { width:min(1180px,calc(100% - 64px)); margin:0 auto; }
.ex-section { padding:36px 0; border-top:1px solid var(--ex-border); }
.ex-eyebrow { font-family:'Montserrat',sans-serif; font-size:10px; letter-spacing:.28em; text-transform:uppercase; color:var(--ex-gold); margin-bottom:14px; }
.ex-section-title { font-family:'Cormorant Garamond',serif; font-size:34px; font-weight:400; line-height:1.1; margin-bottom:18px; }
.ex-gold-line { width:38px; height:1px; background:var(--ex-gold); margin:0 0 26px; }
.ex-copy { color:rgba(247,243,234,.86); font-size:14px; line-height:1.85; }
.ex-more { display:inline-block; margin-top:24px; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ex-gold); text-decoration:none; border-bottom:1px solid rgba(201,169,110,.4); padding-bottom:2px; }

/* INTRO GRID */
.ex-intro-grid { display:grid; grid-template-columns:280px 1fr; gap:48px; }

/* GALLERY */
.ex-gal-main { position:relative; cursor:pointer; border:1px solid rgba(201,169,110,.28); box-shadow:var(--ex-shadow); overflow:hidden; }
.ex-gal-main img { width:100%; height:360px; object-fit:cover; display:block; }
.ex-gal-label { position:absolute; right:16px; bottom:14px; padding:7px 14px; background:rgba(6,12,24,.72); border:1px solid var(--ex-border); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ex-gold); }
.ex-gal-arr { position:absolute; top:50%; transform:translateY(-50%); background:rgba(0,0,0,.5); border:none; color:#fff; width:40px; height:40px; font-size:24px; cursor:pointer; z-index:3; backdrop-filter:blur(4px); transition:.2s; }
.ex-gal-arr:hover { background:rgba(201,169,110,.5); }
.ex-gal-prev { left:0; }
.ex-gal-next { right:0; }
.ex-thumbs { display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin-top:6px; }
.ex-thumb { height:90px; object-fit:cover; width:100%; border:1px solid rgba(201,169,110,.22); cursor:pointer; opacity:.75; transition:.2s; }
.ex-thumb.active,.ex-thumb:hover { opacity:1; border-color:var(--ex-gold); }

/* INFO GRID */
.ex-info-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:24px; }
.ex-panel { border:1px solid var(--ex-border); background:linear-gradient(145deg,rgba(6,18,34,.58),rgba(38,54,93,.72)); padding:24px; }
.ex-panel-img { padding:0; overflow:hidden; }
.ex-panel-img img { height:100%; width:100%; object-fit:cover; display:block; min-height:280px; }
.ex-check-list { list-style:none; padding:0; margin:0; }
.ex-check-list li { margin:10px 0; color:rgba(247,243,234,.86); font-size:14px; padding-left:20px; position:relative; }
.ex-check-list li::before { content:'✓'; color:var(--ex-gold); position:absolute; left:0; }
.ex-dist { display:grid; grid-template-columns:auto 1fr auto; gap:10px; align-items:center; margin:10px 0; color:rgba(247,243,234,.9); font-size:13px; }
.ex-di { color:var(--ex-gold); font-size:15px; }
.ex-dist b { color:var(--ex-gold); }

/* MATCHING */
.ex-match { display:grid; grid-template-columns:120px 1fr 160px; gap:32px; align-items:center; border:1px solid var(--ex-border); background:rgba(255,255,255,.04); padding:28px 36px; margin:20px 0 0; }
.ex-profile-icon { width:88px; height:88px; border:1px solid var(--ex-gold); border-radius:50%; display:grid; place-items:center; color:var(--ex-gold); }
.ex-profile-icon svg { width:40px; height:40px; stroke:currentColor; stroke-width:1.25; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.ex-chips { display:flex; flex-wrap:wrap; gap:12px; margin-top:14px; }
.ex-chip { font-size:12px; color:rgba(247,243,234,.86); padding-left:18px; position:relative; }
.ex-chip::before { content:'✓'; color:var(--ex-gold); position:absolute; left:0; }
.ex-circle { width:128px; height:128px; border-radius:50%; display:grid; place-items:center; text-align:center; background:conic-gradient(var(--ex-gold) 0 var(--pct,91%), rgba(255,255,255,.15) var(--pct,91%) 100%); position:relative; }
.ex-circle::before { content:''; position:absolute; inset:11px; border-radius:50%; background:#13213b; }
.ex-circle span { position:relative; font-family:'Cormorant Garamond',serif; font-size:28px; line-height:1; }
.ex-circle small { position:relative; font-size:9px; letter-spacing:.12em; text-transform:uppercase; display:block; }

/* CTA CONTACT */
.ex-cta { background:linear-gradient(135deg,#101b31 0%,#182a4c 100%); border-top:1px solid var(--ex-border); border-bottom:1px solid var(--ex-border); padding:48px 0; }
.ex-cta-grid { display:grid; grid-template-columns:260px 1fr 1fr; gap:40px; align-items:stretch; }
.ex-agent img { height:280px; width:100%; object-fit:cover; object-position:center top; display:block; }
.ex-btn-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:24px; }
.ex-btn-email { grid-column:1/-1; background:linear-gradient(135deg,var(--ex-gold),var(--ex-gold2)); color:#09101d; border-color:transparent; font-weight:600; }
.ex-quote-block { border-left:1px solid var(--ex-border); padding-left:32px; display:flex; flex-direction:column; justify-content:center; }
.ex-quote-mark { font-family:'Cormorant Garamond',serif; font-size:64px; color:var(--ex-gold); line-height:1; opacity:.6; }
.ex-signature { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:28px; color:var(--ex-gold); margin-top:18px; }

/* STRIP */
.ex-strip { display:grid; grid-template-columns:repeat(5,1fr); }
.ex-strip img { height:110px; width:100%; object-fit:cover; filter:saturate(.85); display:block; }

/* LIGHTBOX */
.ex-lightbox { position:fixed; inset:0; background:rgba(3,7,13,.96); z-index:19999; display:none; align-items:center; justify-content:center; padding:20px; }
.ex-lightbox.open { display:flex; }
.ex-lb-img { max-width:min(1100px,92vw); max-height:85vh; object-fit:contain; border:1px solid var(--ex-border); box-shadow:var(--ex-shadow); }
.ex-lb-close { position:absolute; top:16px; right:20px; border:1px solid rgba(201,169,110,.4); background:rgba(6,12,24,.85); color:#fff; cursor:pointer; width:44px; height:44px; font-size:22px; display:flex; align-items:center; justify-content:center; z-index:20000; }
.ex-lb-btn { position:absolute; top:50%; transform:translateY(-50%); border:1px solid rgba(201,169,110,.3); background:rgba(6,12,24,.8); color:#fff; cursor:pointer; width:52px; height:52px; font-size:32px; display:flex; align-items:center; justify-content:center; z-index:20000; }
.ex-lb-prev { left:16px; }
.ex-lb-next { right:16px; }
.ex-lb-count { position:absolute; bottom:16px; left:50%; transform:translateX(-50%); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--ex-gold); font-family:'Montserrat',sans-serif; z-index:20000; }

/* RESPONSIVE */
@media(max-width:900px) {
  .ex-header { height:auto; min-height:68px; padding:12px 20px; }
  .ex-nav { gap:16px; }
  .ex-hero { min-height:480px; padding:72px 24px 36px; }
  .ex-facts-inner { grid-template-columns:repeat(2,1fr); }
  .ex-fact { justify-content:flex-start; border-bottom:1px solid var(--ex-line); }
  .ex-container { width:calc(100% - 40px); }
  .ex-intro-grid, .ex-info-grid, .ex-match, .ex-cta-grid { grid-template-columns:1fr; }
  .ex-gal-main img { height:260px; }
  .ex-thumbs { grid-template-columns:repeat(2,1fr); }
  .ex-match { padding:20px; }
  .ex-circle { width:100px; height:100px; }
  .ex-quote-block { border-left:0; border-top:1px solid var(--ex-border); padding-left:0; padding-top:20px; }
  .ex-strip { grid-template-columns:repeat(2,1fr); }
  .ex-btn-row { grid-template-columns:1fr; }
  .ex-btn-email { grid-column:auto; }
}


/* ── MATCHING DUAL STATE (compact) ── */
.ex-match-section { margin:0; }
.ex-ms { border-top:1px solid var(--ex-border); padding:32px 0; }
.ex-ms-a { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.ex-ms-left { display:flex; flex-direction:column; gap:16px; }
.ex-ms-score-row { display:flex; align-items:center; gap:20px; }
.ex-ms-circle { width:72px; height:72px; border-radius:50%; border:2px solid var(--ex-gold); display:flex; flex-direction:column; align-items:center; justify-content:center; flex-shrink:0; background:rgba(201,169,110,.06); }
.ex-ms-circle span { font-family:'Cormorant Garamond',serif; font-size:22px; color:var(--ex-gold); line-height:1; }
.ex-ms-circle small { font-size:9px; letter-spacing:.1em; color:rgba(247,243,234,.6); }
.ex-ms-headline { font-family:'Cormorant Garamond',serif; font-size:20px; color:#fff; margin-bottom:4px; }
.ex-ms-sub { font-size:13px; color:rgba(247,243,234,.65); line-height:1.6; margin:0; }
.ex-ms-right { display:flex; align-items:center; border-left:1px solid rgba(201,169,110,.2); padding-left:40px; }
.ex-ms-tags { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.ex-ms-tags li { font-family:'Montserrat',sans-serif; font-size:12px; color:rgba(247,243,234,.8); padding-left:16px; position:relative; }
.ex-ms-tags li::before { content:'✓'; color:var(--ex-gold); position:absolute; left:0; }
.ex-ms-b { display:grid; grid-template-columns:1fr 1px 320px; gap:0; align-items:center; background:linear-gradient(135deg,rgba(11,20,38,.5),rgba(32,60,112,.35)); border:1px solid rgba(201,169,110,.18); padding:28px 36px; min-height:0; }
.ex-ms-b-left { padding-right:36px; }
.ex-ms-b-title { font-family:'Cormorant Garamond',serif; font-size:clamp(16px,1.6vw,20px); font-weight:400; color:#fff; line-height:1.3; margin:6px 0 10px; }
.ex-ms-b-title em { color:var(--ex-gold); font-style:italic; }
.ex-ms-b-checks { display:flex; gap:14px; flex-wrap:wrap; margin:8px 0 12px; }
.ex-ms-b-checks span { font-family:'Montserrat',sans-serif; font-size:10px; color:rgba(247,243,234,.7); }
.ex-ms-cta { display:inline-block; background:linear-gradient(135deg,var(--ex-gold),var(--ex-gold2)); color:#09101d; font-family:'Montserrat',sans-serif; font-size:10px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; padding:10px 20px; text-decoration:none; transition:.2s; }
.ex-ms-cta:hover { opacity:.88; }
.ex-ms-b-divider { background:rgba(201,169,110,.25); align-self:stretch; margin:0; width:1px; }
.ex-ms-b-right { padding-left:36px; display:flex; flex-direction:column; justify-content:center; }
.ex-ms-b-quote { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:15px; color:rgba(247,243,234,.7); line-height:1.65; }
.ex-impressionen { padding:32px 0 0; }
.ex-impr-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.ex-impr-card { cursor:default; }
.ex-impr-img { height:110px; background:rgba(20,40,80,.6); border:1px solid rgba(201,169,110,.12); display:flex; align-items:center; justify-content:center; transition:.2s; }
.ex-impr-img:hover { border-color:rgba(201,169,110,.3); }
.ex-impr-icon { font-size:26px; opacity:.45; }
.ex-impr-label { font-family:'Montserrat',sans-serif; font-size:9px; letter-spacing:.15em; text-transform:uppercase; color:rgba(247,243,234,.4); text-align:center; padding:7px 0; }
.ex-strip { display:none !important; }
@media(max-width:700px){
  .ex-ms-a { grid-template-columns:1fr; gap:20px; padding:24px 0; }
  .ex-ms-right { border-left:0; border-top:1px solid rgba(201,169,110,.15); padding-left:0; padding-top:18px; }
  .ex-ms-b { grid-template-columns:1fr; padding:20px; gap:16px; }
  .ex-ms-b-divider { width:80%; height:1px; margin:4px auto; }
  .ex-ms-b-right { padding-left:0; }
  .ex-impr-grid { grid-template-columns:repeat(2,1fr); gap:8px; }
}

/* ▲▲▲ END:LPD-DETAIL ▲▲▲ */


/* ▼▼▼ BEGIN:ATLAS-TEASER ▼▼▼ */
/* ATLAS TEASER */
.atlas-teaser{background:linear-gradient(135deg,#0a1628 0%,#1a2a4a 50%,#0f1e38 100%);padding:100px 40px;position:relative;overflow:hidden;}
.atlas-teaser::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(201,169,110,.08),transparent 60%);}
.atlas-teaser-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1;}
.atlas-eyebrow{font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;}
.atlas-teaser-title{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:300;color:#fff;line-height:1.15;margin-bottom:24px;}
.atlas-teaser-title em{color:var(--gold);font-style:italic;}
.atlas-teaser-text{color:rgba(255,255,255,.7);font-family:'Montserrat',sans-serif;font-size:15px;line-height:1.7;margin-bottom:36px;max-width:460px;}
.atlas-teaser-benefits{display:flex;flex-direction:column;gap:16px;margin-bottom:40px;}
.atlas-benefit{display:flex;gap:14px;align-items:flex-start;}
.ab-icon{color:var(--gold);font-size:18px;margin-top:2px;flex-shrink:0;}
.atlas-benefit b{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;color:#fff;display:block;margin-bottom:2px;letter-spacing:.05em;}
.atlas-benefit p{font-family:'Montserrat',sans-serif;font-size:12px;color:rgba(255,255,255,.55);margin:0;}
.atlas-teaser-btn{display:inline-block;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#0a1628;font-family:'Montserrat',sans-serif;font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;padding:18px 40px;text-decoration:none;transition:all .3s;box-shadow:0 8px 30px rgba(201,169,110,.3);}
.atlas-teaser-btn:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(201,169,110,.4);}
.atlas-teaser-map{position:relative;}
.atlas-map-preview{width:100%;border-radius:4px;box-shadow:0 30px 80px rgba(0,0,0,.5);border:1px solid rgba(201,169,110,.2);}
@media(max-width:900px){.atlas-teaser-inner{grid-template-columns:1fr;gap:40px;}.atlas-teaser-title{font-size:36px;}.atlas-teaser{padding:60px 20px;}}

/* SKELETON LOADER */
.prop-skeleton{background:rgba(255,255,255,.04);border:1px solid rgba(201,169,110,.1);overflow:hidden;}
.skel-img{width:100%;height:260px;background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);background-size:200% 100%;animation:skel-shimmer 1.5s infinite;}
.skel-body{padding:20px;}
.skel-line{height:12px;border-radius:4px;margin-bottom:12px;background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);background-size:200% 100%;animation:skel-shimmer 1.5s infinite;}
.skel-line-short{width:40%;}
.skel-line-long{width:90%;}
.skel-line-med{width:60%;}
@keyframes skel-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* ▲▲▲ END:ATLAS-TEASER ▲▲▲ */

