/* ==========================================================================
   Casa Rural La Prensa — rediseño minimalista 2026
   Tipografía: Fraunces (display serif) + Inter (texto)
   Paleta: hueso · tinta · vino · salvia (Ribera del Duero)
   ========================================================================== */

:root{
	--bone:      #f7f3ec;   /* fondo página */
	--bone-2:    #efe8dc;   /* paneles suaves */
	--white:     #fffdf9;
	--ink:       #241f1b;   /* texto principal */
	--ink-soft:  #6a6157;   /* texto secundario */
	--wine:      #7d2c4d;   /* acento principal */
	--wine-dark: #5d1d39;
	--sage:      #6e7a4e;   /* acento natural */
	--sage-dark: #525c39;
	--line:      #e3dccd;   /* líneas finas */
	--shadow:    0 18px 50px rgba(36,31,27,.10);
	--shadow-sm: 0 8px 24px rgba(36,31,27,.08);
	--serif: 'Fraunces', Georgia, 'Times New Roman', serif;
	--sans:  'Inter', system-ui, -apple-system, 'Segoe UI', Arial, sans-serif;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
	font-family:var(--sans);
	font-size:17px;
	line-height:1.7;
	color:var(--ink);
	background:var(--bone);
	-webkit-font-smoothing:antialiased;
}

a{ color:var(--wine); text-decoration:none; transition:color .18s ease; }
a:hover{ color:var(--wine-dark); }

img{ max-width:100%; height:auto; }

/* ===== Navbar ============================================================ */
#navmain{
	background:rgba(247,243,236,.82);
	backdrop-filter:blur(12px);
	-webkit-backdrop-filter:blur(12px);
	border-bottom:1px solid transparent;
	padding:.55rem 0;
	transition:background .25s ease, border-color .25s ease, box-shadow .25s ease;
}
#navmain.scrolled{
	background:rgba(247,243,236,.96);
	border-bottom-color:var(--line);
	box-shadow:0 6px 24px rgba(36,31,27,.06);
}
#navmain .navbar-brand{ display:flex; align-items:center; line-height:1; padding:0; }
#navmain .navbar-brand img{ height:56px; width:auto; display:block; border-radius:10px; }
@media (max-width:575px){ #navmain .navbar-brand img{ height:46px; } }
.brand-over{
	font-family:var(--sans); font-size:10.5px; font-weight:600;
	letter-spacing:.22em; text-transform:uppercase; color:var(--sage); margin-bottom:3px;
}
.brand-name{
	font-family:var(--serif); font-weight:600; font-size:25px;
	color:var(--ink); letter-spacing:.01em;
}
#navmain .navbar-nav{ gap:.35rem; }
#navmain .nav-link{
	font-size:14px; font-weight:500; letter-spacing:.02em;
	color:var(--ink-soft); padding:.5rem .9rem; position:relative; border-radius:8px;
}
#navmain .nav-link::after{
	content:""; position:absolute; left:.9rem; right:.9rem; bottom:.32rem;
	height:1.5px; background:var(--wine); transform:scaleX(0); transform-origin:left;
	transition:transform .22s ease;
}
#navmain .nav-link:hover{ color:var(--ink); }
#navmain .nav-link:hover::after,
#navmain .nav-link.active::after{ transform:scaleX(1); }
#navmain .nav-link.active{ color:var(--ink); }
/* CTA "Reservar" */
#navmain .nav-cta{
	background:var(--wine); color:#fff !important; padding:.5rem 1.25rem; margin-left:.4rem;
}
#navmain .nav-cta::after{ display:none; }
#navmain .nav-cta:hover{ background:var(--wine-dark); }
.navbar-toggler{ border:none; padding:.25rem; }
.navbar-toggler:focus{ box-shadow:none; }

@media (max-width:991px){
	#navmain{ background:rgba(247,243,236,.96); }
	#navmain .navbar-collapse{ padding-top:.5rem; }
	#navmain .nav-link{ padding:.6rem .2rem; }
	#navmain .nav-link::after{ display:none; }
	#navmain .nav-cta{ display:inline-block; margin:.5rem 0 0; }
}

