/* FILE: assets/css/style.css */
/* ---------------------------------------------
   LEONCHIC — Boutique / Elegante / Responsivo
   Paleta: ivório + cinza quente + carvão + dourado
---------------------------------------------- */

/* FONTES */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --ivory:#faf9f7;
  --warm-gray:#e6e3df;
  --charcoal:#1c1c1c;
  --gold:#c9a24d;

  --radius:16px;
  --shadow:0 20px 40px rgba(0,0,0,.06);
  --shadow-soft:0 12px 30px rgba(0,0,0,.06);

  --max:1200px;
  --header-h:72px;
}

/* RESET */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--ivory);
  color:var(--charcoal);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:10px}

/* LAYOUT */
main{padding-top:var(--header-h)}
section{
  padding:clamp(3.5rem,6vw,6rem) 1.25rem;
  max-width:var(--max);
  margin:0 auto;
}
.section-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.75rem,2.6vw,2.25rem);
  margin-bottom:1.25rem;
  letter-spacing:.2px;
}
.muted{color:rgba(28,28,28,.72)}

/* HEADER + NAV */
header{
  position:fixed;top:0;left:0;right:0;
  height:var(--header-h);
  padding:0 1.25rem;
  display:flex;align-items:center;
  background:rgba(250,249,247,.92);
  backdrop-filter:blur(10px);
  z-index:1000;
  transition:box-shadow .25s ease, background .25s ease;
}
header.scrolled{
  box-shadow:0 16px 44px rgba(0,0,0,.08);
  background:rgba(250,249,247,.96);
}
.nav{
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  text-decoration:none;
}
.brand span{
  font-family:'Playfair Display',serif;
  font-size:1.1rem;
  letter-spacing:.2px;
}

/* Desktop links */
.nav-links{
  display:flex;
  align-items:center;
  gap:1.25rem;
  list-style:none;
}
.nav-links a{
  text-decoration:none;
  font-size:.92rem;
  font-weight:450;
  opacity:.92;
}
.nav-links a:hover{color:var(--gold);opacity:1}
.nav-links a[aria-current="page"]{
  color:var(--gold);
  opacity:1;
}

/* Hamburger */
.nav-toggle{
  display:none;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  border-radius:14px;
  padding:.55rem .7rem;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(0,0,0,.05);
}
.nav-toggle svg{width:22px;height:22px;display:block}

/* Mobile drawer */
.mobile-drawer{
  position:fixed;
  top:0; right:-100%;
  width:min(86vw,360px);
  height:100vh;
  background:rgba(250,249,247,.98);
  backdrop-filter:blur(10px);
  box-shadow:-20px 0 60px rgba(0,0,0,.12);
  padding:1.1rem;
  z-index:1200;
  transition:right .25s ease;
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.mobile-drawer.open{right:0}
.drawer-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:.8rem;
  padding-bottom:.75rem;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.drawer-close{
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  border-radius:14px;
  padding:.5rem .65rem;
  cursor:pointer;
}
.drawer-close svg{width:20px;height:20px;display:block}
.drawer-links{list-style:none;display:grid;gap:.5rem;margin-top:.5rem}
.drawer-links a{
  display:flex;
  padding:.8rem .85rem;
  border-radius:14px;
  text-decoration:none;
  background:#fff;
  box-shadow:var(--shadow-soft);
}
.drawer-links a:hover{color:var(--gold)}
.drawer-links a[aria-current="page"]{outline:2px solid rgba(201,162,77,.35)}
.backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.32);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
  z-index:1100;
}
.backdrop.open{
  opacity:1;
  pointer-events:auto;
}

/* HERO */
.hero{
  min-height:clamp(520px,78vh,820px);
  background-size:cover;
  background-position:center;
  border-radius:0 0 var(--radius) var(--radius);
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  position:relative;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(to top,
    rgba(0,0,0,.55),
    rgba(0,0,0,.18),
    rgba(0,0,0,.05));
}
.hero-content{
  position:relative;
  padding:clamp(1.4rem,3.6vw,3.5rem);
  max-width:680px;
  color:#fff;
}
.hero h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.1rem,4.5vw,3.2rem);
  margin-bottom:.8rem;
  letter-spacing:.2px;
}
.hero p{
  font-size:clamp(1rem,1.3vw,1.1rem);
  opacity:.95;
}

/* CARDS */
.cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.5rem;
  margin-top:1.5rem;
}
.card{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 26px 55px rgba(0,0,0,.10);
}
.card-content{padding:1.25rem 1.25rem 1.35rem}
.card h3{
  font-family:'Playfair Display',serif;
  font-size:1.25rem;
  margin-bottom:.35rem;
}
.card p{color:rgba(28,28,28,.72)}

