/* =====================================================================
   style.css — ÚNICA hoja de estilo del proyecto.
   La leen TODAS las páginas (público + admin). Cualquier cambio aquí
   afecta a toda la web. Mobile-first: estilos base = móvil, y se
   amplían con @media (min-width) hacia tablet/escritorio.
   ===================================================================== */

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

:root{
  /* Paleta (extraída del diseño de referencia) */
  --color-bg:        #f3eee3;
  --color-surface:   #ffffff;
  --color-dark:      #221d16;
  --color-brown:     #352c22;
  --color-text:      #2c2620;
  --color-text-soft: #756a5c;
  --color-border:    #e6ddcc;
  --color-accent:    #c8682f;
  --color-accent-dk: #a8552a;
  --color-accent-soft: #f1e2d3;

  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Poppins', Arial, sans-serif;

  --radius-sm: 10px;
  --radius: 16px;
  --radius-lg: 28px;
  --shadow: 0 10px 30px rgba(34,29,22,.08);
  --shadow-lg: 0 20px 50px rgba(34,29,22,.14);

  --container: 1180px;
  --gap: 1rem;

  --space-1: .5rem;
  --space-2: 1rem;
  --space-3: 1.5rem;
  --space-4: 2.5rem;
  --space-5: 4rem;
}

