/* basic.css — Plan Básico
   Hotel boutique de una sola página. Sobrio, editorial, italiano de provincia.
   Hero + descripción + servicios + booking. Nada más.
*/

body.plan-basic {
  font-family: var(--font-sans);
  color: var(--color-ink);
  background: var(--color-bg);
}
.plan-basic h1, .plan-basic h2, .plan-basic h3 { font-family: var(--font-serif); font-weight: 500; letter-spacing: -0.01em; }

/* Top bar */
.plan-basic .topbar {
  position: absolute; inset: 0 0 auto 0;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.6rem clamp(16px, 4vw, 48px);
  color: #fff; z-index: 5;
}
.plan-basic .topbar .brand {
  font-family: var(--font-serif); font-size: 1.4rem;
}

/* Hero */
.plan-basic .hero {
  position: relative; min-height: 92vh;
  display: grid; grid-template-rows: 1fr auto;
  color: #fff; overflow: hidden;
}
.plan-basic .hero::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.2) 50%, rgba(0,0,0,0.6) 100%);
  z-index: 1;
}
.plan-basic .hero-bg {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  transform: scale(1.04); transition: transform 12s ease-out;
}
.plan-basic .hero:hover .hero-bg { transform: scale(1); }

.plan-basic .hero-content {
  position: relative; z-index: 2;
  align-self: end;
  max-width: 800px;
  padding: 0 clamp(16px, 4vw, 48px) clamp(4rem, 10vh, 8rem);
}
.plan-basic .hero h1 {
  font-size: clamp(2.6rem, 6vw, 4.6rem); line-height: 1.04;
  margin: 0 0 1.2rem;
}
.plan-basic .hero p.sub {
  font-size: clamp(1.05rem, 1.6vw, 1.2rem); max-width: 60ch;
  margin: 0 0 2rem; opacity: 0.92;
}
.plan-basic .hero .actions { display: flex; gap: 0.8rem; flex-wrap: wrap; }

/* Intro */
.plan-basic .intro {
  padding: clamp(4rem, 10vh, 7rem) 0;
  text-align: center;
}
.plan-basic .intro .container { max-width: 740px; }
.plan-basic .intro h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); margin: 0.6rem 0 1.5rem; }
.plan-basic .intro p { color: var(--color-mute); font-size: 1.05rem; }

/* Servicios */
.plan-basic .services {
  padding: clamp(3rem, 8vh, 5rem) 0;
  background: var(--color-cream);
}
.plan-basic .services-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 2rem; margin-top: 2.5rem;
}
.plan-basic .service-item {
  text-align: center;
  padding: 1rem;
}
.plan-basic .service-item .ico {
  width: 48px; height: 48px; margin: 0 auto 0.8rem;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--color-accent); border-radius: 50%;
  color: var(--color-accent);
}
.plan-basic .service-item h3 { font-size: 1.05rem; margin: 0.6rem 0 0.3rem; }
.plan-basic .service-item p { color: var(--color-mute); font-size: 0.9rem; margin: 0; }

/* Booking CTA */
.plan-basic .booking-cta {
  padding: clamp(4rem, 10vh, 7rem) 0;
  text-align: center;
  background: var(--color-primary);
  color: #fff;
}
.plan-basic .booking-cta h2 { font-size: clamp(1.8rem, 3.4vw, 2.8rem); color: #fff; margin: 0 0 1rem; }
.plan-basic .booking-cta p { opacity: 0.85; margin: 0 0 2rem; }
.plan-basic .booking-cta .btn-primary {
  background: var(--color-accent); color: var(--color-primary);
  padding: 1.1rem 2.6rem; font-size: 0.95rem;
}

/* Footer */
.plan-basic footer {
  padding: 3rem 0 2rem; background: #0c0c0c; color: #999;
  font-size: 0.85rem;
}
.plan-basic footer .container {
  display: flex; flex-wrap: wrap; gap: 1.6rem;
  justify-content: space-between; align-items: center;
}
.plan-basic footer a { color: #ccc; }
.plan-basic footer a:hover { color: var(--color-accent); }

@media (max-width: 640px) {
  .plan-basic .topbar .lang-switch { display: none; }
}
