/*!
 * SBC Theme — Single Beach Listing styles v4.0
 * Scoped under .sbc-listing to leave the rest of the frontend untouched.
 */

.sbc-listing {
	--sbc-bg:        #ffffff;
	--sbc-surface:   #ffffff;
	--sbc-muted:     #f4f6fa;
	--sbc-text:      #0f172a;
	--sbc-text-2:    #475569;
	--sbc-text-3:    #94a3b8;
	--sbc-border:    #e5e7eb;
	--sbc-border-2:  #f1f5f9;
	--sbc-accent:    #3c50e0;
	--sbc-accent-d:  #2c3fc9;
	--sbc-success:   #10b981;
	--sbc-warning:   #f59e0b;
	--sbc-danger:    #ef4444;
	--sbc-radius:    14px;
	--sbc-radius-sm: 10px;
	--sbc-shadow:    0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);
	--sbc-shadow-2:  0 4px 16px rgba(15, 23, 42, .08);

	font-family: 'DM Sans', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	color: var(--sbc-text);
	background: var(--sbc-muted);
	-webkit-font-smoothing: antialiased;
}

.sbc-listing *, .sbc-listing *::before, .sbc-listing *::after { box-sizing: border-box; }

.sbc-listing img { max-width: 100%; height: auto; display: block; }

.sbc-listing a { color: var(--sbc-accent); text-decoration: none; }
.sbc-listing a:hover { color: var(--sbc-accent-d); }

/* ─────────────────────────── HERO ─────────────────────────── */
.sbc-hero {
	position: relative;
	min-height: 420px;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
	color: #fff;
	margin-bottom: 24px; /* fix #5: tight spacing */
}

.sbc-hero__media { position: absolute; inset: 0; z-index: 0; }
.sbc-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.sbc-hero__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #1e3a8a 0%, #3c50e0 100%); }

.sbc-hero__shade {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.15) 50%, rgba(0,0,0,.65) 100%);
}

.sbc-hero__inner {
	position: relative; z-index: 1;
	width: 100%;
	max-width: 1240px;
	margin: 0 auto;
	padding: 32px 24px 28px;
}

