:root {
      --navy: #1f2b5c;
      --navy-dark: #141c42;
      --burgundy: #7a1f2b;
      --burgundy-dark: #5d1620;
      --gold: #f2c319;
      --white: #ffffff;
      --soft: #f5f7fb;
      --text: #1d2433;
      --muted: #647084;
      --border: #dfe5f1;
      --shadow: 0 18px 40px rgba(20, 28, 66, 0.16);
      --radius: 22px;
    }

    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      font-family: Arial, Helvetica, sans-serif;
      color: var(--text);
      background: var(--soft);
      line-height: 1.6;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    .top-bar {
      background: var(--navy-dark);
      color: var(--white);
      font-size: 14px;
      padding: 9px 5%;
      display: flex;
      justify-content: space-between;
      gap: 16px;
      flex-wrap: wrap;
    }

    .top-bar a {
      color: var(--white);
      font-weight: 700;
    }

    header {
      background: linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 58%, var(--burgundy-dark) 100%);
      color: var(--white);
      position: relative;
      overflow: hidden;
    }

    header::before {
      content: "PRZYBYLSKI TEAM";
      position: absolute;
      inset: auto -80px 25px auto;
      font-size: clamp(42px, 10vw, 130px);
      font-weight: 900;
      letter-spacing: 7px;
      color: rgba(255, 255, 255, 0.045);
      transform: rotate(-10deg);
      pointer-events: none;
      white-space: nowrap;
    }

    nav {
      padding: 22px 5%;
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 18px;
      position: relative;
      z-index: 2;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 14px;
    }

    .brand-mark {
      width: 48px;
      height: 48px;
      border: 3px solid var(--gold);
      border-radius: 14px;
      display: grid;
      place-items: center;
      font-weight: 900;
      color: var(--gold);
      background: rgba(255,255,255,0.08);
    }

    .brand-title {
      font-size: 20px;
      font-weight: 900;
      letter-spacing: 0.4px;
      line-height: 1.1;
    }

    .brand-subtitle {
      font-size: 12px;
      color: rgba(255,255,255,0.78);
      margin-top: 4px;
    }

    .nav-links {
      display: flex;
      gap: 18px;
      align-items: center;
      flex-wrap: wrap;
      justify-content: flex-end;
      font-size: 14px;
      font-weight: 700;
    }

    .nav-links a {
      color: rgba(255,255,255,0.92);
    }

    .nav-links a:hover {
      color: var(--gold);
    }

    .hero {
      padding: 55px 5% 85px;
      display: grid;
      grid-template-columns: 1.1fr 0.9fr;
      gap: 38px;
      align-items: center;
      position: relative;
      z-index: 1;
    }

    .kicker {
      display: inline-flex;
      gap: 10px;
      align-items: center;
      background: rgba(255,255,255,0.11);
      border: 1px solid rgba(255,255,255,0.16);
      border-radius: 999px;
      padding: 8px 14px;
      color: var(--gold);
      font-weight: 900;
      font-size: 13px;
      letter-spacing: 0.3px;
      margin-bottom: 18px;
    }

    h1 {
      font-size: clamp(38px, 6vw, 72px);
      line-height: 1.02;
      margin: 0 0 20px;
      letter-spacing: -1.6px;
    }

    .hero p {
      font-size: 19px;
      color: rgba(255,255,255,0.88);
      margin: 0 0 28px;
      max-width: 740px;
    }

    .button-row {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
      align-items: center;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      border-radius: 999px;
      padding: 14px 22px;
      font-weight: 900;
      border: 2px solid transparent;
      transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
      cursor: pointer;
    }

    .btn:hover {
      transform: translateY(-2px);
      box-shadow: 0 12px 24px rgba(0,0,0,0.18);
    }

    .btn-gold {
      background: var(--gold);
      color: var(--navy-dark);
    }

    .btn-white {
      background: rgba(255,255,255,0.08);
      color: var(--white);
      border-color: rgba(255,255,255,0.28);
    }

    .btn-burgundy {
      background: var(--burgundy);
      color: var(--white);
    }

    .hero-card {
      background: rgba(255,255,255,0.10);
      border: 1px solid rgba(255,255,255,0.18);
      border-radius: var(--radius);
      padding: 22px;
      box-shadow: var(--shadow);
      backdrop-filter: blur(10px);
    }

    .photo-placeholder {
      min-height: 350px;
      border-radius: 18px;
      border: 3px solid var(--gold);
      background:
        linear-gradient(135deg, rgba(255,255,255,0.14), rgba(255,255,255,0.05)),
        repeating-linear-gradient(45deg, rgba(255,255,255,0.04), rgba(255,255,255,0.04) 10px, rgba(255,255,255,0.01) 10px, rgba(255,255,255,0.01) 20px);
      display: grid;
      place-items: center;
      text-align: center;
      padding: 26px;
      color: rgba(255,255,255,0.86);
      font-weight: 800;
    }

    .section {
      padding: 76px 5%;
    }

    .section.white {
      background: var(--white);
    }

    .section.navy {
      background: var(--navy);
      color: var(--white);
    }

    .section-title {
      max-width: 850px;
      margin: 0 auto 36px;
      text-align: center;
    }

    .section-title .eyebrow {
      color: var(--burgundy);
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: 1.2px;
      font-size: 13px;
      margin-bottom: 8px;
    }

    .section.navy .section-title .eyebrow {
      color: var(--gold);
    }

    h2 {
      font-size: clamp(30px, 4vw, 48px);
      line-height: 1.08;
      margin: 0 0 14px;
      letter-spacing: -1px;
    }

    .section-title p {
      margin: 0;
      color: var(--muted);
      font-size: 18px;
    }

    .section.navy .section-title p {
      color: rgba(255,255,255,0.82);
    }

    .cards {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 20px;
      max-width: 1180px;
      margin: 0 auto;
    }

    .card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 26px;
      box-shadow: 0 12px 30px rgba(20, 28, 66, 0.08);
    }

    .card-icon {
      width: 48px;
      height: 48px;
      border-radius: 14px;
      background: var(--navy);
      color: var(--gold);
      display: grid;
      place-items: center;
      font-weight: 900;
      margin-bottom: 16px;
    }

    .card h3 {
      margin: 0 0 10px;
      font-size: 21px;
      color: var(--navy-dark);
    }

    .card p {
      margin: 0;
      color: var(--muted);
    }

    .review-box {
      max-width: 980px;
      margin: 0 auto;
      background: var(--white);
      color: var(--text);
      border-radius: 28px;
      padding: 34px;
      box-shadow: var(--shadow);
      border-top: 7px solid var(--gold);
    }

    .review-buttons {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 14px;
      margin-top: 24px;
    }

    .review-btn {
      border-radius: 18px;
      padding: 18px 16px;
      color: var(--white);
      font-weight: 900;
      text-align: center;
      background: var(--navy);
    }

    .review-btn:nth-child(2) {
      background: var(--burgundy);
    }

    .review-btn:nth-child(3) {
      background: var(--navy-dark);
    }

    .listings-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 22px;
      max-width: 1180px;
      margin: 0 auto;
    }

    .listing {
      background: var(--white);
      border-radius: var(--radius);
      overflow: hidden;
      border: 1px solid var(--border);
      box-shadow: 0 12px 30px rgba(20, 28, 66, 0.08);
    }

    .listing-image {
      height: 190px;
      background:
        linear-gradient(135deg, rgba(31,43,92,0.76), rgba(122,31,43,0.58)),
        repeating-linear-gradient(45deg, #e7ecf6, #e7ecf6 10px, #d9e1ee 10px, #d9e1ee 20px);
      color: var(--white);
      display: grid;
      place-items: center;
      text-align: center;
      padding: 20px;
      font-weight: 900;
    }

    .listing-body {
      padding: 22px;
    }

    .status {
      display: inline-flex;
      padding: 5px 10px;
      border-radius: 999px;
      font-size: 12px;
      font-weight: 900;
      color: var(--navy-dark);
      background: var(--gold);
      margin-bottom: 10px;
      text-transform: uppercase;
      letter-spacing: 0.5px;
    }

    .status.pending {
      color: var(--white);
      background: var(--burgundy);
    }

    .status.sold {
      color: var(--white);
      background: var(--navy);
    }

    .listing h3 {
      margin: 0 0 7px;
      color: var(--navy-dark);
      font-size: 20px;
    }

    .price {
      color: var(--burgundy);
      font-weight: 900;
      font-size: 20px;
      margin-bottom: 12px;
    }

    .details {
      color: var(--muted);
      font-size: 14px;
      margin-bottom: 18px;
    }

    .small-link {
      display: inline-flex;
      color: var(--navy);
      font-weight: 900;
      border-bottom: 2px solid var(--gold);
    }

    .contact-wrap {
      max-width: 1060px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
      align-items: stretch;
    }

    .contact-card {
      background: var(--white);
      border-radius: var(--radius);
      padding: 30px;
      box-shadow: var(--shadow);
      border-left: 7px solid var(--gold);
    }

    .contact-card h3 {
      color: var(--navy-dark);
      margin-top: 0;
      font-size: 26px;
    }

    .contact-list {
      margin: 0;
      padding: 0;
      list-style: none;
    }

    .contact-list li {
      padding: 9px 0;
      border-bottom: 1px solid var(--border);
    }

    .contact-list strong {
      color: var(--navy);
    }

    footer {
      background: var(--navy-dark);
      color: rgba(255,255,255,0.82);
      padding: 34px 5%;
      text-align: center;
      font-size: 14px;
    }

    footer strong {
      color: var(--white);
    }

    .legal {
      max-width: 980px;
      margin: 16px auto 0;
      color: rgba(255,255,255,0.62);
      font-size: 12px;
    }

    .edit-note {
      background: #fff8d7;
      border: 1px solid #f0d46b;
      color: #4d3f00;
      border-radius: 14px;
      padding: 12px 14px;
      margin-top: 16px;
      font-size: 13px;
      font-weight: 700;
    }


    .page-hero {
      padding: 54px 5% 64px;
      position: relative;
      z-index: 1;
      text-align: center;
      max-width: 1050px;
      margin: 0 auto;
    }

    .page-hero h1 {
      margin-left: auto;
      margin-right: auto;
    }

    .page-hero p {
      max-width: 780px;
      margin: 0 auto 24px;
      color: rgba(255,255,255,0.88);
      font-size: 19px;
    }

    .filter-row {
      max-width: 1180px;
      margin: 0 auto 24px;
      display: flex;
      gap: 12px;
      justify-content: center;
      flex-wrap: wrap;
    }

    .filter-btn {
      border: 2px solid var(--border);
      background: var(--white);
      color: var(--navy);
      border-radius: 999px;
      padding: 10px 16px;
      font-weight: 900;
      cursor: pointer;
    }

    .filter-btn.active {
      background: var(--navy);
      color: var(--white);
      border-color: var(--navy);
    }

    .listing img,
    .property-photo {
      width: 100%;
      display: block;
      object-fit: cover;
    }

    .listing-image img {
      height: 190px;
      border: 0;
    }

    .empty-state {
      max-width: 760px;
      margin: 0 auto;
      background: var(--white);
      border-radius: var(--radius);
      padding: 28px;
      text-align: center;
      border: 1px solid var(--border);
      box-shadow: 0 12px 30px rgba(20, 28, 66, 0.08);
    }

    .property-layout {
      max-width: 1180px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1.25fr 0.75fr;
      gap: 24px;
      align-items: start;
    }

    .property-main,
    .property-side,
    .review-card,
    .form-card {
      background: var(--white);
      border-radius: var(--radius);
      border: 1px solid var(--border);
      box-shadow: 0 12px 30px rgba(20, 28, 66, 0.08);
      padding: 26px;
    }

    .property-main h2,
    .property-side h3 {
      color: var(--navy-dark);
    }

    .property-photo {
      height: min(52vw, 520px);
      border-radius: 18px;
      margin-bottom: 22px;
      background:
        linear-gradient(135deg, rgba(31,43,92,0.76), rgba(122,31,43,0.58)),
        repeating-linear-gradient(45deg, #e7ecf6, #e7ecf6 10px, #d9e1ee 10px, #d9e1ee 20px);
    }

    .property-facts {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 12px;
      margin: 20px 0;
    }

    .fact {
      background: var(--soft);
      border-radius: 16px;
      padding: 14px;
      border: 1px solid var(--border);
    }

    .fact strong {
      display: block;
      color: var(--navy);
      font-size: 18px;
    }

    .platform {
      display: inline-flex;
      padding: 5px 10px;
      border-radius: 999px;
      font-size: 12px;
      font-weight: 900;
      background: var(--soft);
      color: var(--navy);
      margin-bottom: 10px;
      text-transform: uppercase;
      letter-spacing: 0.5px;
    }

    .reviews-list {
      max-width: 980px;
      margin: 0 auto;
      display: grid;
      gap: 18px;
    }

    .review-card blockquote {
      margin: 0 0 12px;
      font-size: 18px;
      color: var(--text);
    }

    .stars {
      color: var(--burgundy);
      font-weight: 900;
      letter-spacing: 1px;
    }

    .contact-page-grid {
      max-width: 1060px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
      align-items: start;
    }

    .contact-form {
      display: grid;
      gap: 12px;
    }

    .contact-form label {
      font-weight: 900;
      color: var(--navy);
    }

    .contact-form input,
    .contact-form textarea,
    .contact-form select {
      width: 100%;
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 13px 14px;
      font: inherit;
      background: var(--white);
    }

    .contact-form textarea {
      min-height: 130px;
      resize: vertical;
    }

    .response-badge {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: #fff8d7;
      color: #4d3f00;
      border: 1px solid #f0d46b;
      border-radius: 999px;
      padding: 10px 14px;
      font-weight: 900;
      margin: 12px 0 18px;
    }

    .admin-note {
      max-width: 980px;
      margin: 26px auto 0;
      background: #fff8d7;
      border: 1px solid #f0d46b;
      color: #4d3f00;
      border-radius: 14px;
      padding: 14px 16px;
      font-size: 14px;
      font-weight: 700;
    }

    @media (max-width: 920px) {
      .property-layout,
      .contact-page-grid,
      .property-facts {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 920px) {
      .hero,
      .contact-wrap {
        grid-template-columns: 1fr;
      }

      .cards,
      .listings-grid,
      .review-buttons {
        grid-template-columns: 1fr;
      }

      nav {
        align-items: flex-start;
        flex-direction: column;
      }

      .nav-links {
        justify-content: flex-start;
      }

      .photo-placeholder {
        min-height: 260px;
      }
    }

    .pagination {
      max-width: 1180px;
      margin: 28px auto 0;
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
    }

    .pagination button,
    .pagination .ellipsis {
      border: 1px solid var(--border);
      background: var(--white);
      color: var(--navy);
      border-radius: 999px;
      padding: 9px 13px;
      font-weight: 900;
      font: inherit;
    }

    .pagination button {
      cursor: pointer;
    }

    .pagination button.active {
      background: var(--navy);
      color: var(--white);
      border-color: var(--navy);
    }

    .pagination button:disabled {
      opacity: 0.45;
      cursor: not-allowed;
    }

/* ===== Enhanced property templates ===== */
.premium-listing-card {
  position: relative;
  transform: translateY(0);
  transition: transform .2s ease, box-shadow .2s ease;
}

.premium-listing-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 42px rgba(20, 28, 66, 0.14);
}

.premium-listing-image {
  position: relative;
  overflow: hidden;
}

.premium-listing-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(20,28,66,0.05), rgba(20,28,66,0.58));
  pointer-events: none;
}

