/* =============================================================
   Maggy Beach Hotel — Custom Styles
   Paleta: turquesa #00a99d | blanco #ffffff | oscuro #1a1a2e
   ============================================================= */

/* ── CSS Custom Properties ─────────────────────────────────── */
:root {
	/* Paleta */
	--maggy-turquesa:       #00a99d;
	--maggy-turquesa-hover: #007a72;
	--maggy-turquesa-light: #f0fafa;
	--maggy-blanco:         #ffffff;
	--maggy-oscuro:         #1a1a2e;
	--maggy-oscuro-soft:    #2a2a4e;
	--maggy-gray:           #555566;
	--maggy-gray-light:     #f5f5f8;
	--maggy-whatsapp:       #25d366;

	/* Tipografía */
	--maggy-font-display: 'Playfair Display', Georgia, serif;
	--maggy-font-body:    'DM Sans', system-ui, -apple-system, sans-serif;
	--maggy-font-accent:  'Cormorant Garamond', Georgia, serif;

	/* Radios */
	--maggy-radius:    8px;
	--maggy-radius-lg: 16px;
	--maggy-radius-xl: 20px;

	/* Sombras */
	--maggy-shadow:       0 4px 20px rgba(0, 169, 157, 0.18);
	--maggy-shadow-md:    0 8px 40px rgba(0, 0, 0, 0.08);
	--maggy-shadow-hover: 0 24px 60px rgba(0, 0, 0, 0.14);

	/* Transición */
	--maggy-trans: 0.3s ease;

	/* Layout */
	--maggy-section-pad: 6.25rem 0;
	--maggy-inner-max:   1200px;
	--maggy-inner-pad:   0 1.5rem;
}

/* ── Editor block color palette ────────────────────────────── */
.has-turquesa-color             { color: var(--maggy-turquesa) !important; }
.has-turquesa-background-color  { background-color: var(--maggy-turquesa) !important; }
.has-blanco-color               { color: var(--maggy-blanco) !important; }
.has-blanco-background-color    { background-color: var(--maggy-blanco) !important; }
.has-oscuro-color               { color: var(--maggy-oscuro) !important; }
.has-oscuro-background-color    { background-color: var(--maggy-oscuro) !important; }

/* =============================================================
   GeneratePress container reset on front page
   ============================================================= */
.maggy-homepage #page.site,
.maggy-homepage .site-content {
	max-width: none;
	padding: 0;
	margin: 0;
	width: 100%;
}

/* =============================================================
   Shared section base
   ============================================================= */
.maggy-section {
	padding: var(--maggy-section-pad);
	background: var(--maggy-blanco);
}
.maggy-section--alt   { background: var(--maggy-turquesa-light); }
.maggy-section--dark  { background: var(--maggy-oscuro); color: var(--maggy-blanco); }

.maggy-section__inner {
	max-width: var(--maggy-inner-max);
	margin: 0 auto;
	padding: var(--maggy-inner-pad);
}

.maggy-section__header {
	text-align: center;
	margin-bottom: 3rem;
}
.maggy-section__title {
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	font-weight: 800;
	color: var(--maggy-oscuro);
	margin: 0 0 0.6rem;
	line-height: 1.15;
	letter-spacing: -0.02em;
}
.maggy-section__subtitle {
	font-size: 1.05rem;
	color: var(--maggy-gray);
	line-height: 1.65;
	margin: 0;
}

/* =============================================================
   Buttons
   ============================================================= */
.maggy-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 13px 28px;
	font-size: 0.95rem;
	font-weight: 700;
	border-radius: 50px;
	text-decoration: none;
	cursor: pointer;
	transition: background var(--maggy-trans), color var(--maggy-trans),
	            transform 0.18s ease, box-shadow var(--maggy-trans);
	border: 2px solid transparent;
	letter-spacing: 0.02em;
}
.maggy-btn:hover,
.maggy-btn:focus-visible {
	text-decoration: none;
	transform: translateY(-2px);
}
.maggy-btn:active { transform: translateY(0); }

.maggy-btn--primary {
	background: var(--maggy-turquesa);
	color: var(--maggy-blanco);
	box-shadow: 0 4px 16px rgba(0,169,157,0.30);
}
.maggy-btn--primary:hover,
.maggy-btn--primary:focus-visible {
	background: var(--maggy-turquesa-hover);
	color: var(--maggy-blanco);
	box-shadow: 0 8px 24px rgba(0,169,157,0.40);
}

.maggy-btn--outline {
	background: transparent;
	color: var(--maggy-turquesa);
	border-color: var(--maggy-turquesa);
}
.maggy-btn--outline:hover,
.maggy-btn--outline:focus-visible {
	background: var(--maggy-turquesa);
	color: var(--maggy-blanco);
}

.maggy-btn--white {
	background: var(--maggy-blanco);
	color: var(--maggy-oscuro);
	border-color: var(--maggy-blanco);
}
.maggy-btn--white:hover,
.maggy-btn--white:focus-visible {
	background: var(--maggy-turquesa-light);
	color: var(--maggy-oscuro);
}

.maggy-btn--whatsapp {
	background: var(--maggy-whatsapp);
	color: var(--maggy-blanco);
	box-shadow: 0 4px 16px rgba(37,211,102,0.30);
}
.maggy-btn--whatsapp:hover,
.maggy-btn--whatsapp:focus-visible {
	background: #1da851;
	color: var(--maggy-blanco);
}

@media (prefers-reduced-motion: reduce) {
	.maggy-btn { transition: background var(--maggy-trans), color var(--maggy-trans); transform: none !important; }
}

/* =============================================================
   S1 — HERO
   ============================================================= */
.maggy-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	background:
		linear-gradient(160deg, rgba(0,169,157,0.90) 0%, rgba(26,26,46,0.97) 100%),
		url('../img/hero/hero-playa.webp') center/cover no-repeat;
	/* Swap url('') with the real hero image URL when available */
	color: var(--maggy-blanco);
	padding: 6rem 0 4rem;
}

.maggy-hero__overlay {
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at 60% 40%, rgba(0,169,157,0.15) 0%, transparent 70%);
	pointer-events: none;
}

.maggy-hero__inner {
	position: relative;
	z-index: 1;
	text-align: center;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 2rem;
}

.maggy-hero__title {
	font-size: clamp(2rem, 5vw, 3.6rem);
	font-weight: 900;
	color: var(--maggy-blanco);
	line-height: 1.08;
	letter-spacing: -0.03em;
	margin: 0 0 1rem;
	text-shadow: 0 2px 16px rgba(0,0,0,0.35);
}
.maggy-hero__title-accent {
	color: var(--maggy-turquesa);
	font-style: italic;
}

.maggy-hero__subtitle {
	font-size: clamp(1rem, 2vw, 1.2rem);
	color: rgba(255,255,255,0.88);
	margin: 0 auto 2.5rem;
	max-width: 600px;
	line-height: 1.6;
}
.maggy-hero__br { display: none; }

/* Reservation widget */
.maggy-search-widget {
	background: rgba(255,255,255,0.10);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,0.20);
	border-radius: var(--maggy-radius-lg);
	padding: 1.5rem;
	margin: 0 auto 2rem;
	max-width: 860px;
}

.maggy-search-widget__fields {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	align-items: flex-end;
	justify-content: center;
}

.maggy-search-widget__field {
	display: flex;
	flex-direction: column;
	gap: 4px;
	flex: 1 1 160px;
}

.maggy-search-widget__label {
	font-size: 0.78rem;
	font-weight: 600;
	color: rgba(255,255,255,0.75);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.maggy-search-widget__input {
	padding: 10px 14px;
	border: 1px solid rgba(255,255,255,0.30);
	border-radius: var(--maggy-radius);
	background: rgba(255,255,255,0.15);
	color: var(--maggy-blanco);
	font-size: 0.95rem;
	appearance: none;
	-webkit-appearance: none;
}
.maggy-search-widget__input::placeholder { color: rgba(255,255,255,0.50); }
.maggy-search-widget__input:focus {
	outline: 2px solid var(--maggy-turquesa);
	outline-offset: 2px;
}
.maggy-search-widget__input option { background: var(--maggy-oscuro); color: var(--maggy-blanco); }

.maggy-search-widget__btn {
	flex: 1 1 200px;
	white-space: nowrap;
}

/* Trust badges */
.maggy-trust-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
}
.maggy-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255,255,255,0.12);
	border: 1px solid rgba(255,255,255,0.25);
	border-radius: 50px;
	padding: 8px 18px;
	font-size: 0.9rem;
}
.maggy-badge__source { font-weight: 600; }
.maggy-badge__stars  { color: #f5c518; letter-spacing: 1px; }

/* =============================================================
   S2 — HABITACIONES
   ============================================================= */
.maggy-rooms-grid {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.maggy-room-card {
	background: var(--maggy-blanco);
	border-radius: var(--maggy-radius-lg);
	padding: 1.75rem;
	box-shadow: var(--maggy-shadow-md);
	border: 1px solid rgba(0,169,157,0.10);
	display: flex;
	flex-direction: row;
	gap: 1.5rem;
	align-items: flex-start;
	transition: box-shadow var(--maggy-trans), transform 0.2s ease;
}
.maggy-room-card:hover {
	box-shadow: 0 12px 40px rgba(0,169,157,0.20);
	transform: translateY(-3px);
}

/* Left column: icon + price */
.maggy-room-card__side {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.6rem;
	min-width: 88px;
	flex-shrink: 0;
	padding-top: 0.125rem;
	text-align: center;
}

/* Right column: all text content */
.maggy-room-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	min-width: 0;
}

.maggy-room-card__icon {
	font-size: 2.4rem;
	line-height: 1;
}
.maggy-room-card__title {
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--maggy-oscuro);
	margin: 0;
}
.maggy-room-card__desc {
	font-size: 0.95rem;
	color: var(--maggy-gray);
	line-height: 1.6;
	margin: 0;
}
.maggy-room-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	list-style: none;
	padding: 0;
	margin: 0;
}
.maggy-pill {
	background: var(--maggy-turquesa-light);
	color: var(--maggy-turquesa);
	font-size: 0.78rem;
	font-weight: 600;
	padding: 4px 12px;
	border-radius: 50px;
	border: 1px solid rgba(0,169,157,0.20);
}
.maggy-room-card__cta { align-self: flex-start; margin-top: 0.25rem; }

.maggy-room-card__img {
	width: calc(100% + 3.5rem);
	margin: -2rem -1.75rem 1.25rem;
	height: 220px;
	object-fit: cover;
	border-radius: var(--maggy-radius-lg) var(--maggy-radius-lg) 0 0;
	flex-shrink: 0;
	display: block;
}

@media (prefers-reduced-motion: reduce) {
	.maggy-room-card { transition: none; transform: none !important; }
}

/* =============================================================
   S3 — SERVICIOS
   ============================================================= */
.maggy-services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1.5rem;
	list-style: none;
	padding: 0;
	margin: 0;
}

.maggy-service-item {
	background: var(--maggy-blanco);
	border-radius: var(--maggy-radius-lg);
	padding: 2rem 1.5rem;
	text-align: center;
	box-shadow: var(--maggy-shadow);
	border: 1px solid rgba(0,169,157,0.08);
	transition: box-shadow var(--maggy-trans), transform 0.2s ease;
}
.maggy-service-item:hover {
	box-shadow: 0 8px 28px rgba(0,169,157,0.20);
	transform: translateY(-3px);
}
.maggy-service-item__icon {
	display: block;
	font-size: 2.4rem;
	margin-bottom: 0.75rem;
	line-height: 1;
}
.maggy-service-item__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--maggy-oscuro);
	margin: 0 0 0.4rem;
}
.maggy-service-item__desc {
	font-size: 0.88rem;
	color: var(--maggy-gray);
	line-height: 1.5;
	margin: 0;
}

@media (prefers-reduced-motion: reduce) {
	.maggy-service-item { transition: none; transform: none !important; }
}

/* =============================================================
   S4 — UBICACIÓN
   ============================================================= */
.maggy-ubicacion__layout {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
}

.maggy-distance-list {
	list-style: none;
	padding: 0;
	margin: 0 0 2rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.maggy-distance-list__item {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
}
.maggy-distance-list__icon {
	font-size: 1.4rem;
	flex-shrink: 0;
	line-height: 1.4;
}
.maggy-distance-list__item div {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.maggy-distance-list__item strong {
	font-weight: 700;
	color: var(--maggy-oscuro);
	font-size: 1rem;
}
.maggy-distance-list__item span {
	color: var(--maggy-gray);
	font-size: 0.92rem;
}

.maggy-map-wrapper {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	border-radius: var(--maggy-radius-lg);
	box-shadow: var(--maggy-shadow-md);
}
.maggy-map-wrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
	border-radius: var(--maggy-radius-lg);
}

/* =============================================================
   S5 — GALERÍA
   ============================================================= */
.maggy-gallery-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: repeat(3, 220px);
	gap: 0.75rem;
}