.sbc-breadcrumb {
	font-size: 13px;
	margin-bottom: 24px;
	color: rgba(255, 255, 255, .85);
	display: flex; flex-wrap: wrap; gap: 6px;
	align-items: center;
}
.sbc-breadcrumb a { color: rgba(255, 255, 255, .85); }
.sbc-breadcrumb a:hover { color: #fff; text-decoration: underline; }
.sbc-breadcrumb__current { color: #fff; font-weight: 500; }

.sbc-hero__head { display: flex; flex-direction: column; gap: 12px; }

.sbc-hero__tags { display: flex; flex-wrap: wrap; gap: 8px; }
.sbc-tag {
	display: inline-block;
	padding: 4px 10px;
	background: rgba(255, 255, 255, .18);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	border: 1px solid rgba(255, 255, 255, .25);
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
	color: #fff !important;
	letter-spacing: .02em;
}
.sbc-tag:hover { background: rgba(255, 255, 255, .28); }

.sbc-hero__title {
	font-size: clamp(28px, 4.2vw, 44px);
	line-height: 1.1;
	font-weight: 700;
	margin: 0;
	letter-spacing: -0.02em;
	text-shadow: 0 1px 12px rgba(0, 0, 0, .25);
}

.sbc-hero__meta { display: flex; flex-wrap: wrap; gap: 20px; font-size: 14px; }
.sbc-hero__meta-item { display: inline-flex; align-items: center; gap: 6px; color: rgba(255, 255, 255, .92); }
.sbc-hero__meta-item svg { width: 16px; height: 16px; flex-shrink: 0; }
.sbc-hero__meta-item--rating strong { font-size: 15px; }

.sbc-open-indicator { font-weight: 500; }
.sbc-open-dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: var(--sbc-text-3);
	display: inline-block;
}
.sbc-open-indicator[data-open="1"] .sbc-open-dot { background: #34d399; box-shadow: 0 0 8px rgba(52, 211, 153, .8); }
.sbc-open-indicator[data-open="0"] .sbc-open-dot { background: #f87171; }
.sbc-open-indicator[data-open="1"] .sbc-open-label { color: #d1fae5; }
.sbc-open-indicator[data-open="0"] .sbc-open-label { color: #fecaca; }

.sbc-hero__gallery-btn {
	position: absolute;
	bottom: 28px;
	right: 24px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: rgba(255, 255, 255, .92);
	color: var(--sbc-text);
	border: 0;
	border-radius: 10px;
	font-family: inherit;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	box-shadow: 0 4px 12px rgba(0, 0, 0, .15);
	transition: transform .12s ease, background .12s ease;
}
.sbc-hero__gallery-btn:hover { background: #fff; transform: translateY(-1px); }
.sbc-hero__gallery-btn svg { width: 18px; height: 18px; }

/* ─────────────────────────── BODY ─────────────────────────── */
.sbc-body {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 24px 64px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: 28px;
	align-items: flex-start;
}

.sbc-body__content { display: flex; flex-direction: column; gap: 24px; } /* fix #5 */

.sbc-section {
	background: var(--sbc-surface);
	border: 1px solid var(--sbc-border);
	border-radius: var(--sbc-radius);
	padding: 24px;
	box-shadow: var(--sbc-shadow);
}

.sbc-section__title {
	font-size: 19px;
	font-weight: 700;
	margin: 0 0 16px;
	letter-spacing: -0.01em;
	color: var(--sbc-text);
}

.sbc-prose { font-size: 15px; line-height: 1.65; color: var(--sbc-text-2); }
.sbc-prose p { margin: 0 0 12px; }
.sbc-prose p:last-child { margin-bottom: 0; }
.sbc-prose__fallback { font-style: italic; color: var(--sbc-text-3); }

/* GALLERY */
.sbc-gallery {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
}
.sbc-gallery__item {
	position: relative;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: 10px;
	border: 0;
	padding: 0;
	cursor: pointer;
	background: var(--sbc-muted);
}
.sbc-gallery__item img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .35s ease;
}
.sbc-gallery__item:hover img { transform: scale(1.05); }
.sbc-gallery__overlay {
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center;
	background: rgba(15, 23, 42, .55);
	color: #fff;
	font-size: 22px;
	font-weight: 700;
}

/* AMENITIES */
.sbc-amenities {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 10px;
}
.sbc-amenity {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	background: var(--sbc-muted);
	border-radius: var(--sbc-radius-sm);
	font-size: 14px;
	color: var(--sbc-text);
}
.sbc-amenity__icon {
	display: inline-flex;
	width: 32px; height: 32px;
	background: #fff;
	border-radius: 8px;
	align-items: center; justify-content: center;
	color: var(--sbc-accent);
	flex-shrink: 0;
	box-shadow: 0 1px 2px rgba(15, 23, 42, .05);
}
.sbc-amenity__icon svg { width: 18px; height: 18px; }
.sbc-amenity__label { font-weight: 500; }

/* INFO grid */
.sbc-info-grid { margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.sbc-info-grid__row {
	padding: 12px 14px;
	background: var(--sbc-muted);
	border-radius: var(--sbc-radius-sm);
}
.sbc-info-grid__label {
	display: flex; align-items: center; gap: 8px;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--sbc-text-3);
	font-weight: 600;
	margin-bottom: 4px;
}
.sbc-info-grid__label svg { width: 14px; height: 14px; color: var(--sbc-accent); }
.sbc-info-grid__value { font-size: 15px; font-weight: 600; color: var(--sbc-text); }

/* HOURS table */
.sbc-hours-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.sbc-hours-table th, .sbc-hours-table td {
	padding: 12px 14px;
	text-align: start;
	border-bottom: 1px solid var(--sbc-border-2);
}
.sbc-hours-table tr:last-child th, .sbc-hours-table tr:last-child td { border-bottom: 0; }
.sbc-hours-table th { font-weight: 500; color: var(--sbc-text-2); }
.sbc-hours-table td { font-weight: 600; text-align: end; }
.sbc-hours-table__row--today { background: rgba(60, 80, 224, .06); }
.sbc-hours-table__row--today th, .sbc-hours-table__row--today td { color: var(--sbc-accent); }
.sbc-hours-closed { color: var(--sbc-danger); font-weight: 500; }
.sbc-pill {
	display: inline-block;
	padding: 2px 8px;
	background: var(--sbc-accent);
	color: #fff;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 700;
	margin-inline-start: 6px;
	letter-spacing: .04em;
	text-transform: uppercase;
}

/* PRICES */
.sbc-prices {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 12px;
}
.sbc-price-card {
	display: flex; align-items: flex-start; gap: 12px;
	padding: 16px;
	background: var(--sbc-muted);
	border-radius: var(--sbc-radius-sm);
	border: 1px solid transparent;
	transition: border-color .12s ease, transform .12s ease;
}
.sbc-price-card:hover { border-color: var(--sbc-accent); transform: translateY(-2px); }
.sbc-price-card__icon {
	display: inline-flex;
	width: 40px; height: 40px;
	background: #fff;
	border-radius: 10px;
	align-items: center; justify-content: center;
	color: var(--sbc-accent);
	flex-shrink: 0;
	box-shadow: 0 1px 3px rgba(15, 23, 42, .05);
}
.sbc-price-card__icon svg { width: 22px; height: 22px; }
.sbc-price-card__body { flex: 1; min-width: 0; }
.sbc-price-card__label { font-size: 13px; color: var(--sbc-text-2); font-weight: 500; margin-bottom: 2px; }
.sbc-price-card__value { font-size: 19px; font-weight: 700; color: var(--sbc-text); display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; }
.sbc-price-card__unit { font-size: 12px; font-weight: 500; color: var(--sbc-text-3); }
.sbc-price-card__note { font-size: 12px; color: var(--sbc-text-3); margin-top: 4px; }

.sbc-prices__disclaimer { font-size: 12px; color: var(--sbc-text-3); margin: 14px 0 0; font-style: italic; }

/* MAP */
.sbc-map {
	width: 100%;
	aspect-ratio: 16 / 9;
	background: var(--sbc-muted);
	border-radius: var(--sbc-radius-sm);
	overflow: hidden;
	margin-bottom: 12px;
}
.sbc-map iframe, .sbc-map img { width: 100%; height: 100%; border: 0; display: block; }
.sbc-map__address {
	display: flex; align-items: center; gap: 6px;
	font-size: 14px;
	color: var(--sbc-text-2);
	margin: 0 0 8px;
}
.sbc-map__address svg { width: 16px; height: 16px; color: var(--sbc-accent); flex-shrink: 0; }
.sbc-link { font-size: 14px; font-weight: 600; }

/* ─────────────────────────── SIDEBAR ─────────────────────────── */
.sbc-body__sidebar {
	display: flex; flex-direction: column; gap: 16px;
	position: sticky;
	top: 24px;
}

.sbc-side-card {
	background: var(--sbc-surface);
	border: 1px solid var(--sbc-border);
	border-radius: var(--sbc-radius);
	padding: 20px;
	box-shadow: var(--sbc-shadow);
}
.sbc-side-card__title {
	font-size: 14px;
	font-weight: 700;
	margin: 0 0 14px;
	color: var(--sbc-text);
	text-transform: uppercase;
	letter-spacing: .04em;
}
.sbc-side-card__note { font-size: 13px; color: var(--sbc-text-2); margin: 12px 0 0; }
.sbc-side-card__big { font-size: 22px; font-weight: 700; margin: 0 0 8px; color: var(--sbc-text); }
.sbc-side-card__big--closed { color: var(--sbc-danger); }

.sbc-cta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 12px 16px;
	margin-bottom: 8px;
	border-radius: 10px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none !important;
	transition: transform .12s ease, background .12s ease, color .12s ease;
}
.sbc-cta:last-child { margin-bottom: 0; }
.sbc-cta svg { width: 18px; height: 18px; flex-shrink: 0; }
.sbc-cta--whatsapp { background: #25d366; color: #fff !important; }
.sbc-cta--whatsapp:hover { background: #1fb958; transform: translateY(-1px); color: #fff !important; }
.sbc-cta--ghost { background: var(--sbc-muted); color: var(--sbc-text) !important; }
.sbc-cta--ghost:hover { background: #e2e8f0; }

.sbc-side-card__social {
	display: flex; justify-content: center; gap: 8px;
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px solid var(--sbc-border-2);
}
.sbc-side-card__social a {
	display: inline-flex;
	width: 36px; height: 36px;
	border-radius: 50%;
	background: var(--sbc-muted);
	color: var(--sbc-text) !important;
	align-items: center; justify-content: center;
	transition: background .12s ease, transform .12s ease;
}
.sbc-side-card__social a:hover { background: var(--sbc-accent); color: #fff !important; transform: translateY(-1px); }
.sbc-side-card__social svg { width: 18px; height: 18px; }

/* WEATHER */
.sbc-weather__loading { font-size: 13px; color: var(--sbc-text-3); }
.sbc-weather__main { display: flex; align-items: baseline; gap: 8px; margin-bottom: 12px; }
.sbc-weather__temp { font-size: 32px; font-weight: 700; color: var(--sbc-text); }
.sbc-weather__desc { font-size: 13px; color: var(--sbc-text-2); }
.sbc-weather__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 0; }
.sbc-weather__grid > div { padding: 8px 10px; background: var(--sbc-muted); border-radius: 8px; }
.sbc-weather__grid dt { font-size: 11px; color: var(--sbc-text-3); text-transform: uppercase; font-weight: 600; margin-bottom: 2px; letter-spacing: .04em; }
.sbc-weather__grid dd { font-size: 14px; font-weight: 600; color: var(--sbc-text); margin: 0; }

/* ─────────────────────────── LIGHTBOX ─────────────────────────── */
.sbc-lightbox {
	position: fixed; inset: 0;
	z-index: 9999;
	background: rgba(0, 0, 0, .92);
	display: flex; align-items: center; justify-content: center;
	padding: 40px;
}
.sbc-lightbox[hidden] { display: none !important; }
.sbc-lightbox__close, .sbc-lightbox__prev, .sbc-lightbox__next {
	position: absolute;
	background: rgba(255, 255, 255, .15);
	color: #fff;
	border: 0;
	cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%;
	font-size: 24px;
	transition: background .12s ease;
}
.sbc-lightbox__close:hover, .sbc-lightbox__prev:hover, .sbc-lightbox__next:hover { background: rgba(255, 255, 255, .3); }
.sbc-lightbox__close { top: 20px; right: 20px; width: 44px; height: 44px; font-size: 28px; }
.sbc-lightbox__prev { left: 20px; top: 50%; transform: translateY(-50%); width: 50px; height: 50px; font-size: 32px; }
.sbc-lightbox__next { right: 20px; top: 50%; transform: translateY(-50%); width: 50px; height: 50px; font-size: 32px; }
.sbc-lightbox__figure {
	margin: 0;
	max-width: 100%; max-height: 100%;
	display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.sbc-lightbox__img { max-width: 100%; max-height: 85vh; object-fit: contain; border-radius: 8px; }
.sbc-lightbox__caption { color: rgba(255, 255, 255, .8); font-size: 14px; text-align: center; }

/* ─────────────────────────── RESPONSIVE ─────────────────────────── */
@media (max-width: 1024px) {
	.sbc-body { grid-template-columns: 1fr; gap: 20px; }
	.sbc-body__sidebar { position: static; order: -1; }
	.sbc-gallery { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 640px) {
	.sbc-hero { min-height: 340px; }
	.sbc-hero__inner { padding: 24px 16px 20px; }
	.sbc-hero__gallery-btn { bottom: 16px; right: 16px; padding: 8px 12px; font-size: 13px; }
	.sbc-body { padding: 0 16px 40px; gap: 16px; }
	.sbc-body__content { gap: 16px; }
	.sbc-section { padding: 18px; }
	.sbc-gallery { grid-template-columns: repeat(2, 1fr); gap: 6px; }
	.sbc-amenities { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
	.sbc-info-grid { grid-template-columns: 1fr 1fr; }
	.sbc-prices { grid-template-columns: 1fr; }
	.sbc-lightbox { padding: 16px; }
	.sbc-lightbox__prev, .sbc-lightbox__next { width: 40px; height: 40px; font-size: 24px; }
}

/* ─────────────────────────── RTL ─────────────────────────── */
.rtl .sbc-listing, [dir="rtl"] .sbc-listing {
	font-family: 'Heebo', 'DM Sans', system-ui, sans-serif;
}
.rtl .sbc-hero__gallery-btn, [dir="rtl"] .sbc-hero__gallery-btn { right: auto; left: 24px; }
@media (max-width: 640px) {
	.rtl .sbc-hero__gallery-btn, [dir="rtl"] .sbc-hero__gallery-btn { left: 16px; }
}
.rtl .sbc-lightbox__prev, [dir="rtl"] .sbc-lightbox__prev { left: auto; right: 20px; }
.rtl .sbc-lightbox__close, [dir="rtl"] .sbc-lightbox__close { right: auto; left: 20px; }
.rtl .sbc-lightbox__next, [dir="rtl"] .sbc-lightbox__next { right: auto; left: 20px; }

/* ─────────────────────────── PRINT ─────────────────────────── */
@media print {
	.sbc-body__sidebar, .sbc-hero__gallery-btn, .sbc-lightbox { display: none !important; }
	.sbc-body { display: block; }
	.sbc-section { box-shadow: none; border-color: #ccc; }
}
