.property-hero { padding: clamp(64px, 8vw, 96px) 0 clamp(32px, 6vw, 72px); background: var(--ek-color-neutral-050); }
.property-hero__top { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 24px; }
.property-crumb { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; border-radius: 999px; background: #fff; border: 1px solid var(--ek-color-neutral-200); color: var(--ek-color-neutral-700); font-weight: 600; text-decoration: none; transition: all 160ms ease; }
.property-crumb:hover { color: var(--ek-color-primary); border-color: var(--ek-color-primary); }
.property-hero__tags { display: flex; gap: 10px; flex-wrap: wrap; }
.property-badge { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 999px; font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; background: rgba(96, 165, 250, 0.16); color: var(--ek-color-primary); }
.property-badge--muted { background: rgba(11, 31, 58, 0.08); color: var(--ek-color-secondary); }
.property-badge--accent { background: rgba(220, 38, 38, 0.12); color: #b91c1c; }
.property-hero__heading { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; flex-wrap: wrap; margin-bottom: clamp(28px, 5vw, 48px); }
.property-title { margin: 0; font-size: clamp(32px, 4vw, 48px); font-weight: 600; color: var(--ek-color-neutral-900); }
.property-address { display: flex; align-items: center; gap: 8px; color: var(--ek-color-neutral-700); margin: 12px 0 0; font-size: 16px; }
.property-meta { display: flex; flex-wrap: wrap; gap: 12px; list-style: none; padding: 0; margin: 18px 0 0; }
.property-meta li { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; border-radius: 999px; background: #fff; border: 1px solid var(--ek-color-neutral-200); font-weight: 500; color: var(--ek-color-neutral-900); }
.property-meta li i { color: var(--ek-color-primary); }
.property-hero__layout { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); gap: clamp(24px, 4vw, 36px); align-items: start; }
.property-gallery { position: relative; }
.property-gallery__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); grid-template-rows: repeat(2, minmax(140px, 200px)); gap: 12px; }
.property-gallery__grid figure { margin: 0; border-radius: 18px; overflow: hidden; background: #fff; }
.property-gallery__grid img { width: 100%; height: 100%; object-fit: cover; transition: transform 200ms ease; }
.property-gallery__grid figure:hover img { transform: scale(1.04); }
.property-gallery__primary { grid-column: 1 / span 3; grid-row: 1 / span 2; }
.property-gallery__viewAll { position: absolute; right: 18px; bottom: 18px; border-radius: 999px; padding: 10px 18px; backdrop-filter: blur(6px); background: rgba(0, 0, 0, 0.35); color: #fff; border-color: rgba(255, 255, 255, 0.45); display: inline-flex; align-items: center; gap: 8px; transition: background 160ms ease; }
.property-gallery__viewAll:hover { background: rgba(0, 0, 0, 0.55); color: #fff; }
.property-gallery__overlay { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.88); z-index: 1050; display: none; align-items: center; justify-content: center; padding: clamp(24px, 5vw, 48px); }
.property-gallery__overlay .swiper-container { width: min(100%, 1080px); height: min(90vh, 720px); }
.property-gallery__overlay .swiper-slide { display: flex; align-items: center; justify-content: center; }
.property-gallery__overlay img { max-width: 100%; max-height: 100%; object-fit: contain; }
.property-gallery__overlay .swiper-button-next,
.property-gallery__overlay .swiper-button-prev { color: #fff; }
.property-gallery__close { position: absolute; top: clamp(16px, 4vw, 32px); right: clamp(16px, 4vw, 32px); font-size: 32px; color: #fff; background: transparent; border: none; cursor: pointer; }
body.property-overlay-open { overflow: hidden; }
.property-booking { background: #fff; border-radius: 24px; padding: clamp(24px, 3vw, 32px); border: 1px solid rgba(15, 42, 63, 0.08); box-shadow: 0 24px 48px rgba(12, 32, 46, 0.12); display: flex; flex-direction: column; gap: 18px; }
.property-booking__header { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.property-booking__header h3 { margin: 0; font-size: 22px; font-weight: 600; color: var(--ek-color-neutral-900); }
.property-booking__form { display: flex; flex-direction: column; gap: 16px; }
.property-booking__field { display: flex; flex-direction: column; gap: 6px; }
.property-booking__label { font-size: 13px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ek-color-neutral-700); font-weight: 600; margin: 0; }
.property-booking__input { position: relative; display: flex; align-items: center; }
.property-booking__input i { position: absolute; left: 16px; color: var(--ek-color-neutral-400); }
.property-booking__input .form-control { padding-left: 42px; height: 48px; border-radius: 14px; border: 1px solid var(--ek-color-neutral-200); background: var(--ek-color-neutral-050); }
.property-booking__input .form-control:focus { box-shadow: 0 0 0 2px rgba(96, 165, 250, 0.15); border-color: var(--ek-color-primary); }
.property-booking__pricing { display: flex; flex-direction: column; gap: 12px; padding: 16px; border-radius: 18px; background: var(--ek-color-neutral-050); border: 1px solid var(--ek-color-neutral-200); }
.property-booking__row { display: flex; align-items: center; justify-content: space-between; gap: 12px; color: var(--ek-color-neutral-700); font-size: 15px; }
.property-booking__row del { color: var(--ek-color-neutral-400); margin-right: 8px; }
.property-booking__value { font-weight: 600; color: var(--ek-color-neutral-900); display: inline-flex; gap: 8px; align-items: center; }
.property-booking__total { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 12px; border-top: 1px solid var(--ek-color-neutral-200); font-weight: 600; color: var(--ek-color-neutral-900); }
.property-booking__notice { padding: 16px; background: rgba(220, 38, 38, 0.08); border: 1px solid rgba(220, 38, 38, 0.16); border-radius: 18px; color: #7f1d1d; font-size: 14px; }
.property-booking .btn.disabled,
.property-booking .btn[disabled] { opacity: 0.6; cursor: not-allowed; box-shadow: none; }
.property-section { padding: clamp(48px, 8vw, 88px) 0; background: #fff; }
.property-section--alt { background: var(--ek-color-neutral-050); }
.property-section--map { background: var(--ek-color-neutral-050); padding-bottom: clamp(64px, 9vw, 104px); }
.property-section__container { display: flex; flex-direction: column; gap: clamp(24px, 4vw, 36px); }
.property-section__header { display: flex; flex-direction: column; gap: 12px; max-width: 720px; }
.property-section__eyebrow { text-transform: uppercase; letter-spacing: 0.22em; font-size: 12px; font-weight: 600; color: var(--ek-color-primary); }
.property-section__title { margin: 0; font-size: clamp(26px, 3vw, 36px); font-weight: 600; color: var(--ek-color-neutral-900); }
.property-section__subtitle { margin: 0; color: var(--ek-color-neutral-700); max-width: 520px; }
.property-section__body { display: flex; flex-direction: column; gap: clamp(24px, 4vw, 36px); }
.property-description { max-width: 720px; display: flex; flex-direction: column; gap: 12px; color: var(--ek-color-neutral-700); line-height: 1.7; font-size: 16px; }
.property-description__toggle { align-self: flex-start; background: transparent; border: none; color: var(--ek-color-primary); font-weight: 600; display: inline-flex; align-items: center; gap: 6px; cursor: pointer; padding: 0; }
.property-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 16px; }
.property-fact { background: var(--ek-color-neutral-050); border: 1px solid var(--ek-color-neutral-200); border-radius: 18px; padding: 18px; display: flex; flex-direction: column; gap: 6px; }
.property-fact span { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ek-color-neutral-700); }
.property-fact strong { font-size: 18px; font-weight: 600; color: var(--ek-color-neutral-900); }
.property-amenities { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; list-style: none; padding: 0; margin: 0; }
.property-amenities__item { display: flex; align-items: center; gap: 12px; padding: 16px; background: #fff; border-radius: 18px; border: 1px solid var(--ek-color-neutral-200); box-shadow: 0 12px 28px rgba(12, 32, 46, 0.08); }
.property-amenities__icon { width: 44px; height: 44px; border-radius: 12px; background: var(--ek-color-neutral-050); border: 1px solid var(--ek-color-neutral-200); display: grid; place-items: center; }
.property-amenities__icon img { width: 28px; height: 28px; object-fit: contain; }
.property-amenities__text { font-weight: 600; color: var(--ek-color-neutral-900); }
.property-terms { list-style: none; display: flex; flex-direction: column; gap: 12px; margin: 0; padding: 0; }
.property-term { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; border-radius: 14px; border: 1px solid var(--ek-color-neutral-200); background: var(--ek-color-neutral-050); color: var(--ek-color-neutral-900); }
.property-term i { font-size: 20px; margin-top: 2px; }
.property-term--allowed { border-color: rgba(56, 189, 116, 0.4); background: rgba(56, 189, 116, 0.12); color: #14532d; }
.property-term--allowed i { color: #16a34a; }
.property-term--restricted { border-color: rgba(248, 113, 113, 0.4); background: rgba(248, 113, 113, 0.12); color: #7f1d1d; }
.property-term--restricted i { color: #dc2626; }
.property-terms__empty { color: var(--ek-color-neutral-700); margin: 0; }
.property-map iframe { width: 100%; height: clamp(320px, 45vw, 420px); border: none; border-radius: 22px; box-shadow: 0 24px 48px rgba(15, 42, 63, 0.16); }
.property-map__empty { padding: 32px; border-radius: 22px; border: 1px dashed var(--ek-color-neutral-200); background: #fff; color: var(--ek-color-neutral-700); text-align: center; }
.property-empty { padding: clamp(80px, 12vw, 120px) 0; text-align: center; display: flex; flex-direction: column; gap: 16px; align-items: center; }
.property-empty__title { font-size: clamp(28px, 4vw, 36px); font-weight: 600; color: var(--ek-color-neutral-900); margin: 0; }
.property-empty__subtitle { color: var(--ek-color-neutral-700); margin: 0; max-width: 420px; }
@media (max-width: 1200px) {
  .property-gallery__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); grid-template-rows: repeat(3, minmax(120px, 180px)); }
  .property-gallery__primary { grid-column: 1 / span 3; grid-row: 1 / span 2; }
}
@media (max-width: 992px) {
  .property-hero__layout { grid-template-columns: 1fr; }
  .property-gallery__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-template-rows: repeat(3, minmax(140px, 180px)); }
  .property-gallery__primary { grid-column: 1 / span 2; grid-row: 1 / span 2; }
  .property-gallery__viewAll { position: static; margin-top: 12px; width: 100%; justify-content: center; }
}
@media (max-width: 768px) {
  .property-hero { padding-top: 56px; }
  .property-meta li { width: calc(50% - 12px); justify-content: flex-start; }
  .property-gallery__grid { grid-template-columns: 1fr; grid-template-rows: repeat(4, minmax(180px, 220px)); }
  .property-gallery__primary { grid-column: 1; grid-row: 1; }
}
@media (max-width: 576px) {
  .property-meta li { width: 100%; }
  .property-booking__input .form-control { height: 52px; }
  .property-amenities__item { flex-direction: row; }
  .property-hero__top { flex-direction: column; align-items: flex-start; }
}