/* BUTTONS */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  margin-top:1.1rem;
  padding:.8rem 1.25rem;
  border-radius:999px;
  background:var(--charcoal);
  color:#fff;
  text-decoration:none;
  font-size:.92rem;
  border:1px solid rgba(0,0,0,.08);
  transition:transform .2s ease, filter .2s ease;
}
.btn:hover{transform:translateY(-1px);filter:brightness(1.02)}
.btn.gold{background:var(--gold); color:#111}
.btn.ghost{
  background:transparent;
  color:var(--charcoal);
  border:1px solid rgba(0,0,0,.18);
}

/* HIGHLIGHTS (ícones + texto) */
.highlights{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.25rem;
  margin-top:1.5rem;
}
.highlight{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.25rem;
  display:flex;
  gap:.85rem;
  align-items:flex-start;
}
.highlight svg{flex:0 0 auto; width:26px; height:26px}
.highlight h3{
  font-family:'Playfair Display',serif;
  font-size:1.15rem;
  margin-bottom:.25rem;
}
.highlight p{color:rgba(28,28,28,.72)}

/* GALLERY */
.gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:1rem;
  margin-top:1.5rem;
}
.gallery img{
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  min-height:160px;
  object-fit:cover;
}

/* FORMS */
form{display:grid;gap:.9rem}
.field{display:grid;gap:.35rem}
label{font-size:.86rem;color:rgba(28,28,28,.85)}
input,textarea,select{
  width:100%;
  padding:.8rem .85rem;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  font:inherit;
}
textarea{min-height:130px;resize:vertical}
.help{font-size:.82rem;color:rgba(28,28,28,.6)}
.error{
  font-size:.82rem;
  color:#9a2b2b;
}
.input-error{
  border-color:rgba(154,43,43,.45);
  background:rgba(154,43,43,.04);
}

/* BOOKING TABS */
.tabs{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  margin-top:1.2rem;
}
.tab-btn{
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  border-radius:999px;
  padding:.65rem .95rem;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(0,0,0,.04);
  font:inherit;
  font-size:.92rem;
}
.tab-btn[aria-selected="true"]{
  border-color:rgba(201,162,77,.55);
  outline:2px solid rgba(201,162,77,.22);
}
.tab-panel{
  display:none;
  margin-top:1.25rem;
}
.tab-panel.active{display:block}

.panel-card{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.25rem;
}

/* CONTACT 2 COLS */
.grid-2{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
}
.info-box{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.25rem;
}
.info-line{padding:.55rem 0;border-bottom:1px solid rgba(0,0,0,.07)}
.info-line:last-child{border-bottom:none}
.kicker{
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(28,28,28,.55);
}

/* CONSOLADO DARK (só nesta página) */
.dark-section{
  background:#101010;
  color:#f5f5f5;
}
.dark-section .section-title{color:#fff}
.dark-section .muted{color:rgba(245,245,245,.72)}
.dark-section .panel-card{background:#141414}
.dark-section input,.dark-section textarea,.dark-section select{
  background:#111;
  color:#f5f5f5;
  border-color:rgba(255,255,255,.14);
}

/* MODAL */
.modal-backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.45);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:2000;
  padding:1.25rem;
}
.modal-backdrop.open{display:flex}
.modal{
  width:min(520px,100%);
  background:#fff;
  border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.22);
  overflow:hidden;
}
.modal-header{
  padding:1rem 1.15rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.modal-header h3{
  font-family:'Playfair Display',serif;
  font-size:1.15rem;
}
.modal-body{padding:1.15rem}
.modal-actions{padding:0 1.15rem 1.15rem}
.modal-close{
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  border-radius:12px;
  padding:.45rem .6rem;
  cursor:pointer;
}

/* RECENT LIST */
.recent-list{
  margin-top:1rem;
  display:grid;
  gap:.65rem;
  list-style:none;
}
.recent-item{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow-soft);
  padding:.85rem .95rem;
}
.badge{
  display:inline-flex;
  padding:.15rem .55rem;
  border-radius:999px;
  background:rgba(201,162,77,.18);
  border:1px solid rgba(201,162,77,.35);
  font-size:.78rem;
  margin-right:.5rem;
}

/* ANIMAÇÕES (IntersectionObserver) */
.fade{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .6s ease, transform .6s ease;
}
.visible{
  opacity:1;
  transform:translateY(0);
}

/* BACK TO TOP */
.back-to-top{
  position:fixed;
  right:18px;
  bottom:18px;
  width:44px;height:44px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  box-shadow:0 16px 40px rgba(0,0,0,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
  z-index:1500;
}
.back-to-top.show{
  opacity:1;
  pointer-events:auto;
  transform:translateY(-2px);
}

/* FOOTER */
footer{
  padding:2.5rem 1.25rem;
  text-align:center;
  font-size:.85rem;
  color:rgba(28,28,28,.55);
}

/* RESPONSIVO */
@media (max-width: 980px){
  .nav-links{display:none}
  .nav-toggle{display:inline-flex}
  .grid-2{grid-template-columns:1fr}
}
@media (min-width: 981px){
  .grid-2{grid-template-columns:1.05fr .95fr}
}
