:root{--bg:#f5f7fb;--panel:#fff;--text:#172033;--muted:#667085;--border:#e5e7eb;--primary:#1f6feb;--primary-dark:#1557b0;--danger:#dc2626;--success:#16a34a;--warning:#f59e0b;--shadow:0 18px 40px rgba(15,23,42,.08);--radius:18px}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}.app{display:grid;grid-template-columns:280px 1fr}.sidebar{background:#111827;color:white;min-height:100vh;padding:24px;display:flex;flex-direction:column;gap:28px;position:sticky;top:0}.brand{display:flex;gap:14px;align-items:center}.brand-mark{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#1f6feb,#5eead4);font-weight:900}.brand span{display:block;color:#9ca3af;font-size:13px;margin-top:2px}nav{display:grid;gap:8px}button,input,select,textarea{font:inherit}.nav-btn,.ghost,.primary,.secondary,.danger,.whatsapp{border:0;border-radius:12px;padding:11px 14px;cursor:pointer;text-decoration:none;display:inline-block}.nav-btn{text-align:left;background:transparent;color:#d1d5db}.nav-btn:hover,.nav-btn.active{background:rgba(255,255,255,.1);color:white}.primary{background:var(--primary);color:white;font-weight:700}.primary:hover{background:var(--primary-dark)}.secondary{background:#e8f0ff;color:var(--primary-dark);font-weight:700}.ghost{background:#f3f4f6;color:#374151}.danger{background:#fee2e2;color:var(--danger)}.whatsapp{background:#dcfce7;color:#166534;font-weight:800}.small{font-size:13px;padding:9px 10px}.sidebar-footer{margin-top:auto;display:grid;gap:8px}.main{padding:32px;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:28px}h1,h2,h3,p{margin-top:0}h1{margin-bottom:6px;font-size:34px}.muted,#pageSubtitle{color:var(--muted)}.topbar-actions{display:flex;gap:12px}.view{display:none}.view.active{display:block}.cards{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:16px;margin-bottom:20px}.stat-card,.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.stat-card{padding:22px}.stat-card span{color:var(--muted);display:block;margin-bottom:10px}.stat-card strong{font-size:32px}.panel{padding:22px}.panel-header{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px}.panel-header h2{margin-bottom:0}.split{display:grid;grid-template-columns:minmax(360px,.9fr) minmax(420px,1.1fr);gap:20px}.search,input,select,textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:11px 12px;background:white}.search{margin-bottom:14px}.list,.match-list{display:grid;gap:12px}.item,.match-card{border:1px solid var(--border);border-radius:16px;padding:14px;background:#fff;cursor:pointer}.item:hover,.match-card:hover{border-color:#bfdbfe;box-shadow:0 8px 20px rgba(31,111,235,.08)}.item.active{outline:2px solid #bfdbfe;border-color:var(--primary)}.item-top,.match-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.item-title{font-weight:800;margin-bottom:4px}.item-meta{color:var(--muted);font-size:14px}.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.tag{font-size:12px;padding:5px 8px;border-radius:999px;background:#f3f4f6;color:#374151}.score{min-width:62px;height:62px;border-radius:18px;display:grid;place-items:center;font-weight:900;color:white;background:#64748b}.score.hot{background:var(--success)}.score.good{background:var(--primary)}.score.mid{background:var(--warning)}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:18px}.detail-field{background:#f9fafb;border-radius:14px;padding:12px}.detail-field span{display:block;color:var(--muted);font-size:12px;margin-bottom:4px}.empty-detail{color:var(--muted);padding:32px;text-align:center;background:#f9fafb;border-radius:16px}.reasons{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.reason-box{background:#f9fafb;border-radius:14px;padding:12px;font-size:14px}.reason-box ul{padding-left:20px;margin-bottom:0}.reason-box.positive h4{color:var(--success)}.reason-box.negative h4{color:var(--danger)}.match-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.match-actions select{max-width:190px}dialog{border:0;border-radius:22px;box-shadow:0 35px 80px rgba(0,0,0,.25);width:min(980px,94vw);padding:0}dialog::backdrop{background:rgba(15,23,42,.55)}.modal-form{padding:24px}.grid-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.grid-form label{display:grid;gap:6px;color:#344054;font-size:14px;font-weight:700}.grid-form .wide{grid-column:1/-1}.checkbox-label{display:flex!important;align-items:center;gap:10px!important;padding:12px;background:#f9fafb;border-radius:12px}.checkbox-label input{width:auto}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.filters{display:flex;gap:10px}.auth-page{display:grid;place-items:center;min-height:100vh;padding:24px}.auth-card{width:min(520px,100%);background:#fff;border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow);padding:28px}.public-page{max-width:900px;margin:0 auto;padding:28px}.notice{background:#e8f0ff;border:1px solid #bfdbfe;border-radius:16px;padding:14px;margin-bottom:18px;color:#1e3a8a}.error{color:var(--danger);font-weight:700;margin-top:12px}@media(max-width:1050px){.app{grid-template-columns:1fr}.sidebar{min-height:auto;position:static}.cards{grid-template-columns:repeat(2,1fr)}.split{grid-template-columns:1fr}}@media(max-width:640px){.main{padding:18px}.topbar{flex-direction:column}.cards,.grid-form,.reasons{grid-template-columns:1fr}.topbar-actions{width:100%}.topbar-actions button{flex:1}}
.language-panel{margin-bottom:18px}.language-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:22px}.language-card{border:1px solid var(--border);border-radius:18px;background:#fff;padding:20px;text-align:left;cursor:pointer;box-shadow:0 8px 20px rgba(15,23,42,.05)}.language-card:hover{border-color:#bfdbfe;box-shadow:0 14px 28px rgba(31,111,235,.12);transform:translateY(-1px)}.language-card strong{display:block;font-size:20px;margin-bottom:8px;color:var(--text)}.language-card span{color:var(--muted);font-size:14px}.form-language-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}.form-language-bar span{font-weight:800;color:var(--primary-dark)}@media(max-width:640px){.language-grid{grid-template-columns:1fr}.form-language-bar{align-items:flex-start;flex-direction:column}}

.public-body {
  display: block;
  background: var(--bg);
  min-height: 100vh;
}
.public-wrap {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: 34px 0 56px;
}
.public-hero {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 28px;
  margin-bottom: 20px;
  display: flex;
  justify-content: space-between;
  gap: 22px;
  align-items: center;
}
.public-hero h1 { margin-bottom: 8px; }
.public-hero p { color: var(--muted); max-width: 720px; margin-bottom: 0; }
.eyebrow {
  display: inline-block;
  color: var(--primary);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 12px;
  margin-bottom: 8px;
}
.public-filters {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 12px;
  margin-bottom: 18px;
}
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.catalog-card {
  overflow: hidden;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.catalog-card a {
  color: inherit;
  text-decoration: none;
  display: block;
}
.catalog-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  background: #e5e7eb;
}
.catalog-card-body { padding: 18px; }
.catalog-card-body h2 { font-size: 20px; margin: 6px 0 8px; }
.catalog-card-body strong { font-size: 22px; }
.property-page {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, .85fr);
  gap: 22px;
  margin-top: 18px;
  align-items: start;
}
.property-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
.property-gallery img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 16px;
  background: #e5e7eb;
}
.property-gallery .main-img {
  grid-column: 1 / -1;
  height: 430px;
}
.property-public-detail h1 { margin-top: 6px; }
.property-public-detail h2 { color: var(--primary-dark); }
.property-public-detail p {
  color: var(--muted);
  line-height: 1.65;
  margin: 18px 0;
}
.property-public-detail .primary,
.property-public-detail .secondary {
  display: inline-block;
  text-decoration: none;
  margin-right: 10px;
  margin-top: 8px;
}
@media (max-width: 900px) {
  .catalog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .property-page { grid-template-columns: 1fr; }
  .public-hero { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 640px) {
  .catalog-grid, .public-filters { grid-template-columns: 1fr; }
  .property-gallery .main-img, .property-gallery img { height: 260px; }
}

.upload-note{font-size:13px;color:var(--muted);background:#f9fafb;border:1px dashed var(--border);border-radius:12px;padding:10px 12px}.image-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.image-preview img{width:100%;height:86px;object-fit:cover;border-radius:12px;border:1px solid var(--border);background:#f3f4f6}.image-preview .preview-card{position:relative}.image-preview .preview-card span{display:block;font-size:11px;color:var(--muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Galería pública de propiedad */
.property-gallery-wrap {
  display: grid;
  gap: 12px;
}
.property-gallery-main {
  position: relative;
  cursor: zoom-in;
  border-radius: 18px;
  overflow: hidden;
  background: #e5e7eb;
  box-shadow: var(--shadow);
}
.property-gallery-main img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  display: block;
  transition: transform .2s ease;
}
.property-gallery-main:hover img { transform: scale(1.015); }
.gallery-badge {
  position: absolute;
  right: 16px;
  bottom: 16px;
  background: rgba(17, 24, 39, .82);
  color: #fff;
  padding: 9px 13px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 14px;
}
.property-gallery-thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}
.thumb-btn {
  border: 0;
  padding: 0;
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer;
  background: #e5e7eb;
  outline: 2px solid transparent;
}
.thumb-btn.active,
.thumb-btn:hover { outline-color: var(--primary); }
.thumb-btn img {
  width: 100%;
  height: 86px;
  object-fit: cover;
  display: block;
}
.no-scroll { overflow: hidden; }
.gallery-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(3, 7, 18, .94);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 28px 74px;
}
.gallery-lightbox.open { display: flex; }
.gallery-lightbox img {
  max-width: 100%;
  max-height: 92vh;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 25px 80px rgba(0,0,0,.45);
}
.lightbox-close,
.lightbox-nav {
  position: fixed;
  border: 0;
  color: #fff;
  background: rgba(255,255,255,.14);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background .15s ease;
}
.lightbox-close:hover,
.lightbox-nav:hover { background: rgba(255,255,255,.24); }
.lightbox-close {
  top: 20px;
  right: 20px;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  font-size: 32px;
  line-height: 1;
}
.lightbox-nav {
  top: 50%;
  transform: translateY(-50%);
  width: 54px;
  height: 74px;
  border-radius: 18px;
  font-size: 52px;
  line-height: 1;
}
.lightbox-prev { left: 20px; }
.lightbox-next { right: 20px; }
.lightbox-counter {
  position: fixed;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%);
  color: #fff;
  background: rgba(255,255,255,.14);
  padding: 8px 13px;
  border-radius: 999px;
  font-weight: 800;
}
@media (max-width: 640px) {
  .property-gallery-main img { height: 320px; }
  .gallery-lightbox { padding: 18px; }
  .lightbox-nav {
    width: 44px;
    height: 58px;
    font-size: 42px;
  }
  .lightbox-prev { left: 8px; }
  .lightbox-next { right: 8px; }
  .lightbox-close { top: 10px; right: 10px; }
}