.listing-status-overlay {
  position: absolute;
  left: 14px;
  top: 14px;
  z-index: 2;
  display: inline-flex;
  padding: 6px 11px;
  border-radius: 999px;
  background: var(--gold);
  color: var(--navy-dark);
  font-weight: 900;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .6px;
  box-shadow: 0 8px 18px rgba(0,0,0,.18);
}

.listing-status-overlay.pending { background: var(--burgundy); color: var(--white); }
.listing-status-overlay.sold { background: var(--navy); color: var(--white); }

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.type-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 10px;
  background: var(--soft);
  color: var(--navy);
  font-weight: 900;
  font-size: 12px;
  border: 1px solid var(--border);
}

.gold-chip {
  background: rgba(242, 195, 25, .18);
  color: var(--navy-dark);
  border-color: rgba(242, 195, 25, .55);
}

.mini-facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 14px 0 16px;
}

.mini-facts span {
  background: var(--soft);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.mini-facts strong {
  display: block;
  color: var(--navy-dark);
  font-size: 15px;
  line-height: 1.1;
}

.property-layout {
  max-width: 1280px;
}

.property-detail-shell {
  width: 100%;
}

.property-hero-card {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  padding: clamp(28px, 5vw, 52px);
  color: var(--white);
  background:
    radial-gradient(circle at 88% 20%, rgba(242,195,25,.22), transparent 28%),
    linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 58%, var(--burgundy-dark) 100%);
  box-shadow: var(--shadow);
  margin-bottom: 28px;
}