.maggy-gallery__item {
	border-radius: var(--maggy-radius);
	overflow: hidden;
	position: relative;
	background: linear-gradient(135deg, var(--maggy-turquesa) 0%, var(--maggy-oscuro) 100%);
	cursor: pointer;
}
.maggy-gallery__item--1 { background: linear-gradient(135deg, #00a99d 0%, #007a72 100%); }
.maggy-gallery__item--2 { background: linear-gradient(135deg, #00bfb2 0%, #00a99d 100%); }
.maggy-gallery__item--3 { background: linear-gradient(135deg, #1a1a2e 0%, #00a99d 100%); }
.maggy-gallery__item--4 { background: linear-gradient(135deg, #008f84 0%, #1a1a2e 100%); }
.maggy-gallery__item--5 { background: linear-gradient(135deg, #00d4c8 0%, #008f84 100%); }
.maggy-gallery__item--6 { background: linear-gradient(135deg, #2a2a4e 0%, #00a99d 100%); }

.maggy-gallery__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.45s ease;
}
.maggy-gallery__item:hover img { transform: scale(1.08); }

.maggy-gallery__caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0.75rem 1rem;
	background: linear-gradient(transparent, rgba(26,26,46,0.80));
	color: var(--maggy-blanco);
	font-size: 0.82rem;
	font-weight: 600;
}

/* =============================================================
   S6 — OPINIONES
   ============================================================= */
.maggy-reviews-grid {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.maggy-review-card {
	background: var(--maggy-blanco);
	border-radius: var(--maggy-radius-lg);
	padding: 1.75rem;
	box-shadow: var(--maggy-shadow-md);
	border-left: 4px solid var(--maggy-turquesa);
	display: flex;
	flex-direction: row;
	gap: 1.5rem;
	align-items: flex-start;
}

/* Left column: name, origin, stars */
.maggy-review-card__side {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 130px;
	max-width: 160px;
	flex-shrink: 0;
}
.maggy-review-card__side .maggy-stars { margin-top: 0.35rem; }

.maggy-review-card__name {
	font-weight: 700;
	color: var(--maggy-oscuro);
	font-size: 1rem;
	font-style: normal;
}
.maggy-review-card__origin {
	font-size: 0.82rem;
	color: var(--maggy-gray);
}
.maggy-stars {
	color: #f5c518;
	font-size: 1.1rem;
	letter-spacing: 2px;
	line-height: 1;
}
.maggy-review-card__text {
	margin: 0;
	border: 0;
	padding: 0.5rem 0 0;
	position: relative;
	flex: 1;
	min-width: 0;
}
.maggy-review-card__text::before {
	content: '\201C';
	position: absolute;
	top: -0.5rem;
	left: -0.25rem;
	font-size: 4rem;
	line-height: 1;
	color: var(--maggy-turquesa);
	opacity: 0.20;
	font-weight: 900;
	font-style: normal;
	pointer-events: none;
}
.maggy-review-card__text p {
	color: var(--maggy-gray);
	font-size: 0.95rem;
	line-height: 1.68;
	margin: 0;
	font-style: italic;
}
.maggy-review-card__avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--maggy-turquesa-light);
	flex-shrink: 0;
}

/* =============================================================
   S7 — FAQ
   ============================================================= */
.maggy-faq {
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.maggy-faq__item {
	background: var(--maggy-blanco);
	border-radius: var(--maggy-radius);
	border: 1px solid rgba(0,169,157,0.15);
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(26,26,46,0.06);
}

.maggy-faq__question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.1rem 1.5rem;
	background: none;
	border: none;
	text-align: left;
	font-size: 1rem;
	font-weight: 600;
	color: var(--maggy-oscuro);
	cursor: pointer;
	transition: background var(--maggy-trans), color var(--maggy-trans);
}
.maggy-faq__question:hover {
	background: var(--maggy-turquesa-light);
	color: var(--maggy-turquesa);
}
.maggy-faq__question:focus-visible {
	outline: 2px solid var(--maggy-turquesa);
	outline-offset: -2px;
}
.maggy-faq__item.is-open .maggy-faq__question {
	background: var(--maggy-turquesa-light);
	color: var(--maggy-turquesa);
}

.maggy-faq__arrow {
	font-size: 1.4rem;
	line-height: 1;
	transition: transform 0.3s ease;
	flex-shrink: 0;
}
.maggy-faq__item.is-open .maggy-faq__arrow {
	transform: rotate(90deg);
}

.maggy-faq__answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.35s ease, padding 0.35s ease;
	padding: 0 1.5rem;
}
.maggy-faq__item.is-open .maggy-faq__answer {
	max-height: 400px;
	padding: 0 1.5rem 1.25rem;
}
.maggy-faq__answer p {
	margin: 0;
	color: var(--maggy-gray);
	font-size: 0.95rem;
	line-height: 1.7;
}

@media (prefers-reduced-motion: reduce) {
	.maggy-faq__answer { transition: none; }
	.maggy-faq__arrow  { transition: none; }
}

/* =============================================================
   S8 — FOOTER CTA
   ============================================================= */
.maggy-footer-cta {
	background: var(--maggy-oscuro);
	color: var(--maggy-blanco);
	padding: 5rem 0;
}

.maggy-footer-cta__inner {
	text-align: center;
}

.maggy-footer-cta__title {
	font-size: clamp(1.8rem, 3.5vw, 2.8rem);
	font-weight: 900;
	color: var(--maggy-blanco);
	margin: 0 0 0.75rem;
}
.maggy-footer-cta__subtitle {
	font-size: 1.05rem;
	color: rgba(255,255,255,0.72);
	margin: 0 0 2.5rem;
}

.maggy-footer-cta__contact {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem 2rem;
	margin-bottom: 2.5rem;
}
.maggy-footer-cta__contact-item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: rgba(255,255,255,0.85);
	font-size: 0.95rem;
	text-decoration: none;
	transition: color var(--maggy-trans);
}
.maggy-footer-cta__contact-item:hover {
	color: var(--maggy-turquesa);
	text-decoration: none;
}

.maggy-footer-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
}

/* =============================================================
   Bio Links Page (shortcode [maggy_bio])
   ============================================================= */
/* See functions/bio-links.php — styles injected inline; override here */

/* =============================================================
   Floating Reservar Button
   ============================================================= */
/* See functions/floating-btn.php — styles injected inline; override here */

/* =============================================================
   HEADER — Sticky navigation
   ============================================================= */
.maggy-header {
	position: sticky;
	top: 0;
	z-index: 999;
	background: var(--maggy-blanco);
	box-shadow: 0 2px 16px rgba(26,26,46,0.08);
	border-bottom: 1px solid rgba(0,169,157,0.08);
	transition: box-shadow var(--maggy-trans);
}
.maggy-header__inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 2rem;
	height: 68px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
}
.maggy-header__logo {
	display: flex;
	align-items: center;
	text-decoration: none;
	flex-shrink: 0;
	gap: 0.75rem;
}
.maggy-header__logo img {
	height: 40px;
	width: auto;
	display: block;
}
.maggy-header__logo-text {
	font-size: 1.1rem;
	font-weight: 800;
	color: var(--maggy-oscuro);
	letter-spacing: -0.02em;
	line-height: 1.2;
}
.maggy-header__logo-text span { color: var(--maggy-turquesa); }

/* Nav links: hover turquesa */
.maggy-nav__menu a {
	position: relative;
}
.maggy-nav__menu a::after {
	content: '';
	position: absolute;
	bottom: 2px;
	left: 14px;
	right: 14px;
	height: 2px;
	background: var(--maggy-turquesa);
	border-radius: 2px;
	transform: scaleX(0);
	transition: transform var(--maggy-trans);
}
.maggy-nav__menu a:hover::after,
.maggy-nav__menu a:focus-visible::after { transform: scaleX(1); }

/* =============================================================
   LUXURY COASTAL — Maggy Beach Hotel Design System
   Barú · Cartagena  |  refined · tropical · premium
   ============================================================= */

/* ── Tipografía global ───────────────────────────────────────── */
body,
input, select, button, textarea {
	font-family: var(--maggy-font-body);
}
.maggy-section__title,
.maggy-hero__title,
.maggy-footer-cta__title,
.maggy-room-card__title,
.maggy-header__logo-text {
	font-family: var(--maggy-font-display);
}
.maggy-section__subtitle,
.maggy-hero__subtitle,
.maggy-footer-cta__subtitle {
	font-family: var(--maggy-font-accent);
	font-style: italic;
}
.maggy-section__title {
	font-size: clamp(1.8rem, 3.5vw, 2.6rem);
	font-weight: 700;
	letter-spacing: -0.02em;
}
.maggy-section__subtitle {
	font-size: 1.15rem;
	font-weight: 500;
	letter-spacing: 0.01em;
}
.maggy-section__header { margin-bottom: 3.5rem; }

/* ── S1. Hero ────────────────────────────────────────────────── */
.maggy-hero {
	background:
		linear-gradient(135deg, rgba(0,40,40,0.65) 0%, rgba(0,40,40,0.20) 55%, transparent 100%),
		url('../img/hero/hero-playa.webp') center/cover no-repeat;
}
.maggy-hero__title {
	font-size: clamp(2.4rem, 6vw, 4.5rem);
	font-weight: 800;
	line-height: 1.08;
	letter-spacing: -0.025em;
	text-shadow: 0 4px 24px rgba(0,0,0,0.28);
}
.maggy-hero__subtitle {
	font-size: clamp(1.15rem, 2.2vw, 1.4rem);
	font-weight: 500;
	opacity: 0.92;
	letter-spacing: 0.02em;
	margin-bottom: 2.5rem;
}

/* Widget reserva: fondo blanco, sombra fuerte, campos en fila */
.maggy-search-widget {
	background: var(--maggy-blanco);
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	border: none;
	border-radius: var(--maggy-radius-xl);
	box-shadow: 0 20px 60px rgba(0,0,0,0.22);
}
.maggy-search-widget__label {
	color: var(--maggy-gray);
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.09em;
}
.maggy-search-widget__input {
	background: var(--maggy-gray-light);
	border: 1.5px solid rgba(0,169,157,0.15);
	color: var(--maggy-oscuro);
}
.maggy-search-widget__input::placeholder { color: #b0b0c0; }
.maggy-search-widget__input:focus {
	border-color: var(--maggy-turquesa);
	background: var(--maggy-blanco);
	outline: none;
	outline-offset: 0;
}
/* appearance:none elimina el ícono nativo; el popup custom maneja la selección */
input[type="date"].maggy-search-widget__input,
input[type="date"].maggy-date-input {
	-webkit-appearance: none;
	appearance: none;
	cursor: pointer;
	color-scheme: light;
	min-width: 0;
}
.maggy-search-widget__btn {
	border-radius: 10px;
	letter-spacing: 0.02em;
}
.maggy-trust-badges { gap: 1.5rem; }

/* ── S2. Header — glassmorphism sticky ───────────────────────── */
.maggy-header {
	backdrop-filter: blur(12px) saturate(180%);
	-webkit-backdrop-filter: blur(12px) saturate(180%);
	background: rgba(255,255,255,0.92);
	border-bottom: 1px solid rgba(0,169,157,0.15);
	box-shadow: 0 1px 16px rgba(0,0,0,0.06);
}
.maggy-header__logo-text {
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: -0.025em;
}
.maggy-nav__menu a {
	font-size: 0.78rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.09em;
	border-radius: 0;
}
.maggy-nav__menu a:hover,
.maggy-nav__menu a:focus-visible {
	background: transparent;
	color: var(--maggy-turquesa);
}

/* ── S3. Habitaciones ────────────────────────────────────────── */
.maggy-room-card {
	border-radius: var(--maggy-radius-xl);
	overflow: hidden;
	box-shadow: var(--maggy-shadow-md);
	border: none;
}
.maggy-room-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--maggy-shadow-hover);
}
.maggy-room-card__img {
	height: 240px;
	border-radius: 0;
}
.maggy-room-card__title {
	font-size: 1.25rem;
	letter-spacing: -0.02em;
}
.maggy-room-card__meta {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin-bottom: 0.5rem;
}
.maggy-room-card__meta span {
	font-size: 0.82rem;
	color: var(--maggy-gray);
	line-height: 1.4;
}
.maggy-room-card__price {
	display: inline-flex;
	align-items: baseline;
	gap: 5px;
	background: var(--maggy-turquesa);
	color: var(--maggy-blanco);
	font-size: 1.05rem;
	font-weight: 700;
	padding: 6px 14px;
	border-radius: 50px;
	letter-spacing: 0.02em;
	margin: 0;
	text-align: center;
	flex-wrap: wrap;
	justify-content: center;
	line-height: 1.4;
}
.maggy-room-card__price small {
	font-size: 0.75rem;
	font-weight: 400;
	opacity: 0.85;
}

/* ── S4. Servicios ───────────────────────────────────────────── */
.maggy-service-item {
	background: #f8fffe;
	border: 1px solid rgba(0,169,157,0.10);
	transition: border-color var(--maggy-trans), background var(--maggy-trans),
	            box-shadow var(--maggy-trans), transform var(--maggy-trans);
}
.maggy-service-item:hover {
	border-color: var(--maggy-turquesa);
	background: var(--maggy-blanco);
	box-shadow: 0 8px 32px rgba(0,169,157,0.14);
	transform: translateY(-4px);
}
.maggy-service-item__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	background: rgba(0,169,157,0.10);
	border-radius: 12px;
	margin: 0 auto 1rem;
	font-size: 1.8rem;
	line-height: 1;
}
.maggy-service-item__title {
	font-weight: 600;
	font-size: 1rem;
	letter-spacing: -0.01em;
}
.maggy-service-item__desc {
	font-size: 0.875rem;
	line-height: 1.55;
}

/* ── S5. Ubicación ───────────────────────────────────────────── */
.maggy-distance-list__icon { color: var(--maggy-turquesa); }
.maggy-distance-list__item + .maggy-distance-list__item {
	padding-top: 0.875rem;
	border-top: 1px solid rgba(0,169,157,0.10);
}
.maggy-map-wrapper {
	border-radius: var(--maggy-radius-xl);
	border: 3px solid var(--maggy-turquesa);
	box-shadow: 0 12px 48px rgba(0,169,157,0.16);
}
.maggy-map-wrapper iframe {
	border-radius: calc(var(--maggy-radius-xl) - 3px);
}

/* ── S6. Galería ─────────────────────────────────────────────── */
.maggy-gallery-grid { gap: 12px; }
.maggy-gallery__item {
	border-radius: var(--maggy-radius-lg);
	transition: transform 0.4s ease;
}
.maggy-gallery__item::after {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0,169,157,0);
	border-radius: inherit;
	transition: background 0.4s ease;
	pointer-events: none;
}
.maggy-gallery__item:hover { transform: scale(1.03); }
.maggy-gallery__item:hover::after { background: rgba(0,169,157,0.18); }
.maggy-gallery__caption {
	font-size: 0.72rem;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	z-index: 1;
}

/* ── S7. Opiniones ───────────────────────────────────────────── */
.maggy-review-card {
	border-radius: var(--maggy-radius-lg);
	box-shadow: 0 8px 40px rgba(0,0,0,0.07);
}
.maggy-review-card__text::before {
	font-family: var(--maggy-font-accent);
	font-size: 7.5rem;
	opacity: 0.10;
	top: -1.75rem;
	left: -0.5rem;
}
.maggy-stars { color: #f4c542; }
.maggy-review-card__name { letter-spacing: -0.01em; }
.maggy-review-card__text p {
	font-family: var(--maggy-font-accent);
	font-size: 1.05rem;
	line-height: 1.65;
}
.maggy-review-card__avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--maggy-turquesa-light);
	color: var(--maggy-turquesa);
	font-weight: 700;
	font-size: 0.85rem;
	flex-shrink: 0;
	border: 2px solid rgba(0,169,157,0.20);
}

/* ── S8. FAQ ──────────────────────────────────────────────────── */
.maggy-faq__item {
	background: transparent;
	border: none;
	border-bottom: 1px solid rgba(0,169,157,0.15);
	border-radius: 0;
	box-shadow: none;
	overflow: visible;
}
.maggy-faq__item:first-child { border-top: 1px solid rgba(0,169,157,0.15); }
.maggy-faq__question {
	font-size: 1.05rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	padding: 1.25rem 0;
}
.maggy-faq__question:hover,
.maggy-faq__item.is-open .maggy-faq__question {
	background: rgba(0,169,157,0.04);
	padding-left: 0.75rem;
	padding-right: 0.75rem;
	color: var(--maggy-turquesa);
}
.maggy-faq__arrow { color: var(--maggy-turquesa); font-size: 1.5rem; }
.maggy-faq__item.is-open .maggy-faq__arrow { transform: rotate(45deg); }
.maggy-faq__answer { padding: 0; }
.maggy-faq__item.is-open .maggy-faq__answer {
	padding: 0 0.75rem 1.25rem;
	max-height: 400px;
}

/* ── S9. Footer CTA ──────────────────────────────────────────── */
.maggy-footer-cta {
	background: linear-gradient(135deg, #0d2b2b 0%, #1a4a4a 60%, #0d3333 100%);
}
.maggy-footer-cta__title {
	font-size: clamp(2rem, 4.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
}
.maggy-footer-cta__subtitle {
	font-size: 1.2rem;
	opacity: 0.88;
}
.maggy-footer-cta .maggy-btn--primary {
	background: var(--maggy-turquesa);
	border-color: var(--maggy-turquesa);
}
.maggy-footer-cta .maggy-btn--primary:hover {
	background: #007a72;
	border-color: #007a72;
}
.maggy-footer-cta .maggy-btn--outline {
	color: var(--maggy-blanco);
	border-color: rgba(255,255,255,0.55);
}
.maggy-footer-cta .maggy-btn--outline:hover {
	background: var(--maggy-blanco);
	color: var(--maggy-oscuro);
	border-color: var(--maggy-blanco);
}

/* ── Botón flotante: pulso ───────────────────────────────────── */
@keyframes maggy-pulso {
	0%   { box-shadow: 0 8px 32px rgba(0,169,157,0.50), 0 0 0 0    rgba(0,169,157,0.40); }
	60%  { box-shadow: 0 8px 32px rgba(0,169,157,0.50), 0 0 0 16px rgba(0,169,157,0);    }
	100% { box-shadow: 0 8px 32px rgba(0,169,157,0.50), 0 0 0 0    rgba(0,169,157,0);    }
}
.maggy-fab {
	border-radius: 50px !important;
	font-weight: 700 !important;
	letter-spacing: 0.03em !important;
	animation: maggy-pulso 2.5s infinite !important;
}
.maggy-fab:hover { animation-play-state: paused !important; }

@media (prefers-reduced-motion: reduce) {
	.maggy-fab { animation: none !important; }
}

/* =============================================================
   PÁGINA COMODIDADES — Grid detallado de habitaciones
   ============================================================= */

.maggy-page-hero__subtitle {
	font-size: 1rem;
	color: rgba(255,255,255,0.80);
	margin: 0.5rem 0 0;
	font-weight: 400;
	letter-spacing: 0.03em;
}

.maggy-comodidades-rooms {
	padding: 3.5rem 0 5rem;
}

.maggy-comodidades-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
	gap: 2.5rem;
	align-items: start;
}

.maggy-comodidades-card {
	background: var(--maggy-blanco);
	border-radius: var(--maggy-radius-xl);
	box-shadow: var(--maggy-shadow-md);
	padding: 2rem 1.8rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	border: 1px solid rgba(0,169,157,0.08);
	transition: transform var(--maggy-trans), box-shadow var(--maggy-trans);
}
.maggy-comodidades-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--maggy-shadow-hover);
}

.maggy-comodidades-card__header {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
}
.maggy-comodidades-card__icon {
	font-size: 2.8rem;
	line-height: 1;
	flex-shrink: 0;
}
.maggy-comodidades-card__header-text {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.maggy-comodidades-card__title {
	font-family: var(--maggy-font-display);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--maggy-oscuro);
	margin: 0;
	line-height: 1.2;
}
.maggy-comodidades-card__price {
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
	background: var(--maggy-turquesa);
	color: var(--maggy-blanco);
	font-size: 1.05rem;
	font-weight: 700;
	padding: 5px 14px;
	border-radius: 50px;
	letter-spacing: 0.02em;
	width: fit-content;
}
.maggy-comodidades-card__price small {
	font-size: 0.72rem;
	font-weight: 400;
	opacity: 0.85;
}
/* COP price — landing cards */
.maggy-comodidades-card__price .maggy-cop-price {
	font-size: 0.7rem;
	font-weight: 400;
	opacity: 0.82;
	white-space: nowrap;
}

.maggy-comodidades-card__desc {
	font-size: 0.95rem;
	color: var(--maggy-gray);
	line-height: 1.65;
	margin: 0;
}

.maggy-comodidades-card__details {
	margin: 0;
	padding: 1rem 1.25rem;
	background: rgba(0,169,157,0.04);
	border: 1px solid rgba(0,169,157,0.10);
	border-radius: var(--maggy-radius);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.maggy-comodidades-card__detail-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 0.75rem;
	font-size: 0.875rem;
}
.maggy-comodidades-card__detail-row dt {
	color: var(--maggy-gray);
	font-weight: 600;
	white-space: nowrap;
}
.maggy-comodidades-card__detail-row dd {
	margin: 0;
	color: var(--maggy-oscuro);
	font-weight: 500;
	text-align: right;
}

.maggy-comodidades-card__cta {
	width: 100%;
	text-align: center;
	justify-content: center;
	margin-top: auto;
}