/* ---------- Reset básico ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:var(--font-body);
  background:var(--color-bg);
  color:var(--color-text);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; margin:0 0 var(--space-2); color:var(--color-dark); }
p{ margin:0 0 var(--space-2); color:var(--color-text-soft); }
button{ font-family:inherit; cursor:pointer; }
input,select,textarea{ font-family:inherit; font-size:1rem; }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 1.25rem; }
.section{ padding:var(--space-5) 0; }
.text-center{ text-align:center; }

/* ---------- Tipografía responsive ---------- */
h1{ font-size:clamp(2rem,6vw,3.4rem); line-height:1.1; }
h2{ font-size:clamp(1.6rem,4vw,2.4rem); line-height:1.2; }
h3{ font-size:1.25rem; }
.eyebrow{
  display:inline-flex; align-items:center; gap:.5rem;
  font-size:.75rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--color-accent-dk); font-weight:600; margin-bottom:var(--space-2);
}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.85rem 1.6rem; border-radius:50px; border:none;
  font-weight:500; font-size:.95rem; transition:all .2s ease;
  white-space:nowrap;
}
.btn-accent{ background:var(--color-accent); color:#fff; }
.btn-accent:hover{ background:var(--color-accent-dk); }
.btn-outline{ background:transparent; border:1px solid var(--color-border); color:var(--color-dark); }
.btn-dark{ background:var(--color-dark); color:#fff; }
.btn-block{ width:100%; }
.btn-icon-circle{
  width:34px; height:34px; border-radius:50%; background:var(--color-accent);
  color:#fff; display:inline-flex; align-items:center; justify-content:center;
  font-size:.8rem; flex-shrink:0;
}

/* ---------- Header / navegación ---------- */
.site-header{
  position:relative; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem 0;
}
.logo{ font-family:var(--font-display); font-size:1.4rem; font-weight:700; letter-spacing:.03em; }
.nav-toggle{
  display:flex; align-items:center; justify-content:center;
  width:42px; height:42px; border-radius:50%; border:1px solid var(--color-border);
  background:transparent;
}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:''; display:block; width:18px; height:2px; background:var(--color-dark); position:relative;
}
.main-nav{
  position:fixed; inset:0 0 0 auto; width:78%; max-width:320px;
  background:var(--color-surface); padding:5.5rem 1.5rem 2rem;
  transform:translateX(100%); transition:transform .3s ease; z-index:100;
  box-shadow:var(--shadow-lg);
}
.main-nav.is-open{ transform:translateX(0); }
.main-nav ul{ display:flex; flex-direction:column; gap:1.1rem; }
.nav-overlay{
  position:fixed; inset:0; background:rgba(0,0,0,.4); opacity:0; pointer-events:none;
  transition:opacity .3s ease; z-index:90;
}
.nav-overlay.is-open{ opacity:1; pointer-events:auto; }

@media (min-width:900px){
  .nav-toggle{ display:none; }
  .main-nav{
    position:static; width:auto; max-width:none; transform:none; padding:0;
    box-shadow:none; background:transparent;
  }
  .main-nav ul{ flex-direction:row; gap:2rem; font-size:.95rem; }
}

/* ---------- Hero ---------- */
.hero{
  position:relative; border-radius:0 0 var(--radius-lg) var(--radius-lg);
  overflow:hidden; min-height:520px; display:flex; align-items:flex-end;
  background:#222 center/cover no-repeat;
}
.hero::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(20,16,10,.15),rgba(20,16,10,.75));
}
.hero-content{ position:relative; z-index:2; color:#fff; padding:2rem 1.25rem 2.5rem; width:100%; }
.hero-content h1{ color:#fff; }
.hero-actions{ display:flex; align-items:center; gap:.8rem; margin-top:1.2rem; }
.hero-actions p{ color:#e9e2d6; font-size:.85rem; margin:0; }

.booking-card{
  background:var(--color-surface); border-radius:var(--radius); box-shadow:var(--shadow-lg);
  padding:1.4rem; margin:1.25rem 1.25rem 0; position:relative; z-index:3;
}
.booking-card .field-row{ display:grid; grid-template-columns:1fr 1fr; gap:.8rem; margin-bottom:.8rem; }
.booking-card label{ font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:var(--color-text-soft); display:block; margin-bottom:.3rem; }
.booking-card input,.booking-card select{
  width:100%; border:1px solid var(--color-border); border-radius:var(--radius-sm); padding:.6rem .7rem; background:#fafafa;
}
@media (min-width:900px){
  .hero{ min-height:600px; }
  .booking-card{
    position:absolute; right:3rem; top:50%; transform:translateY(-50%); width:340px; margin:0;
  }
}

/* ---------- Iconos / features ---------- */
.feature-strip{
  background:var(--color-surface); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:1.5rem; display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-top:-2.5rem; position:relative; z-index:5;
}
.feature-item{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:.5rem; }
.feature-item .icon{ color:var(--color-accent); font-size:1.4rem; }
.feature-item span{ font-size:.8rem; color:var(--color-text-soft); }
@media (min-width:900px){
  .feature-strip{ grid-template-columns:repeat(5,1fr); }
}

/* ---------- Tarjetas de habitación ---------- */
.room-grid{ display:grid; grid-template-columns:1fr; gap:1.5rem; }
@media (min-width:700px){ .room-grid{ grid-template-columns:1fr 1fr; } }
@media (min-width:1100px){ .room-grid{ grid-template-columns:repeat(3,1fr); } }

.room-card{ background:var(--color-surface); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.room-card .thumb{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.room-card .thumb img{ width:100%; height:100%; object-fit:cover; }
.room-card .price-badge{
  position:absolute; top:.8rem; left:.8rem; background:#fff; padding:.3rem .7rem;
  border-radius:50px; font-size:.7rem; font-weight:600; color:var(--color-dark);
}
.room-card .body{ padding:1.2rem; }
.room-card .meta{ display:flex; gap:.9rem; font-size:.75rem; color:var(--color-text-soft); margin-bottom:.6rem; }
.room-card .meta span{ display:inline-flex; align-items:center; gap:.3rem; }
.room-card .actions{ display:flex; align-items:center; justify-content:space-between; margin-top:1rem; }

/* ---------- Sección oscura / CTA ---------- */
.section-dark{ background:var(--color-brown); color:#f1ece2; border-radius:var(--radius-lg); }
.section-dark p{ color:#cdc3b4; }
.section-dark h2{ color:#fff; }

/* ---------- Equipo ---------- */
.team-grid{ display:grid; grid-template-columns:1fr; gap:1.5rem; }
@media (min-width:700px){ .team-grid{ grid-template-columns:repeat(3,1fr); } }
.team-card{ background:var(--color-surface); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); text-align:center; }
.team-card img{ aspect-ratio:1/1; object-fit:cover; }
.team-card .info{ padding:1rem; }
.team-card .social{ display:flex; justify-content:center; gap:.7rem; margin-top:.6rem; font-size:.85rem; color:var(--color-text-soft); }

/* ---------- FAQ ---------- */
.faq-item{ border-bottom:1px solid #4a3f31; padding:1.1rem 0; }
.faq-question{ display:flex; align-items:center; justify-content:space-between; cursor:pointer; font-weight:500; }
.faq-answer{ display:none; padding-top:.7rem; }
.faq-item.is-open .faq-answer{ display:block; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--color-dark); color:#cfc7ba; border-radius:var(--radius-lg) var(--radius-lg) 0 0; margin-top:var(--space-5); }
.site-footer h4{ color:#fff; font-size:1rem; }
.footer-grid{ display:grid; grid-template-columns:1fr; gap:2rem; padding:var(--space-5) 0 2rem; }
@media (min-width:700px){ .footer-grid{ grid-template-columns:2fr 1fr 1fr 1fr; } }
.footer-bottom{ border-top:1px solid #3a3227; padding:1.2rem 0; font-size:.8rem; text-align:center; color:#9a9082; }

/* =====================================================================
   PANEL DE ADMINISTRACIÓN — mismo archivo, mismas variables.
   Mobile-first: en móvil el menú lateral se convierte en barra inferior.
   ===================================================================== */
.admin-layout{ display:flex; min-height:100vh; flex-direction:column; }
.admin-sidebar{
  display:flex; order:2; position:fixed; bottom:0; left:0; right:0; z-index:80;
  background:var(--color-dark); padding:.5rem .5rem env(safe-area-inset-bottom);
  justify-content:space-around;
}
.admin-sidebar a{
  display:flex; flex-direction:column; align-items:center; gap:.2rem;
  font-size:.65rem; color:#bdb3a3; padding:.4rem; flex:1;
}
.admin-sidebar a.is-active{ color:#fff; }
.admin-sidebar .icon{ font-size:1.1rem; }
.admin-main{ order:1; flex:1; padding:1rem 1rem 5.5rem; background:var(--color-bg); }
.admin-topbar{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem; }

@media (min-width:900px){
  .admin-layout{ flex-direction:row; }
  .admin-sidebar{
    position:static; order:0; flex-direction:column; width:230px; min-height:100vh;
    padding:1.5rem 1rem; justify-content:flex-start; gap:.3rem;
  }
  .admin-sidebar a{ flex-direction:row; justify-content:flex-start; gap:.7rem; font-size:.85rem; padding:.65rem .8rem; border-radius:var(--radius-sm); }
  .admin-sidebar a.is-active{ background:rgba(255,255,255,.08); }
  .admin-main{ order:1; padding:2rem; }
}

/* Tarjetas y tablas del admin */
.admin-card{ background:var(--color-surface); border-radius:var(--radius); box-shadow:var(--shadow); padding:1.2rem; margin-bottom:1.2rem; }
.admin-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
@media (min-width:700px){ .admin-grid{ grid-template-columns:repeat(4,1fr); } }
.stat-card{ text-align:center; }
.stat-card .num{ font-family:var(--font-display); font-size:1.8rem; color:var(--color-accent-dk); }
.stat-card .label{ font-size:.75rem; color:var(--color-text-soft); }

.data-table{ width:100%; border-collapse:collapse; font-size:.85rem; }
.data-table th{ text-align:left; font-size:.7rem; text-transform:uppercase; letter-spacing:.04em; color:var(--color-text-soft); padding:.6rem; }
.data-table td{ padding:.7rem .6rem; border-top:1px solid var(--color-border); }
/* En móvil la tabla se convierte en tarjetas apiladas */
@media (max-width:699px){
  .data-table thead{ display:none; }
  .data-table tr{ display:block; background:var(--color-surface); border-radius:var(--radius-sm); margin-bottom:.7rem; box-shadow:var(--shadow); }
  .data-table td{ display:flex; justify-content:space-between; gap:.6rem; border-top:none; padding:.5rem .8rem; }
  .data-table td::before{ content:attr(data-label); font-weight:600; color:var(--color-text-soft); font-size:.75rem; }
}

.badge{ display:inline-block; padding:.2rem .6rem; border-radius:50px; font-size:.7rem; font-weight:600; }
.badge-hold{ background:#fdeccb; color:#92620a; }
.badge-confirmed{ background:#dbeee0; color:#2e7d4f; }
.badge-checked_in{ background:#dce9fb; color:#2a5ea8; }
.badge-checked_out{ background:#e6e1d8; color:#6f6457; }
.badge-cancelled{ background:#f8dada; color:#a3322f; }

/* ---------- Calendario de reservas (admin) ---------- */
/* Escritorio: cuadrícula tipo timeline (habitaciones x días). */
.booking-calendar{ overflow-x:auto; }
.calendar-grid{ display:grid; min-width:760px; }
.calendar-cell{ border:1px solid var(--color-border); min-height:46px; font-size:.7rem; padding:.2rem; }
.calendar-cell.is-booked{ background:var(--color-accent-soft); }

/* Móvil: en vez de cuadrícula, agenda en lista clara día por día */
.calendar-agenda{ display:flex; flex-direction:column; gap:.6rem; }
.calendar-agenda .day-row{
  display:flex; align-items:center; justify-content:space-between;
  background:var(--color-surface); border-radius:var(--radius-sm); padding:.7rem .9rem; box-shadow:var(--shadow);
}
@media (min-width:900px){
  .booking-calendar{ display:block; }
  .calendar-agenda{ display:none; }
}
@media (max-width:899px){
  .calendar-grid{ display:none; }
}

/* ---------- Formularios genéricos (público + admin) ---------- */
.form-group{ margin-bottom:1rem; }
.form-group label{ display:block; font-size:.8rem; font-weight:500; margin-bottom:.35rem; }
.form-control{ width:100%; border:1px solid var(--color-border); border-radius:var(--radius-sm); padding:.65rem .8rem; background:#fff; }
.form-row{ display:grid; grid-template-columns:1fr; gap:1rem; }
@media (min-width:700px){ .form-row{ grid-template-columns:1fr 1fr; } }

/* ---------- Ficha de habitación: galería, chips, caja de precio ---------- */
.gallery-main{ border-radius:var(--radius); overflow:hidden; aspect-ratio:16/10; margin-bottom:.6rem; }
.gallery-main img{ width:100%; height:100%; object-fit:cover; }
.gallery-thumbs{ display:grid; grid-template-columns:repeat(4,1fr); gap:.5rem; }
.gallery-thumbs img{ aspect-ratio:1/1; object-fit:cover; border-radius:var(--radius-sm); cursor:pointer; opacity:.7; }
.gallery-thumbs img.is-active{ opacity:1; outline:2px solid var(--color-accent); }

.amenity-chip{
  display:inline-flex; align-items:center; gap:.4rem; background:var(--color-accent-soft);
  color:var(--color-accent-dk); padding:.4rem .8rem; border-radius:50px; font-size:.8rem; margin:0 .4rem .4rem 0;
}

.price-box{ background:var(--color-surface); border-radius:var(--radius); box-shadow:var(--shadow); padding:1.3rem; position:sticky; top:1rem; }
.price-box .total-row{ display:flex; justify-content:space-between; font-weight:600; padding-top:.6rem; border-top:1px solid var(--color-border); margin-top:.6rem; }
.price-breakdown{ font-size:.8rem; color:var(--color-text-soft); max-height:160px; overflow-y:auto; margin:.6rem 0; }
.price-breakdown div{ display:flex; justify-content:space-between; padding:.15rem 0; }

.alert{ padding:.8rem 1rem; border-radius:var(--radius-sm); font-size:.85rem; margin-bottom:1rem; }
.alert-error{ background:#fbe2e1; color:#a3322f; }
.alert-success{ background:#dbeee0; color:#2e7d4f; }
.alert-info{ background:var(--color-accent-soft); color:var(--color-accent-dk); }

/* ---------- Utilidades ---------- */
.flex{ display:flex; } .items-center{ align-items:center; } .justify-between{ justify-content:space-between; }
.gap-1{ gap:.5rem; } .gap-2{ gap:1rem; }
.mt-1{ margin-top:.5rem; } .mt-2{ margin-top:1rem; } .mt-3{ margin-top:1.5rem; }
.mb-0{ margin-bottom:0; }
.hidden{ display:none; }