.property-hero-card::before {
  content: "PRZYBYLSKI TEAM";
  position: absolute;
  right: -50px;
  bottom: -30px;
  font-size: clamp(50px, 10vw, 150px);
  font-weight: 900;
  letter-spacing: 8px;
  color: rgba(255,255,255,.045);
  transform: rotate(-8deg);
  white-space: nowrap;
}

.property-hero-card > * {
  position: relative;
  z-index: 1;
}

.large-tags .status,
.large-tags .type-chip {
  margin-bottom: 0;
}

.property-hero-card h2 {
  font-size: clamp(36px, 5.2vw, 70px);
  line-height: 1.02;
  letter-spacing: -1.6px;
  margin: 16px 0 10px;
  max-width: 920px;
}

.property-price-line {
  color: var(--gold);
  font-weight: 900;
  font-size: clamp(25px, 3vw, 42px);
}

.property-location-line {
  color: rgba(255,255,255,.82);
  margin: 4px 0 22px;
  font-weight: 800;
}

.elevated-facts {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  max-width: 1050px;
  margin-bottom: 0;
}

.elevated-facts .fact {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(10px);
  color: rgba(255,255,255,.82);
}

.elevated-facts .fact strong {
  color: var(--white);
  font-size: 20px;
}

.elevated-facts .fact span {
  color: rgba(255,255,255,.72);
  font-weight: 800;
}