.maggy-comodidades-extra {
	max-width: 900px;
	margin: 0 auto;
	padding: 1rem 1.5rem 4rem;
}

@media (max-width: 768px) {
	.maggy-comodidades-grid { grid-template-columns: 1fr; }
	.maggy-comodidades-rooms { padding: 2rem 0 3rem; }
}

/* =============================================================
   PÁGINAS MOTOPRESS — Hero strip + content + overrides
   ============================================================= */

/* ── Hero strip pequeño ──────────────────────────────────────── */
.maggy-page-hero {
	background: linear-gradient(135deg, var(--maggy-turquesa) 0%, var(--maggy-turquesa-hover) 100%);
	padding: 3rem 0 2.5rem;
	position: relative;
	overflow: hidden;
}
.maggy-page-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at 70% 50%, rgba(255,255,255,0.10) 0%, transparent 60%);
	pointer-events: none;
}
.maggy-page-hero__inner {
	position: relative;
	z-index: 1;
	text-align: center;
}
.maggy-page-hero__title {
	font-family: var(--maggy-font-display);
	font-size: clamp(1.6rem, 4vw, 2.4rem);
	font-weight: 700;
	color: var(--maggy-blanco);
	margin: 0;
	letter-spacing: -0.02em;
	line-height: 1.2;
}
.maggy-page-hero__breadcrumb {
	font-family: var(--maggy-font-body);
	font-size: 0.82rem;
	color: rgba(255,255,255,0.70);
	margin-bottom: 0.6rem;
	letter-spacing: 0.04em;
}
.maggy-page-hero__breadcrumb a {
	color: rgba(255,255,255,0.80);
	text-decoration: none;
}
.maggy-page-hero__breadcrumb a:hover { color: var(--maggy-blanco); }

/* ── Wrapper y contenido ─────────────────────────────────────── */
.maggy-motopress-wrap {
	background: var(--maggy-gray-light);
	min-height: 50vh;
}
.maggy-motopress-main {
	padding: 3.5rem 0 4rem;
}
.maggy-motopress-main__inner {
	max-width: 960px;
	margin: 0 auto;
	padding: 3rem 3rem;
	background: var(--maggy-blanco);
	border-radius: var(--maggy-radius-lg);
	box-shadow: 0 4px 24px rgba(0,0,0,0.06);
}

/* ── MotoPress — wrapper de búsqueda ─────────────────────────── */
.mphb_sc_availability_search,
.mphb-search-form-wrap,
.mphb-sc-availability-search-wrap {
	background: linear-gradient(135deg, rgba(0,169,157,0.06) 0%, rgba(0,169,157,0.02) 100%) !important;
	border: 1.5px solid rgba(0,169,157,0.18) !important;
	border-radius: var(--maggy-radius-xl) !important;
	padding: 2rem !important;
	margin-bottom: 2.5rem !important;
}

/* ── MotoPress — labels ──────────────────────────────────────── */
.mphb-search-form label,
.mphb_sc_availability_search label,
.mphb-checkout-form label {
	font-family: var(--maggy-font-body) !important;
	font-size: 0.78rem !important;
	font-weight: 600 !important;
	color: var(--maggy-gray) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.07em !important;
	margin-bottom: 6px !important;
	display: block !important;
}

/* ── MotoPress — tipografía ──────────────────────────────────── */
.mphb-room-type-title,
.mphb-room-type-title a {
	font-family: var(--maggy-font-display) !important;
	color: var(--maggy-oscuro) !important;
	font-weight: 700 !important;
	font-size: 1.2rem !important;
	letter-spacing: -0.02em !important;
}
.mphb-section-title,
h2.mphb-title, h3.mphb-title {
	font-family: var(--maggy-font-display) !important;
	color: var(--maggy-oscuro) !important;
	font-weight: 700 !important;
}

/* ── MotoPress — inputs y selects ────────────────────────────── */
.mphb-search-form input,
.mphb-search-form select,
.mphb_sc_availability_search input,
.mphb_sc_availability_search select,
.mphb-checkout-form input,
.mphb-checkout-form select,
.mphb-checkout-form textarea {
	border: 1.5px solid rgba(0,169,157,0.25) !important;
	border-radius: 8px !important;
	padding: 11px 14px !important;
	font-family: var(--maggy-font-body) !important;
	font-size: 0.95rem !important;
	background: var(--maggy-blanco) !important;
	transition: border-color var(--maggy-trans), box-shadow var(--maggy-trans) !important;
	width: 100% !important;
	box-sizing: border-box !important;
}
.mphb-search-form input:focus,
.mphb-search-form select:focus,
.mphb_sc_availability_search input:focus,
.mphb_sc_availability_search select:focus,
.mphb-checkout-form input:focus,
.mphb-checkout-form select:focus,
.mphb-checkout-form textarea:focus {
	border-color: var(--maggy-turquesa) !important;
	box-shadow: 0 0 0 3px rgba(0,169,157,0.12) !important;
	outline: none !important;
}

/* ── MotoPress — botones submit ──────────────────────────────── */
.mphb-search-form button[type="submit"],
.mphb_sc_availability_search button[type="submit"],
.mphb_sc_availability_search input[type="submit"],
.mphb-checkout-form .button,
.mphb-checkout-form input[type="submit"] {
	background: var(--maggy-turquesa) !important;
	color: var(--maggy-blanco) !important;
	border: none !important;
	border-radius: 8px !important;
	padding: 13px 32px !important;
	font-family: var(--maggy-font-body) !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.02em !important;
	cursor: pointer !important;
	transition: background var(--maggy-trans), transform 0.15s ease !important;
	display: inline-block !important;
}
.mphb-search-form button[type="submit"]:hover,
.mphb_sc_availability_search button[type="submit"]:hover,
.mphb_sc_availability_search input[type="submit"]:hover,
.mphb-checkout-form .button:hover,
.mphb-checkout-form input[type="submit"]:hover {
	background: var(--maggy-turquesa-hover) !important;
	transform: translateY(-2px) !important;
}

/* ── MotoPress — botón "Reservar" en cards ───────────────────── */
.mphb-book-button,
a.mphb-book-button {
	background: var(--maggy-turquesa) !important;
	border-color: var(--maggy-turquesa) !important;
	border-radius: 8px !important;
	font-family: var(--maggy-font-body) !important;
	font-weight: 700 !important;
	letter-spacing: 0.02em !important;
	padding: 11px 26px !important;
	transition: background var(--maggy-trans), transform 0.15s ease !important;
}
.mphb-book-button:hover,
a.mphb-book-button:hover {
	background: var(--maggy-turquesa-hover) !important;
	border-color: var(--maggy-turquesa-hover) !important;
	transform: translateY(-2px) !important;
}

/* ── MotoPress — cards [mphb_rooms] ──────────────────────────── */
.mphb-rooms-list,
ul.mphb-room-types-list {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
	gap: 1.75rem !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}
.mphb-room-type {
	border-radius: var(--maggy-radius-lg) !important;
	overflow: hidden !important;
	box-shadow: var(--maggy-shadow-md) !important;
	background: var(--maggy-blanco) !important;
	transition: transform var(--maggy-trans), box-shadow var(--maggy-trans) !important;
	display: flex !important;
	flex-direction: column !important;
}
.mphb-room-type:hover {
	transform: translateY(-6px) !important;
	box-shadow: var(--maggy-shadow-hover) !important;
}
.mphb-room-type-thumbnail img {
	width: 100% !important;
	height: 220px !important;
	object-fit: cover !important;
	display: block !important;
}
.mphb-room-type-info {
	padding: 1.5rem !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0.75rem !important;
	flex: 1 !important;
}
.mphb-room-type-price {
	font-family: var(--maggy-font-body) !important;
}
.mphb-room-type-price .amount {
	font-size: 1.4rem !important;
	font-family: var(--maggy-font-display) !important;
	font-weight: 700 !important;
	color: var(--maggy-turquesa) !important;
}
.mphb-attributes-list {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	font-size: 0.875rem !important;
	color: var(--maggy-gray) !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 3px !important;
}

/* ── MotoPress — sin resultados ──────────────────────────────── */
.mphb-rooms-not-found,
.mphb-no-rooms-available,
.mphb-sc-rooms-not-found {
	text-align: center !important;
	padding: 3rem 2rem !important;
	background: rgba(0,169,157,0.04) !important;
	border: 1.5px dashed rgba(0,169,157,0.25) !important;
	border-radius: var(--maggy-radius-xl) !important;
	margin-top: 2rem !important;
}
.mphb-rooms-not-found p,
.mphb-no-rooms-available p {
	color: var(--maggy-gray) !important;
	font-size: 1rem !important;
	margin-bottom: 1.5rem !important;
}

/* ── Página buscar-disponibilidad ────────────────────────────── */
.maggy-buscar-form-wrap {
	background: var(--maggy-blanco);
	padding: 2rem 0;
	box-shadow: 0 4px 20px rgba(0,0,0,0.06);
}
.maggy-buscar-form.maggy-search-widget {
	max-width: 860px;
	margin: 0 auto;
	background: rgba(0,169,157,0.04);
	border: 1.5px solid rgba(0,169,157,0.18);
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	box-shadow: none;
}
.maggy-buscar-form .maggy-search-widget__label {
	color: var(--maggy-gray);
}
.maggy-buscar-form .maggy-search-widget__input {
	background: var(--maggy-blanco);
	color: var(--maggy-oscuro);
	border: 1.5px solid rgba(0,169,157,0.20);
}
.maggy-buscar-form .maggy-search-widget__input:focus {
	border-color: var(--maggy-turquesa);
	box-shadow: 0 0 0 3px rgba(0,169,157,0.14);
	outline: none;
}
.maggy-buscar-form .maggy-search-widget__input.maggy-input--error,
.maggy-buscar-form select.maggy-input--error {
	border-color: #e05252 !important;
	box-shadow: 0 0 0 3px rgba(224,82,82,0.12) !important;
}
.maggy-field-error {
	display: block;
	font-size: 0.72rem;
	font-weight: 500;
	color: #c0392b;
	margin-top: 0.3rem;
	letter-spacing: 0.01em;
	line-height: 1.4;
}
.maggy-buscar-rooms {
	padding: 2.5rem 0 3.5rem;
}
.maggy-buscar-rooms__intro {
	font-size: 0.9rem;
	color: var(--maggy-gray);
	margin-bottom: 1.75rem;
	text-align: center;
	letter-spacing: 0.02em;
}

