/* ── Ad Detail Layout ────────────────────────────────────── */
.ad-detail__layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 2rem;
  align-items: start;
}
.ad-detail__main  { min-width: 0; }
.ad-detail__sidebar { position: sticky; top: calc(var(--navbar-h) + 1.5rem); }

/* Breadcrumb */
.breadcrumb { display: flex; align-items: center; gap: .4rem; font-size: .85rem; color: var(--gray-500); flex-wrap: wrap; }
.breadcrumb a:hover { color: var(--primary); }
.breadcrumb i { font-size: .6rem; }

/* Header */
.ad-detail__header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 1.25rem; flex-wrap: wrap; }
.ad-detail__badges { display: flex; gap: .4rem; flex-wrap: wrap; margin-bottom: .5rem; }
.ad-detail__title  { font-size: 1.4rem; font-weight: 800; margin: .3rem 0; color: var(--gray-900); }
.ad-detail__location { font-size: .9rem; color: var(--gray-500); display: flex; align-items: center; gap: .4rem; }
.ad-detail__price-wrap { text-align: end; flex-shrink: 0; }
.ad-detail__price { font-size: 1.6rem; font-weight: 800; color: var(--primary); white-space: nowrap; }

/* Gallery */
.ad-gallery { border-radius: var(--radius-xl); overflow: hidden; margin-bottom: 1.5rem; background: var(--gray-900); }
.ad-gallery__main { position: relative; user-select: none; }
.ad-gallery__main > img { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; cursor: zoom-in; -webkit-user-drag: none; }
.gallery-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(0,0,0,.5); color: #fff; border: none;
  width: 42px; height: 42px; border-radius: 50%; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; transition: background var(--transition);
  z-index: 10;
}
.gallery-nav:hover { background: rgba(0,0,0,.75); }
.gallery-nav--prev { inset-inline-start: 1rem; }
.gallery-nav--next { inset-inline-end: 1rem; }
.gallery-counter {
  position: absolute; bottom: 1rem; inset-inline-end: 1rem;
  background: rgba(0,0,0,.55); color: #fff; padding: .25rem .65rem;
  border-radius: 2rem; font-size: .8rem;
}
.ad-gallery__thumbs { display: flex; gap: .4rem; padding: .5rem; overflow-x: auto; background: var(--gray-900); }
.ad-gallery__thumb  { flex-shrink: 0; width: 72px; height: 54px; border-radius: var(--radius-sm); overflow: hidden; cursor: pointer; border: 2px solid transparent; opacity: .65; transition: all var(--transition); }
.ad-gallery__thumb.active { border-color: #fff; opacity: 1; }
.ad-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.ad-gallery__placeholder { aspect-ratio: 16/9; background: var(--gray-100); display: flex; align-items: center; justify-content: center; font-size: 4rem; color: var(--gray-300); border-radius: var(--radius-xl); margin-bottom: 1.5rem; }

/* Features pills */
.ad-detail__features { display: flex; flex-wrap: wrap; gap: .6rem; margin-bottom: 1.5rem; }
.feature-pill {
  display: flex; align-items: center; gap: .4rem;
  background: var(--gray-50); border: 1px solid var(--gray-200);
  border-radius: var(--radius); padding: .45rem .85rem;
  font-size: .88rem;
}
.feature-pill i { color: var(--primary); }
.feature-pill small { font-size: .72rem; color: var(--gray-400); display: block; }

/* Sections */
.ad-detail__section { margin-bottom: 1.75rem; }
.ad-detail__section h3 { font-size: 1.05rem; font-weight: 700; margin-bottom: .85rem; padding-bottom: .5rem; border-bottom: 2px solid var(--gray-100); display: flex; align-items: center; gap: .5rem; }
.ad-detail__desc { font-size: .95rem; color: var(--gray-700); line-height: 1.75; }

/* Attribute grid */
.ad-attrs-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: .5rem; }
.ad-attr-item  { display: flex; justify-content: space-between; padding: .6rem .85rem; background: var(--gray-50); border-radius: var(--radius-sm); font-size: .88rem; }
.ad-attr-item__label { color: var(--gray-500); }
.ad-attr-item__value { font-weight: 600; }

/* Virtual tour */
.virtual-tour-wrap { border-radius: var(--radius-lg); overflow: hidden; border: 2px solid var(--gray-200); }

/* Bids public */
.bids-list { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1rem; }
.bid-public-item { display: flex; align-items: center; gap: .75rem; padding: .65rem .85rem; background: var(--gray-50); border-radius: var(--radius); font-size: .88rem; }
.bid-public-item__user   { flex: 1; font-weight: 600; display: flex; align-items: center; gap: .35rem; color: var(--gray-700); }
.bid-public-item__amount { font-weight: 700; color: var(--primary); }
.bid-public-item__time   { font-size: .76rem; color: var(--gray-400); }