.property-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(310px, .55fr);
  gap: 24px;
  align-items: start;
}

.property-left-column {
  display: grid;
  gap: 20px;
}

.detail-panel,
.sidebar-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 26px;
  padding: 26px;
  box-shadow: 0 12px 30px rgba(20, 28, 66, 0.08);
}

.gallery-panel {
  padding: 14px;
}

.property-hero-photo,
.property-gallery-grid img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  display: block;
  border-radius: 18px;
}

.property-gallery-grid {
  display: grid;
  grid-template-columns: 1.4fr .8fr .8fr;
  grid-template-rows: 190px 190px;
  gap: 10px;
}

.property-gallery-grid .gallery-main {
  grid-row: 1 / span 2;
  min-height: 390px;
}

.detail-panel h3,
.sidebar-card h3 {
  margin-top: 0;
  color: var(--navy-dark);
  font-size: 24px;
}

.description-panel p {
  font-size: 17px;
  color: var(--text);
}

.highlight-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.highlight-pill {
  border-left: 5px solid var(--gold);
  background: var(--soft);
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 800;
  color: var(--navy-dark);
}

.property-sidebar {
  display: grid;
  gap: 18px;
  position: sticky;
  top: 16px;
}

.contact-sidebar-card {
  border-top: 7px solid var(--gold);
}

