/* ─── Mapro Integration v3 ─────────────────────────────────────────────────
   Cores: Navy #1a2f5e | Gold #c9a84c | Green #16a34a | Red #dc2626
────────────────────────────────────────────────────────────────────────── */
:root {
  --mp-navy:     #1a2f5e;
  --mp-navy-dk:  #142348;
  --mp-gold:     #c9a84c;
  --mp-gold-lt:  #f5e6c0;
  --mp-success:  #16a34a;
  --mp-error:    #dc2626;
  --mp-gray:     #6b7280;
  --mp-gray-lt:  #f3f4f6;
  --mp-border:   #e5e7eb;
  --mp-radius:   10px;
  --mp-shadow:   0 2px 16px rgba(26,47,94,.09);
  --mp-shadow-hv:0 8px 32px rgba(26,47,94,.18);
}

/* ─── Results count ──────────────────────────────────────────────────────── */
.mapro-results-count { font-size:.85rem; color:var(--mp-gray); margin-bottom:16px; padding:0 4px; }

/* ─── Grid ──────────────────────────────────────────────────────────────── */
.mapro-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:24px; margin:20px 0; }
@media(min-width:1025px){ .mapro-grid { grid-template-columns:repeat(3,1fr); } }
@media(min-width:769px) and (max-width:1024px){ .mapro-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:768px){ .mapro-grid { grid-template-columns:1fr; gap:16px; } }