/* ── Bloque contacto alternativo ─────────────────────────────── */
.maggy-mp-contact-fallback {
	margin-top: 2.5rem;
	padding: 2rem;
	background: linear-gradient(135deg, rgba(0,169,157,0.06) 0%, rgba(0,169,157,0.02) 100%);
	border: 1.5px solid rgba(0,169,157,0.18);
	border-radius: var(--maggy-radius-xl);
	text-align: center;
}
.maggy-mp-contact-fallback__title {
	font-family: var(--maggy-font-display);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--maggy-oscuro);
	margin: 0 0 0.4rem;
}
.maggy-mp-contact-fallback__sub {
	color: var(--maggy-gray);
	font-size: 0.95rem;
	margin: 0 0 1.5rem;
}
.maggy-mp-contact-fallback__actions {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* Reset de contenedor GP dentro del template MotoPress */
.maggy-motopress-wrap .site-content {
	max-width: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* ── Móvil: inner padding reducido ───────────────────────────── */
@media (max-width: 480px) {
	.maggy-page-hero { padding: 2rem 0 1.75rem; }
	.maggy-motopress-main { padding: 1.5rem 0 2.5rem; }
	.maggy-motopress-main__inner { padding: 1.5rem 1.25rem; }
}

/* =============================================================
   Responsive — mobile-first breakpoints
   ============================================================= */

/* ── ≥ 600px (phablet) ─────────────────────────────────────── */
@media (min-width: 600px) {
	.maggy-hero__br { display: inline; }

	.maggy-gallery-grid {
		grid-template-columns: repeat(3, 1fr);
		grid-template-rows: repeat(2, 260px);
	}

	.maggy-search-widget__field { flex: 1 1 200px; }
}

/* ── ≥ 900px (tablet landscape / small laptop) ─────────────── */
@media (min-width: 900px) {
	:root { --maggy-section-pad: 6rem 0; }

	.maggy-ubicacion__layout {
		flex-direction: row;
		align-items: flex-start;
		gap: 3rem;
	}
	.maggy-ubicacion__info { flex: 0 0 360px; }
	.maggy-map-wrapper      { flex: 1; padding-bottom: 0; height: 420px; }
	.maggy-map-wrapper iframe { position: static; width: 100%; height: 100%; }

	.maggy-search-widget { padding: 1.5rem 2rem; }
	.maggy-search-widget__fields { flex-wrap: nowrap; }
	.maggy-search-widget__field  { flex: 1 1 auto; }
	.maggy-search-widget__btn    { flex: 0 0 auto; white-space: nowrap; }
}


/* =============================================================
   RESPONSIVE COMPLETO
   Mobile ≤480px | Tablet ≤768px | Desktop ≥1024px
   ============================================================= */

/* ── 1. Hero: clamp global para el título ───────────────────── */
.maggy-hero__title {
	font-size: clamp(1.8rem, 5vw, 3.5rem);
}

/* ── 2. Navegación: hamburguesa (base — desktop oculta) ──────── */
.maggy-nav-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 44px;
	height: 44px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 6px;
	border-radius: var(--maggy-radius);
	transition: background var(--maggy-trans);
	z-index: 1000;
	flex-shrink: 0;
}
.maggy-nav-toggle:hover { background: rgba(0,169,157,0.10); }

.maggy-nav-toggle__bar {
	display: block;
	width: 24px;
	height: 2px;
	background: currentColor;
	border-radius: 2px;
	transition: transform 0.3s ease, opacity 0.3s ease;
}
.maggy-nav-toggle.is-open .maggy-nav-toggle__bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.maggy-nav-toggle.is-open .maggy-nav-toggle__bar:nth-child(2) {
	opacity: 0;
	transform: scaleX(0);
}
.maggy-nav-toggle.is-open .maggy-nav-toggle__bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

.maggy-nav {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	position: relative;
}
.maggy-nav__menu {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 0.25rem;
}
.maggy-nav__menu a {
	display: block;
	padding: 8px 14px;
	color: var(--maggy-oscuro);
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	border-radius: var(--maggy-radius);
	transition: background var(--maggy-trans), color var(--maggy-trans);
}
.maggy-nav__menu a:hover,
.maggy-nav__menu a:focus-visible {
	background: var(--maggy-turquesa-light);
	color: var(--maggy-turquesa);
	text-decoration: none;
}

/* ── 10. Botón flotante: posición desktop ────────────────────── */
.maggy-fab {
	bottom: 30px !important;
	right: 30px !important;
}

@media (prefers-reduced-motion: reduce) {
	.maggy-nav-toggle__bar { transition: none; }
}

/* ── Laptop 1024px–1279px ────────────────────────────────────── */
@media (min-width: 1024px) {
	/* 1. Hero: widget en fila horizontal, sin wrap */
	.maggy-search-widget {
		max-width: 920px;
		padding: 1.5rem 2rem;
	}
	.maggy-search-widget__fields { flex-wrap: nowrap; }
	.maggy-search-widget__field  { flex: 1 1 auto; }
	.maggy-search-widget__btn    { flex: 0 0 auto; white-space: nowrap; }

	/* 3. Habitaciones: columna única, tarjetas horizontales */
	.maggy-rooms-grid { flex-direction: column; }
	.maggy-room-card  { height: auto; }

	/* 4. Servicios: 3 × 2, filas iguales */
	.maggy-services-grid {
		grid-template-columns: repeat(3, 1fr);
		grid-auto-rows: 1fr;
	}

	/* 5. Ubicación: 50/50, texto centrado vertical, mapa 400px */
	.maggy-ubicacion__layout {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 3.5rem;
		align-items: center;
	}
	.maggy-ubicacion__info {
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
	.maggy-map-wrapper {
		padding-bottom: 0;
		height: 400px;
	}
	.maggy-map-wrapper iframe {
		position: static;
		width: 100%;
		height: 100%;
	}

	/* 6. Galería: 3 × 2, gap uniforme */
	.maggy-gallery-grid {
		grid-template-columns: repeat(3, 1fr);
		grid-template-rows: repeat(2, 270px);
		gap: 0.75rem;
	}

	/* 7. Opiniones: columna única, tarjetas horizontales */
	.maggy-reviews-grid { flex-direction: column; }
	.maggy-review-card  { height: auto; }

	/* 9. Footer CTA: 4 datos en fila, botones side by side */
	.maggy-footer-cta__contact {
		flex-direction: row;
		flex-wrap: nowrap;
		gap: 2.5rem;
	}
	.maggy-footer-cta__actions {
		flex-wrap: nowrap;
		gap: 1.25rem;
	}
}

/* ── Desktop ≥1280px ─────────────────────────────────────────── */
@media (min-width: 1280px) {
	:root { --maggy-inner-pad: 0 2rem; }

	/* 1. Hero: widget más ancho en desktop grande */
	.maggy-search-widget { max-width: 1000px; }

	/* 6. Galería: celdas más altas */
	.maggy-gallery-grid { grid-template-rows: repeat(2, 300px); }

	/* 8. Navegación: más espacio entre links */
	.maggy-nav__menu { gap: 0.5rem; }
	.maggy-nav__menu a { padding: 8px 16px; }
}

/* ── Tablet ≤768px ───────────────────────────────────────────── */
@media (max-width: 768px) {
	/* 1. Widget reserva: fechas en fila, huéspedes + botón abajo */
	.maggy-search-widget { padding: 1.25rem 1.25rem; }
	.maggy-search-widget__fields { flex-wrap: wrap; gap: 0.75rem; }
	.maggy-search-widget__field  { flex: 1 1 140px; min-width: 0; }
	.maggy-search-widget__btn    { flex: 0 0 100%; width: 100%; }

	/* 2. Navegación: logo izquierda, hamburguesa derecha */
	.maggy-nav-toggle { display: flex; }

	.maggy-nav__menu {
		display: none;
		flex-direction: column;
		position: absolute;
		top: calc(100% + 8px);
		left: 0;
		right: 0;
		background: var(--maggy-blanco);
		box-shadow: var(--maggy-shadow-md);
		border-radius: var(--maggy-radius-lg);
		padding: 0.75rem;
		gap: 0.25rem;
		z-index: 999;
		min-width: 200px;
	}
	.maggy-nav__menu.is-open { display: flex; }
	.maggy-nav__menu a { padding: 12px 16px; font-size: 1rem; }

	/* 3. Habitaciones: columna única (horizontal cards) */
	.maggy-rooms-grid {
		flex-direction: column;
		gap: 1rem;
	}

	/* 4. Servicios: 2 × 3 */
	.maggy-services-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.25rem;
	}

	/* 5. Ubicación: stack vertical, mapa full-width */
	.maggy-ubicacion__layout {
		display: flex;
		flex-direction: column;
		gap: 2rem;
	}
}

/* =============================================================
   PÁGINAS DE ESTADO — Confirmación / Cancelación / Error
   ============================================================= */

/* ── Hero — variantes de color ───────────────────────────────── */
.maggy-page-hero--success {
	background: linear-gradient(135deg, #00b894 0%, #00a99d 50%, #00867d 100%);
}
.maggy-page-hero--danger {
	background: linear-gradient(135deg, #e74c3c 0%, #c0392b 100%);
}
.maggy-page-hero--warning {
	background: linear-gradient(135deg, #e67e22 0%, #d35400 100%);
}

/* ── Bloque de estado ────────────────────────────────────────── */
.maggy-state-block {
	text-align: center;
	padding: 2.5rem 2rem 3rem;
	margin-bottom: 2rem;
}
.maggy-state-block__icon {
	display: block;
	font-size: 4rem;
	line-height: 1;
	margin-bottom: 1.25rem;
}
.maggy-state-block__title {
	font-family: var(--maggy-font-display);
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 700;
	color: var(--maggy-oscuro);
	margin: 0 0 0.75rem;
	letter-spacing: -0.02em;
}
.maggy-state-block__message {
	font-size: 1.05rem;
	color: var(--maggy-gray);
	line-height: 1.65;
	max-width: 520px;
	margin: 0 auto 2rem;
}
.maggy-state-block__actions {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* Bordes de acento por tipo */
.maggy-state-block--success { border-top: 4px solid #00a99d; border-radius: 0 0 var(--maggy-radius-xl) var(--maggy-radius-xl); }
.maggy-state-block--danger  { border-top: 4px solid #e74c3c; border-radius: 0 0 var(--maggy-radius-xl) var(--maggy-radius-xl); }
.maggy-state-block--warning { border-top: 4px solid #e67e22; border-radius: 0 0 var(--maggy-radius-xl) var(--maggy-radius-xl); }

/* ── Checkout — secciones limpias ────────────────────────────── */
.mphb-checkout-section,
.mphb-booking-confirmation-section {
	background: var(--maggy-blanco) !important;
	border-radius: 16px !important;
	padding: 2rem !important;
	margin-bottom: 1.5rem !important;
	box-shadow: 0 4px 20px rgba(0,0,0,0.06) !important;
	border: 1px solid rgba(0,169,157,0.08) !important;
}
.mphb-checkout-section h3,
.mphb-checkout-section h2,
.mphb-booking-confirmation-section h3 {
	font-family: var(--maggy-font-display) !important;
	color: var(--maggy-oscuro) !important;
	font-size: 1.2rem !important;
	border-bottom: 2px solid var(--maggy-turquesa) !important;
	padding-bottom: 0.75rem !important;
	margin-bottom: 1.5rem !important;
}

/* Botón de pago/submit checkout */
.mphb-payment-btn,
#mphb-payment-form button[type="submit"],
.mphb-checkout button[type="submit"],
.mphb-checkout input[type="submit"] {
	background: var(--maggy-turquesa) !important;
	color: var(--maggy-blanco) !important;
	border: none !important;
	border-radius: 8px !important;
	padding: 16px 40px !important;
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	width: 100% !important;
	cursor: pointer !important;
	transition: background var(--maggy-trans), transform 0.15s ease !important;
	font-family: var(--maggy-font-body) !important;
}
.mphb-payment-btn:hover,
#mphb-payment-form button[type="submit"]:hover {
	background: var(--maggy-turquesa-hover) !important;
	transform: translateY(-2px) !important;
}

/* Datepicker de MotoPress */
.mphb-datepick,
.ui-datepicker-trigger,
.mphb-search-form .mphb-datepick {
	border: 1.5px solid rgba(0,169,157,0.30) !important;
	border-radius: 8px !important;
	padding: 10px 14px !important;
	width: 100% !important;
	font-family: var(--maggy-font-body) !important;
	cursor: pointer !important;
}
.ui-datepicker {
	border: 1px solid rgba(0,169,157,0.20) !important;
	border-radius: 12px !important;
	box-shadow: 0 8px 32px rgba(0,0,0,0.12) !important;
	font-family: var(--maggy-font-body) !important;
}
.ui-datepicker .ui-datepicker-header {
	background: var(--maggy-turquesa) !important;
	border-radius: 10px 10px 0 0 !important;
	color: var(--maggy-blanco) !important;
	border: none !important;
}
.ui-datepicker td.ui-datepicker-current-day a,
.ui-datepicker td.ui-state-active a {
	background: var(--maggy-turquesa) !important;
	color: var(--maggy-blanco) !important;
	border-radius: 6px !important;
}

/* Mi Cuenta — dashboard limpio */
.mphb-account-section,
.mphb-bookings-table-wrap {
	background: var(--maggy-blanco) !important;
	border-radius: 12px !important;
	overflow: hidden !important;
	box-shadow: 0 4px 20px rgba(0,0,0,0.06) !important;
}
.mphb-bookings-table th {
	background: var(--maggy-turquesa) !important;
	color: var(--maggy-blanco) !important;
	font-family: var(--maggy-font-body) !important;
	font-weight: 600 !important;
	padding: 12px 16px !important;
}
.mphb-bookings-table td {
	padding: 12px 16px !important;
	border-bottom: 1px solid rgba(0,169,157,0.08) !important;
}
	.maggy-map-wrapper {
		padding-bottom: 56.25%;
		height: 0;
	}
	.maggy-map-wrapper iframe {
		position: absolute;
		top: 0; left: 0;
		width: 100%; height: 100%;
	}

	/* 6. Galería: 2 × 3 */
	.maggy-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
		grid-template-rows: repeat(3, 200px);
		gap: 0.6rem;
	}

	/* 7. Opiniones: columna única (horizontal cards) */
	.maggy-reviews-grid {
		flex-direction: column;
		gap: 1rem;
	}

	/* 9. Footer CTA: 4 datos en columna */
	.maggy-footer-cta__contact {
		flex-direction: column;
		align-items: center;
		gap: 0.75rem;
	}
}

/* ── Móvil ≤480px ────────────────────────────────────────────── */
@media (max-width: 480px) {
	:root {
		--maggy-section-pad: 3rem 0;
		--maggy-inner-pad:   0 1rem;
	}

	/* 1. Hero */
	.maggy-hero {
		padding: 4.5rem 0 2.5rem;
		min-height: 100svh;
	}
	.maggy-hero__title {
		font-size: clamp(1.8rem, 5vw, 3.5rem);
		margin-bottom: 0.75rem;
	}
	.maggy-hero__subtitle {
		font-size: clamp(0.92rem, 4vw, 1.1rem);
		margin-bottom: 1.5rem;
		padding: 0 0.5rem;
	}
	.maggy-search-widget {
		padding: 1.25rem 1rem;
		margin: 0 0 1.5rem;
	}
	.maggy-search-widget__fields {
		flex-direction: column;
		gap: 0.625rem;
	}
	.maggy-search-widget__field,
	.maggy-search-widget__btn {
		flex: 1 1 auto;
		width: 100%;
	}
	.maggy-trust-badges {
		justify-content: center;
		gap: 0.5rem;
	}
	.maggy-badge { font-size: 0.82rem; padding: 6px 12px; }

	/* Headers de sección */
	.maggy-section__header  { margin-bottom: 1.75rem; }
	.maggy-section__subtitle { font-size: 0.95rem; }

	/* 3. Habitaciones: stack vertical en móvil pequeño */
	.maggy-rooms-grid { gap: 0.875rem; }
	.maggy-room-card {
		flex-direction: column;
		padding: 1.25rem;
		gap: 0.75rem;
	}
	.maggy-room-card__side {
		flex-direction: row;
		align-items: center;
		min-width: 0;
		gap: 0.75rem;
	}

	/* 4. Servicios: 1 columna centrado */
	.maggy-services-grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	.maggy-service-item {
		padding: 1.5rem 1.25rem;
		text-align: center;
	}

	/* 5. Ubicación: stack, mapa más alto */
	.maggy-ubicacion__layout {
		flex-direction: column;
		gap: 1.5rem;
	}
	.maggy-map-wrapper { padding-bottom: 65%; }

	/* 6. Galería: 2 × 3 compacto */
	.maggy-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
		grid-template-rows: repeat(3, 140px);
		gap: 0.5rem;
	}

	/* 7. Opiniones: stack vertical en móvil pequeño */
	.maggy-reviews-grid { gap: 0.875rem; }
	.maggy-review-card {
		flex-direction: column;
		padding: 1.25rem;
		gap: 0.75rem;
	}
	.maggy-review-card__side { min-width: 0; }

	/* 8. FAQ: padding reducido */
	.maggy-faq__question {
		padding: 1rem 1.25rem;
		font-size: 0.95rem;
	}
	.maggy-faq__answer { padding: 0 1.25rem; }
	.maggy-faq__item.is-open .maggy-faq__answer { padding: 0 1.25rem 1rem; }

	/* 9. Footer CTA: stack vertical, botones full-width */
	.maggy-footer-cta { padding: 3rem 0; }
	.maggy-footer-cta__contact {
		flex-direction: column;
		align-items: center;
		gap: 0.75rem;
	}
	.maggy-footer-cta__actions {
		flex-direction: column;
		align-items: stretch;
		gap: 0.75rem;
	}
	.maggy-footer-cta__actions .maggy-btn {
		width: 100%;
		justify-content: center;
	}

	/* 10. Botón flotante */
	.maggy-fab {
		bottom: 16px !important;
		right: 16px !important;
		font-size: 0.875rem !important;
		padding: 12px 18px !important;
	}
}

/* =============================================================
   CALENDARIO POPUP MÓVIL — Date-range picker
   ============================================================= */

/* ── Wrapper del campo de fecha ───────────────────────────── */
.maggy-date-wrapper {
	position: relative;
	display: flex;
	align-items: stretch;
	width: 100%;
}
.maggy-date-wrapper .maggy-search-widget__input {
	width: 100%;
	padding-right: 44px;
	min-width: 0;
	box-sizing: border-box;
}

/* Botón icono calendario — visible en todos los dispositivos */
.maggy-date-btn {
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	width: 44px;
	background: transparent;
	border: none;
	color: rgba(255, 255, 255, 0.72);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	transition: color var(--maggy-trans);
	-webkit-tap-highlight-color: transparent;
}
.maggy-date-btn:hover { color: #fff; }

/* ── Overlay de fondo ─────────────────────────────────────── */
.maggy-cal {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease;
}
.maggy-cal.is-open {
	opacity: 1;
	pointer-events: auto;
}
.maggy-cal__bd {
	position: absolute;
	inset: 0;
	background: rgba(26, 26, 46, 0.55);
}

/* ── Panel deslizable (bottom-sheet) ──────────────────────── */
.maggy-cal__panel {
	position: relative;
	z-index: 1;
	background: #fff;
	border-radius: 20px 20px 0 0;
	padding: 1.5rem 1.25rem 2.25rem;
	width: 100%;
	max-width: 420px;
	box-shadow: 0 -6px 40px rgba(0, 0, 0, 0.18);
	transform: translateY(100%);
	transition: transform 0.32s cubic-bezier(0.34, 1.15, 0.64, 1);
}
.maggy-cal.is-open .maggy-cal__panel {
	transform: translateY(0);
}

/* Drag handle */
.maggy-cal__panel::before {
	content: '';
	display: block;
	width: 40px;
	height: 4px;
	border-radius: 2px;
	background: #ddd;
	margin: 0 auto 1.25rem;
}

/* ── Texto de estado (hint) ───────────────────────────────── */
.maggy-cal__hint {
	text-align: center;
	font-size: 0.875rem;
	color: var(--maggy-gray, #555566);
	margin: 0 0 1rem;
	min-height: 1.5em;
	line-height: 1.5;
	font-family: var(--maggy-font-body, sans-serif);
}
.maggy-cal__hint b { color: var(--maggy-turquesa, #00a99d); font-weight: 700; }

/* ── Navegación de mes ────────────────────────────────────── */
.maggy-cal__nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 0.875rem;
}
.maggy-cal__arr {
	background: none;
	border: 1px solid rgba(0, 169, 157, 0.3);
	border-radius: 50%;
	width: 38px;
	height: 38px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--maggy-turquesa, #00a99d);
	padding: 0;
	transition: background var(--maggy-trans), border-color var(--maggy-trans);
	-webkit-tap-highlight-color: transparent;
}
.maggy-cal__arr:hover,
.maggy-cal__arr:focus-visible {
	background: rgba(0, 169, 157, 0.10);
	border-color: var(--maggy-turquesa, #00a99d);
}
.maggy-cal__month {
	font-size: 1rem;
	font-weight: 700;
	color: var(--maggy-oscuro, #1a1a2e);
	text-transform: capitalize;
	font-family: var(--maggy-font-display, serif);
}

/* ── Cabecera de días de la semana ────────────────────────── */
.maggy-cal__wk {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	margin-bottom: 4px;
}
.maggy-cal__wd {
	text-align: center;
	font-size: 0.68rem;
	font-weight: 700;
	color: #999;
	text-transform: uppercase;
	padding: 5px 0;
	letter-spacing: 0.04em;
}

/* ── Grid de días ─────────────────────────────────────────── */
.maggy-cal__grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 1px;
}

/* Celda base */
.maggy-cal__cell {
	position: relative;
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 0;
	font-size: 0.875rem;
	color: var(--maggy-oscuro, #1a1a2e);
	font-family: var(--maggy-font-body, sans-serif);
	-webkit-tap-highlight-color: transparent;
	outline: none;
}
.maggy-cal__cell.mc-blank { cursor: default; pointer-events: none; }
.maggy-cal__cell[disabled] { cursor: default; }
.maggy-cal__cell.mc-past { color: rgba(0, 0, 0, 0.22); pointer-events: none; }

/* Número del día (círculo) */
.maggy-cal__cell > span {
	position: relative;
	z-index: 1;
	width: 34px;
	height: 34px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	transition: background 0.15s, color 0.15s;
	line-height: 1;
}

/* Fila de rango entre fechas (pseudo-elemento de fondo) */
.maggy-cal__cell::before {
	content: '';
	position: absolute;
	top: 15%;
	bottom: 15%;
	left: 0;
	right: 0;
	background: transparent;
	z-index: 0;
}
.maggy-cal__cell.mc-mid::before {
	background: rgba(0, 169, 157, 0.13);
}
.maggy-cal__cell.mc-start.mc-rafter::before {
	background: rgba(0, 169, 157, 0.13);
	left: 50%;
}
.maggy-cal__cell.mc-end.mc-rbefore::before {
	background: rgba(0, 169, 157, 0.13);
	right: 50%;
}

/* Hoy */
.maggy-cal__cell.mc-today > span {
	font-weight: 700;
	color: var(--maggy-turquesa, #00a99d);
	box-shadow: inset 0 0 0 1.5px rgba(0, 169, 157, 0.5);
}

/* Check-in / Check-out seleccionados */
.maggy-cal__cell.mc-start > span,
.maggy-cal__cell.mc-end > span {
	background: var(--maggy-turquesa, #00a99d);
	color: #fff !important;
	font-weight: 700;
	box-shadow: 0 2px 10px rgba(0, 169, 157, 0.40);
}

/* Hover en celdas habilitadas */
.maggy-cal__cell:not([disabled]):not(.mc-blank):not(.mc-past):hover > span,
.maggy-cal__cell:not([disabled]):not(.mc-blank):not(.mc-past):focus-visible > span {
	background: rgba(0, 169, 157, 0.15);
}

/* ── Footer del panel ─────────────────────────────────────── */
.maggy-cal__foot {
	display: flex;
	gap: 0.75rem;
	margin-top: 1.25rem;
	align-items: center;
}
.maggy-cal__cancel {
	flex: 0 0 auto;
	background: none;
	border: 1px solid #ddd;
	border-radius: 50px;
	padding: 11px 22px;
	cursor: pointer;
	font-size: 0.9rem;
	color: var(--maggy-gray, #555566);
	font-family: var(--maggy-font-body, sans-serif);
	transition: border-color 0.2s, color 0.2s;
}
.maggy-cal__cancel:hover { border-color: #aaa; color: #333; }
.maggy-cal__ok {
	flex: 1;
	min-height: 46px;
	font-size: 0.95rem;
}
.maggy-cal__ok:disabled {
	opacity: 0.40;
	cursor: not-allowed;
	pointer-events: none;
	transform: none !important;
	box-shadow: none !important;
}

@media (prefers-reduced-motion: reduce) {
	.maggy-cal,
	.maggy-cal__panel { transition: none; }
}

/* =============================================================
   MEJORAS VISUALES — Cards de habitaciones con imagen
   ============================================================= */

/* Overflow hidden para que el borde redondeado clip la imagen */
.maggy-comodidades-card {
	overflow: hidden;
}

/* Imagen placeholder (gradiente) encima de cada card */
.maggy-comodidades-card__img {
	width: calc(100% + 3.6rem);
	height: 220px;
	margin: -2rem -1.8rem 1.5rem;
	border-radius: var(--maggy-radius-xl) var(--maggy-radius-xl) 0 0;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	flex-shrink: 0;
}
.maggy-comodidades-card__img-icon {
	font-size: 4rem;
	filter: drop-shadow(0 3px 12px rgba(0, 0, 0, 0.35));
	position: relative;
	z-index: 1;
	user-select: none;
}

/* Gradientes por tipo de habitación */
.maggy-comodidades-card--cabana .maggy-comodidades-card__img {
	background: linear-gradient(145deg, #2d6a4f 0%, #0a3622 55%, #1b4332 100%);
}
.maggy-comodidades-card--suite-parcial .maggy-comodidades-card__img {
	background: linear-gradient(145deg, #1a2a4a 0%, #0d1b2a 55%, #162032 100%);
}
.maggy-comodidades-card--super-suite .maggy-comodidades-card__img {
	background: linear-gradient(145deg, #006d75 0%, #00474d 55%, #003a40 100%);
}

/* Foto real de habitación — cubre todo el contenedor con zoom suave al hover */
.maggy-comodidades-card__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.45s ease;
}
.maggy-comodidades-card:hover .maggy-comodidades-card__img img {
	transform: scale(1.06);
}

/* Overlay sutil encima de la foto (decorativo) */
.maggy-comodidades-card__img::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, transparent 55%, rgba(0, 0, 0, 0.28) 100%);
	pointer-events: none;
}

/* Botón "Ver todas las habitaciones" */
.maggy-habitaciones__ver-todas {
	text-align: center;
	margin-top: 2.5rem;
}
.maggy-habitaciones__ver-todas .maggy-btn--outline {
	color: var(--maggy-turquesa);
	border-color: var(--maggy-turquesa);
	font-size: 1rem;
}

/* Mobile: altura mínima de la imagen */
@media (max-width: 768px) {
	.maggy-comodidades-card__img { height: 180px; }
}
@media (max-width: 480px) {
	.maggy-comodidades-card__img { height: 155px; }
	.maggy-comodidades-card { min-height: 200px; }
}

/* =============================================================
   MEJORAS VISUALES — MotoPress: búsqueda de disponibilidad
   ============================================================= */

/* Wrapper del formulario de búsqueda */
.mphb-search-form,
.mphb_sc_availability_search-wrap,
.mphb_sc_availability_search {
	background: #ffffff !important;
	padding: 2rem !important;
	border-radius: 16px !important;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08) !important;
	max-width: 700px !important;
	margin: 0 auto 2rem !important;
	border: 1px solid rgba(0, 169, 157, 0.12) !important;
}

/* Inputs de fecha en MotoPress */
.mphb-datepick-wrap input,
.mphb-datepick,
.mphb_sc_availability_search input[type="text"] {
	border: 2px solid rgba(0, 169, 157, 0.25) !important;
	border-radius: 8px !important;
	padding: 10px 14px !important;
	width: 100% !important;
	box-sizing: border-box !important;
	font-family: var(--maggy-font-body) !important;
}

/* Botón buscar (clase propia MotoPress) */
.mphb_sc_search-submit,
input.mphb_sc_search-submit,
button.mphb_sc_search-submit {
	background: var(--maggy-turquesa) !important;
	color: #ffffff !important;
	border-radius: 8px !important;
	padding: 14px 32px !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	width: 100% !important;
	margin-top: 16px !important;
	cursor: pointer !important;
	border: none !important;
	font-family: var(--maggy-font-body) !important;
	transition: background var(--maggy-trans) !important;
}
.mphb_sc_search-submit:hover { background: var(--maggy-turquesa-hover) !important; }

/* =============================================================
   MEJORAS VISUALES — MotoPress: cards resultados habitaciones
   ============================================================= */

/* Card contenedor */
.mphb-room-type {
	border: 1px solid rgba(0, 169, 157, 0.15) !important;
}

/* Placeholder cuando no hay imagen */
.mphb-room-type-thumbnail {
	background: linear-gradient(135deg, var(--maggy-turquesa) 0%, var(--maggy-turquesa-hover) 100%) !important;
	min-height: 200px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	overflow: hidden !important;
}
.mphb-room-type-thumbnail:not(:has(img))::after {
	content: '🏨';
	font-size: 3.5rem;
	filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.25));
}

/* Título de la habitación */
.mphb-room-type-title a {
	font-family: var(--maggy-font-display) !important;
	color: var(--maggy-oscuro) !important;
	font-size: 1.4rem !important;
	font-weight: 700 !important;
	text-decoration: none !important;
}

/* Botones Reservar / Ver habitación */
.mphb-book-button,
.mphb-reserve-button,
a.mphb-reserve-button,
.mphb-room-type .button,
.mphb-room-type a.button {
	background: var(--maggy-turquesa) !important;
	color: #ffffff !important;
	border-radius: 8px !important;
	padding: 12px 24px !important;
	text-decoration: none !important;
	display: inline-block !important;
	margin-top: 12px !important;
	border: none !important;
	font-weight: 700 !important;
	font-family: var(--maggy-font-body) !important;
	transition: background var(--maggy-trans), transform 0.15s ease !important;
}
.mphb-book-button:hover,
.mphb-reserve-button:hover,
.mphb-room-type .button:hover {
	background: var(--maggy-turquesa-hover) !important;
	color: #ffffff !important;
	transform: translateY(-2px) !important;
}

/* Precio */
.mphb-price,
.mphb-room-type-price .amount,
.mphb-room-type-price .price {
	color: var(--maggy-turquesa) !important;
	font-weight: 700 !important;
	font-size: 1.2rem !important;
	font-family: var(--maggy-font-display) !important;
}

/* =============================================================
   MEJORAS VISUALES — Checkout completo
   ============================================================= */

/* Secciones del checkout */
.mphb-checkout-section,
.mphb-booking-details-section,
.mphb-customer-details-section,
.mphb-booking-confirmation-section {
	background: #ffffff !important;
	border-radius: 16px !important;
	padding: 28px !important;
	margin-bottom: 20px !important;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06) !important;
	border: 1px solid rgba(0, 169, 157, 0.08) !important;
}

/* Títulos dentro del checkout */
.mphb-checkout h3,
.mphb-checkout h2,
.mphb-checkout-section h3,
.mphb-checkout-section h2,
.mphb-booking-details-section h3,
.mphb-customer-details-section h3 {
	font-family: var(--maggy-font-display) !important;
	color: var(--maggy-oscuro) !important;
	border-bottom: 2px solid var(--maggy-turquesa) !important;
	padding-bottom: 10px !important;
	margin-bottom: 20px !important;
}

/* Inputs del checkout */
.mphb-checkout input[type="text"],
.mphb-checkout input[type="email"],
.mphb-checkout input[type="tel"],
.mphb-checkout select,
.mphb-checkout textarea {
	border: 2px solid rgba(0, 169, 157, 0.20) !important;
	border-radius: 8px !important;
	padding: 10px 14px !important;
	width: 100% !important;
	margin-bottom: 12px !important;
	font-family: var(--maggy-font-body) !important;
	box-sizing: border-box !important;
	transition: border-color var(--maggy-trans) !important;
}
.mphb-checkout input[type="text"]:focus,
.mphb-checkout input[type="email"]:focus,
.mphb-checkout input[type="tel"]:focus,
.mphb-checkout select:focus,
.mphb-checkout textarea:focus {
	border-color: var(--maggy-turquesa) !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(0, 169, 157, 0.12) !important;
}

/* Botón de pago — todos los selectores posibles */
#mphb-payment-form button,
#mphb-payment-form button[type="submit"],
.mphb-checkout button[type="submit"],
input[name="mphb_book_button"],
.mphb-checkout input[type="submit"],
.mphb-payment-btn {
	background: var(--maggy-turquesa) !important;
	color: #ffffff !important;
	border-radius: 8px !important;
	padding: 16px 40px !important;
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	width: 100% !important;
	border: none !important;
	cursor: pointer !important;
	margin-top: 16px !important;
	font-family: var(--maggy-font-body) !important;
	transition: background var(--maggy-trans), transform 0.15s ease !important;
}
#mphb-payment-form button:hover,
input[name="mphb_book_button"]:hover {
	background: var(--maggy-turquesa-hover) !important;
	transform: translateY(-2px) !important;
}

/* Desglose de precio */
.mphb-price-breakdown {
	background: rgba(0, 169, 157, 0.05) !important;
	border-radius: 12px !important;
	padding: 20px !important;
	border: 1px solid rgba(0, 169, 157, 0.15) !important;
	margin-top: 1rem !important;
}

/* Precio total */
.mphb-total-price,
.mphb-total-price .amount {
	font-size: 1.4rem !important;
	font-weight: 700 !important;
	color: var(--maggy-oscuro) !important;
	font-family: var(--maggy-font-display) !important;
}

/* =============================================================
   FIX — Hero widget: un solo ícono de calendario (todos los dispositivos)
   El botón .maggy-date-btn es el único trigger; el ícono nativo se oculta.
   ============================================================= */

/* Ocultar el ícono nativo del browser — selector doble para superar appearance:auto */
input[type="date"].maggy-date-input::-webkit-calendar-picker-indicator,
.maggy-date-input::-webkit-calendar-picker-indicator {
	display: none !important;
	visibility: hidden !important;
	opacity: 0 !important;
	width: 0 !important;
	height: 0 !important;
	padding: 0 !important;
	pointer-events: none !important;
	background: transparent !important;
}
.maggy-date-input::-moz-calendar-picker-indicator {
	display: none !important;
}

/* El input no recibe clics directos: solo el botón los recibe */
.maggy-date-wrapper .maggy-date-input {
	pointer-events: none;
	user-select: none;
	padding-right: 44px;
}
/* El botón sí recibe todos los eventos */
.maggy-date-btn {
	pointer-events: auto;
}

/* =============================================================
   MotoPress — Resultados de búsqueda: diseño mejorado
   ============================================================= */

/* Wrapper principal de resultados */
.maggy-motopress-results-wrap,
.mphb-sc-search-results-wrap {
	padding: 2rem 0 3rem;
}

/* Grid de cards */
.mphb_sc_search_results-wrapper .mphb-rooms-list,
.mphb_sc_search_results-wrapper ul.mphb-room-types-list {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
	gap: 1.75rem !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* Card de resultado individual */
.mphb_sc_search_results-wrapper .mphb-room-type {
	display: flex !important;
	flex-direction: column !important;
	border-radius: 16px !important;
	overflow: hidden !important;
	background: #ffffff !important;
	border: 1px solid rgba(0, 169, 157, 0.15) !important;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06) !important;
	transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}
.mphb_sc_search_results-wrapper .mphb-room-type:hover {
	transform: translateY(-4px) !important;
	box-shadow: 0 12px 40px rgba(0, 169, 157, 0.18) !important;
}

/* Imagen / placeholder de la card — MotoPress usa mphb-loop-room-thumbnail */
.mphb_sc_search_results-wrapper .mphb-room-type-thumbnail,
.mphb_sc_search_results-wrapper .mphb-loop-room-thumbnail {
	background: linear-gradient(135deg, var(--maggy-turquesa) 0%, var(--maggy-turquesa-hover) 100%) !important;
	min-height: 200px !important;
	max-height: 220px !important;
	overflow: hidden !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex-shrink: 0 !important;
}
.mphb_sc_search_results-wrapper .mphb-room-type-thumbnail img,
.mphb_sc_search_results-wrapper .mphb-loop-room-thumbnail img {
	width: 100% !important;
	height: 220px !important;
	object-fit: cover !important;
	display: block !important;
}
.mphb_sc_search_results-wrapper .mphb-loop-room-thumbnail:not(:has(img))::after {
	content: '🏨';
	font-size: 3.5rem;
	filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.25));
}

/* Sección de información de la card */
.mphb_sc_search_results-wrapper .mphb-room-type-info {
	padding: 1.5rem !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0.75rem !important;
	flex: 1 !important;
}

/* Título de la habitación */
.mphb_sc_search_results-wrapper .mphb-room-type-title,
.mphb_sc_search_results-wrapper .mphb-room-type-title a {
	font-family: var(--maggy-font-display) !important;
	font-size: 1.3rem !important;
	font-weight: 700 !important;
	color: var(--maggy-oscuro) !important;
	text-decoration: none !important;
	line-height: 1.2 !important;
	margin: 0 !important;
}

/* Precio */
.mphb_sc_search_results-wrapper .mphb-room-type-price .amount,
.mphb_sc_search_results-wrapper .mphb-price {
	font-size: 1.4rem !important;
	font-weight: 700 !important;
	color: var(--maggy-turquesa) !important;
	font-family: var(--maggy-font-display) !important;
}

/* Ocultar el select de cantidad — el badge "N disponibles" queda visible */
select.mphb-rooms-quantity {
	display: none !important;
}
/* Badge de disponibilidad (span.mphb-available-rooms-count) */
@keyframes maggy-avail-dot {
	0%, 100% { opacity: 1;    }
	50%       { opacity: 0.25; }
}
.mphb-available-rooms-count {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	background: rgba(0, 169, 157, 0.10);
	border: 1.5px solid rgba(0, 169, 157, 0.28);
	color: var(--maggy-turquesa);
	font-size: 0.76rem;
	font-weight: 700;
	padding: 0.28rem 0.85rem;
	border-radius: 20px;
	letter-spacing: 0.02em;
	transition: background 0.3s, border-color 0.3s, color 0.3s;
}
/* Dot pulsante que indica disponibilidad en tiempo real */
.mphb-available-rooms-count::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: currentColor;
	flex-shrink: 0;
	animation: maggy-avail-dot 2.4s ease-in-out infinite;
}
/* Disponibilidad baja (≤ 3 unidades) — ámbar */
.mphb-available-rooms-count.maggy-stock-low {
	background: rgba(245, 158, 11, 0.10);
	border-color: rgba(245, 158, 11, 0.40);
	color: #b45309;
}
.mphb-available-rooms-count.maggy-stock-low::before {
	animation-duration: 1.5s;
}
/* Disponibilidad crítica (1 unidad) — rojo urgente */
.mphb-available-rooms-count.maggy-stock-critical {
	background: rgba(220, 38, 38, 0.08);
	border-color: rgba(220, 38, 38, 0.32);
	color: #dc2626;
}
.mphb-available-rooms-count.maggy-stock-critical::before {
	animation-duration: 0.80s;
}

/* Botón "Ver detalles" — estilo secundario discreto */
.mphb-search-results .mphb-read-more,
.mphb-search-results a.mphb-read-more,
.mphb-search-results .mphb-room-type-link,
.mphb-read-more,
a.mphb-read-more {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 5px !important;
	color: var(--maggy-gray) !important;
	font-size: 0.85rem !important;
	font-weight: 600 !important;
	text-decoration: none !important;
	padding: 7px 16px !important;
	border: 1px solid rgba(0, 0, 0, 0.12) !important;
	border-radius: 50px !important;
	margin-top: 8px !important;
	transition: border-color var(--maggy-trans), color var(--maggy-trans) !important;
	background: transparent !important;
}
.mphb-search-results .mphb-read-more:hover,
a.mphb-read-more:hover {
	border-color: var(--maggy-turquesa) !important;
	color: var(--maggy-turquesa) !important;
}

/* Atributos de la habitación (capacidad, camas, etc.) */
.mphb-search-results .mphb-attributes-list {
	background: rgba(0, 169, 157, 0.04) !important;
	border: 1px solid rgba(0, 169, 157, 0.10) !important;
	border-radius: 8px !important;
	padding: 0.75rem 1rem !important;
	list-style: none !important;
	margin: 0 !important;
	font-size: 0.875rem !important;
	color: var(--maggy-gray) !important;
}
.mphb-search-results .mphb-attributes-list li {
	padding: 2px 0 !important;
}

/* Mensaje sin resultados */
.mphb-search-results .mphb-rooms-not-found,
.mphb-no-rooms-available {
	text-align: center !important;
	padding: 3rem 1.5rem !important;
	background: rgba(0, 169, 157, 0.04) !important;
	border-radius: 16px !important;
	border: 1px solid rgba(0, 169, 157, 0.15) !important;
	color: var(--maggy-gray) !important;
	font-size: 1rem !important;
}

/* =============================================================
   Página: Buscar Disponibilidad — layout de secciones
   ============================================================= */

/* ── Sección de búsqueda: fondo gris, tarjeta blanca centrada ── */
.maggy-buscar-search-section {
	background: #f2f5f6;
	padding: 2.5rem 0 2rem;
	border-bottom: 1px solid rgba(0, 169, 157, 0.10);
}

.maggy-search-card {
	background: #ffffff;
	border-radius: var(--maggy-radius-xl);
	box-shadow: 0 2px 24px rgba(0, 0, 0, 0.07);
	padding: 2rem 2.5rem;
	max-width: 820px;
	margin: 0 auto;
	border: 1px solid rgba(0, 169, 157, 0.10);
}

/* Widget nuestro dentro de .maggy-search-card: transparente, sin sombra propia */
.maggy-search-card .maggy-search-widget {
	background: transparent;
	box-shadow: none;
	border-radius: 0;
	padding: 0;
}

/* Eliminar fondo propio del form MotoPress cuando está dentro de .maggy-search-card */
.maggy-search-card .mphb_sc_availability_search,
.maggy-search-card .mphb-search-form-wrap,
.maggy-search-card .mphb-sc-availability-search-wrap {
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
	padding: 0 !important;
	box-shadow: none !important;
}

/* ── Panel de disponibilidad por subtipo ────────────────────── */
.maggy-avail-panel-section {
	background: #fff;
	padding: 2rem 0 1.5rem;
	border-bottom: 1px solid #e8ecee;
}
.maggy-avail-panel {
	max-width: 680px;
}
.maggy-avail-panel__title {
	font-family: var(--maggy-font-display);
	font-size: 1.1rem;
	color: var(--maggy-oscuro);
	margin-bottom: 1.1rem;
	font-weight: 700;
}
.maggy-avail-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
}
.maggy-avail-item {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.55rem 0.9rem;
	background: #f7f9fa;
	border-radius: 8px;
	border: 1px solid #e4e9eb;
}
.maggy-avail-item--unavailable {
	opacity: 0.65;
}
.maggy-avail-item__icon {
	font-size: 1rem;
	flex-shrink: 0;
	width: 1.4rem;
	text-align: center;
}
.maggy-avail-item__name {
	font-family: var(--maggy-font-body);
	font-size: 0.9rem;
	color: var(--maggy-oscuro);
	flex: 1;
	min-width: 0;
}
.maggy-avail-badge {
	font-size: 0.75rem;
	font-weight: 600;
	padding: 3px 10px;
	border-radius: 50px;
	white-space: nowrap;
	flex-shrink: 0;
}
.maggy-avail-badge--ok {
	background: #d4f0e8;
	color: #0e6b47;
}
.maggy-avail-badge--low {
	background: #fff3cd;
	color: #7a5800;
}
.maggy-avail-badge--none {
	background: #fde8e8;
	color: #9b1c1c;
}

@media (max-width: 480px) {
	.maggy-avail-item {
		flex-wrap: wrap;
		gap: 0.4rem;
	}
	.maggy-avail-item__name {
		flex: 1 1 auto;
	}
}

/* ── Sección de resultados: fondo gris claro ─────────────────── */
.maggy-buscar-results-section {
	background: #f2f5f6;
	padding: 2.5rem 0 4rem;
}

/* ── Grid de resultados custom (maggy-sr-card) ───────────────── */
.maggy-buscar-results-section .mphb_sc_search_results-wrapper {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 1.75rem;
	align-items: start;
}

/* El título "Se encontraron X alojamientos" ocupa toda la fila */
.maggy-buscar-results-section .mphb_sc_search_results-wrapper > p,
.maggy-buscar-results-section .mphb_sc_search_results-wrapper > h2,
.maggy-buscar-results-section .mphb_sc_search_results-wrapper > div:first-child {
	grid-column: 1 / -1;
}

/* Card wrapper */
.maggy-sr-card {
	background: #ffffff;
	border-radius: 14px;
	border: 1px solid rgba(0, 169, 157, 0.12);
	box-shadow: 0 2px 18px rgba(0, 0, 0, 0.05);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.maggy-sr-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 36px rgba(0, 169, 157, 0.15);
}

/* Imagen */
.maggy-sr-card__img-wrap {
	position: relative;
	flex-shrink: 0;
	height: 210px;
	overflow: hidden;
	background: linear-gradient(135deg, #00a99d 0%, #007a73 100%);
}
.maggy-sr-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}
.maggy-sr-card:hover .maggy-sr-card__img {
	transform: scale(1.04);
}
.maggy-sr-card__img--placeholder {
	background: linear-gradient(135deg, #00a99d 0%, #007a73 100%);
}

/* Badge de disponibilidad (overlay sobre imagen) */
.maggy-sr-avail-badge {
	position: absolute;
	top: 12px;
	right: 12px;
	font-size: 0.72rem;
	font-weight: 700;
	padding: 4px 11px;
	border-radius: 50px;
	letter-spacing: 0.01em;
	backdrop-filter: blur(4px);
}
.maggy-sr-avail--ok {
	background: rgba(16, 110, 74, 0.88);
	color: #ffffff;
}
.maggy-sr-avail--low {
	background: rgba(154, 90, 0, 0.88);
	color: #ffffff;
}
.maggy-sr-avail--none {
	background: rgba(155, 28, 28, 0.88);
	color: #ffffff;
}

/* Cuerpo */
.maggy-sr-card__body {
	padding: 1.4rem 1.5rem 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.7rem;
	flex: 1;
}

/* Título */
.maggy-sr-card__title {
	font-family: var(--maggy-font-display);
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--maggy-oscuro);
	margin: 0;
	line-height: 1.3;
}

/* Descripción */
.maggy-sr-card__desc {
	font-size: 0.875rem;
	color: var(--maggy-gray);
	line-height: 1.55;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Servicios */
.maggy-sr-card__services {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

/* Bloque de precio */
.maggy-sr-card__price {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 0.3rem 0.5rem;
	margin-top: 0.1rem;
}
.maggy-sr-card__price-usd {
	font-family: var(--maggy-font-display);
	font-size: 1.35rem;
	font-weight: 800;
	color: var(--maggy-turquesa);
}
.maggy-sr-card__price-cop {
	font-size: 0.82rem;
	font-weight: 500;
	color: #5a6872;
}
.maggy-sr-card__price-label {
	font-size: 0.78rem;
	color: #8a9499;
	width: 100%;
}

/* CTA / botón MotoPress */
.maggy-sr-card__cta {
	margin-top: auto;
	padding-top: 0.25rem;
}

/* Override botón MotoPress Book → turquesa */
.maggy-sr-card .mphb-reserve-room-section {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.maggy-sr-card .mphb-book-button,
.maggy-sr-card button.mphb-book-button {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	background: var(--maggy-turquesa) !important;
	color: #ffffff !important;
	padding: 0.9rem 1.5rem !important;
	border-radius: 10px !important;
	font-family: var(--maggy-font-body) !important;
	font-weight: 700 !important;
	font-size: 0.95rem !important;
	border: none !important;
	cursor: pointer !important;
	box-shadow: 0 4px 14px rgba(0, 169, 157, 0.28) !important;
	transition: background 0.2s ease, transform 0.15s ease !important;
	box-sizing: border-box !important;
	letter-spacing: 0.02em !important;
}
.maggy-sr-card .mphb-book-button:hover,
.maggy-sr-card button.mphb-book-button:hover {
	background: #008f84 !important;
	transform: translateY(-2px) !important;
}
.maggy-sr-card .mphb-confirm-reservation {
	display: block !important;
	width: 100% !important;
	background: var(--maggy-oscuro) !important;
	color: #ffffff !important;
	padding: 0.75rem 1.5rem !important;
	border-radius: 10px !important;
	font-weight: 600 !important;
	font-size: 0.9rem !important;
	border: none !important;
	cursor: pointer !important;
	text-align: center !important;
	box-sizing: border-box !important;
}
.maggy-sr-card .mphb-rooms-quantity-wrapper {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	font-size: 0.82rem;
	color: var(--maggy-gray);
	margin: 0;
}
.maggy-sr-card .mphb-rooms-quantity {
	padding: 0.3rem 0.6rem;
	border: 1px solid rgba(0, 169, 157, 0.25);
	border-radius: 6px;
	font-size: 0.85rem;
}
.maggy-sr-card .mphb-rooms-reservation-message-wrapper {
	font-size: 0.82rem;
}

/* Responsive */
@media (max-width: 768px) {
	.maggy-buscar-results-section .mphb_sc_search_results-wrapper {
		grid-template-columns: 1fr;
	}
}
@media (min-width: 769px) and (max-width: 1023px) {
	.maggy-buscar-results-section .mphb_sc_search_results-wrapper {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Título "Se encontraron X alojamientos…" */
.maggy-buscar-results-section h2,
.maggy-buscar-results-section .mphb-search-results-title,
.maggy-buscar-results-section .mphb-sc-search-results-title {
	font-family: var(--maggy-font-display) !important;
	font-size: clamp(1.1rem, 2.5vw, 1.4rem) !important;
	font-weight: 700 !important;
	color: var(--maggy-oscuro) !important;
	margin: 0 0 1.75rem !important;
	padding-bottom: 1rem !important;
	border-bottom: 2px solid rgba(0, 169, 157, 0.15) !important;
}

/* ── Grid de cards de habitaciones ──────────────────────────── */
.maggy-buscar-results-section .mphb-rooms-list,
.maggy-buscar-results-section ul.mphb-room-types-list,
.maggy-buscar-results-section .mphb-room-types-list,
.maggy-buscar-results-section ul[class*="mphb"] {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)) !important;
	gap: 1.75rem !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* Card individual */
.maggy-buscar-results-section .mphb-room-type,
.maggy-buscar-results-section li.mphb-room-type {
	background: #ffffff !important;
	border-radius: var(--maggy-radius-xl) !important;
	border: 1px solid rgba(0, 169, 157, 0.12) !important;
	box-shadow: 0 2px 18px rgba(0, 0, 0, 0.05) !important;
	overflow: hidden !important;
	display: flex !important;
	flex-direction: column !important;
	transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}

.maggy-buscar-results-section .mphb-room-type:hover {
	transform: translateY(-5px) !important;
	box-shadow: 0 14px 40px rgba(0, 169, 157, 0.14) !important;
}

/* Imagen / placeholder de la card */
.maggy-buscar-results-section .mphb-room-type-thumbnail {
	background: linear-gradient(135deg, var(--maggy-turquesa) 0%, var(--maggy-turquesa-hover) 100%) !important;
	min-height: 200px !important;
	max-height: 220px !important;
	overflow: hidden !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex-shrink: 0 !important;
}

.maggy-buscar-results-section .mphb-room-type-thumbnail img {
	width: 100% !important;
	height: 220px !important;
	object-fit: cover !important;
	display: block !important;
}

/* Body de la card */
.maggy-buscar-results-section .mphb-room-type-info {
	padding: 1.5rem !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0.6rem !important;
	flex: 1 !important;
}

/* Título de habitación */
.maggy-buscar-results-section .mphb-room-type-title,
.maggy-buscar-results-section .mphb-room-type-title a {
	font-family: var(--maggy-font-display) !important;
	font-size: 1.2rem !important;
	font-weight: 700 !important;
	color: var(--maggy-oscuro) !important;
	text-decoration: none !important;
	margin: 0 !important;
	line-height: 1.3 !important;
}

/* Extracto / descripción */
.maggy-buscar-results-section .mphb-room-type-excerpt,
.maggy-buscar-results-section .mphb-room-type-description {
	font-size: 0.9rem !important;
	color: var(--maggy-gray) !important;
	line-height: 1.5 !important;
	margin: 0 !important;
}

/* Atributos (capacidad, camas, etc.) */
.maggy-buscar-results-section .mphb-attributes-list,
.maggy-buscar-results-section ul.mphb-attributes-list {
	background: rgba(0, 169, 157, 0.04) !important;
	border: 1px solid rgba(0, 169, 157, 0.10) !important;
	border-radius: 8px !important;
	padding: 0.7rem 1rem !important;
	list-style: none !important;
	margin: 0.25rem 0 0 !important;
	font-size: 0.85rem !important;
	color: var(--maggy-gray) !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0.25rem !important;
}

/* Precio */
.maggy-buscar-results-section .mphb-room-type-price,
.maggy-buscar-results-section .mphb-price-wrap {
	margin-top: 0.25rem !important;
}
/* COP price — search results MotoPress */
.maggy-buscar-results-section .maggy-cop-price {
	display: inline;
	font-size: 0.78rem;
	font-weight: 400;
	color: #666;
	white-space: nowrap;
}

.maggy-buscar-results-section .mphb-room-type-price .amount,
.maggy-buscar-results-section .mphb-price {
	font-family: var(--maggy-font-display) !important;
	font-size: 1.35rem !important;
	font-weight: 700 !important;
	color: var(--maggy-turquesa) !important;
}

/* Área de acciones — empuja los botones al fondo de la card */
.maggy-buscar-results-section .mphb-room-type-actions {
	margin-top: auto !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 0.6rem !important;
	padding-top: 0.5rem !important;
}

/* Botón "Hacer Reserva" */
.maggy-buscar-results-section .mphb-book-button,
.maggy-buscar-results-section a.mphb-book-button,
.maggy-buscar-results-section .mphb-reserve-button {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	background: var(--maggy-turquesa) !important;
	color: #ffffff !important;
	padding: 0.85rem 1.5rem !important;
	border-radius: 10px !important;
	font-weight: 600 !important;
	font-size: 0.975rem !important;
	text-decoration: none !important;
	border: none !important;
	cursor: pointer !important;
	box-shadow: 0 4px 14px rgba(0, 169, 157, 0.28) !important;
	transition: background var(--maggy-trans), transform 0.15s ease !important;
	box-sizing: border-box !important;
}

.maggy-buscar-results-section .mphb-book-button:hover,
.maggy-buscar-results-section a.mphb-book-button:hover {
	background: var(--maggy-turquesa-hover) !important;
	color: #ffffff !important;
	transform: translateY(-2px) !important;
}

/* Botón "Ver detalles" */
.maggy-buscar-results-section .mphb-read-more,
.maggy-buscar-results-section a.mphb-read-more {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	padding: 0.65rem 1rem !important;
	border: 1.5px solid rgba(0, 169, 157, 0.30) !important;
	border-radius: 8px !important;
	color: var(--maggy-gray) !important;
	font-size: 0.875rem !important;
	text-decoration: none !important;
	background: transparent !important;
	box-sizing: border-box !important;
	transition: border-color var(--maggy-trans), color var(--maggy-trans) !important;
}

.maggy-buscar-results-section .mphb-read-more:hover,
.maggy-buscar-results-section a.mphb-read-more:hover {
	border-color: var(--maggy-turquesa) !important;
	color: var(--maggy-turquesa) !important;
}

/* Sin resultados */
.maggy-buscar-results-section .mphb-rooms-not-found,
.maggy-buscar-results-section .mphb-no-rooms-available {
	text-align: center !important;
	padding: 3rem 1.5rem !important;
	background: rgba(0, 169, 157, 0.04) !important;
	border-radius: var(--maggy-radius-xl) !important;
	border: 1px solid rgba(0, 169, 157, 0.15) !important;
	color: var(--maggy-gray) !important;
	font-size: 1rem !important;
}

/* ── Sección de contacto: fondo blanco ───────────────────────── */
.maggy-buscar-contact-section {
	background: #ffffff;
	padding: 2.5rem 0 3rem;
	border-top: 1px solid rgba(0, 169, 157, 0.10);
}

/* ── Responsive: 1 columna en móvil ─────────────────────────── */
@media (max-width: 640px) {
	.maggy-search-card {
		padding: 1.5rem 1.25rem;
	}

	.maggy-buscar-results-section .mphb-rooms-list,
	.maggy-buscar-results-section ul.mphb-room-types-list {
		grid-template-columns: 1fr !important;
	}
}

/* ── Formulario MotoPress en tarjeta: grilla 2 columnas ─────── */
.maggy-search-card .mphb_sc_availability_search > form,
.maggy-search-card form.mphb_sc_availability_search,
.maggy-search-card .mphb_sc_availability_search fieldset {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	gap: 0.85rem 1.25rem !important;
	align-items: end !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
	min-inline-size: 0 !important;
}
.maggy-search-card .mphb_sc_availability_search form > p,
.maggy-search-card .mphb_sc_availability_search fieldset > p,
.maggy-search-card .mphb_sc_availability_search form > div,
.maggy-search-card .mphb_sc_availability_search fieldset > div {
	margin: 0 !important;
}
.maggy-search-card .mphb_sc_availability_search input[type="submit"],
.maggy-search-card .mphb_sc_availability_search button[type="submit"] {
	grid-column: 1 / -1 !important;
	width: 100% !important;
	padding: 0.85rem 1.5rem !important;
	font-size: 1.05rem !important;
	font-weight: 600 !important;
	border-radius: var(--maggy-radius-lg) !important;
	cursor: pointer !important;
	box-sizing: border-box !important;
}
.maggy-search-card .mphb_sc_availability_search select,
.maggy-search-card .mphb_sc_availability_search input[type="text"],
.maggy-search-card .mphb_sc_availability_search input[type="date"] {
	width: 100% !important;
	box-sizing: border-box !important;
}
@media (max-width: 500px) {
	.maggy-search-card .mphb_sc_availability_search > form,
	.maggy-search-card form.mphb_sc_availability_search,
	.maggy-search-card .mphb_sc_availability_search fieldset {
		grid-template-columns: 1fr !important;
	}
}

/* ── Ocultar sección de recomendación MotoPress ─────────────── */
.maggy-buscar-results-section [class*="mphb-recommend"],
.maggy-buscar-results-section .mphb-rooms-cart,
.maggy-buscar-results-section .mphb-booking-cart {
	display: none !important;
}

/* Ocultar solo el botón "Confirmar Reserva" en el carrito — la barra sticky lo reemplaza */
.maggy-buscar-results-section #mphb-reservation-cart .mphb-confirm-reservation,
.maggy-buscar-results-section .mphb-reservation-cart .mphb-confirm-reservation {
	display: none !important;
}
/* Botón "Confirmar Reserva" dentro del card — outline turquesa, visible con .mphb-rooms-added */
.maggy-buscar-results-section .mphb-reserve-room-section.mphb-rooms-added .mphb-confirm-reservation {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	background: transparent !important;
	color: var(--maggy-turquesa) !important;
	padding: 0.75rem 1.5rem !important;
	border-radius: 10px !important;
	font-weight: 600 !important;
	font-size: 0.95rem !important;
	border: 2px solid var(--maggy-turquesa) !important;
	cursor: pointer !important;
	box-shadow: none !important;
	transition: background var(--maggy-trans), color var(--maggy-trans) !important;
	box-sizing: border-box !important;
	font-family: var(--maggy-font-body) !important;
}
.maggy-buscar-results-section .mphb-reserve-room-section.mphb-rooms-added .mphb-confirm-reservation:hover {
	background: var(--maggy-turquesa) !important;
	color: #ffffff !important;
}

/* ── Barra sticky de confirmación ───────────────────────────── */
.maggy-sticky-confirm {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 9998;
	background: #ffffff;
	border-top: 3px solid var(--maggy-turquesa);
	box-shadow: 0 -4px 28px rgba(0,0,0,0.14);
	padding: 0.9rem 1.5rem;
	display: flex;
	align-items: center;
	gap: 1rem;
	transform: translateY(100%);
	transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.maggy-sticky-confirm.is-active {
	transform: translateY(0);
}
.maggy-sticky-confirm__label {
	flex: 1;
	font-size: 0.88rem;
	color: var(--maggy-gray);
	line-height: 1.4;
}
.maggy-sticky-confirm__label strong {
	display: block;
	font-size: 1rem;
	color: var(--maggy-oscuro);
	font-weight: 700;
}
.maggy-sticky-confirm__btn {
	flex-shrink: 0;
	background: var(--maggy-turquesa) !important;
	color: #ffffff !important;
	padding: 0.8rem 2rem !important;
	border-radius: var(--maggy-radius-lg) !important;
	font-weight: 700 !important;
	font-size: 0.95rem !important;
	text-decoration: none !important;
	white-space: nowrap;
	border: none !important;
	cursor: pointer !important;
	font-family: var(--maggy-font-body) !important;
	transition: background var(--maggy-trans), transform 0.15s ease !important;
	display: inline-block !important;
}
.maggy-sticky-confirm__btn:hover {
	background: var(--maggy-turquesa-hover) !important;
	transform: translateY(-2px) !important;
	color: #ffffff !important;
}
@media (max-width: 480px) {
	.maggy-sticky-confirm {
		flex-direction: column;
		align-items: stretch;
		padding: 1rem;
	}
	.maggy-sticky-confirm__btn {
		text-align: center !important;
		padding: 0.85rem 1rem !important;
	}
}

/* ── Selector de cantidad de habitaciones ────────────────────── */
.maggy-buscar-results-section input[name="mphb_rooms"],
.maggy-buscar-results-section select[name="mphb_rooms"],
.maggy-buscar-results-section .mphb-rooms-count {
	width: 80px !important;
	padding: 0.45rem 0.6rem !important;
	border: 2px solid rgba(0,169,157,0.30) !important;
	border-radius: 8px !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	text-align: center !important;
	color: var(--maggy-oscuro) !important;
	background: #ffffff !important;
	transition: border-color var(--maggy-trans) !important;
	-moz-appearance: textfield !important;
	appearance: textfield !important;
}
.maggy-buscar-results-section input[name="mphb_rooms"]:focus,
.maggy-buscar-results-section select[name="mphb_rooms"]:focus {
	border-color: var(--maggy-turquesa) !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(0,169,157,0.12) !important;
}
/* Mensaje "X × Habitación añadida a su reserva" */
.maggy-buscar-results-section .mphb-notice,
.maggy-buscar-results-section .mphb-success {
	background: rgba(0,169,157,0.06) !important;
	border-left: 3px solid var(--maggy-turquesa) !important;
	border-radius: 0 8px 8px 0 !important;
	padding: 0.5rem 0.75rem !important;
	font-size: 0.85rem !important;
	color: var(--maggy-oscuro) !important;
	margin: 0.5rem 0 !important;
}
/* "Borrar" / "Remove" link — discreto */
.maggy-buscar-results-section a.mphb-remove-room-from-cart,
.maggy-buscar-results-section a.mphb-remove-from-reservation {
	font-size: 0.78rem !important;
	color: var(--maggy-gray) !important;
	text-decoration: underline !important;
}
.maggy-buscar-results-section a.mphb-remove-room-from-cart:hover,
.maggy-buscar-results-section a.mphb-remove-from-reservation:hover {
	color: var(--maggy-oscuro) !important;
}
/* Heading "Detalles" dentro de las cards: reducir tamaño */
.maggy-buscar-results-section .mphb-room-type-info h2,
.maggy-buscar-results-section .mphb-room-type-info h3,
.maggy-buscar-results-section .mphb-room-type-info h4 {
	font-size: 0.75rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	color: var(--maggy-gray) !important;
	margin: 1rem 0 0.4rem !important;
}

/* =============================================================
   FIX — Select de adultos: forzar valor inicial visible
   ============================================================= */

/* Oculta la opción vacía "Elegir —" en navegadores que lo soporten */
select[name*="adults"] option[value=""],
select[name*="adults"] option:disabled:first-child {
	display: none;
}

/* =============================================================
   TARJETAS DE RESULTADOS — [mphb_search_results]
   Diseño premium horizontal: imagen izquierda | contenido derecha
   ============================================================= */

/* Info "X alojamientos encontrados desde … hasta …" */
.mphb_sc_search_results-info,
.mphb_sc_search_results-wrapper > p:first-child {
	font-size: 0.92rem;
	color: var(--maggy-gray);
	margin: 0 0 2rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(0, 169, 157, 0.12);
}

/* Wrapper general: columna con gap uniforme */
.maggy-buscar-results-section .mphb_sc_search_results-wrapper {
	display: flex;
	flex-direction: column;
	gap: 0;
}

/* ── Tarjeta individual ─────────────────────────────────── */
.mphb_sc_search_results-wrapper .mphb-room-type {
	background: var(--maggy-blanco);
	border-radius: var(--maggy-radius-xl);
	box-shadow: var(--maggy-shadow-md);
	border: 1px solid rgba(0, 169, 157, 0.10);
	border-top: 3px solid var(--maggy-turquesa);
	overflow: hidden;
	display: grid;
	grid-template-columns: 320px 1fr;
	grid-template-rows: auto;
	margin-top: 0 !important;
	margin-bottom: 2rem;
	transition: box-shadow var(--maggy-trans), transform var(--maggy-trans);
}
.mphb_sc_search_results-wrapper .mphb-room-type:hover {
	box-shadow: var(--maggy-shadow-hover);
	transform: translateY(-3px);
}

/* ── Sin imagen: colapsamos a 1 columna (grid con columna vacía) ── */
.mphb_sc_search_results-wrapper .mphb-room-type:not(:has(.post-thumbnail)):not(:has(.mphb-loop-room-thumbnail)):not(:has(.mphb-room-type-images)) {
	grid-template-columns: 1fr !important;
}
.mphb_sc_search_results-wrapper .mphb-room-type:not(:has(.post-thumbnail)):not(:has(.mphb-loop-room-thumbnail)):not(:has(.mphb-room-type-images)) > * {
	grid-column: 1 !important;
}

/* ── Imagen ─────────────────────────────────────────────── */
.mphb_sc_search_results-wrapper .mphb-room-type .post-thumbnail,
.mphb_sc_search_results-wrapper .mphb-room-type .mphb-loop-room-thumbnail,
.mphb_sc_search_results-wrapper .mphb-room-type .mphb-room-type-images {
	grid-column: 1;
	grid-row: 1 / -1;
	margin: 0;
	padding: 0;
	overflow: hidden;
	line-height: 0;
}
.mphb_sc_search_results-wrapper .mphb-room-type .post-thumbnail a,
.mphb_sc_search_results-wrapper .mphb-room-type .mphb-loop-room-thumbnail a {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 260px;
}
.mphb_sc_search_results-wrapper .mphb-room-type .post-thumbnail img,
.mphb_sc_search_results-wrapper .mphb-room-type .mphb-loop-room-thumbnail img,
.mphb_sc_search_results-wrapper .mphb-room-type .mphb-room-type-images img {
	width: 100%;
	height: 100%;
	min-height: 260px;
	object-fit: cover;
	display: block;
	transition: transform 0.45s ease;
}
.mphb_sc_search_results-wrapper .mphb-room-type:hover .post-thumbnail img,
.mphb_sc_search_results-wrapper .mphb-room-type:hover .mphb-loop-room-thumbnail img {
	transform: scale(1.05);
}

/* ── Columna de contenido — todos los hijos que no son imagen ── */
.mphb_sc_search_results-wrapper .mphb-room-type > *:not(.post-thumbnail):not(.mphb-loop-room-thumbnail):not(.mphb-room-type-images) {
	grid-column: 2;
	padding-left: 2rem;
	padding-right: 2rem;
}

/* ── Título ─────────────────────────────────────────────── */
.mphb_sc_search_results-wrapper h2.mphb-room-type-title {
	font-family: var(--maggy-font-display);
	font-size: 1.45rem;
	color: var(--maggy-oscuro);
	margin: 1.5rem 0 0.4rem;
	line-height: 1.25;
}
.mphb_sc_search_results-wrapper h2.mphb-room-type-title a.mphb-room-type-title {
	color: var(--maggy-oscuro);
	text-decoration: none;
	transition: color var(--maggy-trans);
}
.mphb_sc_search_results-wrapper h2.mphb-room-type-title a.mphb-room-type-title:hover {
	color: var(--maggy-turquesa);
}

/* ── Excerpt / descripción ──────────────────────────────── */
.mphb_sc_search_results-wrapper .mphb-room-type > p:not(.mphb-regular-price):not(.mphb-view-details-button-wrapper):not(.post-thumbnail):not(.mphb-loop-room-thumbnail) {
	color: var(--maggy-gray);
	font-size: 0.875rem;
	font-style: italic;
	line-height: 1.6;
	margin: 0 0 0.25rem;
	border-left: 2px solid rgba(0, 169, 157, 0.35) !important;
	padding-left: 0.75rem !important;
}

/* ── Atributos (Guests, Cama, Amenities) ────────────────── */
.mphb_sc_search_results-wrapper .mphb-room-type-details-title {
	font-size: 0.64rem !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.12em !important;
	color: var(--maggy-turquesa) !important;
	margin: 0.875rem 0 0.45rem !important;
}
.mphb_sc_search_results-wrapper .mphb-loop-room-type-attributes {
	list-style: none;
	padding: 0;
	margin: 0 0 0.75rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}
.mphb_sc_search_results-wrapper .mphb-loop-room-type-attributes li {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	margin: 0 !important;
	padding: 0.22rem 0.65rem !important;
	border: 1px solid rgba(0, 169, 157, 0.20) !important;
	border-radius: 50px !important;
	background: rgba(0, 169, 157, 0.05) !important;
	font-size: 0.78rem;
}
.mphb_sc_search_results-wrapper .mphb-loop-room-type-attributes .mphb-attribute-title {
	color: var(--maggy-gray);
	font-weight: 500;
	font-size: 0.76rem;
}
.mphb_sc_search_results-wrapper .mphb-loop-room-type-attributes .mphb-attribute-value {
	color: var(--maggy-oscuro);
	font-weight: 700;
	font-size: 0.78rem;
}

/* ── Precio para las fechas seleccionadas ───────────────── */
.mphb_sc_search_results-wrapper .mphb-regular-price {
	margin: 0.75rem 0 0.5rem;
	line-height: 1.2;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	background: linear-gradient(135deg, rgba(0, 169, 157, 0.05) 0%, rgba(0, 169, 157, 0.09) 100%);
	border: 1px solid rgba(0, 169, 157, 0.16);
	border-radius: 12px;
	padding: 0.75rem 1rem;
}
.mphb_sc_search_results-wrapper .mphb-regular-price strong {
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--maggy-turquesa);
	display: block;
	margin-bottom: 2px;
}
/* Precio numérico: oscuro + Playfair (grande, sin subrayado) */
.mphb_sc_search_results-wrapper .mphb-regular-price .mphb-price,
.mphb_sc_search_results-wrapper .mphb-regular-price .amount,
.mphb_sc_search_results-wrapper .mphb-price {
	color: var(--maggy-oscuro);
	font-family: var(--maggy-font-display);
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.1;
}
/* Eliminar subrayado punteado en precio y sus descendientes */
.mphb_sc_search_results-wrapper .mphb-regular-price,
.mphb_sc_search_results-wrapper .mphb-regular-price *,
.mphb_sc_search_results-wrapper .mphb-regular-price a {
	text-decoration: none !important;
	border-bottom: none !important;
}

/* ── Área de botones ────────────────────────────────────── */
.mphb_sc_search_results-wrapper .mphb-to-book-btn-wrapper {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0.6rem;
	padding-top: 0.75rem;
	padding-bottom: 1.75rem !important;
	border-top: 1px solid rgba(0,169,157,0.10);
}
.mphb_sc_search_results-wrapper .mphb-to-book-btn-wrapper br {
	display: none;
}
.mphb_sc_search_results-wrapper .mphb-view-details-button-wrapper {
	padding-bottom: 0.75rem !important;
	margin: 0;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

/* "Hacer reserva" — CTA principal turquesa, full-width */
.mphb_sc_search_results-wrapper .mphb-book-button,
.mphb_sc_search_results-wrapper .button.mphb-book-button {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 100% !important;
	text-align: center;
	background: var(--maggy-turquesa);
	color: #fff !important;
	border: 2px solid var(--maggy-turquesa);
	border-radius: 50px;
	padding: 0.875rem 1.75rem;
	font-family: var(--maggy-font-body);
	font-size: 0.975rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	text-decoration: none;
	cursor: pointer;
	transition: background var(--maggy-trans), transform 0.15s ease, box-shadow var(--maggy-trans);
	box-shadow: 0 4px 16px rgba(0, 169, 157, 0.32);
	box-sizing: border-box;
}
.mphb_sc_search_results-wrapper .mphb-book-button:hover,
.mphb_sc_search_results-wrapper .button.mphb-book-button:hover {
	background: var(--maggy-turquesa-hover);
	border-color: var(--maggy-turquesa-hover);
	color: #fff !important;
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0, 169, 157, 0.42);
}

/* "Ver detalles" — pill outline turquesa discreto */
.mphb_sc_search_results-wrapper .mphb-view-details-button,
.mphb_sc_search_results-wrapper .button.mphb-view-details-button {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	background: transparent !important;
	border: 1.5px solid rgba(0,169,157,0.35) !important;
	border-radius: 50px !important;
	box-shadow: none !important;
	color: var(--maggy-gray) !important;
	font-size: 0.80rem;
	font-weight: 600;
	text-decoration: none !important;
	padding: 5px 14px !important;
	cursor: pointer;
	transition: border-color var(--maggy-trans), color var(--maggy-trans), background var(--maggy-trans);
	white-space: nowrap;
}
.mphb_sc_search_results-wrapper .mphb-view-details-button:hover,
.mphb_sc_search_results-wrapper .button.mphb-view-details-button:hover {
	border-color: var(--maggy-turquesa) !important;
	color: var(--maggy-turquesa) !important;
	background: rgba(0,169,157,0.05) !important;
}

/* Mensaje "habitación añadida" / botón quitar */
.mphb_sc_search_results-wrapper .mphb-reserve-room-section {
	grid-column: 2;
}
.mphb_sc_search_results-wrapper .mphb-rooms-reservation-message-wrapper {
	display: flex !important;
	flex-direction: row !important;
	align-items: baseline !important;
	gap: 0.5rem !important;
	font-size: 0.875rem;
	background: rgba(0,169,157,0.05);
	border: 1px solid rgba(0,169,157,0.15);
	border-radius: var(--maggy-radius);
	padding: 0.5rem 0.875rem;
}
.mphb_sc_search_results-wrapper .mphb-rooms-reservation-message {
	flex: 1 !important;
	min-width: 0 !important;
	margin: 0 !important;
	font-size: 0.85rem !important;
	color: var(--maggy-gray) !important;
	line-height: 1.45 !important;
}
.mphb_sc_search_results-wrapper .mphb-remove-from-reservation {
	float: none !important;
	display: inline !important;
	order: 99 !important;
	flex-shrink: 0 !important;
	font-size: 0.78rem !important;
	color: var(--maggy-gray) !important;
	cursor: pointer !important;
	text-decoration: underline !important;
	background: none !important;
	border: none !important;
	padding: 0 !important;
	white-space: nowrap !important;
	box-shadow: none !important;
}
.mphb_sc_search_results-wrapper .mphb-remove-from-reservation:hover {
	color: var(--maggy-oscuro) !important;
}
.mphb_sc_search_results-wrapper .mphb-remove-from-reservation::before {
	content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23555566' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3 6 5 6 21 6'/%3E%3Cpath d='M19 6l-1 14H6L5 6'/%3E%3Cpath d='M10 11v6'/%3E%3Cpath d='M14 11v6'/%3E%3Cpath d='M9 6V4h6v2'/%3E%3C%2Fsvg%3E");
	vertical-align: -2px;
	margin-right: 3px;
	opacity: 0.60;
	transition: opacity 0.2s ease;
}
.mphb_sc_search_results-wrapper .mphb-remove-from-reservation:hover::before {
	opacity: 1;
}

/* ── Carrito de reserva ─────────────────────────────────── */
.mphb_sc_search_results-wrapper .mphb-reservation-cart {
	background: var(--maggy-blanco);
	border-radius: var(--maggy-radius-xl);
	box-shadow: var(--maggy-shadow-md);
	border: 1px solid rgba(0, 169, 157, 0.15);
	border-left: 4px solid var(--maggy-turquesa);
	padding: 1.5rem 2rem;
	margin: 0 0 2rem;
}
.mphb_sc_search_results-wrapper .mphb-reservation-cart .mphb-cart-total-price {
	font-family: var(--maggy-font-display);
	font-size: 1.25rem;
	color: var(--maggy-oscuro);
	margin: 0.5rem 0;
}
.mphb_sc_search_results-wrapper .mphb-reservation-cart .mphb-cart-total-price-value {
	color: var(--maggy-turquesa);
	font-weight: 700;
}
.mphb_sc_search_results-wrapper .mphb-reservation-cart .mphb-confirm-reservation,
.mphb_sc_search_results-wrapper .mphb-reservation-cart .button.mphb-confirm-reservation {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--maggy-turquesa);
	color: #fff !important;
	border: 2px solid var(--maggy-turquesa);
	border-radius: var(--maggy-radius-lg);
	padding: 0.75rem 2rem;
	font-family: var(--maggy-font-body);
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	cursor: pointer;
	transition: background var(--maggy-trans), box-shadow var(--maggy-trans);
	margin-top: 0.75rem;
	width: 100%;
	box-shadow: 0 4px 14px rgba(0, 169, 157, 0.28);
}
.mphb_sc_search_results-wrapper .mphb-reservation-cart .mphb-confirm-reservation:hover {
	background: #008f85;
	border-color: #008f85;
	box-shadow: 0 6px 20px rgba(0, 169, 157, 0.40);
}
/* Carrito vacío: ocultar botón confirmar y total (MotoPress lo maneja con JS) */
.mphb_sc_search_results-wrapper .mphb-reservation-cart.mphb-empty-cart {
	display: none;
}

/* ── Responsive: 1 columna en móvil ─────────────────────── */
@media (max-width: 860px) {
	.mphb_sc_search_results-wrapper .mphb-room-type {
		grid-template-columns: 1fr;
	}
	.mphb_sc_search_results-wrapper .mphb-room-type .post-thumbnail,
	.mphb_sc_search_results-wrapper .mphb-room-type .mphb-loop-room-thumbnail,
	.mphb_sc_search_results-wrapper .mphb-room-type .mphb-room-type-images {
		grid-column: 1;
		grid-row: 1;
		min-height: 210px;
	}
	.mphb_sc_search_results-wrapper .mphb-room-type .post-thumbnail img,
	.mphb_sc_search_results-wrapper .mphb-room-type .mphb-loop-room-thumbnail img {
		min-height: 210px;
	}
	.mphb_sc_search_results-wrapper .mphb-room-type > *:not(.post-thumbnail):not(.mphb-loop-room-thumbnail):not(.mphb-room-type-images) {
		grid-column: 1;
		padding-left: 1.25rem;
		padding-right: 1.25rem;
	}
	.mphb_sc_search_results-wrapper .mphb-reserve-room-section {
		grid-column: 1;
	}
	.mphb_sc_search_results-wrapper .mphb-to-book-btn-wrapper {
		flex-direction: column;
		align-items: stretch;
		gap: 0.5rem;
	}
	.mphb_sc_search_results-wrapper .mphb-book-button,
	.mphb_sc_search_results-wrapper .button.mphb-book-button {
		width: 100% !important;
		text-align: center;
		justify-content: center;
	}
}

/* =============================================================
   PÁGINA SINGLE DE HABITACIÓN — body.single-mphb_room_type
   Estilos para la ficha de detalle generada por MotoPress
   ("Ver detalles" desde los resultados de búsqueda)
   ============================================================= */

/* ── Headings de sección ─────────────────────────────────────── */
.single-mphb_room_type .mphb-details-title,
.single-mphb_room_type .mphb-calendar-title,
.single-mphb_room_type .mphb-reservation-form-title {
	font-family: var(--maggy-font-body) !important;
	font-size: 0.70rem !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.12em !important;
	color: var(--maggy-turquesa) !important;
	border-bottom: 1px solid rgba(0, 169, 157, 0.15) !important;
	padding-bottom: 0.5rem !important;
	margin: 2rem 0 0.75rem !important;
}

/* ── Lista de atributos ──────────────────────────────────────── */
.single-mphb_room_type ul.mphb-single-room-type-attributes {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 0 1.5rem !important;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}
.single-mphb_room_type ul.mphb-single-room-type-attributes li {
	display: flex;
	gap: 0.5rem;
	align-items: baseline;
	font-size: 0.9rem;
	padding: 0.35rem 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}
.single-mphb_room_type ul.mphb-single-room-type-attributes li:last-child {
	border-bottom: none;
}
.single-mphb_room_type .mphb-attribute-title {
	color: var(--maggy-gray);
	font-weight: 600;
	flex-shrink: 0;
	min-width: 90px;
}
.single-mphb_room_type .mphb-attribute-value {
	color: var(--maggy-oscuro);
}

/* ── Precio: sin subrayado punteado ──────────────────────────── */
.single-mphb_room_type .mphb-regular-price,
.single-mphb_room_type .mphb-regular-price * {
	text-decoration: none !important;
	border-bottom: none !important;
}
.single-mphb_room_type .mphb-regular-price strong {
	font-size: 0.65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--maggy-turquesa);
	display: block;
	margin-bottom: 2px;
}
.single-mphb_room_type .mphb-regular-price .mphb-price,
.single-mphb_room_type .mphb-regular-price .amount {
	font-family: var(--maggy-font-display);
	font-size: 2rem;
	font-weight: 700;
	color: var(--maggy-oscuro);
}

/* ── Formulario de reserva ───────────────────────────────────── */
.single-mphb_room_type .mphb-booking-form {
	background: #f6fffe;
	border: 1px solid rgba(0, 169, 157, 0.15);
	border-radius: var(--maggy-radius-xl);
	padding: 1.5rem;
	margin-top: 0.5rem;
}
.single-mphb_room_type .mphb-required-fields-tip {
	font-size: 0.78rem !important;
	color: var(--maggy-gray) !important;
	margin-bottom: 1rem !important;
}
.single-mphb_room_type .mphb-booking-form label {
	display: block;
	font-size: 0.76rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--maggy-gray);
	margin-bottom: 0.3rem;
}
.single-mphb_room_type .mphb-datepick,
.single-mphb_room_type .mphb-booking-form select {
	width: 100%;
	padding: 0.65rem 0.875rem !important;
	border: 2px solid rgba(0, 169, 157, 0.25) !important;
	border-radius: 10px !important;
	font-size: 0.95rem !important;
	color: var(--maggy-oscuro) !important;
	background: #ffffff !important;
	box-shadow: none !important;
	transition: border-color var(--maggy-trans), box-shadow var(--maggy-trans);
}
.single-mphb_room_type .mphb-datepick:focus,
.single-mphb_room_type .mphb-booking-form select:focus {
	border-color: var(--maggy-turquesa) !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(0, 169, 157, 0.12) !important;
}
.single-mphb_room_type .mphb-check-in-date-wrapper,
.single-mphb_room_type .mphb-check-out-date-wrapper,
.single-mphb_room_type .mphb-adults-wrapper,
.single-mphb_room_type .mphb-children-wrapper {
	margin-bottom: 1rem !important;
}

/* ── Botón "Comprobar disponibilidad" → turquesa ─────────────── */
.single-mphb_room_type .mphb-reserve-btn-wrapper {
	margin-top: 0.25rem !important;
}
.single-mphb_room_type .mphb-reserve-btn,
.single-mphb_room_type input.mphb-reserve-btn,
.single-mphb_room_type .button.mphb-reserve-btn {
	display: block !important;
	width: 100% !important;
	text-align: center !important;
	background: var(--maggy-turquesa) !important;
	color: #ffffff !important;
	border: 2px solid var(--maggy-turquesa) !important;
	border-radius: 50px !important;
	padding: 0.875rem 1.75rem !important;
	font-family: var(--maggy-font-body) !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.03em !important;
	cursor: pointer !important;
	transition: background var(--maggy-trans), box-shadow var(--maggy-trans) !important;
	box-shadow: 0 4px 16px rgba(0, 169, 157, 0.28) !important;
	-webkit-appearance: none;
	appearance: none;
}
.single-mphb_room_type .mphb-reserve-btn:hover,
.single-mphb_room_type input.mphb-reserve-btn:hover,
.single-mphb_room_type .button.mphb-reserve-btn:hover {
	background: var(--maggy-turquesa-hover) !important;
	border-color: var(--maggy-turquesa-hover) !important;
	box-shadow: 0 8px 24px rgba(0, 169, 157, 0.40) !important;
	transform: translateY(-2px);
}

/* =============================================================
   SINGLE ROOM — Mejoras visuales v2
   Jerarquía visual, iconos, cabecera premium
   ============================================================= */

/* Centra contenido en desktop */
.single-mphb_room_type .inside-article {
	max-width: 780px;
	margin: 0 auto;
	padding-bottom: 3rem;
}

/* ── Hero strip: gradiente sutil + barra turquesa ─────────── */
.single-mphb_room_type .entry-header {
	position: relative;
	padding: 2rem 1.5rem 1.75rem;
	background: linear-gradient(155deg,
		rgba(0, 169, 157, 0.05) 0%,
		rgba(26, 26, 46, 0.03) 100%
	);
	overflow: hidden;
}
.single-mphb_room_type .entry-header::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 4px;
	background: linear-gradient(90deg,
		var(--maggy-turquesa) 0%,
		rgba(0, 169, 157, 0.3) 80%,
		transparent 100%
	);
}
.single-mphb_room_type .entry-header::after {
	content: '';
	position: absolute;
	bottom: -30px; right: -30px;
	width: 140px; height: 140px;
	border-radius: 50%;
	background: radial-gradient(circle,
		rgba(0, 169, 157, 0.08) 0%, transparent 70%
	);
	pointer-events: none;
}

/* ── H1: Playfair + underline turquesa ───────────────────── */
.single-mphb_room_type h1.entry-title {
	font-family: var(--maggy-font-display) !important;
	font-size: clamp(1.65rem, 4.5vw, 2.5rem) !important;
	font-weight: 700 !important;
	color: var(--maggy-oscuro) !important;
	line-height: 1.2 !important;
	margin: 0 0 0.5rem !important;
}
.single-mphb_room_type h1.entry-title::after {
	content: '';
	display: block;
	width: 44px;
	height: 3px;
	background: var(--maggy-turquesa);
	border-radius: 2px;
	margin-top: 0.6rem;
}

/* ── Excerpt: Cormorant italic ────────────────────────────── */
.single-mphb_room_type .entry-content > p:first-of-type {
	font-family: var(--maggy-font-accent) !important;
	font-style: italic !important;
	font-size: 1.05rem !important;
	color: var(--maggy-gray) !important;
	line-height: 1.65 !important;
	margin-bottom: 1.5rem !important;
	padding-left: 0 !important;
	border-left: none !important;
}

/* ── Precio: tarjeta con border-left turquesa ─────────────── */
.single-mphb_room_type .mphb-regular-price {
	display: flex !important;
	flex-direction: column !important;
	background: linear-gradient(135deg,
		rgba(0, 169, 157, 0.07) 0%,
		rgba(0, 169, 157, 0.12) 100%
	) !important;
	border: 1px solid rgba(0, 169, 157, 0.20) !important;
	border-left: 3px solid var(--maggy-turquesa) !important;
	border-bottom: none !important;
	border-radius: 14px !important;
	padding: 1.1rem 1.4rem !important;
	margin: 1.5rem 0 1.75rem !important;
	text-decoration: none !important;
}
.single-mphb_room_type .mphb-regular-price strong {
	font-size: 0.60rem !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.14em !important;
	color: var(--maggy-turquesa) !important;
	display: block !important;
	margin-bottom: 3px !important;
}
.single-mphb_room_type .mphb-regular-price .mphb-price,
.single-mphb_room_type .mphb-regular-price .amount {
	font-family: var(--maggy-font-display) !important;
	font-size: 2.25rem !important;
	font-weight: 700 !important;
	color: var(--maggy-oscuro) !important;
	line-height: 1.1 !important;
}

/* ── Atributos: hover feedback + iconos por tipo ─────────── */
.single-mphb_room_type ul.mphb-single-room-type-attributes li {
	padding: 0.6rem 0.6rem !important;
	border-radius: 8px;
	transition: background 0.15s ease;
}
.single-mphb_room_type ul.mphb-single-room-type-attributes li:hover {
	background: rgba(0, 169, 157, 0.04) !important;
}
.single-mphb_room_type .mphb-attribute-title {
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.35rem !important;
}
/* Icon: adultos / capacidad */
.single-mphb_room_type .mphb-attribute-item-adults .mphb-attribute-title::before,
.single-mphb_room_type .mphb-attribute-item-total-capacity .mphb-attribute-title::before {
	content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%2300a99d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 20c0-4 3.6-7 8-7s8 3 8 7'/%3E%3C%2Fsvg%3E");
	vertical-align: -2px;
	flex-shrink: 0;
}
/* Icon: vista */
.single-mphb_room_type .mphb-attribute-item-view .mphb-attribute-title::before {
	content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%2300a99d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C%2Fsvg%3E");
	vertical-align: -2px;
	flex-shrink: 0;
}
/* Icon: tipo de cama */
.single-mphb_room_type .mphb-attribute-item-bed .mphb-attribute-title::before,
.single-mphb_room_type .mphb-attribute-item-bed-type .mphb-attribute-title::before,
.single-mphb_room_type .mphb-attribute-item-bedtype .mphb-attribute-title::before {
	content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%2300a99d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='7' width='20' height='14' rx='2'/%3E%3Cpath d='M16 7V5a2 2 0 0 0-2-2h-4a2 2 0 0 0-2 2v2'/%3E%3C%2Fsvg%3E");
	vertical-align: -2px;
	flex-shrink: 0;
}
/* Icon: niños */
.single-mphb_room_type .mphb-attribute-item-children .mphb-attribute-title::before {
	content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%2300a99d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='6' r='3'/%3E%3Cpath d='M6 21v-2a4 4 0 0 1 4-4h4a4 4 0 0 1 4 4v2'/%3E%3C%2Fsvg%3E");
	vertical-align: -2px;
	flex-shrink: 0;
}
/* Icon: servicios / facilities */
.single-mphb_room_type .mphb-attribute-item-facilities .mphb-attribute-title::before {
	content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%2300a99d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpolyline points='22 4 12 14.01 9 11.01'/%3E%3C%2Fsvg%3E");
	vertical-align: -2px;
	flex-shrink: 0;
}

/* ── Calendario: card con borde + sombra ──────────────────── */
.single-mphb_room_type .mphb-datepick-wrap {
	border: 1px solid rgba(0, 169, 157, 0.18) !important;
	border-radius: var(--maggy-radius-xl) !important;
	overflow: hidden !important;
	box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06) !important;
	margin-bottom: 0.5rem !important;
}

/* ── Formulario: border-top turquesa + sombra suave ───────── */
.single-mphb_room_type .mphb-booking-form {
	background: linear-gradient(145deg, #f5fffd 0%, #f0fffe 100%) !important;
	border: 1px solid rgba(0, 169, 157, 0.15) !important;
	border-top: 3px solid var(--maggy-turquesa) !important;
	box-shadow: 0 4px 18px rgba(0, 169, 157, 0.06) !important;
}