.catalog-tabs{display:flex;gap:10px;margin:18px 0}
.catalog-tab{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:999px;padding:10px 16px;cursor:pointer;font-weight:800}
.catalog-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.catalog-map-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}
.catalog-map{height:620px;border-radius:16px;overflow:hidden}
.property-map-section{margin-top:28px;border-top:1px solid var(--border);padding-top:22px}
.property-map{height:360px;border-radius:16px;overflow:hidden;border:1px solid var(--border);margin-top:10px}
.map-note{color:var(--muted);font-size:13px;margin:10px 0 0}
.map-popup{display:grid;gap:4px;min-width:180px}
.map-popup span{color:#667085}
.map-popup a{color:#1f6feb;font-weight:800;text-decoration:none}
.leaflet-container{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}


/* ===== Branding public pages v14 ===== */
.public-body {
  --primary: #b28557;
  --primary-dark: #8f633c;
  --bg: #f5efe8;
  --panel: #fffdfb;
  --text: #2e241d;
  --muted: #6f6258;
  --border: #eadfce;
}
.public-brand-page .primary { background: linear-gradient(135deg, #c89b6a, #a9784d); color: #fff; }
.public-brand-page .primary:hover { background: linear-gradient(135deg, #b98c5c, #956840); }
.public-brand-page .secondary { background: #f3ece3; color: #7c5734; }
.public-brand-page .ghost { background: #fff; color: #5d4f43; border: 1px solid var(--border); }
.brand-topbar {
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  background: rgba(255,253,251,.92); backdrop-filter: blur(10px);
  border:1px solid var(--border); border-radius: 22px; box-shadow: var(--shadow);
  padding: 18px 22px; margin-bottom: 20px;
}
.brand-lockup img { height: 72px; width: auto; display:block; }
.brand-nav { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.brand-nav a, .brand-nav button {
  color: var(--text); text-decoration:none; font-weight:700; background:transparent; border:0; cursor:pointer; padding:8px 10px; border-radius: 999px;
}
.brand-nav a:hover, .brand-nav button:hover, .brand-nav a.active { background:#f4ece2; }
.topbar-whatsapp { white-space: nowrap; }
.brand-hero { align-items: stretch; padding: 34px; gap: 28px; background: linear-gradient(135deg, #fffdfb, #f7f0e8); }
.hero-copy h1 { font-size: clamp(32px, 5vw, 52px); line-height: 1.05; margin-bottom: 12px; }
.hero-copy p { font-size: 17px; line-height: 1.7; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top: 18px; }
.hero-side-card { display:grid; grid-template-columns: 130px 1fr; gap:18px; align-items:center; min-width: 340px; }
.hero-agent-photo { width: 130px; height: 130px; border-radius: 24px; object-fit: cover; box-shadow: 0 18px 35px rgba(0,0,0,.12); }
.hero-side-card h2 { margin-bottom: 8px; }
.hero-side-text { color: var(--muted); margin-bottom: 12px; }
.mini-contact-list { display:grid; gap:6px; }
.mini-contact-list a { color: var(--text); text-decoration:none; font-weight:600; }
.brand-pills { display:flex; gap:8px; flex-wrap:wrap; margin-top: 16px; }
.brand-highlight-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 22px; }
.tip-card h3 { margin-bottom: 8px; }
.tip-card p { color: var(--muted); line-height: 1.65; margin-bottom: 0; }
.premium-filters { margin-top: 12px; }
.premium-card { transition: transform .18s ease, box-shadow .18s ease; }
.premium-card:hover { transform: translateY(-3px); box-shadow: 0 18px 36px rgba(76, 55, 34, 0.12); }
.catalog-link-text { display:inline-block; margin-top: 14px; font-weight: 800; color: var(--primary-dark); }
.brand-footer { margin-top: 28px; padding: 26px 28px; background: #fffdfb; border: 1px solid var(--border); border-radius: 22px; box-shadow: var(--shadow); }
.brand-footer-main { display:grid; grid-template-columns: 1.4fr .8fr; gap: 22px; align-items:start; }
.brand-footer-logo { width: min(100%, 360px); display:block; margin-bottom: 10px; }
.brand-footer-text { color: var(--muted); line-height: 1.7; }
.brand-contact-list { display:grid; gap: 10px; justify-items: start; }
.brand-contact-list a, .brand-contact-list span { color: var(--text); text-decoration:none; font-weight:600; }
.brand-footer-note { color: var(--muted); font-size: 13px; margin: 18px 0 0; }
.floating-whatsapp { position: fixed; right: 20px; bottom: 20px; z-index: 50; text-decoration:none; background: #1fa855; color: #fff; font-weight: 800; padding: 14px 18px; border-radius: 999px; box-shadow: 0 20px 45px rgba(31,168,85,.28); }
.property-top-actions { margin-bottom: 12px; }
.property-main-column { display:grid; gap: 18px; }
.property-sidebar { display:grid; gap: 18px; position: sticky; top: 18px; align-self: start; }
.property-description-panel h1 { margin-bottom: 10px; }
.property-feature-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; margin-top: 20px; }
.branded-sidebar-card { padding: 24px; }
.property-price { font-size: clamp(30px, 4vw, 40px); color: var(--primary-dark); margin: 8px 0 12px; }
.property-cta-stack { display:grid; gap: 10px; margin-top: 18px; }
.property-cta-stack a { text-decoration:none; text-align:center; }
.agent-card-public { padding: 20px; }
.agent-photo { width: 100%; height: 300px; object-fit: cover; border-radius: 18px; display:block; margin-bottom: 16px; }
.agent-card-copy p { color: var(--muted); line-height: 1.7; }
.agent-contact-grid { display:grid; gap:10px; margin: 16px 0; }
.agent-contact-grid a { text-decoration:none; text-align:center; }
.trust-list { margin: 0; padding-left: 18px; color: var(--muted); display:grid; gap: 8px; }
@media (max-width: 980px) {
  .brand-topbar, .public-hero, .hero-side-card, .brand-footer-main { grid-template-columns: 1fr; flex-direction: column; align-items: flex-start; }
  .brand-nav { width:100%; }
  .hero-side-card { min-width: 0; }
  .brand-highlight-grid { grid-template-columns: 1fr; }
  .property-sidebar { position: static; }
}
@media (max-width: 720px) {
  .brand-lockup img { height: 58px; }
  .hero-side-card { display:block; }
  .hero-agent-photo { width: 100px; height: 100px; margin-bottom: 12px; }
  .property-feature-grid { grid-template-columns: 1fr; }
  .brand-footer { padding: 22px; }
  .floating-whatsapp { right: 12px; bottom: 12px; }
}


/* ===== Branded public lead form v15 ===== */
.lead-form-brand-page .public-wrap { max-width: 1180px; }
.lead-form-hero { margin-bottom: 22px; }
.lead-form-layout {
  display: grid;
  grid-template-columns: minmax(280px, .78fr) minmax(0, 1.22fr);
  gap: 22px;
  align-items: start;
}
.lead-form-content { display: grid; gap: 18px; }
.form-trust-card {
  position: sticky;
  top: 18px;
  align-self: start;
}
.form-trust-card .agent-photo {
  height: 280px;
}
.form-trust-card h2 {
  margin: 8px 0 10px;
}
.form-trust-card p {
  color: var(--muted);
  line-height: 1.65;
}
.branded-language-panel,
.branded-form-panel {
  padding: 28px;
}
.branded-language-panel {
  background:
    radial-gradient(circle at top right, rgba(200,155,106,.15), transparent 36%),
    var(--panel);
}
.branded-language-panel .language-card {
  border-color: var(--border);
  background: #fffdfb;
}
.branded-language-panel .language-card:hover {
  border-color: #c89b6a;
  box-shadow: 0 16px 32px rgba(143, 99, 60, .12);
}
.branded-form-panel form input,
.branded-form-panel form select,
.branded-form-panel form textarea,
.lead-form-brand-page .search {
  background: #fff;
  border-color: #e6d8c8;
}
.branded-form-panel form input:focus,
.branded-form-panel form select:focus,
.branded-form-panel form textarea:focus {
  outline: 2px solid rgba(200,155,106,.25);
  border-color: #c89b6a;
}
.branded-form-panel .form-actions {
  justify-content: flex-start;
}
.thanks-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, .7fr);
  gap: 22px;
  align-items: stretch;
}
.thanks-card-branded {
  padding: 36px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.thanks-card-branded h1 {
  font-size: clamp(36px, 6vw, 58px);
}
.thanks-card-branded p {
  font-size: 18px;
  line-height: 1.7;
  max-width: 680px;
}
@media (max-width: 980px) {
  .lead-form-layout,
  .thanks-layout {
    grid-template-columns: 1fr;
  }
  .form-trust-card {
    position: static;
  }
}
@media (max-width: 640px) {
  .branded-language-panel,
  .branded-form-panel,
  .thanks-card-branded {
    padding: 22px;
  }
  .lead-form-hero {
    padding: 24px;
  }
}


/* ===== v16 public multilingual + responsive fixes ===== */
.brand-topbar-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.public-language-select {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 82px;
  background: #fffdfb;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 7px 10px;
  color: var(--text);
  font-weight: 800;
}
.public-language-select select {
  width: auto;
  min-width: 48px;
  border: 0;
  padding: 0;
  background: transparent;
  font-weight: 800;
  color: var(--text);
  cursor: pointer;
}
.public-language-select select:focus { outline: none; }

.brand-topbar,
.hero-side-card,
.form-trust-card,
.agent-card-public,
.brand-footer,
.branded-form-panel,
.branded-language-panel,
.property-public-detail {
  min-width: 0;
}

.mini-contact-list,
.brand-contact-list,
.agent-contact-grid {
  min-width: 0;
}

.mini-contact-list a,
.brand-contact-list a,
.agent-contact-grid a,
.hero-side-text,
.form-trust-card p,
.agent-card-copy p,
.trust-list li,
.brand-footer-text {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.brand-nav {
  min-width: 0;
}

.brand-nav a,
.brand-nav button,
.topbar-whatsapp {
  white-space: nowrap;
}

.hero-side-card {
  min-width: 0 !important;
}

.form-trust-card {
  overflow: hidden;
}

.form-trust-card .agent-photo,
.agent-card-public .agent-photo {
  max-width: 100%;
}

@media (max-width: 1180px) {
  .brand-topbar {
    display: grid;
    grid-template-columns: 1fr;
  }
  .brand-nav,
  .brand-topbar-actions {
    width: 100%;
  }
  .brand-topbar-actions {
    justify-content: space-between;
  }
}

@media (max-width: 900px) {
  .public-wrap {
    width: min(100% - 24px, 1180px);
    padding-top: 18px;
  }
  .brand-topbar {
    padding: 16px;
  }
  .brand-lockup img {
    max-width: 100%;
    height: auto;
    max-height: 66px;
  }
  .brand-nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  .brand-nav a,
  .brand-nav button {
    text-align: center;
    background: #f7f0e8;
    width: 100%;
    white-space: normal;
  }
  .brand-topbar-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .public-language-select,
  .topbar-whatsapp {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
  .brand-hero {
    padding: 24px;
  }
  .hero-side-card {
    grid-template-columns: 92px 1fr;
    width: 100%;
  }
  .hero-agent-photo {
    width: 92px;
    height: 92px;
    border-radius: 18px;
  }
  .lead-form-layout,
  .thanks-layout,
  .property-page {
    grid-template-columns: 1fr !important;
  }
  .property-sidebar,
  .form-trust-card {
    position: static !important;
  }
  .catalog-map {
    height: 480px;
  }
}

@media (max-width: 640px) {
  .public-wrap {
    width: min(100% - 18px, 1180px);
  }
  .brand-topbar {
    border-radius: 18px;
  }
  .brand-nav {
    grid-template-columns: 1fr;
  }
  .brand-topbar-actions {
    grid-template-columns: 1fr;
  }
  .brand-hero,
  .public-hero {
    padding: 20px;
  }
  .hero-copy h1 {
    font-size: clamp(30px, 10vw, 42px);
  }
  .hero-side-card {
    display: grid !important;
    grid-template-columns: 76px 1fr;
    gap: 12px;
    padding: 16px;
  }
  .hero-agent-photo {
    width: 76px;
    height: 76px;
  }
  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .hero-actions a,
  .property-cta-stack a,
  .agent-contact-grid a {
    width: 100%;
    text-align: center;
  }
  .catalog-grid {
    grid-template-columns: 1fr !important;
  }
  .catalog-card img {
    height: 240px;
  }
  .catalog-map {
    height: 380px;
  }
  .brand-highlight-grid {
    grid-template-columns: 1fr !important;
  }
  .brand-footer-main {
    grid-template-columns: 1fr !important;
  }
  .brand-footer-logo {
    max-width: 100%;
  }
  .floating-whatsapp {
    left: 12px;
    right: 12px;
    text-align: center;
  }
  .lead-form-layout {
    gap: 14px;
  }
  .form-trust-card .agent-photo,
  .agent-card-public .agent-photo {
    height: 220px;
  }
  .language-grid {
    grid-template-columns: 1fr !important;
  }
  .property-gallery-main img {
    height: 300px;
  }
  .property-gallery-thumbs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .property-feature-grid {
    grid-template-columns: 1fr !important;
  }
  .thanks-card-branded h1 {
    font-size: 38px;
  }
}


/* ===== v17 form optimization: dates + sliders ===== */
.branded-form-panel small {
  color: var(--muted);
  font-weight: 500;
  line-height: 1.35;
}
.range-label {
  align-content: start;
}
.range-label input[type="range"] {
  accent-color: var(--primary);
  padding-left: 0;
  padding-right: 0;
}
.range-label strong {
  display: inline-flex;
  width: fit-content;
  min-width: 72px;
  justify-content: center;
  padding: 7px 12px;
  border-radius: 999px;
  background: #f3ece3;
  color: var(--primary-dark);
}
input[type="date"] {
  min-height: 44px;
}

.catalog-availability,
.property-availability {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: 700;
}


/* ===== v18 catalog filters + map popup + form simplification ===== */
.catalog-layout {
  display: grid;
  grid-template-columns: 290px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.catalog-filter-sidebar {
  position: sticky;
  top: 18px;
  display: grid;
  gap: 14px;
  padding: 20px;
}
.catalog-filter-sidebar h2 {
  margin-bottom: 0;
}
.catalog-filter-sidebar label {
  display: grid;
  gap: 7px;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.catalog-filter-sidebar .search {
  margin-bottom: 0;
}
.catalog-map-wrap {
  margin-top: 0;
}
.catalog-map {
  height: min(72vh, 760px);
  min-height: 520px;
}
.property-map-popup {
  gap: 6px;
}
.property-map-popup img {
  width: 100%;
  height: 118px;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: 4px;
  display: block;
}
.property-map-popup strong {
  line-height: 1.25;
}
.lead-form-content .branded-form-panel {
  display: block;
}
@media (max-width: 980px) {
  .catalog-layout {
    grid-template-columns: 1fr;
  }
  .catalog-filter-sidebar {
    position: static;
  }
  .catalog-filter-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .catalog-filter-sidebar h2,
  .catalog-filter-sidebar #clearFilters {
    grid-column: 1 / -1;
  }
}
@media (max-width: 640px) {
  .catalog-filter-sidebar {
    grid-template-columns: 1fr;
  }
  .catalog-map {
    height: 70vh;
    min-height: 420px;
  }
}


/* ===== v19 custom property features ===== */
.custom-features-section {
  margin-top: 24px;
  border-top: 1px solid var(--border);
  padding-top: 20px;
}
.custom-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.custom-feature-box {
  display: flex;
  align-items: center;
  min-height: 48px;
  padding: 12px 14px;
  border-radius: 14px;
  background: #f8f0e7;
  border: 1px solid #eadfce;
  color: var(--text);
  font-weight: 800;
  overflow-wrap: anywhere;
}


/* ===== v21 landing page + map spacing ===== */
.landing-page .public-wrap {
  padding-top: 26px;
}
.landing-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
  gap: 24px;
  align-items: stretch;
  margin-bottom: 24px;
}
.landing-hero-copy {
  background: linear-gradient(135deg, #fffdfb, #f7f0e8);
  border: 1px solid var(--border);
  border-radius: 28px;
  box-shadow: var(--shadow);
  padding: clamp(30px, 6vw, 58px);
}
.landing-hero-copy h1 {
  font-size: clamp(38px, 6vw, 70px);
  line-height: 1.02;
  margin-bottom: 16px;
}
.landing-hero-copy p {
  color: var(--muted);
  font-size: 18px;
  line-height: 1.75;
  max-width: 760px;
}
.landing-contact-card {
  padding: 22px;
}
.landing-contact-card .agent-photo {
  height: 330px;
  margin-bottom: 16px;
}
.landing-reviews-section {
  margin: 24px 0;
  padding: 30px;
}
.landing-section-head {
  margin-bottom: 18px;
}
.landing-section-head p {
  color: var(--muted);
  line-height: 1.6;
}
.reviews-carousel {
  display: grid;
  grid-template-columns: 48px minmax(0,1fr) 48px;
  gap: 16px;
  align-items: center;
}
.review-card {
  min-height: 190px;
  display: grid;
  align-content: center;
  gap: 12px;
  padding: 28px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: #fff9f1;
  text-align: center;
}
.review-card p {
  font-size: clamp(18px, 2.2vw, 24px);
  line-height: 1.55;
  color: var(--text);
  margin: 0;
}
.review-stars {
  color: #b28557;
  letter-spacing: 3px;
  font-size: 20px;
}
.review-nav {
  width: 48px;
  height: 62px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fffdfb;
  color: var(--primary-dark);
  font-size: 40px;
  cursor: pointer;
}
.review-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 14px;
}
.review-dots button {
  width: 10px;
  height: 10px;
  border: 0;
  border-radius: 50%;
  background: #d8c6b0;
  cursor: pointer;
}
.review-dots button.active {
  background: var(--primary-dark);
}
.landing-featured-section {
  margin: 28px 0;
}
.featured-grid {
  margin-top: 18px;
}
.center-actions {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}
#catalogMapWrap {
  margin-top: 30px;
  padding-top: 22px;
}
.catalog-tabs {
  margin-bottom: 24px !important;
}
@media (max-width: 900px) {
  .landing-hero {
    grid-template-columns: 1fr;
  }
  .reviews-carousel {
    grid-template-columns: 1fr;
  }
  .review-nav {
    display: none;
  }
}
@media (max-width: 640px) {
  .landing-hero-copy {
    padding: 26px;
  }
  .landing-contact-card .agent-photo {
    height: 260px;
  }
  .landing-reviews-section {
    padding: 22px;
  }
  .review-card {
    padding: 22px;
  }
}


/* ===== v22 backend reviews + multi-review carousel ===== */
.review-photo-preview img,
.review-list-photo,
.review-detail-photo {
  border-radius: 14px;
  object-fit: cover;
  border: 1px solid var(--border);
  background: #f3f4f6;
}
.review-photo-preview img {
  width: 140px;
  height: 140px;
}
.review-list-photo {
  width: 62px;
  height: 62px;
  flex: 0 0 auto;
}
.review-detail-photo {
  width: min(100%, 320px);
  height: 220px;
  margin-bottom: 16px;
}
.reviews-carousel-multi {
  grid-template-columns: 48px minmax(0,1fr) 48px;
}
.reviews-track {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}
.reviews-track .review-card {
  min-height: 260px;
  text-align: left;
  align-content: start;
}
.review-card-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.review-person-photo,
.review-person-fallback {
  width: 58px;
  height: 58px;
  border-radius: 999px;
  flex: 0 0 auto;
}
.review-person-photo {
  object-fit: cover;
  border: 2px solid #eadfce;
}
.review-person-fallback {
  display: grid;
  place-items: center;
  background: #eadfce;
  color: var(--primary-dark);
  font-weight: 900;
  font-size: 22px;
}
.reviews-track .review-card p {
  font-size: 16px;
}
@media (max-width: 980px) {
  .reviews-track {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}
@media (max-width: 640px) {
  .reviews-track {
    grid-template-columns: 1fr;
  }
}


/* ===== v23 visual property labels ===== */
.property-accent {
  position: relative;
  overflow: hidden;
}
.property-accent::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 6px;
  background: var(--listing-color, #b28557);
  border-radius: inherit;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.catalog-card.property-accent::before {
  z-index: 2;
}
.listing-sale { --listing-color: #2e9d64; --listing-soft: rgba(46,157,100,.12); --listing-text: #17623d; }
.listing-longRental { --listing-color: #f28c28; --listing-soft: rgba(242,140,40,.14); --listing-text: #8a4d09; }
.listing-shortRental { --listing-color: #f4c430; --listing-soft: rgba(244,196,48,.2); --listing-text: #735c00; }
.listing-featured { --listing-color: #d946ef; --listing-soft: rgba(217,70,239,.13); --listing-text: #86198f; }
.listing-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  gap: 6px;
  margin: 6px 0 2px;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--listing-soft, #f4ece2);
  color: var(--listing-text, var(--primary-dark));
  border: 1px solid color-mix(in srgb, var(--listing-color, #b28557) 35%, transparent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .01em;
}
.listing-badge::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--listing-color, #b28557);
}
.tags .listing-badge {
  margin: 0;
}
.map-popup .listing-badge {
  margin-bottom: 4px;
}
.property-public-detail.property-accent {
  padding-left: 28px;
}
.item.property-accent {
  padding-left: 18px;
}

/* v23 review copy and backend sync polish */
.reviews-track .review-card {
  border-top: 4px solid #c89b6a;
}


/* ===== v25 review type + contact spacing ===== */
.review-type-badge {
  display: inline-flex;
  width: fit-content;
  margin-top: 6px;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  background: #f4ece2;
  color: var(--primary-dark);
  border: 1px solid #eadfce;
}
.review-type-buyer { background: rgba(46,157,100,.12); color: #17623d; border-color: rgba(46,157,100,.28); }
.review-type-tenant { background: rgba(242,140,40,.14); color: #8a4d09; border-color: rgba(242,140,40,.28); }
.review-type-owner { background: rgba(178,133,87,.14); color: #6f4b2c; border-color: rgba(178,133,87,.30); }

.lead-form-brand-page .hero-side-card {
  align-items: start;
  gap: 22px;
  padding: 24px;
}
.lead-form-brand-page .hero-side-card h2 {
  margin-bottom: 10px;
}
.lead-form-brand-page .hero-side-text {
  margin-bottom: 16px;
  line-height: 1.75;
}
.lead-form-brand-page .mini-contact-list {
  gap: 10px;
}
.lead-form-brand-page .mini-contact-list a {
  display: block;
  padding: 7px 0;
  line-height: 1.35;
}
@media (max-width: 640px) {
  .lead-form-brand-page .hero-side-card {
    gap: 14px;
    padding: 18px;
  }
}


/* ===== v28 fixes: public assets, reviews, removable images, map address ===== */
.reviews-carousel,
.reviews-carousel-multi,
.reviews-track,
.reviews-track .review-card {
  min-width: 0;
}
.reviews-track {
  align-items: stretch;
}
.reviews-track .review-card {
  height: 100%;
  overflow: hidden;
  overflow-wrap: anywhere;
  word-break: normal;
}
.review-card-head {
  min-width: 0;
}
.review-card-head > div {
  min-width: 0;
}
.review-card-head strong {
  display: block;
  overflow-wrap: anywhere;
}
@media (max-width: 980px) {
  .reviews-track {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 640px) {
  .reviews-carousel-multi {
    grid-template-columns: 1fr !important;
  }
  .reviews-track {
    grid-template-columns: 1fr !important;
  }
}

.image-preview .removable-preview {
  padding-bottom: 4px;
}
.image-preview .preview-card {
  min-width: 0;
}
.remove-image-btn {
  position: absolute;
  top: 6px;
  right: 6px;
  border: 0;
  border-radius: 999px;
  background: rgba(17,24,39,.82);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  padding: 5px 8px;
  cursor: pointer;
}
.remove-image-btn:hover {
  background: #b91c1c;
}
.clear-pending-images {
  min-height: 86px;
  border: 1px dashed var(--border);
  border-radius: 12px;
}
.map-address-field small {
  color: var(--muted);
  font-weight: 500;
  line-height: 1.4;
}
.map-tools {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.map-status {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}
@media (max-width: 640px) {
  .map-tools {
    display: grid;
    grid-template-columns: 1fr;
  }
}


/* ===== v29: X buttons, review photo removal and compact property detail ===== */
.remove-image-btn {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  padding: 0;
  font-size: 20px;
  line-height: 1;
  border-radius: 999px;
}
.review-preview-card {
  position: relative;
  width: fit-content;
  max-width: 180px;
}
.review-preview-card img {
  width: 150px;
  height: 150px;
  border-radius: 16px;
  object-fit: cover;
  border: 1px solid var(--border);
  background: #f3f4f6;
}
.property-compact-card {
  padding: 18px 18px 18px 24px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(17,24,39,.06);
}
.property-compact-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
}
.property-compact-head h3 {
  margin: 4px 0;
}
.property-compact-price {
  white-space: nowrap;
  font-size: 22px;
  color: var(--primary-dark);
}
.compact-facts {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.compact-facts span {
  padding: 7px 10px;
  border-radius: 999px;
  background: #f8f0e7;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.compact-tags {
  margin-top: 12px;
}
.property-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 14px 0;
}
.compact-details {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fffdfb;
  margin-top: 12px;
  overflow: hidden;
}
.compact-details summary {
  cursor: pointer;
  padding: 14px 16px;
  font-weight: 900;
  color: var(--text);
  background: #f8f0e7;
}
.compact-details .detail-grid,
.compact-details .match-list {
  padding: 14px;
}
.compact-match-list .match-card {
  padding: 14px;
}
.compact-match-list .reasons {
  display: none;
}
.compact-match-list .match-top h3 {
  font-size: 15px;
}
@media (max-width: 640px) {
  .property-compact-head {
    display: grid;
  }
  .property-compact-price {
    font-size: 20px;
  }
  .property-quick-actions {
    display: grid;
  }
  .property-quick-actions a,
  .property-quick-actions button {
    width: 100%;
  }
}


/* ===== v30: editor de propiedad por bloques ===== */
.property-editor-dialog {
  width: min(980px, calc(100% - 24px));
}
.property-editor-form {
  max-height: min(88vh, 920px);
  overflow: auto;
  padding: 0;
}
.property-editor-header {
  position: sticky;
  top: 0;
  z-index: 5;
  background: #fffdfb;
  border-bottom: 1px solid var(--border);
  padding: 22px 24px 16px;
}
.property-editor-header h2 {
  margin-bottom: 6px;
}
.property-editor-header p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}
.editor-section {
  margin: 14px 20px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  overflow: hidden;
}
.editor-section summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  padding: 16px 18px;
  background: #f8f0e7;
  color: var(--text);
}
.editor-section summary::-webkit-details-marker {
  display: none;
}
.editor-section summary::after {
  content: "+";
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #fff;
  border: 1px solid var(--border);
  font-weight: 900;
  color: var(--primary-dark);
  flex: 0 0 auto;
}
.editor-section[open] summary::after {
  content: "–";
}
.editor-section summary span {
  font-weight: 950;
}
.editor-section summary small {
  color: var(--muted);
  font-weight: 700;
  text-align: right;
}
.editor-grid {
  padding: 18px;
}
.checkbox-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}
.checkbox-grid .checkbox-label {
  margin: 0;
  min-height: 48px;
}
.property-editor-actions {
  position: sticky;
  bottom: 0;
  z-index: 5;
  background: #fffdfb;
  border-top: 1px solid var(--border);
  padding: 14px 20px 20px;
  margin-top: 14px;
}
.property-editor-actions .primary,
.property-editor-actions .ghost {
  min-width: 150px;
}
@media (max-width: 780px) {
  .property-editor-dialog {
    width: min(100% - 14px, 980px);
  }
  .property-editor-header {
    padding: 18px 16px 12px;
  }
  .editor-section {
    margin: 10px 12px;
    border-radius: 15px;
  }
  .editor-section summary {
    display: grid;
    gap: 4px;
    padding: 14px;
  }
  .editor-section summary::after {
    position: absolute;
    right: 16px;
  }
  .editor-section summary small {
    text-align: left;
    padding-right: 42px;
  }
  .editor-grid {
    padding: 14px;
  }
  .checkbox-grid {
    grid-template-columns: 1fr 1fr;
  }
  .property-editor-actions {
    display: grid;
    grid-template-columns: 1fr;
    padding: 12px;
  }
  .property-editor-actions .primary,
  .property-editor-actions .ghost {
    width: 100%;
  }
}
@media (max-width: 460px) {
  .checkbox-grid {
    grid-template-columns: 1fr;
  }
}


/* ===== v30 final photo editor cleanup ===== */
.image-preview:empty::before {
  content: "Todavía no hay fotos asociadas a esta propiedad.";
  display: block;
  grid-column: 1 / -1;
  color: var(--muted);
  border: 1px dashed var(--border);
  border-radius: 14px;
  padding: 16px;
  background: #fffdfb;
}


/* ===== v31: backup completo, orden de fotos y legal público ===== */
.image-card-actions {
  position: absolute;
  top: 6px;
  right: 6px;
  display: flex;
  gap: 5px;
  align-items: center;
}
.move-image-btn {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  color: var(--text);
  font-weight: 900;
  box-shadow: 0 4px 12px rgba(17,24,39,.16);
  cursor: pointer;
}
.move-image-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
}
.image-card-actions .remove-image-btn {
  position: static;
  flex: 0 0 auto;
}
.legal-consent {
  align-items: flex-start;
  gap: 10px;
  background: #fffdfb;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 14px;
  line-height: 1.45;
}
.legal-consent input {
  margin-top: 3px;
}
.legal-consent a {
  color: var(--primary-dark);
  font-weight: 900;
  text-decoration: none;
}
.legal-consent a:hover {
  text-decoration: underline;
}
.legal-panel {
  max-width: 920px;
  margin: 24px auto;
  padding: clamp(24px, 4vw, 44px);
}
.legal-panel h1 {
  font-size: clamp(36px, 6vw, 58px);
  margin-bottom: 14px;
}
.legal-panel h2 {
  margin-top: 28px;
  margin-bottom: 8px;
}
.legal-panel p {
  line-height: 1.75;
}
.legal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}
.brand-contact-list a {
  overflow-wrap: anywhere;
}
@media (max-width: 640px) {
  .legal-actions {
    display: grid;
  }
  .legal-actions a {
    width: 100%;
    text-align: center;
  }
}


/* ===== v32: enlace público generado automáticamente ===== */
.generated-link-box {
  display: grid;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fffdfb;
  padding: 14px;
}
.generated-link-box label {
  gap: 7px;
}
.generated-link-box input[readonly] {
  background: #f8f0e7;
  color: var(--text);
  font-weight: 800;
}
.generated-link-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.generated-link-box small {
  color: var(--muted);
  line-height: 1.45;
}
@media (max-width: 640px) {
  .generated-link-actions {
    display: grid;
  }
  .generated-link-actions button,
  .generated-link-actions a {
    width: 100%;
    text-align: center;
  }
}


/* ===== v33: botones de enlace público corregidos ===== */
.generated-link-actions button,
.property-quick-actions button {
  pointer-events: auto;
  position: relative;
  z-index: 2;
}
.generated-link-actions [hidden] {
  display: none !important;
}