/* ===== Hero ============================================================== */
.hero{
	position:relative;
	height:clamp(460px, 80vh, 760px);
	margin-top:-1px;
	overflow:hidden;
	display:flex; align-items:center; justify-content:center;
	text-align:center;
}
.hero-slides{ position:absolute; inset:0; }
.hero-slides img{
	position:absolute; inset:0; width:100%; height:100%;
	object-fit:cover; opacity:0; transition:opacity 1.6s ease;
}
.hero-slides img:first-child{ opacity:1; }      /* fallback sin JS */
.hero-slides.js img{ opacity:0; }                /* con JS lo controla la clase is-active */
.hero-slides.js img.is-active{ opacity:1; }
.hero-overlay{
	position:absolute; inset:0;
	background:linear-gradient(180deg, rgba(36,31,27,.28) 0%, rgba(36,31,27,.18) 40%, rgba(36,31,27,.62) 100%);
}
.hero-content{ position:relative; z-index:2; color:#fff; padding:0 22px; max-width:820px; }
.hero-kicker{
	font-size:13px; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
	margin:0 0 18px; color:rgba(255,255,255,.9);
}
.hero-title{
	font-family:var(--serif); font-weight:600;
	font-size:clamp(40px, 6vw, 76px); line-height:1.04; margin:0;
	text-shadow:0 2px 30px rgba(0,0,0,.35);
}
.hero-sub{
	font-size:clamp(16px, 2vw, 20px); font-weight:400;
	margin:18px auto 30px; max-width:560px; color:rgba(255,255,255,.92);
}
.hero-btn{
	display:inline-block; font-size:14px; font-weight:600; letter-spacing:.06em;
	text-transform:uppercase; color:#fff; background:var(--wine);
	padding:15px 34px; border-radius:40px; box-shadow:0 12px 30px rgba(93,29,57,.4);
	transition:transform .2s ease, background .2s ease;
}
.hero-btn:hover{ color:#fff; background:var(--wine-dark); transform:translateY(-2px); }
.hero-scroll{
	position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:2;
	width:26px; height:42px; border:2px solid rgba(255,255,255,.6); border-radius:14px;
}
.hero-scroll span{
	position:absolute; top:8px; left:50%; transform:translateX(-50%);
	width:4px; height:8px; border-radius:2px; background:#fff;
	animation:scrolldot 1.8s infinite;
}
@keyframes scrolldot{ 0%{opacity:0; top:8px;} 40%{opacity:1;} 80%{opacity:0; top:22px;} 100%{opacity:0;} }

/* ===== Layout =========================================================== */
.page{ padding-top:64px; padding-bottom:40px; }

/* ===== Contenido (tipografía editorial) ================================= */
.contenido{ font-size:17px; }

.contenido h2{
	font-family:var(--serif); font-weight:600;
	font-size:clamp(30px, 4vw, 44px); line-height:1.12; color:var(--ink);
	margin:0 0 8px;
}
.contenido h2::after{
	content:""; display:block; width:54px; height:3px; border-radius:3px;
	background:var(--wine); margin:20px 0 4px;
}
.contenido h2 + p{ color:var(--ink-soft); font-size:19px; }

.contenido h3{
	font-family:var(--serif); font-weight:600; font-size:25px; color:var(--wine);
	margin:42px 0 12px; line-height:1.25;
}
.contenido h3 a{
	font-family:var(--sans); font-size:13px; font-weight:500;
	color:var(--ink-soft); letter-spacing:.02em; margin-left:6px;
}
.contenido h3 a:hover{ color:var(--wine); }
.contenido h3.titulo{ margin-top:0; }

.contenido p{ margin:16px 0; }
.contenido strong{ font-weight:600; color:var(--ink); }

.contenido ul{ list-style:none; margin:18px 0; padding:0; }
.contenido li{ position:relative; padding:6px 0 6px 30px; }
.contenido li::before{
	content:""; position:absolute; left:4px; top:15px;
	width:7px; height:7px; border-radius:50%; background:var(--sage);
	box-shadow:0 0 0 4px rgba(110,122,78,.14);
}

/* imágenes de contenido */
.contenido .row img{
	border-radius:14px; box-shadow:var(--shadow-sm);
	width:100%; object-fit:cover;
}
.contenido iframe{ border-radius:16px; max-width:100%; box-shadow:var(--shadow-sm); }
.contenido video{ border-radius:14px; width:100%; }

/* entradilla destacada */
.lead-intro{ font-size:20px; line-height:1.6; color:var(--ink); }

/* tira de "destacados" (servicios clave) */
.destacados{ display:flex; flex-wrap:wrap; gap:10px; list-style:none; margin:26px 0 10px; padding:0; }
.destacados li{
	padding:8px 18px; font-size:14px; font-weight:600; color:var(--sage-dark);
	background:var(--bone-2); border-radius:30px;
}
.destacados li::before{ display:none; }

/* llamada a la acción al cierre de una sección */
.cta-final{
	margin:52px 0 8px; padding:38px 32px; text-align:center;
	background:var(--bone-2); border-radius:22px;
}
.cta-final p{ font-family:var(--serif); font-size:25px; line-height:1.3; color:var(--ink); margin:0 0 22px; }
.btn-cta{
	display:inline-block; font-size:14px; font-weight:600; letter-spacing:.05em; text-transform:uppercase;
	color:#fff; background:var(--wine); padding:15px 36px; border-radius:40px;
	transition:background .2s ease, transform .2s ease;
}
.btn-cta:hover{ color:#fff; background:var(--wine-dark); transform:translateY(-2px); }

/* ===== Galería en rejilla (GLightbox) =================================== */
.galeria{
	display:grid; grid-template-columns:repeat(auto-fill, minmax(150px, 1fr));
	gap:12px; margin:26px 0 8px;
}
.galeria a{
	display:block; position:relative; overflow:hidden; border-radius:12px;
	aspect-ratio:4/3; box-shadow:var(--shadow-sm);
}
.galeria img{
	width:100%; height:100%; object-fit:cover; display:block;
	transition:transform .5s ease;
}
.galeria a::after{
	content:""; position:absolute; inset:0; background:rgba(93,29,57,0);
	transition:background .3s ease;
}
.galeria a:hover img{ transform:scale(1.08); }
.galeria a:hover::after{ background:rgba(93,29,57,.18); }
@media (max-width:575px){
	.galeria{ grid-template-columns:repeat(2, 1fr); gap:8px; }
}

/* ===== Destinos turísticos (tarjetas) ================================== */
.destinos{ display:grid; grid-template-columns:repeat(2, 1fr); gap:24px; margin:32px 0 10px; }
.destino{
	background:var(--white); border:1px solid var(--line); border-radius:18px;
	overflow:hidden; display:flex; flex-direction:column;
	box-shadow:var(--shadow-sm); transition:transform .25s ease, box-shadow .25s ease;
}
.destino:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.destino-img{ position:relative; display:block; aspect-ratio:16/10; overflow:hidden; }
.destino-img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; border-radius:0; box-shadow:none; }
.destino:hover .destino-img img{ transform:scale(1.06); }
.destino-dist{
	position:absolute; top:14px; left:14px; z-index:2;
	font-size:12px; font-weight:600; letter-spacing:.04em; color:#fff;
	background:rgba(125,44,77,.92); padding:6px 14px; border-radius:30px;
	-webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
}
.destino-body{ padding:22px 24px 24px; display:flex; flex-direction:column; flex:1; }
.destino-body .destino-sub{
	font-size:12px; font-weight:600; color:var(--sage);
	text-transform:uppercase; letter-spacing:.08em; margin:0 0 8px;
}
.destino-body h3{ margin:0 0 10px; padding:0; border:none; color:var(--ink); font-size:23px; }
.destino-body p{ margin:0 0 16px; font-size:15.5px; color:var(--ink-soft); flex:1; }
.destino-link{ font-weight:600; font-size:14px; align-self:flex-start; }
@media (max-width:767px){ .destinos{ grid-template-columns:1fr; gap:18px; } }

/* créditos de imágenes */
.creditos{
	margin-top:44px; padding-top:16px; border-top:1px solid var(--line);
	font-size:12px; line-height:1.6; color:var(--ink-soft);
}
.creditos a{ color:var(--ink-soft); text-decoration:underline; }

/* ===== Situación: actividades / media / mapa =========================== */
.actividades{
	display:grid; grid-template-columns:repeat(4, 1fr); gap:16px;
	margin:30px 0 10px; list-style:none; padding:0;
}
.actividades li{ padding:0; }
.actividades li::before{ display:none; }
.actividad{
	background:var(--white); border:1px solid var(--line); border-radius:16px;
	padding:24px 16px; text-align:center; height:100%;
	transition:transform .2s ease, box-shadow .2s ease;
}
.actividad:hover{ transform:translateY(-3px); box-shadow:var(--shadow-sm); }
.actividad svg{ width:30px; height:30px; color:var(--sage); margin-bottom:10px; }
.actividad span{ display:block; font-weight:600; font-size:15px; color:var(--ink); line-height:1.3; }
@media (max-width:767px){ .actividades{ grid-template-columns:repeat(2, 1fr); } }

.situacion-media{ display:grid; grid-template-columns:repeat(3, 1fr); gap:16px; margin:32px 0; }
.situacion-media a, .situacion-media video{
	display:block; width:100%; aspect-ratio:4/3; margin:0;
	border-radius:14px; overflow:hidden; box-shadow:var(--shadow-sm);
}
.situacion-media img{ width:100%; height:100%; object-fit:cover; display:block; }
.situacion-media video{ object-fit:cover; background:#000; }
@media (max-width:767px){ .situacion-media{ grid-template-columns:1fr; } }

.mapa-bloque{ display:grid; grid-template-columns:2fr 1fr; gap:22px; margin:38px 0 10px; align-items:stretch; }
.mapa-marco{ border-radius:18px; overflow:hidden; box-shadow:var(--shadow-sm); line-height:0; }
.mapa-marco iframe{ display:block; width:100%; height:100%; min-height:440px; border:0; }
.mapa-info{
	background:var(--ink); color:#fff; border-radius:18px; padding:32px 30px;
	display:flex; flex-direction:column;
}
.mapa-info h3{ color:#fff; margin:0 0 18px; padding:0; border:none; }
.mapa-info .dato{ display:block; font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--sage); margin-bottom:3px; }
.mapa-info p{ margin:0 0 18px; color:rgba(255,255,255,.82); font-size:15px; line-height:1.55; }
.mapa-info a{ color:#fff; }
.maps-btn{
	display:inline-block; text-align:center; margin-top:auto;
	background:var(--wine); color:#fff; font-weight:600; font-size:14px;
	letter-spacing:.03em; padding:14px 22px; border-radius:30px; transition:background .2s ease;
}
.maps-btn:hover{ background:var(--wine-dark); color:#fff; }
@media (max-width:767px){
	.mapa-bloque{ grid-template-columns:1fr; }
	.mapa-marco iframe{ min-height:320px; }
}

/* ===== Reservas ======================================================== */
/* pasos */
.pasos{ display:grid; grid-template-columns:repeat(3, 1fr); gap:16px; margin:30px 0 10px; list-style:none; padding:0; }
.pasos li{ padding:0; }
.pasos li::before{ display:none; }
.paso{
	background:var(--white); border:1px solid var(--line); border-radius:16px;
	padding:24px 22px; display:flex; gap:16px; align-items:flex-start; height:100%;
}
.paso-num{
	flex:none; width:40px; height:40px; border-radius:50%;
	background:var(--wine); color:#fff; font-family:var(--serif); font-weight:600; font-size:19px;
	display:flex; align-items:center; justify-content:center;
}
.paso h4{ margin:0 0 4px; font-family:var(--serif); font-weight:600; font-size:17px; color:var(--ink); }
.paso p{ margin:0; font-size:14px; color:var(--ink-soft); line-height:1.5; }
@media (max-width:767px){ .pasos{ grid-template-columns:1fr; } }

/* tarifas + calendario */
.reservas-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin:22px 0; align-items:start; }
.caja-tarifas h4{ font-family:var(--serif); font-weight:600; font-size:20px; color:var(--ink); text-align:center; margin:0 0 14px; }
@media (max-width:767px){ .reservas-grid{ grid-template-columns:1fr; } }

/* formulario + contacto */
.reservas-bloque{ display:grid; grid-template-columns:1.7fr 1fr; gap:22px; margin:22px 0; align-items:stretch; }
.reserva-info{
	background:var(--ink); color:#fff; border-radius:18px; padding:32px 30px;
	display:flex; flex-direction:column;
}
.reserva-info h4{ font-family:var(--serif); font-weight:600; font-size:21px; color:#fff; margin:0 0 18px; }
.reserva-info .dato{ display:block; font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--sage); margin-bottom:3px; }
.reserva-info p{ margin:0 0 18px; color:rgba(255,255,255,.82); font-size:15px; line-height:1.5; }
.reserva-info a{ color:#fff; }
.reserva-info .tel-grande{ font-family:var(--serif); font-size:25px; font-weight:600; }
.reserva-info .maps-btn{ margin-top:auto; }
@media (max-width:991px){ .reservas-bloque{ grid-template-columns:1fr; } }

/* canales externos (Booking / Tripadvisor) */
.canales{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin:24px 0; }
.canal{
	background:var(--white); border:1px solid var(--line); border-radius:18px;
	padding:30px 26px; text-align:center; display:flex; flex-direction:column; align-items:center;
}
.canal img{ max-height:48px; width:auto; margin-bottom:16px; }
.canal p{ color:var(--ink-soft); font-size:15px; margin:0 0 18px; flex:1; }
@media (max-width:575px){ .canales{ grid-template-columns:1fr; } }

/* ===== Barra lateral / widgets ========================================= */
.sidebar{ padding-top:6px; }
.widget{
	background:var(--white); border:1px solid var(--line); border-radius:16px;
	padding:22px 22px; margin-bottom:18px;
}
.widget h4{
	font-family:var(--serif); font-weight:600; font-size:19px; color:var(--ink);
	margin:0 0 8px;
}
.widget p{ font-size:15px; color:var(--ink-soft); margin:0 0 14px; }
.widget-reserva{ background:var(--ink); border-color:var(--ink); }
.widget-reserva h4{ color:#fff; }
.widget-reserva p{ color:rgba(255,255,255,.72); }
.widget-btn{
	display:inline-block; width:100%; text-align:center; font-family:var(--sans);
	font-size:14px; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
	color:#fff; background:var(--wine); padding:13px 18px; border-radius:30px;
	transition:background .2s ease;
}
.widget-btn:hover{ color:#fff; background:var(--wine-dark); }

.widget-ofertas{ background:var(--bone-2); border-color:var(--bone-2); }
.widget-tag{
	display:inline-block; font-size:11px; font-weight:600; letter-spacing:.12em;
	text-transform:uppercase; color:#fff; background:var(--sage);
	padding:4px 12px; border-radius:20px; margin-bottom:10px;
}
.widget-ofertas a{ font-weight:600; }

.widget-redes .redes-iconos{ display:flex; gap:14px; align-items:center; }
.widget-redes .redes-iconos a{ transition:transform .15s ease; }
.widget-redes .redes-iconos a:hover{ transform:translateY(-3px); }
.widget-wifi{ padding:14px; text-align:center; }
.widget-wifi img{ border-radius:10px; }
.widget-tiempo{ padding:14px; }
.widget-tiempo .completo{ margin:auto; }

/* ===== Tarjeta de tarifas + formulario (reservas) ====================== */
.caja-tarifas{
	background:var(--white); border:1px solid var(--line);
	border-radius:18px; padding:24px 24px 28px;
}
.caja-tarifas h3{ margin-top:0; text-align:center; color:var(--ink); }
.tprecios{ width:100%; }
.tprecios td{ padding:13px 4px; border-bottom:1px solid var(--line); font-size:16px; }
.tprecios tr:last-child td{ border-bottom:none; }

.caja-form{
	background:var(--white); border:1px solid var(--line);
	border-radius:18px; padding:26px;
}
.caja-form .form-label{ font-size:14px; font-weight:600; color:var(--ink); margin-bottom:5px; }
.caja-form .form-control{
	border:1px solid var(--line); border-radius:10px; padding:.6rem .8rem;
	background:var(--bone); font-size:15px;
}
.caja-form .form-control:focus{
	border-color:var(--wine); box-shadow:0 0 0 .2rem rgba(125,44,77,.12); background:#fff;
}

/* Botones Bootstrap → paleta de marca */
.btn-success{
	--bs-btn-bg:var(--wine); --bs-btn-border-color:var(--wine);
	--bs-btn-hover-bg:var(--wine-dark); --bs-btn-hover-border-color:var(--wine-dark);
	--bs-btn-active-bg:var(--wine-dark); --bs-btn-active-border-color:var(--wine-dark);
	font-weight:600; letter-spacing:.03em; border-radius:30px; padding:.6rem 1.8rem;
}

/* enlace/píldora "¡OFERTAS!" */
.aofertas{
	display:inline-block; font-size:13px; font-weight:600; letter-spacing:.06em;
	text-transform:uppercase; color:#fff; background:var(--sage);
	padding:8px 20px; border-radius:30px;
}
.aofertas:hover{ color:#fff; background:var(--sage-dark); }

/* ===== Ofertas ========================================================= */
#ofertas{ margin-top:64px; }
#ofertas h2{ font-family:var(--serif); font-weight:600; font-size:34px; color:var(--ink); margin-bottom:24px; }
.oferta{
	background:var(--white); border:1px solid var(--line); border-radius:18px;
	padding:24px 26px; margin-bottom:20px; overflow:hidden;
}
.oferta .foto{ float:right; margin:0 0 14px 22px; }
.oferta .foto img{ border-radius:12px; box-shadow:var(--shadow-sm); }
.oferta h3.titulo{ margin:0 0 8px; color:var(--wine); font-size:22px; }
.oferta .detalles{ font-size:16px; color:var(--ink-soft); }

/* ===== Mapa ============================================================= */
#mapa{ border-radius:16px; overflow:hidden; box-shadow:var(--shadow-sm); margin-top:10px; line-height:0; }
#mapa iframe{ display:block; width:100%; height:450px; border:0; }
@media (max-width:575px){ #mapa iframe{ height:340px; } }
#direcciones{ max-height:250px; overflow:auto; border:1px solid var(--line); border-radius:10px; font-size:14px; padding:8px; }

/* ===== Pie de página ==================================================== */
.site-footer{ background:var(--ink); color:rgba(255,255,255,.74); margin-top:50px; }
.site-footer .container{ padding-top:56px; padding-bottom:24px; }
.footer-grid{
	display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:32px;
	padding-bottom:34px; border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-brand .brand-over{ color:var(--sage); }
.footer-brand .brand-name{ color:#fff; font-size:30px; }
.footer-brand p{ margin-top:8px; font-size:14px; color:rgba(255,255,255,.6); }
.footer-col h4{
	font-family:var(--sans); font-size:12px; font-weight:600; letter-spacing:.14em;
	text-transform:uppercase; color:rgba(255,255,255,.5); margin:0 0 14px;
}
.footer-col p{ margin:6px 0; font-size:15px; }
.site-footer a{ color:#fff; }
.site-footer a:hover{ color:var(--sage); }
.footer-bottom{
	display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
	padding-top:20px; font-size:13px; color:rgba(255,255,255,.5);
}
@media (max-width:767px){
	.footer-grid{ grid-template-columns:1fr; gap:24px; }
	.footer-bottom{ flex-direction:column; text-align:center; }
}

/* ===== Responsive ======================================================= */
@media (max-width:991px){
	.page{ padding-top:40px; }
	.sidebar{ margin-top:24px; }
}
@media (max-width:575px){
	body{ font-size:16px; }
	.contenido h2 + p{ font-size:17px; }
}