.sidebar-buttons .btn {
  width: 100%;
}

.qr-card {
  text-align: center;
}

.qr-card img {
  width: 210px;
  max-width: 100%;
  padding: 12px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 10px 24px rgba(20, 28, 66, .08);
}

.qr-card p {
  color: var(--muted);
  font-size: 14px;
}

.small-detail-card {
  display: grid;
  gap: 12px;
}

.print-flyer-panel {
  border-left: 7px solid var(--burgundy);
}

.missing-image {
  background:
    linear-gradient(135deg, rgba(31,43,92,0.76), rgba(122,31,43,0.58)),
    repeating-linear-gradient(45deg, #e7ecf6, #e7ecf6 10px, #d9e1ee 10px, #d9e1ee 20px);
  color: var(--white);
  font-weight: 900;
  display: grid;
  place-items: center;
}

@media (max-width: 1020px) {
  .property-detail-grid,
  .elevated-facts {
    grid-template-columns: 1fr;
  }

  .property-sidebar {
    position: static;
  }

  .property-gallery-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }

  .property-gallery-grid .gallery-main {
    grid-column: 1 / -1;
    grid-row: auto;
  }
}

@media (max-width: 640px) {
  .mini-facts,
  .highlight-grid,
  .property-gallery-grid {
    grid-template-columns: 1fr;
  }

  .property-hero-card {
    border-radius: 22px;
  }

  .property-gallery-grid .gallery-main,
  .property-gallery-grid img,
  .property-hero-photo {
    min-height: 260px;
  }
}

