/* ═══════════════════════════════════════
   ROSHAN AASHIYANA — property_detail.css
═══════════════════════════════════════ */

/* ═══════ PAGE HERO STRIP ═══════ */
.detail-hero {
  position: relative;
  background: var(--navy);
  padding: 40px 0 36px;
  overflow: hidden;
}
.detail-hero-bg {
  position: absolute; inset: 0;
  background-image: url('https://t3.ftcdn.net/jpg/03/22/06/68/360_F_322066808_CANrp7u5Cdiz7700TJReqKD299d2AZtD.jpg');
  background-size: cover; background-position: center;
  opacity: .08;
}
.detail-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--navy) 55%, rgba(7,26,52,0.85));
}
.detail-hero-content { position: relative; z-index: 2; }

/* Breadcrumb */
.breadcrumb {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  font-size: 13px; color: rgba(255,255,255,0.55);
  margin-bottom: 16px;
}
.breadcrumb a { color: rgba(255,255,255,0.55); transition: color .2s; }
.breadcrumb a:hover { color: var(--green); }
.bc-sep { font-size: 10px; color: rgba(255,255,255,0.3); }
.breadcrumb span { color: rgba(255,255,255,0.9); }

.dh-title {
  font-size: 32px; font-weight: 800; color: #fff;
  line-height: 1.15; margin-bottom: 12px;
}
.dh-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.dh-location { color: rgba(255,255,255,0.7); font-size: 14px; display: flex; align-items: center; gap: 6px; }
.dh-location i { color: var(--green); }
.dh-badge {
  padding: 5px 16px; border-radius: 20px;
  font-size: 12px; font-weight: 700; color: #fff;
}
.badge-sale { background: var(--green); }
.badge-rent { background: #1976d2; }

/* ═══════ MAIN LAYOUT ═══════ */
.property-page { background: var(--light-gray); padding: 36px 0 80px; }

.property-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 28px;
  align-items: flex-start;
}

/* ══════ SHARED CARD ══════ */
.detail-card {
  background: #fff;
  border-radius: 16px;
  padding: 28px;
  margin-bottom: 24px;
  box-shadow: var(--card-shadow);
}

.card-head {
  display: flex; align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1.5px solid var(--border);
}
.card-head h2 {
  font-size: 18px; font-weight: 800; color: var(--text);
  display: flex; align-items: center; gap: 10px;
}
.card-head h2 i { color: var(--green); font-size: 16px; }

/* ══════ MAIN IMAGE ══════ */
.main-image {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 14px;
  background: #e0e0e0;
}
.main-image img {
  width: 100%; height: 500px;
  object-fit: cover; display: block;
  transition: transform .4s;
}
.main-image:hover img { transform: scale(1.02); }