/* Bid form */
.bid-form__row { display: flex; gap: .75rem; align-items: flex-end; flex-wrap: wrap; }
.bid-form__btn { flex-shrink: 0; height: 42px; }
.bid-form__balance { font-size: .82rem; color: var(--gray-500); margin-top: .5rem; display: flex; align-items: center; gap: .4rem; }

/* Lead form */
.lead-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

/* Sidebar card */
.ad-sidebar-card { background: #fff; border-radius: var(--radius-xl); box-shadow: var(--shadow); padding: 1.25rem; margin-bottom: 1rem; }
.ad-seller { display: flex; align-items: center; gap: .75rem; margin-bottom: 1rem; padding-bottom: 1rem; border-bottom: 1px solid var(--gray-100); }
.ad-seller__avatar { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; border: 2px solid var(--primary-light); }
.ad-seller__name   { font-weight: 700; font-size: .95rem; }
.ad-meta-list { display: flex; flex-direction: column; gap: .45rem; margin-bottom: 1rem; }
.ad-meta-item { display: flex; align-items: center; gap: .5rem; font-size: .85rem; color: var(--gray-600); }
.ad-meta-item i { color: var(--primary); width: 16px; text-align: center; }
.ad-share { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; font-size: .85rem; color: var(--gray-500); margin-top: .75rem; }
.share-btn { width: 34px; height: 34px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .85rem; border: none; cursor: pointer; transition: all var(--transition); }
.share-btn--wa   { background: #25d366; color: #fff; }
.share-btn--fb   { background: #1877f2; color: #fff; }
.share-btn--copy { background: var(--gray-200); color: var(--gray-700); }
.share-btn:hover { transform: scale(1.1); }

/* ── Listing Page ────────────────────────────────────────── */
.listing-layout { display: grid; grid-template-columns: 260px 1fr; gap: 2rem; align-items: start; }
.listing-filters { background: #fff; border-radius: var(--radius-xl); box-shadow: var(--shadow); padding: 1.5rem; position: sticky; top: calc(var(--navbar-h) + 1rem); }
.filters-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.25rem; }
.filters-header h3 { font-size: 1rem; font-weight: 700; margin: 0; display: flex; align-items: center; gap: .4rem; }
.filter-group { margin-bottom: 1.1rem; padding-bottom: 1rem; border-bottom: 1px solid var(--gray-100); }
.filter-group:last-child { border-bottom: none; margin-bottom: 0; }
.filter-label { display: block; font-size: .82rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--gray-500); margin-bottom: .5rem; }
.form-control--sm { padding: .45rem .75rem; font-size: .88rem; }

.listing-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.25rem; flex-wrap: wrap; }
.listing-toolbar__left  { display: flex; align-items: center; gap: .85rem; flex-wrap: wrap; }
.listing-toolbar__right { display: flex; align-items: center; gap: .6rem; }

/* ── Wizard CSS ──────────────────────────────────────────── */
.wizard-step__title { font-size: 1.2rem; font-weight: 700; margin-bottom: 1.5rem; color: var(--gray-800); }
.type-selector { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-bottom: 1rem; }
.type-card { border: 2px solid var(--gray-200); border-radius: var(--radius-xl); padding: 1.5rem 1rem; text-align: center; cursor: pointer; transition: all var(--transition); }
.type-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.type-card:hover, .type-card.active { border-color: var(--primary); background: var(--primary-light); }
.type-card__icon { font-size: 2rem; color: var(--gray-400); margin-bottom: .75rem; transition: color var(--transition); }
.type-card:hover .type-card__icon, .type-card.active .type-card__icon { color: var(--primary); }
.type-card h3 { font-size: 1rem; font-weight: 700; margin-bottom: .35rem; color: var(--gray-800); }
.type-card p  { font-size: .82rem; color: var(--gray-500); margin: 0; }
.form-row-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.form-hint  { font-size: .78rem; color: var(--gray-400); margin-top: .3rem; }
.attributes-section { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--gray-100); }
.attributes-title  { font-size: .95rem; font-weight: 700; color: var(--gray-700); margin-bottom: 1rem; }
.attributes-grid   { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: .85rem; }
.attr-item .form-check { margin-top: .35rem; }
.review-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.review-section { background: var(--gray-50); border-radius: var(--radius); padding: 1.1rem; }
.review-section h4 { font-size: .85rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--gray-500); margin-bottom: .75rem; }
.review-row { display: flex; justify-content: space-between; font-size: .9rem; margin-bottom: .4rem; }
.review-row span { color: var(--gray-500); }
.review-imgs { display: flex; gap: .4rem; flex-wrap: wrap; margin-top: .5rem; }
.review-img { width: 64px; height: 52px; border-radius: var(--radius-sm); object-fit: cover; border: 2px solid transparent; }
.review-img--thumb { border-color: var(--primary); }

