/* Theme & Variables */
:root{
  --bg: #f6efe7; /* warm parchment */
  --card: #fffdfb;
  --muted: #6b5b4b;
  --text: #2b2b2b;
  --brand: #b85c2a; /* terracotta */
  --accent: #f2c6a0; /* sand */
  --danger: #b33a3a;
  --radius: 10px;
  --shadow-sm: 0 8px 22px rgba(43,33,26,.06);
  --shadow-md: 0 14px 36px rgba(43,33,26,.09);
  --gap: 1.25rem;
  --transition: 220ms cubic-bezier(.2,.9,.2,1);
} 

/* Reset */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
/* Fundo estilizado: sobreposição de gradientes quentes e animação suave */
body{font-family:Inter, 'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, Arial;line-height:1.6;color:var(--text);-webkit-font-smoothing:antialiased;position:relative;overflow-x:hidden;background-color:var(--bg);background-image:
  radial-gradient(1200px 600px at 8% 12%, rgba(184,92,42,0.06), transparent 12%),
  radial-gradient(900px 420px at 92% 88%, rgba(242,198,160,0.04), transparent 12%),
  linear-gradient(180deg, rgba(255,255,255,0.7), rgba(255,255,255,0.25));background-attachment:fixed;background-size:120% 120%, 120% 120%, cover;animation:bgFloat 30s linear infinite}

/* Textura com SVG pattern sutil (más nítido) */
body::before{
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  /* SVG inline pattern com ícones de apartamento (mais definidos) */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='192' height='192' viewBox='0 0 192 192'><defs><pattern id='apt' patternUnits='userSpaceOnUse' width='48' height='48'><rect width='48' height='48' fill='transparent'/><rect x='10' y='12' width='28' height='28' rx='3' fill='%23b85c2a' fill-opacity='0.12'/><rect x='14' y='16' width='8' height='8' fill='%23b85c2a' fill-opacity='0.18'/><rect x='26' y='16' width='8' height='8' fill='%23b85c2a' fill-opacity='0.18'/><rect x='14' y='28' width='8' height='8' fill='%23b85c2a' fill-opacity='0.18'/><rect x='26' y='28' width='8' height='8' fill='%23b85c2a' fill-opacity='0.18'/></pattern></defs><rect width='192' height='192' fill='url(%23apt)'/></svg>");
  background-repeat: repeat;
  opacity: .9;
  mix-blend-mode: normal;
  z-index: 0;
  transform: translateZ(0);
}

/* Skyline mais nítido na base */
body::after{
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  height: 16vh;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 200'><g fill='%23000000' fill-opacity='0.16'><rect x='0' y='80' width='120' height='120'/><rect x='140' y='40' width='80' height='160'/><rect x='240' y='100' width='60' height='100'/><rect x='320' y='20' width='120' height='180'/><rect x='460' y='60' width='90' height='140'/><rect x='580' y='30' width='60' height='170'/><rect x='680' y='70' width='70' height='130'/><rect x='770' y='50' width='120' height='150'/><rect x='940' y='90' width='60' height='110'/><rect x='1010' y='30' width='120' height='170'/></g></svg>");
  background-position: center bottom;
  background-repeat: no-repeat;
  opacity: .18;
  z-index: 0;
}

/* Garante que o conteúdo fique acima da camada decorativa */
.container{max-width:1100px;margin:0 auto;padding:1.25rem;position:relative;z-index:1}

@keyframes bgFloat{0%{background-position:0% 0%,100% 100%,50% 50%}50%{background-position:4% 2%,96% 98%,50% 48%}100%{background-position:0% 0%,100% 100%,50% 50%}}

/* Header */
.site-header{background:transparent;position:sticky;top:0;z-index:40;backdrop-filter:saturate(120%) blur(6px);padding:0.5rem 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}
.logo{font-size:1.25rem;color:var(--text);font-weight:600}
.logo span{color:var(--brand)}
.nav{display:flex;gap:1rem;align-items:center}
.nav a{padding:.5rem .75rem;border-radius:8px;text-decoration:none;color:var(--text);transition:background var(--transition), color var(--transition)}
.nav a:hover{background:rgba(10,116,218,0.08);color:var(--brand)}
.nav-toggle{display:none;background:transparent;border:0;font-size:1.25rem;padding:.5rem;border-radius:8px;cursor:pointer}