@media print {
  body {
    background: white;
  }

  .top-bar,
  nav,
  .page-hero,
  footer,
  .property-sidebar .small-detail-card,
  .print-flyer-panel,
  .btn,
  .nav-links {
    display: none !important;
  }

  header {
    background: white !important;
  }

  .section {
    padding: 0;
  }

  .property-detail-grid {
    grid-template-columns: 1.2fr .8fr;
  }

  .property-hero-card,
  .detail-panel,
  .sidebar-card {
    box-shadow: none;
    break-inside: avoid;
  }

  .property-hero-card {
    color: var(--navy-dark);
    background: white;
    border: 3px solid var(--navy);
  }

  .property-price-line {
    color: var(--burgundy);
  }

  .property-location-line,
  .elevated-facts .fact span,
  .elevated-facts .fact strong {
    color: var(--navy-dark);
  }

  .elevated-facts .fact {
    background: var(--soft);
    border: 1px solid var(--border);
  }
}

.sold-meta {
  display: grid;
  gap: 7px;
  margin: 12px 0 14px;
  padding: 12px 14px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(122,31,43,0.08), rgba(242,195,25,0.14));
  border: 1px solid rgba(122,31,43,0.14);
  color: var(--navy-dark);
  font-size: 13px;
}

.sold-meta span {
  display: block;
}

.sold-meta strong {
  color: var(--burgundy);
}

.sold-meta p {
  margin: 4px 0 0;
  color: var(--muted);
}

/* ===== V3 wide property page + click-through gallery ===== */
.property-layout {
  max-width: 1480px;
  width: 100%;
}

.wide-property-shell {
  display: grid;
  gap: 26px;
}

.property-quick-hero {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  padding: clamp(28px, 4vw, 46px);
  color: var(--white);
  background:
    radial-gradient(circle at 92% 18%, rgba(242,195,25,.22), transparent 28%),
    linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 58%, var(--burgundy-dark) 100%);
  box-shadow: var(--shadow);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: end;
}

.property-quick-hero::before {
  content: "PRZYBYLSKI TEAM";
  position: absolute;
  right: -60px;
  bottom: -38px;
  font-size: clamp(52px, 10vw, 150px);
  font-weight: 900;
  letter-spacing: 8px;
  color: rgba(255,255,255,.045);
  transform: rotate(-8deg);
  white-space: nowrap;
}

.property-quick-hero > * { position: relative; z-index: 1; }

.property-quick-hero h2 {
  font-size: clamp(36px, 4.6vw, 66px);
  line-height: 1.02;
  letter-spacing: -1.3px;
  margin: 14px 0 8px;
  max-width: 980px;
}