/* Status tabs */
.status-tabs { display: flex; gap: .35rem; flex-wrap: wrap; }
.status-tab { display: inline-flex; align-items: center; gap: .4rem; padding: .5rem 1rem; border-radius: var(--radius); font-size: .88rem; font-weight: 600; color: var(--gray-600); background: #fff; border: 1px solid var(--gray-200); transition: all var(--transition); }
.status-tab:hover, .status-tab.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.status-tab__count { background: rgba(255,255,255,.25); border-radius: 2rem; padding: .05rem .4rem; font-size: .72rem; }
.status-tab.active .status-tab__count { background: rgba(255,255,255,.25); }

/* Responsive */
@media (max-width: 860px) {
  .ad-detail__layout {
    grid-template-columns: 1fr !important;
  }
  .ad-detail__sidebar {
    position: static;
    order: 2; /* sidebar AFTER main content on mobile */
  }
  .ad-detail__main {
    order: 1;
  }
  .listing-layout { grid-template-columns: 1fr; }
  .listing-filters { position: static; display: none; }
  .listing-filters.open { display: block; }
  #toggleFilters { display: flex !important; }
  .ad-title-bar { flex-direction: column; gap: .75rem; }
  .ad-price-block { text-align: start; }
  .ad-stats-bar { gap: .25rem; }
  .ad-stat { padding: .3rem .5rem; min-width: 60px; }
}
@media (max-width: 640px) {
  .type-selector { grid-template-columns: 1fr; }
  .form-row-3    { grid-template-columns: 1fr; }
  .review-grid   { grid-template-columns: 1fr; }
  .bid-form__row { flex-direction: column; }
  .lead-form .form-row { grid-template-columns: 1fr; }
  .ad-stats-bar { grid-template-columns: repeat(3, 1fr); display: grid; }
  .ad-gallery__main { border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .ad-section { padding: 1rem; }
  .ad-attrs-grid { grid-template-columns: 1fr 1fr; }
  .ad-hero-card__main { flex-direction: column; gap: 1rem; }
  .ad-hero-card__price-wrap { text-align: start; min-width: unset; width: 100%; }
  .ad-hero-card__price { font-size: 1.5rem; }
  .vt-hero-btn { padding: .85rem 1rem; }
  .vt-hero-btn__icon { width: 40px; height: 40px; font-size: 1.1rem; }
  .vt-hero-btn__title { font-size: .88rem; }
  .vt-hero-btn__sub { font-size: .72rem; }
}

/* ── Star picker ───────────────────────────────────────────── */
.star-picker { display: flex; align-items: center; gap: .2rem; }
.star-btn {
    background: none; border: none; cursor: pointer;
    font-size: 1.6rem; color: #e5e7eb;
    transition: color .15s, transform .15s;
    padding: 0 .1rem;
    line-height: 1;
}
.star-btn:hover, .star-btn.active { color: #da9831; transform: scale(1.15); }
.star-btn.filled { color: #da9831; }

/* ── Seller profile link ───────────────────────────────────── */
.ad-seller-link {
    display: block;
    text-decoration: none;
    color: inherit;
    border-radius: var(--radius-lg);
    transition: background .15s;
    margin: -.5rem;
    padding: .5rem;
}
.ad-seller-link:hover {
    background: var(--gray-50);
}
.ad-seller-link .ad-seller__name {
    color: var(--primary);
}

/* ── Rich HTML description ─────────────────────────────────── */
.ad-description h2 { font-size:1.15rem; font-weight:700; margin:.9rem 0 .4rem; color:var(--gray-900); }
.ad-description h3 { font-size:1.05rem; font-weight:700; margin:.8rem 0 .35rem; color:var(--gray-800); }
.ad-description h4 { font-size:.95rem;  font-weight:700; margin:.7rem 0 .3rem;  color:var(--gray-700); }
.ad-description p  { margin:.5rem 0; line-height:1.8; }
.ad-description ul,
.ad-description ol { margin:.5rem 0 .5rem 1.4rem; line-height:1.8; }
.ad-description li { margin:.2rem 0; }
.ad-description a  { color:var(--primary); text-decoration:underline; }
.ad-description strong, .ad-description b { font-weight:700; }
.ad-description em, .ad-description i  { font-style:italic; }
.ad-description img { max-width:100%; border-radius:var(--radius); margin:.5rem 0; }

/* Watermark is now burned server-side via public/img.php — no CSS overlay needed */