/* Hero */
.hero{display:block;padding:3rem 0}
.hero-inner{display:flex;gap:2rem;align-items:center}
.hero-text h2{font-size:2rem;margin-bottom:.5rem;color:var(--text);line-height:1.15}
.hero-text p{margin-bottom:1rem;color:var(--muted)}
.btn{display:inline-block;background:var(--brand);color:#fff;padding:.7rem 1.1rem;border-radius:8px;text-decoration:none;box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition)}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.hero-image{position:relative}
.hero-image img{width:420px;height:320px;object-fit:cover;border-radius:12px;box-shadow:var(--shadow-sm)}
#beach-message{display:none;position:absolute;top:10px;right:10px;background:var(--card);padding:10px;border:1px solid var(--muted);border-radius:5px;font-size:0.9rem;z-index:10}

/* Features */
.features{padding:2rem 0}
.cards{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;list-style:none}
.card{background:var(--card);padding:1.2rem;border-radius:12px;box-shadow:var(--shadow-sm);min-width:140px;text-align:center;transition:transform var(--transition), box-shadow var(--transition)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}

/* Gallery */
.gallery{padding:2rem 0}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.grid img{width:100%;height:180px;object-fit:cover;border-radius:10px;cursor:pointer;transition:transform var(--transition), box-shadow var(--transition)}
.grid img:hover{transform:scale(1.04);box-shadow:var(--shadow-sm)}
/* Placeholder/background for local thumbnails while developing */
.grid img.thumb{background:#f4f4f6}

/* Map */
.map-embed iframe{width:100%;height:300px;border:0;border-radius:12px;box-shadow:var(--shadow-sm)}

/* Contact */
.contact{padding:2rem 0}
.contact form{display:grid;gap:.75rem;max-width:640px}
.contact input,.contact textarea{width:100%;padding:.75rem;border:1px solid #e6edf6;border-radius:10px;background:linear-gradient(180deg,#fff,#fbfdff)}
.contact input:focus,.contact textarea:focus{outline:2px solid rgba(10,116,218,.12);border-color:var(--brand)}

/* Booking */
.booking{padding:2rem;background:linear-gradient(180deg,#fbfdff,#ffffff);border-radius:14px;margin-bottom:2rem;border:1px solid #eef6ff;box-shadow:var(--shadow-sm)}

/* Calendar styles */
.booking-calendar{max-width:720px;margin-top:1rem;padding:1rem;border-radius:10px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--shadow-sm);border:1px solid #f1f6fb}
.calendar-note{margin-top:.5rem;color:var(--muted);font-size:.95rem}

/* Flatpickr visual refresh */
.flatpickr-calendar{border-radius:12px;border:0;box-shadow:0 18px 50px rgba(43,33,26,.14);overflow:visible}
.flatpickr-calendar:before{content:'';position:absolute;left:50%;transform:translateX(-50%);top:-12px;width:56px;height:6px;background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:6px;opacity:.12}
.flatpickr-months{background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,.6));padding:.6rem 0;border-bottom:1px solid rgba(15,35,60,.04);border-top-left-radius:12px;border-top-right-radius:12px}
.flatpickr-current-month{display:flex;align-items:center;justify-content:space-between;padding:.2rem 0 .4rem .5rem}
.flatpickr-current-month .flatpickr-month{font-weight:700;color:var(--text);font-size:1rem}
.flatpickr-current-month .flatpickr-year{color:var(--muted);font-weight:600;margin-left:.6rem}
.flatpickr-prev-month,.flatpickr-next-month{background:transparent;border:0;color:var(--brand);font-size:1.15rem;padding:.4rem .6rem;border-radius:8px;cursor:pointer}
.flatpickr-prev-month:hover,.flatpickr-next-month:hover{background:rgba(10,116,218,0.06)}
.flatpickr-weekdays{background:transparent;padding:.4rem .6rem 0;margin-bottom:6px}
.flatpickr-weekday{color:var(--muted);font-weight:700;font-size:.85rem}
.flatpickr-days{padding:.2rem .6rem}
.flatpickr-day{width:42px;height:42px;line-height:42px;border-radius:8px;margin:4px;display:inline-block;text-align:center;color:var(--text);transition:transform var(--transition), background var(--transition), color var(--transition)}
.flatpickr-day:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);background:linear-gradient(180deg,rgba(10,116,218,.06),rgba(10,116,218,.03))}
.flatpickr-day.today{box-shadow:inset 0 -4px 0 rgba(10,116,218,.06);border-radius:8px}
.flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange{background:linear-gradient(180deg,var(--brand),var(--accent));color:#fff}
.flatpickr-day.inRange{background:linear-gradient(90deg,rgba(184,92,42,0.12),rgba(242,198,160,0.06));color:var(--text)}
.flatpickr-day.disabled, .flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay{opacity:.45;color:var(--muted);cursor:not-allowed}
.flatpickr-week{display:flex;justify-content:center}

/* Make inline calendar responsive */
@media (max-width:900px){
  .flatpickr-day{width:44px;height:44px;line-height:44px;margin:3px}
}
@media (max-width:520px){
  .flatpickr-day{width:36px;height:36px;line-height:36px;margin:2px;border-radius:6px}
  .flatpickr-prev-month,.flatpickr-next-month{font-size:1rem}
}

/* extra guest checkbox and price */
.extra-guest-info{display:block;margin-top:.75rem;color:var(--text);font-size:1rem;background:linear-gradient(90deg,rgba(184,92,42,0.04),rgba(242,198,160,0.02));padding:.6rem .8rem;border-radius:10px;border-left:4px solid var(--brand);font-weight:600}
.price-summary{margin-top:.6rem;font-weight:700;color:var(--text)}

/* Make flatpickr fit responsively */
.flatpickr-calendar{max-width:100%}
.flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay{opacity:.5} 
.booking h3{margin-bottom:.25rem}
.booking p{color:var(--muted);margin-bottom:1rem}
.booking-form label{display:block;margin-bottom:.6rem}
.booking-form input[type="date"], .booking-form input[type="text"], .booking-form input[type="email"], .booking-form input[type="tel"], .booking-form select, .booking-form textarea{width:100%;padding:.6rem;border:1px solid #e6edf6;border-radius:10px;background:#fff}
.booking-actions{display:flex;gap:.5rem;align-items:center;margin-top:.5rem}
.availability{margin-top:.75rem;font-weight:600}
.availability.available{color:var(--brand)}
.availability.unavailable{color:var(--danger)}
.booked-list{margin-top:1rem;font-size:.95rem;color:var(--muted)}

/* Modal */
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(6,8,15,.55);opacity:0;pointer-events:none;transition:opacity .18s;z-index:10000}
.modal[aria-hidden="false"]{opacity:1;pointer-events:auto}
.modal img{max-width:92%;max-height:86%;border-radius:12px;z-index:10000}
.modal-close{position:absolute;top:20px;right:20px;background:#fff;border-radius:50%;width:40px;height:40px;border:0;cursor:pointer;box-shadow:var(--shadow-sm);z-index:10001}

/* Mensagem de erro dentro do modal (fallback quando imagem não carrega) */
/* Legenda do modal: nome do cômodo */
.modal-caption{position:absolute;left:50%;transform:translateX(-50%);bottom:6vh;color:#fff;background:rgba(0,0,0,0.5);padding:.5rem .9rem;border-radius:8px;font-weight:600;z-index:10002;max-width:88%;text-align:center;font-size:1rem}

/* Setas visuais no modal */
.modal-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.5);color:#fff;border:0;width:48px;height:64px;border-radius:8px;font-size:32px;line-height:64px;text-align:center;cursor:pointer;z-index:10003;display:none}
.modal-nav:active{transform:translateY(-50%) scale(.98)}
.modal-prev{left:18px}
.modal-next{right:18px}
.modal[aria-hidden="false"] .modal-nav{display:block}

@media (max-width:600px){
  .modal-nav{width:42px;height:54px;font-size:28px;line-height:54px}
  .modal-prev{left:8px}
  .modal-next{right:8px}
}

/* Footer */
.site-footer{padding:1.25rem 0;background:linear-gradient(180deg,#ffffff,#fbfdff);border-top:1px solid #f1f6fb}

/* Utility */
.btn.secondary{background:#eef6ff;color:var(--brand)}

/* Responsivo */
@media (max-width:900px){
  .hero-inner{flex-direction:column}
  .hero-image img{width:100%;height:260px}
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:700px){
  .nav{position:absolute;right:12px;top:62px;flex-direction:column;background:rgba(255,255,255,.98);padding:.75rem;border-radius:10px;box-shadow:var(--shadow-sm);min-width:160px}
  .nav[aria-hidden="true"]{display:none}
  .nav-toggle{display:inline-flex}
}
@media (max-width:520px){
  .nav a{padding:.5rem .6rem}
  .hero-text h2{font-size:1.3rem}
  .grid img{height:120px}
}

/* Estilos para a seção de reservas */
.booking{
  padding:2rem; background:#f8fbff; border-radius:8px; margin-bottom:2rem; border:1px solid #eef4ff;
}
.booking h3{margin-bottom:.25rem}
.booking p{color:#555;margin-bottom:1rem}
.booking-form label{display:block;margin-bottom:.6rem}
.booking-form input[type="date"], .booking-form input[type="text"], .booking-form input[type="email"], .booking-form input[type="tel"], .booking-form select, .booking-form textarea{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:6px}
.row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}
.booking-actions{display:flex;gap:.5rem;align-items:center;margin-top:.5rem}
.availability{margin-top:.75rem;font-weight:600}
.availability.available{color:#0a7e07}
.availability.unavailable{color:#b33a3a}
.booked-list{margin-top:1rem;font-size:.95rem;color:#444}
.booked-list ul{margin:0.5rem 0 0 1rem}
.btn{display:inline-block;padding:.5rem .9rem;border-radius:6px;background:#0a74da;color:#fff;border:0;cursor:pointer}
.btn.primary{background:#155fd6}
.btn[disabled]{opacity:.6;cursor:not-allowed}
@media (max-width:600px){ .row{grid-template-columns:1fr} }