.quick-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.property-feature-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(360px, .55fr);
  gap: 26px;
  align-items: start;
}

.large-gallery-panel {
  padding: 14px;
  min-width: 0;
}

.property-photo-viewer {
  display: grid;
  gap: 12px;
}

.viewer-main-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  background: var(--soft);
  border: 1px solid var(--border);
}

.viewer-main-image {
  width: 100%;
  height: clamp(430px, 55vw, 680px);
  object-fit: cover;
  display: block;
}

.viewer-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.45);
  background: rgba(20,28,66,.72);
  color: var(--white);
  font-size: 32px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  backdrop-filter: blur(8px);
}

.viewer-prev { left: 16px; }
.viewer-next { right: 16px; }

.viewer-count {
  position: absolute;
  right: 16px;
  bottom: 16px;
  z-index: 3;
  border-radius: 999px;
  padding: 7px 12px;
  background: rgba(20,28,66,.78);
  color: var(--white);
  font-weight: 900;
  font-size: 13px;
  backdrop-filter: blur(8px);
}

.viewer-thumbs {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 116px;
  gap: 10px;
  overflow-x: auto;
  padding: 4px 2px 8px;
  scrollbar-width: thin;
}

.viewer-thumb {
  height: 82px;
  border: 3px solid transparent;
  border-radius: 16px;
  padding: 0;
  overflow: hidden;
  cursor: pointer;
  background: var(--white);
  opacity: .76;
}

.viewer-thumb.active {
  border-color: var(--gold);
  opacity: 1;
  box-shadow: 0 8px 18px rgba(20,28,66,.14);
}

.viewer-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.property-info-column,
.property-utility-column {
  display: grid;
  gap: 18px;
}

.property-info-column {
  position: sticky;
  top: 18px;
}

.key-info-panel {
  border-top: 7px solid var(--gold);
}

.key-info-panel h3 {
  font-size: 30px;
  line-height: 1.08;
  margin: 8px 0 10px;
}

.smaller-price {
  font-size: clamp(26px, 3vw, 38px);
}

.compact-facts {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 20px;
}

.property-content-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(310px, 380px);
  gap: 26px;
  align-items: start;
}

.property-main-content {
  display: grid;
  gap: 20px;
  min-width: 0;
}

.expanded-description-panel p {
  font-size: 18px;
  line-height: 1.85;
  max-width: 1100px;
}

.details-table-groups {
  display: grid;
  gap: 18px;
}

.details-table-group h4 {
  margin: 0 0 12px;
  color: var(--burgundy);
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: .8px;
}

.details-table {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
}

.details-table div {
  background: var(--soft);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 13px 14px;
}

.details-table dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 3px;
}

.details-table dd {
  margin: 0;
  color: var(--navy-dark);
  font-weight: 900;
}

.quick-contact-box {
  border-top: 0;
  border-left: 7px solid var(--gold);
}

@media (max-width: 1120px) {
  .property-feature-layout,
  .property-content-grid,
  .property-quick-hero {
    grid-template-columns: 1fr;
  }

  .property-info-column {
    position: static;
  }

  .quick-hero-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 680px) {
  .viewer-main-image {
    height: 330px;
  }

  .viewer-thumbs {
    grid-auto-columns: 92px;
  }

  .viewer-thumb {
    height: 68px;
  }

  .details-table,
  .compact-facts {
    grid-template-columns: 1fr;
  }

  .viewer-arrow {
    width: 38px;
    height: 38px;
    font-size: 26px;
  }
}

@media print {
  .viewer-arrow,
  .viewer-thumbs,
  .quick-hero-actions,
  .small-detail-card,
  .btn {
    display: none !important;
  }

  .property-quick-hero {
    color: var(--navy-dark);
    background: white !important;
    border: 3px solid var(--navy);
    box-shadow: none;
  }

  .property-feature-layout,
  .property-content-grid {
    grid-template-columns: 1.1fr .9fr;
  }

  .viewer-main-image {
    height: 360px;
  }

  .property-info-column {
    position: static;
  }

  .details-table {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