.img-overlay-bar {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(7,26,52,0.75) 0%, transparent 100%);
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 20px 20px 16px;
}
.photo-count {
  color: rgba(255,255,255,0.85); font-size: 13px; font-weight: 500;
  display: flex; align-items: center; gap: 6px;
}
.photo-count i { color: #fff; }

.fav-pill {
  background: rgba(255,255,255,0.92);
  color: var(--text);
  padding: 7px 16px; border-radius: 20px;
  font-size: 13px; font-weight: 600;
  display: flex; align-items: center; gap: 6px;
  transition: background .2s;
}
.fav-pill:hover { background: #fff; }
.fav-pill .fa-solid.fa-heart { color: #e53935; }
.fav-pill .fa-regular.fa-heart { color: var(--text-muted); }

/* ══════ GALLERY ══════ */
.gallery {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-bottom: 24px;
}
.gallery-img {
  height: 90px; border-radius: 10px;
  background-size: cover; background-position: center;
  cursor: pointer;
  border: 2.5px solid transparent;
  transition: border-color .2s, transform .2s;
}
.gallery-img:hover { transform: scale(1.03); border-color: rgba(60,182,72,0.5); }
.gallery-img.active { border-color: var(--green); }

/* ══════ INFO GRID ══════ */
.info-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.info-box {
  background: var(--light-gray);
  border-radius: 12px; padding: 18px 14px;
  display: flex; align-items: center; gap: 12px;
  transition: box-shadow .2s;
}
.info-box:hover { box-shadow: var(--card-shadow); }
.ib-icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--green-light);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.ib-icon i { font-size: 16px; color: var(--green); }
.ib-text { display: flex; flex-direction: column; }
.ib-text span { font-size: 11px; color: var(--text-muted); margin-bottom: 3px; }
.ib-text strong { font-size: 14px; font-weight: 700; color: var(--text); }

/* ══════ DESCRIPTION ══════ */
.desc-text { color: #555; line-height: 1.9; font-size: 14.5px; }

/* ══════ FEATURES ══════ */
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.feature-pill {
  background: var(--light-gray);
  border: 1.5px solid var(--border);
  border-radius: 8px; padding: 12px 16px;
  font-size: 13px; font-weight: 500;
  color: var(--text);
  display: flex; align-items: center; gap: 8px;
  transition: border-color .2s, background .2s;
}
.feature-pill:hover { border-color: var(--green); background: var(--green-light); }
.feature-pill i { color: var(--green); font-size: 12px; }
.empty-note { color: var(--text-muted); font-size: 13.5px; }

/* ══════ REVIEWS ══════ */
.review-head { flex-wrap: wrap; gap: 16px; }

.rating-summary {
  display: flex; align-items: center;
  gap: 16px; margin-top: 14px;
}
.rating-big {
  font-size: 52px; font-weight: 900; color: var(--green);
  line-height: 1;
}
.rating-right p { font-size: 13px; color: var(--text-muted); margin-top: 4px; }
.stars-row { color: #ffb400; font-size: 18px; letter-spacing: 2px; }

.review-btn {
  background: var(--navy); color: #fff; border: none;
  padding: 11px 20px; border-radius: 10px;
  font-size: 13.5px; font-weight: 600; cursor: pointer;
  display: flex; align-items: center; gap: 8px;
  font-family: inherit; transition: background .2s; white-space: nowrap;
  align-self: flex-start;
}
.review-btn:hover { background: var(--green); }

.review-list { display: flex; flex-direction: column; gap: 24px; }

.single-review {
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}
.single-review:last-child { border-bottom: none; padding-bottom: 0; }

.review-user {
  display: flex; align-items: flex-start; gap: 14px; margin-bottom: 12px;
}
.review-user img {
  width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex-shrink: 0;
}
.review-user-info h4 { font-size: 14px; font-weight: 700; margin-bottom: 4px; }
.review-stars { color: #ffb400; font-size: 13px; margin-bottom: 4px; }
.review-stars .fa-regular { color: #ddd; }
.review-time { font-size: 12px; color: var(--text-muted); }
.review-text { font-size: 13.5px; color: #555; line-height: 1.75; }

.no-reviews {
  text-align: center; padding: 32px; color: var(--text-muted);
}
.no-reviews i { font-size: 36px; display: block; margin-bottom: 10px; color: var(--border); }
.no-reviews p { font-size: 14px; }

/* ══════ RIGHT SIDEBAR ══════ */
.prop-sidebar {
  position: sticky; top: 84px;
  height: fit-content;
}

.contact-card {
  background: #fff; border-radius: 16px;
  padding: 24px; box-shadow: var(--card-shadow);
  margin-bottom: 20px;
}

/* Price card */
.price-tag {
  font-size: 28px; font-weight: 900; color: var(--green);
  margin-bottom: 10px; line-height: 1;
}
.prop-title-sm {
  font-size: 16px; font-weight: 700; color: var(--text);
  margin-bottom: 8px; line-height: 1.3;
}
.loc-row {
  font-size: 13px; color: var(--text-muted);
  display: flex; align-items: center; gap: 6px; margin-bottom: 16px;
}
.loc-row i { color: var(--green); }
.quick-specs {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-bottom: 20px; padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
.quick-specs span {
  font-size: 12.5px; color: var(--text-muted);
  display: flex; align-items: center; gap: 5px;
  background: var(--light-gray); padding: 6px 12px; border-radius: 20px;
}
.quick-specs i { color: var(--green); }

/* Buttons */
.side-btn {
  width: 100%; padding: 13px;
  border: none; border-radius: 10px;
  font-size: 14px; font-weight: 700;
  cursor: pointer; font-family: inherit;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: background .2s, color .2s, transform .15s;
  margin-bottom: 10px;
  text-decoration: none;
}
.side-btn:last-child { margin-bottom: 0; }
.side-btn:hover { transform: translateY(-1px); }

.btn-green { background: var(--green); color: #fff; }
.btn-green:hover { background: var(--green-dark); }

.btn-outline-green {
  background: transparent; color: var(--green);
  border: 2px solid var(--green);
}
.btn-outline-green:hover { background: var(--green); color: #fff; }

/* Dealer card */
.card-label { font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .5px; color: var(--text-muted); margin-bottom: 14px; }
.agent-row {
  display: flex; align-items: center; gap: 14px; margin-bottom: 18px;
}
.agent-row img {
  width: 58px; height: 58px; border-radius: 50%; object-fit: cover;
  border: 2px solid var(--green-light);
}
.agent-row h4 { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.verified-badge {
  font-size: 12px; color: var(--green); font-weight: 600;
  display: flex; align-items: center; gap: 4px;
}

/* Inquiry form */
.inquiry-form { display: flex; flex-direction: column; gap: 12px; }
.inq-group {
  display: flex; align-items: center; gap: 10px;
  border: 1.5px solid var(--border); border-radius: 9px;
  padding: 10px 14px; transition: border-color .2s;
}
.inq-group:focus-within { border-color: var(--green); }
.inq-group i { color: var(--green); font-size: 14px; flex-shrink: 0; }
.inq-group input,
.inq-group textarea {
  border: none; outline: none; font-size: 13.5px;
  font-family: inherit; width: 100%; background: transparent;
  color: var(--text);
}
.inq-group input::placeholder,
.inq-group textarea::placeholder { color: #aab4c4; }
.inq-textarea { align-items: flex-start; }
.inq-textarea i { margin-top: 3px; }

/* Overview list */
.overview-list { display: flex; flex-direction: column; gap: 0; }
.ov-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13.5px;
}
.ov-row:last-child { border-bottom: none; }
.ov-row span { color: var(--text-muted); display: flex; align-items: center; gap: 7px; }
.ov-row span i { color: var(--green); font-size: 12px; }
.ov-row strong { font-weight: 700; color: var(--text); }

/* ══════ REVIEW MODAL ══════ */
.review-modal {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(7,26,52,0.65);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity .3s, visibility .3s;
  backdrop-filter: blur(4px);
}
.review-modal.active { opacity: 1; visibility: visible; }

.review-modal-box {
  width: min(500px, 96vw);
  background: #fff; border-radius: 18px;
  padding: 36px; position: relative;
  box-shadow: 0 24px 80px rgba(0,0,0,0.25);
  animation: modalIn .25s ease;
}
@keyframes modalIn { from { opacity:0; transform: scale(.95) translateY(12px); } to { opacity:1; transform:none; } }

.close-review {
  position: absolute; top: 14px; right: 16px;
  background: var(--light-gray); border: none; border-radius: 50%;
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--text-muted); cursor: pointer;
  transition: background .2s, color .2s;
}
.close-review:hover { background: #fde8e8; color: #e53935; }

.review-modal-box h2 {
  font-size: 20px; font-weight: 800; color: var(--text);
  display: flex; align-items: center; gap: 10px; margin-bottom: 24px;
}
.review-modal-box h2 i { color: #ffb400; }

.modal-form-group { margin-bottom: 18px; }
.modal-form-group label {
  display: block; font-size: 13px; font-weight: 700;
  color: var(--text); margin-bottom: 10px;
}

.star-select-row {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.star-label {
  display: flex; align-items: center; gap: 5px;
  padding: 8px 16px; border-radius: 8px;
  border: 1.5px solid var(--border); cursor: pointer;
  font-size: 13px; font-weight: 600; color: var(--text);
  transition: border-color .2s, background .2s;
}
.star-label i { color: #ffb400; }
.star-label input { display: none; }
.star-label:has(input:checked) { border-color: var(--green); background: var(--green-light); color: var(--green); }

.modal-form-group textarea {
  width: 100%; padding: 13px;
  border: 1.5px solid var(--border); border-radius: 10px;
  outline: none; font-family: inherit; font-size: 13.5px;
  color: var(--text); resize: vertical; transition: border-color .2s;
}
.modal-form-group textarea:focus { border-color: var(--green); }
.modal-form-group textarea::placeholder { color: #aab4c4; }

/* ══════ RESPONSIVE ══════ */
@media (max-width: 1100px) {
  .property-layout { grid-template-columns: 1fr; }
  .prop-sidebar { position: static; }
  .info-grid { grid-template-columns: repeat(2, 1fr); }
  .features-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .dh-title { font-size: 24px; }
  .main-image img { height: 300px; }
  .gallery { grid-template-columns: repeat(3, 1fr); }
  .info-grid { grid-template-columns: repeat(2, 1fr); }
  .features-grid { grid-template-columns: 1fr 1fr; }
  .detail-card { padding: 20px; }
}

@media (max-width: 480px) {
  .gallery { grid-template-columns: repeat(2, 1fr); }
  .info-grid { grid-template-columns: 1fr 1fr; }
  .features-grid { grid-template-columns: 1fr; }
  .rating-big { font-size: 40px; }
}