/* ─── Card ──────────────────────────────────────────────────────────────── */
.mapro-card { background:#fff; border-radius:var(--mp-radius); box-shadow:var(--mp-shadow); overflow:hidden; display:flex; flex-direction:column; transition:transform .2s,box-shadow .2s; border:1px solid var(--mp-border); }
.mapro-card:hover { transform:translateY(-5px); box-shadow:var(--mp-shadow-hv); }
.mapro-card__img { position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--mp-gray-lt); }
.mapro-card__img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.mapro-card:hover .mapro-card__img img { transform:scale(1.05); }
.mapro-card__no-img { display:flex; align-items:center; justify-content:center; font-size:56px; height:100%; }
.mapro-card__body { padding:16px 18px 18px; display:flex; flex-direction:column; flex:1; }
.mapro-card__title { margin:0 0 6px; font-size:1rem; font-weight:700; color:var(--mp-navy); line-height:1.3; }
.mapro-card__location { margin:0 0 10px; color:var(--mp-gray); font-size:.82rem; }
.mapro-card__meta { display:flex; gap:10px; flex-wrap:wrap; font-size:.8rem; color:#374151; margin-bottom:10px; }
.mapro-card__amenities { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:14px; }
.mapro-card__amenities span { font-size:.72rem; background:#eef2ff; color:var(--mp-navy); padding:3px 9px; border-radius:999px; border:1px solid #c7d2fe; }
.mapro-card__footer { margin-top:auto; display:flex; justify-content:space-between; align-items:center; padding-top:12px; border-top:1px solid var(--mp-border); }
.mapro-card__price span { font-size:1.15rem; font-weight:800; color:var(--mp-navy); }
.mapro-card__price small { display:block; font-size:.7rem; color:var(--mp-gray); font-weight:400; }

/* ─── Badges ─────────────────────────────────────────────────────────────── */
.mapro-badge--resort { position:absolute; bottom:10px; left:10px; background:rgba(26,47,94,.85); color:#fff; backdrop-filter:blur(4px); padding:4px 12px; border-radius:999px; font-size:.72rem; font-weight:600; }
.mapro-badge--photos { position:absolute; bottom:10px; right:10px; background:rgba(0,0,0,.55); color:#fff; padding:3px 9px; border-radius:999px; font-size:.72rem; }

/* ─── Buttons ─────────────────────────────────────────────────────────────── */
.mapro-btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:10px 20px; border-radius:8px; font-weight:700; font-size:.82rem; letter-spacing:.04em; text-transform:uppercase; cursor:pointer; border:none; text-decoration:none; transition:background .18s,transform .1s; }
.mapro-btn:active { transform:scale(.97); }
.mapro-btn--primary { background:var(--mp-navy); color:#fff; }
.mapro-btn--primary:hover { background:var(--mp-navy-dk); color:#fff; }
.mapro-btn--outline { background:transparent; border:2px solid var(--mp-navy); color:var(--mp-navy); }
.mapro-btn--outline:hover { background:var(--mp-navy); color:#fff; }
.mapro-btn--sm { padding:7px 14px; font-size:.75rem; }
.mapro-btn--whatsapp { background:#25d366; color:#fff; padding:12px 24px; font-size:.88rem; }
.mapro-btn--whatsapp:hover { background:#1ebe57; color:#fff; }

/* ─── Filters ────────────────────────────────────────────────────────────── */
.mapro-filters { display:flex; flex-wrap:wrap; gap:12px; align-items:flex-end; margin-bottom:28px; background:#fff; padding:20px; border-radius:var(--mp-radius); box-shadow:var(--mp-shadow); border:1px solid var(--mp-border); }
.mapro-filter-field { display:flex; flex-direction:column; gap:5px; }
.mapro-filter-field label { font-size:.75rem; font-weight:700; color:var(--mp-navy); text-transform:uppercase; letter-spacing:.05em; }
.mapro-filter-field select, .mapro-filter-field input { padding:9px 14px; border:1.5px solid var(--mp-border); border-radius:8px; font-size:.88rem; min-width:130px; color:#1a1a1a; }
.mapro-filter-field select:focus, .mapro-filter-field input:focus { outline:none; border-color:var(--mp-navy); }
@media(max-width:768px){
  .mapro-filters {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 14px;
  }
  .mapro-filter-field select,
  .mapro-filter-field input { min-width: unset; width: 100%; }
  .mapro-filter-field:last-child { grid-column: 1 / -1; }
}

/* ─── Search form ────────────────────────────────────────────────────────── */
.mapro-search-form { display:flex; flex-wrap:wrap; gap:12px; align-items:flex-end; }
.mapro-search-form--vertical { flex-direction:column; max-width:360px; }
.mapro-field { display:flex; flex-direction:column; gap:5px; flex:1 1 150px; }
.mapro-field label { font-weight:700; font-size:.75rem; color:var(--mp-navy); text-transform:uppercase; letter-spacing:.05em; }
.mapro-field input { padding:10px 14px; border:1.5px solid var(--mp-border); border-radius:8px; font-size:.88rem; }
.mapro-field input:focus { outline:none; border-color:var(--mp-navy); }

/* ─── Alerts / Empty ─────────────────────────────────────────────────────── */
.mapro-alert { padding:12px 16px; border-radius:8px; margin:12px 0; font-size:.88rem; }
.mapro-alert--error { background:#fee2e2; color:#991b1b; }
.mapro-empty { text-align:center; padding:56px 24px; color:var(--mp-gray); font-size:1rem; grid-column:1/-1; }
.mapro-empty--error { color:var(--mp-error); }

/* ─── Skeleton ───────────────────────────────────────────────────────────── */
.mapro-skel { background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%); background-size:200%; animation:mp-shimmer 1.4s infinite; border-radius:6px; }
.mapro-card--skeleton .mapro-card__img { aspect-ratio:16/10; }
.mapro-skel--line { height:14px; margin:10px 18px; }
.mapro-skel--short { width:55%; }
@keyframes mp-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ─── Spinner ────────────────────────────────────────────────────────────── */
.mapro-spinner-wrap { display:flex; justify-content:center; padding:48px; }
.mapro-spinner { width:38px; height:38px; border:3px solid var(--mp-border); border-top-color:var(--mp-navy); border-radius:50%; animation:mp-spin .7s linear infinite; }
@keyframes mp-spin { to{transform:rotate(360deg)} }

/* ─── Modal ──────────────────────────────────────────────────────────────── */
.mapro-modal { display:none; }
.mapro-modal.is-open { display:flex; position:fixed; inset:0; z-index:99999; align-items:center; justify-content:center; }
.mapro-modal__overlay { position:absolute; inset:0; background:rgba(10,20,50,.72); backdrop-filter:blur(4px); }
.mapro-modal__box { position:relative; z-index:1; background:#fff; border-radius:16px; width:min(960px,95vw); max-height:92vh; overflow-y:auto; box-shadow:0 24px 80px rgba(0,0,0,.3); }
@media(max-width:768px){ .mapro-modal__box { width:100vw; max-height:100vh; border-radius:0; position:fixed; inset:0; } }
.mapro-modal__close { position:sticky; top:12px; float:right; margin:12px 12px 0 0; background:var(--mp-gray-lt); border:none; border-radius:50%; width:36px; height:36px; font-size:1rem; cursor:pointer; color:#374151; z-index:2; line-height:1; transition:background .15s; }
.mapro-modal__close:hover { background:var(--mp-border); }
.mapro-modal__body { padding:0 28px 32px; }
@media(max-width:768px){ .mapro-modal__body { padding:0 16px 24px; } }

/* ─── Detail Gallery ─────────────────────────────────────────────────────── */
.mapro-detail__gallery-wrap { margin:0 -28px; }
.mapro-detail__hero-img { width:100%; max-height:420px; object-fit:cover; display:block; }
.mapro-thumbs { display:flex; gap:4px; overflow-x:auto; padding:4px 0; background:#f8f8f8; }
.mapro-thumb { position:relative; flex-shrink:0; width:100px; height:70px; cursor:pointer; overflow:hidden; }
.mapro-thumb img { width:100%; height:100%; object-fit:cover; transition:opacity .2s; }
.mapro-thumb:hover img { opacity:.8; }
.mapro-thumb__more { position:absolute; inset:0; background:rgba(0,0,0,.55); color:#fff; display:flex; align-items:center; justify-content:center; font-size:.9rem; font-weight:700; }
@media(max-width:768px){ .mapro-detail__gallery-wrap { margin:0 -16px; } .mapro-detail__hero-img { max-height:240px; } }

/* ─── Detail Content ─────────────────────────────────────────────────────── */
.mapro-detail__content { padding-top:22px; }
.mapro-detail__header { display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-bottom:20px; }
.mapro-detail__header h2 { margin:0 0 6px; font-size:1.4rem; color:var(--mp-navy); line-height:1.25; }
.mapro-detail__location { color:var(--mp-gray); font-size:.85rem; margin:0 0 8px; }
.mapro-detail__resort { display:inline-block; background:var(--mp-gold-lt); color:#7a5c10; padding:3px 12px; border-radius:999px; font-size:.75rem; font-weight:700; }
.mapro-detail__price { text-align:right; white-space:nowrap; flex-shrink:0; }
.mapro-detail__price span { display:block; font-size:1.5rem; font-weight:800; color:var(--mp-navy); }
.mapro-detail__price small { color:var(--mp-gray); font-size:.75rem; }

.mapro-detail__specs { display:flex; gap:0; margin:0 0 18px; border:1.5px solid var(--mp-border); border-radius:10px; overflow:hidden; }
.mapro-spec { flex:1; text-align:center; padding:14px 8px; border-right:1px solid var(--mp-border); }
.mapro-spec:last-child { border-right:none; }
.mapro-spec strong { display:block; font-size:1.5rem; font-weight:800; color:var(--mp-navy); }
.mapro-spec span { font-size:.68rem; color:var(--mp-gray); text-transform:uppercase; letter-spacing:.05em; }

.mapro-detail__times { font-size:.83rem; color:#374151; background:var(--mp-gray-lt); padding:10px 14px; border-radius:8px; margin-bottom:20px; }

.mapro-detail__amenities { margin-bottom:22px; }
.mapro-detail__amenities h4 { margin:0 0 10px; font-size:.88rem; color:var(--mp-navy); text-transform:uppercase; letter-spacing:.06em; }
.mapro-amenities-grid { display:flex; flex-wrap:wrap; gap:8px; }
.mapro-amenities-grid span { font-size:.8rem; background:#eef2ff; color:var(--mp-navy); padding:5px 12px; border-radius:999px; border:1px solid #c7d2fe; }

.mapro-detail__availability { margin-bottom:24px; }
.mapro-detail__availability h4 { margin:0 0 12px; font-size:.88rem; color:var(--mp-navy); text-transform:uppercase; letter-spacing:.06em; }

.mapro-detail__desc { margin-bottom:22px; }
.mapro-detail__desc h4 { margin:0 0 10px; font-size:.88rem; color:var(--mp-navy); text-transform:uppercase; letter-spacing:.06em; }
.mapro-desc-short, .mapro-desc-full { font-size:.86rem; color:#374151; line-height:1.75; }
.mapro-desc-full { max-height:300px; overflow-y:auto; padding-right:4px; }
.mapro-read-more { background:none; border:none; color:var(--mp-navy); cursor:pointer; font-size:.83rem; font-weight:600; padding:4px 0; text-decoration:underline; }

.mapro-detail__actions { display:flex; gap:12px; flex-wrap:wrap; padding-top:20px; border-top:1.5px solid var(--mp-border); }

@media(max-width:768px){ .mapro-detail__header { flex-direction:column; } .mapro-detail__price { text-align:left; } }

/* ─── Calendário com preços ──────────────────────────────────────────────── */
.mapro-calendar { display:flex; flex-direction:column; gap:12px; }
.mapro-cal-months { display:flex; gap:20px; flex-wrap:wrap; }
.mapro-cal-month { flex:1 1 240px; }
.mapro-cal-month-title { font-weight:700; text-align:center; margin-bottom:8px; color:var(--mp-navy); font-size:.88rem; }
.mapro-cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.mapro-cal-day-name { text-align:center; font-size:.65rem; font-weight:700; color:var(--mp-gray); padding:4px 0; text-transform:uppercase; }
.mapro-cal-day { text-align:center; border-radius:6px; padding:3px 2px; min-height:38px; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.mapro-cal-num { font-size:.75rem; line-height:1; }
.mapro-cal-rate { font-size:.6rem; color:var(--mp-success); font-weight:700; line-height:1; margin-top:2px; }
.mapro-cal-day--empty { background:transparent; }
.mapro-cal-day--past { color:#d1d5db; }
.mapro-cal-day--free { background:#dcfce7; cursor:pointer; }
.mapro-cal-day--free .mapro-cal-num { color:#166534; font-weight:600; }
.mapro-cal-day--blocked { background:#fee2e2; }
.mapro-cal-day--blocked .mapro-cal-num { color:#991b1b; text-decoration:line-through; }
.mapro-cal-legend { display:flex; align-items:center; gap:8px; font-size:.78rem; color:var(--mp-gray); margin-bottom:14px; flex-wrap:wrap; }
.mapro-cal-dot { width:12px; height:12px; border-radius:50%; display:inline-block; }
.mapro-cal-dot--free { background:#dcfce7; border:1.5px solid #16a34a; }
.mapro-cal-dot--blocked { background:#fee2e2; border:1.5px solid #dc2626; }
.mapro-cal-loading { display:flex; justify-content:center; padding:20px; }
.mapro-cal-error { color:var(--mp-gray); font-size:.83rem; }

/* ─── Lightbox ───────────────────────────────────────────────────────────── */
.mapro-lightbox { display:none; }
.mapro-lightbox.is-open { display:flex; position:fixed; inset:0; z-index:999999; align-items:center; justify-content:center; }
.mapro-lb__overlay { position:absolute; inset:0; background:rgba(0,0,0,.92); }
.mapro-lb__content { position:relative; z-index:1; display:flex; align-items:center; gap:12px; max-width:95vw; max-height:90vh; }
.mapro-lb__img { max-width:85vw; max-height:85vh; object-fit:contain; border-radius:8px; }
.mapro-lb__close { position:fixed; top:16px; right:20px; background:rgba(255,255,255,.15); border:none; color:#fff; font-size:1.4rem; width:40px; height:40px; border-radius:50%; cursor:pointer; }
.mapro-lb__prev, .mapro-lb__next { background:rgba(255,255,255,.15); border:none; color:#fff; font-size:2rem; width:44px; height:44px; border-radius:50%; cursor:pointer; flex-shrink:0; transition:background .15s; }
.mapro-lb__prev:hover, .mapro-lb__next:hover { background:rgba(255,255,255,.3); }
.mapro-lb__counter { position:fixed; bottom:20px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.7); font-size:.85rem; }

/* ─── Datas selecionadas no calendário ───────────────────────────────────── */
.mapro-cal-day--selected { background:#bfdbfe !important; }
.mapro-cal-day--selected .mapro-cal-num { color:#1e40af !important; font-weight:700; }

/* ─── Barra de datas selecionadas no modal ───────────────────────────────── */
.mapro-detail__dates-bar {
  background:#eff6ff; border:1.5px solid #bfdbfe; border-radius:8px;
  padding:10px 14px; margin-bottom:16px; font-size:.85rem; color:#1e40af;
}
.mapro-detail__dates-bar strong { color:#1e3a8a; }

/* ─── Interactive Calendar ───────────────────────────────────────────────── */
.mapro-cal-hint {
  font-size:.8rem; color:var(--mp-gray); margin-bottom:10px; font-style:italic;
}
.mapro-cal-selection {
  background:#eff6ff; border:1.5px solid #bfdbfe; border-radius:8px;
  padding:10px 14px; margin-bottom:14px; font-size:.85rem; color:#1e40af;
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
}
.mapro-cal-selection--hint {
  background:var(--mp-gray-lt); border-color:var(--mp-border); color:var(--mp-gray); font-style:italic;
}
.mapro-cal-selection strong { color:#1e3a8a; }
.mapro-cal-clear {
  background:none; border:none; color:#1e40af; cursor:pointer;
  font-size:.9rem; margin-left:auto; padding:2px 6px; border-radius:4px;
}
.mapro-cal-clear:hover { background:#dbeafe; }

/* Selected days */
.mapro-cal-day--selected {
  background:#bfdbfe !important;
}
.mapro-cal-day--selected .mapro-cal-num { color:#1e40af !important; font-weight:700; }
.mapro-cal-day--checkin {
  background:var(--mp-navy) !important; border-radius:6px;
}
.mapro-cal-day--checkin .mapro-cal-num { color:#fff !important; font-weight:800; }
.mapro-cal-day--checkin .mapro-cal-rate { color:rgba(255,255,255,.8) !important; }

/* Hover on free days */
.mapro-cal-day--free:hover {
  background:#86efac !important; transform:scale(1.05);
}

/* ─── Booking Form ───────────────────────────────────────────────────────── */
.mapro-booking-wrap {
  margin-bottom: 24px;
}
.mapro-booking-form {
  background: #f8faff;
  border: 1.5px solid #bfdbfe;
  border-radius: 12px;
  padding: 20px;
}
.mapro-booking-summary {
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--mp-border);
}
.mapro-booking-summary h4 {
  margin: 0 0 8px;
  font-size: .88rem;
  color: var(--mp-navy);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.mapro-booking-dates { font-size: .85rem; color: #374151; margin-bottom: 4px; }
.mapro-booking-total { font-size: .9rem; color: var(--mp-navy); }
.mapro-booking-total strong { font-size: 1.1rem; }

/* ─── Quote Breakdown ────────────────────────────────────────────────────── */
.mapro-quote-breakdown {
  background: #f8faff;
  border: 1.5px solid #e5eaf5;
  border-radius: 10px;
  padding: 14px 18px;
  margin: 16px 0;
}
.mapro-breakdown-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5px 0;
  font-size: .88rem;
  color: #444;
  border-bottom: 1px solid #eef0f6;
}
.mapro-breakdown-row:last-child { border-bottom: none; }
.mapro-breakdown-row--discount { color: #16a34a; }
.mapro-breakdown-row--total {
  font-weight: 700;
  font-size: .95rem;
  color: var(--mp-navy);
  margin-top: 4px;
  padding-top: 8px;
  border-top: 2px solid var(--mp-navy);
  border-bottom: none;
}

/* ─── Coupon ─────────────────────────────────────────────────────────────── */
.mapro-coupon-wrap {
  margin-bottom: 16px;
}
.mapro-coupon-wrap .mapro-btn--outline {
  padding: 8px 16px;
  font-size: .85rem;
}

.mapro-form-row {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.mapro-form-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1 1 140px;
}
.mapro-form-field label {
  font-size: .75rem;
  font-weight: 700;
  color: var(--mp-navy);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.mapro-form-field input {
  padding: 9px 12px;
  border: 1.5px solid var(--mp-border);
  border-radius: 8px;
  font-size: .88rem;
  color: #1a1a1a;
  outline: none;
  transition: border-color .15s;
}
.mapro-form-field input:focus { border-color: var(--mp-navy); }

.mapro-booking-actions { margin-top: 16px; }
.mapro-booking-msg {
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: .85rem;
}
.mapro-booking-msg--success { background: #dcfce7; color: #166534; }
.mapro-booking-msg--error   { background: #fee2e2; color: #991b1b; }

/* ─── Full Booking Form ──────────────────────────────────────────────────── */
.mapro-form-section-title {
  font-size: .8rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--mp-navy);
  margin: 20px 0 10px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--mp-gold);
}
.mapro-form-field select,
.mapro-form-field textarea {
  padding: 9px 12px;
  border: 1.5px solid var(--mp-border);
  border-radius: 8px;
  font-size: .88rem;
  color: #1a1a1a;
  outline: none;
  transition: border-color .15s;
  width: 100%;
  background: #fff;
}
.mapro-form-field select:focus,
.mapro-form-field textarea:focus { border-color: var(--mp-navy); }

/* ─── Calendar Navigation ────────────────────────────────────────────────── */
.mapro-cal-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-bottom: 4px;
}
.mapro-cal-prev,
.mapro-cal-next {
  background: var(--mp-navy);
  color: var(--mp-gold);
  border: none;
  border-radius: 6px;
  padding: 6px 16px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .15s;
  flex-shrink: 0;
}
.mapro-cal-prev:hover,
.mapro-cal-next:hover { opacity: .8; }

/* ─── Share Toast ────────────────────────────────────────────────────────── */
.mapro-share-toast {
  background: var(--mp-navy);
  color: #fff;
  text-align: center;
  padding: 10px 16px;
  border-radius: 8px;
  font-size: .88rem;
  margin-top: 8px;
  animation: fadeIn .2s ease;
}
@keyframes fadeIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }
