/* =========================
   index.css — Home page
   Cozy warm palette (browns/tans), airy layout + VRBO-style layout helpers
   ========================= */

/* Palette tokens (safe defaults) */
:root{
  --page-bg: #faf9f7;
  --text:    #3e2e23;
  --muted:   #6b5646;
  --card:    #ffffff;
  --line:    #e6d5c3;
  --tan:     #d8a75f;
  --brown:   #5a3e2b;
  --blue:    #2f6da8;
  --blue-2:  #4a86c5;
  --chip:    #f6efe7;
  --shadow:  0 10px 25px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);
}

/* Base */
body {
  margin: 0;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  background: var(--page-bg);
  color: var(--text);
}

a { text-decoration: none; color: var(--blue); }
a:hover { color: var(--blue-2); }

/* Buttons (page-level defaults; navbar has its own CSS) */
.btn-primary {
  background: #fff;
  color: var(--brown);
  padding: 10px 16px;
  border-radius: 8px;
  border: 2px solid var(--tan);
  font-weight: 700;
  display: inline-block;
  transition: background .2s ease, color .2s ease, border-color .2s ease, transform .06s ease;
}
.btn-primary:hover { background: var(--tan); color: #fff; transform: translateY(-1px); }

/* -------------------------
   HERO (no overlap with content)
   ------------------------- */
.hero {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 60vh;
  padding: 40px 20px;
  overflow: hidden;
}
.hero .hero-img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
  transform: scale(1.02);
  filter: contrast(1.03) saturate(1.02) brightness(1.0);
}
.hero .hero-text {
  position: relative;
  z-index: 1;
  text-align: center;
  background: rgba(255, 255, 255, 0.92);
  padding: 20px;
  border-radius: 10px;
  max-width: 720px;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
  border: 1px solid var(--line);
  margin: 0 12px;
}
.hero .hero-text h1 {
  font-size: 2.3rem;
  margin: 0 0 10px;
  color: var(--brown);
}
.hero .hero-text p {
  font-size: 1.1rem;
  margin: 0 0 15px;
  color: var(--text);
}

/* -------------------------
   VRBO-style layout helpers already used by your page
   ------------------------- */
.listing-wrap{max-width:1200px;margin:0 auto;padding:18px 16px 28px;}
.listing-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:6px 0 12px;}
.listing-title h1{margin:0;color:var(--brown);font-size:clamp(1.5rem,2.6vw,2rem);}
.badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.badge-chip{background:var(--chip);border:1px solid var(--line);color:var(--text);padding:6px 10px;border-radius:999px;font-weight:600;font-size:.92rem}
.badge-chip.subtle{color:var(--muted)}

/* Photo grid header */
.photo-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-auto-rows:180px;gap:8px;border-radius:12px;overflow:hidden}
.photo-grid a,.photo-grid .ph{display:block;width:100%;height:100%;position:relative;overflow:hidden;background:#eae2d8;border:1px solid var(--line)}
.photo-grid img{width:100%;height:100%;object-fit:cover;display:block}
.ph span{position:absolute;left:12px;bottom:10px;font-size:.9rem;color:#2b2b2b;opacity:.7;background:rgba(255,255,255,.6);padding:4px 8px;border-radius:8px;border:1px solid rgba(0,0,0,.05)}
.pg-big{grid-row:1/3}
.pg-span2{grid-column:2/4}

/* Two-column main area */
.listing-main{display:grid;grid-template-columns:1.8fr .95fr;gap:22px;margin:18px 0}
.card{background:var(--card);border-radius:10px;border:1px solid var(--line);box-shadow:0 4px 12px rgba(0,0,0,0.06);padding:16px}
.card h2{margin:0 0 10px;color:var(--brown);font-size:1.35rem}
.card h3{margin:12px 0 8px;color:var(--text);font-size:1.1rem}
.desc p{margin:.45rem 0}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kv div{background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px}
.list{margin:0;padding-left:18px}
.list li{margin:.25rem 0 .45rem}
.pills{margin-top:2px}
.pill{display:inline-block;margin:6px 6px 0 0;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--text)}

/* -------------------------
   BOOKING WIDGET (modernized, HTML unchanged)
   ------------------------- */
.booking {
  max-width: 800px;
  margin: 28px auto 40px;
  padding: 22px;
  background: var(--card);
  border-radius: 12px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.booking h2 {
  margin: 0 0 14px;
  color: var(--brown);
  font-size: 1.6rem;
}

/* Grid the three fields without changing your markup */
.booking-form {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
}
.booking-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: var(--brown);
  font-weight: 700;
  font-size: 0.98rem;
}

/* Inputs */
.booking-form input {
  padding: 12px 12px;
  border-radius: 10px;
  border: 1px solid #c8b8a6;
  background: #fff;
  color: var(--text);
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8), 0 1px 2px rgba(0,0,0,.02);
  transition: border-color .15s ease, box-shadow .15s ease;
  font-size: 1rem;
}
.booking-form input:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(47,109,168,.12);
}

/* Submit button */
.booking .btn-primary {
  height: 46px;
  border-radius: 12px;
  font-size: 1rem;
  width: 100%;
}

/* Helper text */
.muted { display:block; margin-top:10px; color: var(--muted); font-size:.95rem; }

/* -------------------------
   Gallery (your lightbox)
   ------------------------- */
.gallery .grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.gallery .thumb{border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.gallery img{display:block;width:100%;height:160px;object-fit:cover}
.ph.small{height:160px;display:grid;place-items:center}

/* Map placeholder */
.map-ph{height:320px;border:1px solid var(--line);border-radius:12px;display:grid;place-items:center;background:#f3ede4}

/* -------------------------
   Flatpickr calendar (homepage datepicker) — clear disabled days
   ------------------------- */
.flatpickr-calendar{
  border-radius:12px !important;
  border:1px solid var(--line) !important;
  box-shadow: var(--shadow) !important;
}
.flatpickr-months .flatpickr-month{font-size:1.05rem}
.flatpickr-day{font-size:.98rem;line-height:2.2rem}
.flatpickr-day.today{border-color:var(--tan)}
.flatpickr-day.inRange,
.flatpickr-day.startRange,
.flatpickr-day.endRange{
  background: rgba(47,109,168,.10);
  border-color: rgba(47,109,168,.25);
}
.flatpickr-day.disabled,
.flatpickr-day.disabled:hover{
  color:#a8a29a !important;
  background:#f2efe9 !important;
  cursor:not-allowed;
}

/* -------------------------
   Responsive tweaks
   ------------------------- */
@media (max-width: 980px){
  .listing-main{grid-template-columns:1fr;gap:16px}
  .gallery .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 720px){
  .photo-grid{grid-template-columns:1fr 1fr;grid-auto-rows:140px}
  .pg-big{grid-row:auto}
  .pg-span2{grid-column:auto}
  .booking-form{grid-template-columns:1fr 1fr}
  .booking-form label:nth-child(3){grid-column:1 / -1}
}
@media (max-width: 600px){
  .hero { min-height: 48vh; padding: 20px 14px; }
  .hero .hero-text { padding: 16px; }
  .hero .hero-text h1 { font-size: 1.9rem; }
  .hero .hero-text p  { font-size: 1rem; }
  .gallery .grid{grid-template-columns:1fr}
  .booking-form{grid-template-columns:1fr;gap:10px}
}

/* =========================
   (APPENDED) Modal & info chip polish
   ========================= */
.badge-chip.info-chip{
  background:#fff;
  border-color: var(--line);
  color: var(--text);
  transition: transform .06s ease;
  cursor: pointer;
}
.badge-chip.info-chip:hover{
  transform: translateY(-1px);
}
.info-modal{
  /* kept minimal; detailed inline styles live in index.php for portability */
}

/* === appended: small map card helpers === */
.ep-map-card{margin-top:12px}
.ep-map-card__thumb{height:220px;border:1px solid var(--line);border-radius:10px;overflow:hidden;box-shadow:var(--shadow);background:#fff}

/* === appended: small cards below booking === */
#udot-card .ep-map-card__thumb{height:220px}
#tickets-card .ep-map-card__thumb{height:140px}

/* --- Map card polish --- */
.ep-map-card{transition:transform .08s ease, box-shadow .15s ease}
.ep-map-card:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(0,0,0,.10),0 3px 8px rgba(0,0,0,.06)}
