/**
 * HouseSpa Brand Theme
 * Applies the dark-luxury identity from housespa.mx to the WordPress site.
 */

/* ─── Design Tokens ──────────────────────────────────────────────────────── */
:root {
	--hs-bg:           #050505;
	--hs-bg-card:      #0D0D0D;
	--hs-bg-surface:   #161616;
	--hs-bg-muted:     #262626;
	--hs-ivory:        #FAF9F6;
	--hs-ivory-muted:  #B5B0A7;
	--hs-rose:         #B76E79;
	--hs-rose-light:   #D29FA6;
	--hs-rose-dark:    #9E5562;
	--hs-border:       rgba(255, 255, 255, 0.06);
	--hs-border-rose:  rgba(183, 110, 121, 0.35);
	--hs-font-serif:   'Playfair Display', Georgia, serif;
	--hs-font-sans:    'Inter', system-ui, sans-serif;
}

/* ─── Global Reset to Dark Theme ─────────────────────────────────────────── */
html,
body {
	background-color: var(--hs-bg) !important;
	color: var(--hs-ivory) !important;
	font-family: var(--hs-font-sans) !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Kill WordPress's white/light default backgrounds */
.wp-site-blocks,
.wp-block-group,
.wp-block-template-part,
body .is-root-container {
	background-color: var(--hs-bg);
}

/* Headings use serif */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--hs-font-serif);
	color: var(--hs-ivory);
	letter-spacing: -0.02em;
}

/* Links */
a {
	color: var(--hs-ivory);
	transition: color 0.3s ease;
}
a:hover {
	color: var(--hs-rose);
	text-decoration: none !important;
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--hs-bg-card); }
::-webkit-scrollbar-thumb { background: var(--hs-rose); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--hs-rose-light); }

/* ─── Header ─────────────────────────────────────────────────────────────── */
.hs-theme-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(5, 5, 5, 0.88);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	border-bottom: 1px solid var(--hs-border);
}

.hs-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0.9rem clamp(20px, 5vw, 60px);
}

/* Logo */
.hs-header-logo-link {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	text-decoration: none;
}
.hs-header-logo {
	width: 130px;
	height: auto;
	object-fit: contain;
	display: block;
}

/* Desktop nav links */
.hs-header-nav {
	display: flex;
	align-items: center;
	gap: 2rem;
}
.hs-header-nav-link {
	position: relative;
	font-family: var(--hs-font-sans);
	font-size: 0.72rem;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(250, 249, 246, 0.75);
	text-decoration: none;
	padding: 0.35rem 0;
	transition: color 0.3s ease;
}
.hs-header-nav-link::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 1px;
	background: var(--hs-rose);
	transition: width 0.3s ease;
}
.hs-header-nav-link:hover {
	color: var(--hs-rose);
}
.hs-header-nav-link:hover::after {
	width: 100%;
}

/* Right-side action buttons */
.hs-header-actions {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-shrink: 0;
}

.hs-btn-account {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	font-family: var(--hs-font-sans);
	font-size: 0.72rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(250, 249, 246, 0.75);
	text-decoration: none;
	padding: 0.45rem 1rem;
	border: 1px solid var(--hs-border);
	border-radius: 100px;
	transition: all 0.3s ease;
}
.hs-btn-account:hover {
	color: var(--hs-ivory);
	border-color: rgba(250, 249, 246, 0.35);
	background: rgba(250, 249, 246, 0.05);
}

.hs-btn-reservar {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	font-family: var(--hs-font-sans);
	font-size: 0.72rem;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--hs-ivory);
	text-decoration: none;
	padding: 0.45rem 1.3rem;
	border: 1px solid rgba(183, 110, 121, 0.45);
	border-radius: 100px;
	background: transparent;
	transition: all 0.3s ease;
}
.hs-btn-reservar:hover {
	background: rgba(183, 110, 121, 0.1);
	border-color: var(--hs-rose);
	color: var(--hs-rose);
}

/* Hamburger toggle — hidden on desktop */
.hs-mobile-toggle {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.3rem;
	color: var(--hs-ivory);
	line-height: 0;
}

/* Mobile drawer */
.hs-mobile-nav {
	display: none;
	background: rgba(5, 5, 5, 0.97);
	border-top: 1px solid var(--hs-border);
	padding: 1.5rem clamp(20px, 5vw, 60px) 2rem;
}
.hs-mobile-nav.is-open {
	display: block;
}
.hs-mobile-nav nav {
	display: flex;
	flex-direction: column;
	gap: 0;
}
.hs-mobile-nav-link {
	display: block;
	font-family: var(--hs-font-sans);
	font-size: 0.8rem;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(250, 249, 246, 0.75);
	text-decoration: none;
	padding: 0.9rem 0;
	border-bottom: 1px solid var(--hs-border);
	transition: color 0.25s ease;
}
.hs-mobile-nav-link:hover {
	color: var(--hs-rose);
}
.hs-mobile-actions {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 1.5rem;
}
.hs-mobile-account,
.hs-mobile-reservar {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--hs-font-sans);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none;
	padding: 0.8rem 1.5rem;
	border-radius: 100px;
	transition: all 0.3s ease;
}
.hs-mobile-account {
	color: var(--hs-ivory);
	border: 1px solid var(--hs-border);
}
.hs-mobile-account:hover {
	border-color: rgba(250, 249, 246, 0.3);
	background: rgba(250, 249, 246, 0.05);
}
.hs-mobile-reservar {
	color: var(--hs-ivory);
	background: var(--hs-rose);
	border: 1px solid var(--hs-rose);
}
.hs-mobile-reservar:hover {
	background: var(--hs-rose-dark);
}

/* Responsive — hide nav + show hamburger under 900px */
@media (max-width: 900px) {
	.hs-header-nav,
	.hs-btn-account,
	.hs-btn-reservar {
		display: none;
	}
	.hs-mobile-toggle {
		display: block;
	}
}

/* ─── Main Content Area ───────────────────────────────────────────────────── */
.wp-block-post-content,
.hs-page-main,
main.wp-block-group {
	background-color: var(--hs-bg);
	color: var(--hs-ivory);
}

/* Remove any default white background from post content wrappers */
.wp-block-post-content > *,
.entry-content > * {
	background-color: transparent;
}

/* ─── Footer ─────────────────────────────────────────────────────────────── */
.hs-footer {
	background-color: var(--hs-bg-card) !important;
	border-top: 1px solid var(--hs-border);
	padding-top: 5rem;
	padding-bottom: 2.5rem;
}

.hs-footer .hs-footer__inner {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(20px, 5vw, 60px);
	padding-right: clamp(20px, 5vw, 60px);
	background: transparent !important;
}

/* Footer grid */
.hs-footer-grid.wp-block-columns {
	gap: 3rem;
	margin-bottom: 4rem;
	align-items: flex-start;
}

/* Column resets */
.hs-footer-col-brand,
.hs-footer-col {
	background: transparent !important;
}

/* Footer logo */
.hs-footer .hs-footer-logo {
	margin-bottom: 1.5rem;
}
.hs-footer .wp-block-site-logo img {
	width: 160px;
	height: auto;
	filter: brightness(1);
}

/* Footer description */
.hs-footer-desc {
	font-size: 0.875rem !important;
	line-height: 1.75 !important;
	color: var(--hs-ivory-muted) !important;
	max-width: 360px;
	margin-bottom: 1.5rem !important;
}

/* Badge */
.hs-footer-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.65rem;
	font-family: var(--hs-font-sans);
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--hs-rose);
	background: rgba(183, 110, 121, 0.06);
	border: 1px solid var(--hs-border);
	border-radius: 100px;
	padding: 0.45rem 1rem;
	width: fit-content;
}
.hs-footer-badge svg {
	stroke: var(--hs-rose);
	flex-shrink: 0;
}

/* Footer column titles */
.hs-footer-col-title {
	font-family: var(--hs-font-serif) !important;
	font-size: 0.75rem !important;
	font-weight: 400 !important;
	letter-spacing: 0.2em !important;
	text-transform: uppercase !important;
	color: var(--hs-ivory) !important;
	margin-bottom: 1.5rem !important;
}

/* Footer nav list */
.hs-footer-nav-list {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}
.hs-footer-nav-list li {
	margin: 0 !important;
	padding: 0 !important;
}
.hs-footer-nav-list a {
	font-size: 0.875rem;
	font-family: var(--hs-font-sans);
	color: var(--hs-ivory-muted) !important;
	text-decoration: none !important;
	transition: color 0.3s ease;
}
.hs-footer-nav-list a:hover {
	color: var(--hs-rose) !important;
}

/* Footer contact list */
.hs-footer-contact-list {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.hs-footer-contact-list li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin: 0 !important;
	padding: 0 !important;
}
.hs-footer-contact-icon {
	flex-shrink: 0;
	margin-top: 2px;
	color: var(--hs-rose);
}
.hs-footer-contact-icon svg {
	stroke: var(--hs-rose);
}
.hs-footer-contact-list div {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}
.hs-footer-contact-label {
	display: block;
	font-size: 0.65rem;
	font-family: var(--hs-font-sans);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: rgba(181, 176, 167, 0.5);
}
.hs-footer-contact-list a,
.hs-footer-contact-list span {
	font-size: 0.875rem;
	color: var(--hs-ivory-muted);
	text-decoration: none !important;
}
.hs-footer-contact-list a:hover {
	color: var(--hs-rose);
}
.hs-footer-hours {
	font-size: 0.75rem !important;
	color: rgba(183, 110, 121, 0.85) !important;
}

/* Footer bottom bar */
.hs-footer-bottom {
	border-top: 1px solid var(--hs-border) !important;
	padding-top: 2rem !important;
	margin-top: 1rem;
	background: transparent !important;
}
.hs-footer-copy {
	font-size: 0.7rem !important;
	color: rgba(181, 176, 167, 0.5) !important;
	letter-spacing: 0.05em;
}
.hs-footer-bottom a {
	font-size: 0.7rem;
	color: rgba(181, 176, 167, 0.5) !important;
	text-decoration: none !important;
	letter-spacing: 0.05em;
	transition: color 0.3s ease;
}
.hs-footer-bottom a:hover {
	color: var(--hs-rose) !important;
}
.hs-footer-bottom .wp-block-group {
	gap: 1.5rem;
	background: transparent !important;
}

/* ─── WordPress Admin Bar adjustment ─────────────────────────────────────── */
.admin-bar .hs-theme-header {
	top: 32px;
}
@media (max-width: 782px) {
	.admin-bar .hs-theme-header {
		top: 46px;
	}
}

/* ─── Mobile responsive footer ───────────────────────────────────────────── */
@media (max-width: 768px) {
	.hs-footer-grid.wp-block-columns {
		flex-direction: column;
	}
	.hs-footer-col-brand,
	.hs-footer-col {
		flex-basis: 100% !important;
	}
	.hs-footer-bottom.wp-block-group {
		flex-direction: column;
		gap: 1rem;
		text-align: center;
	}
}

/* ─── Booking form page overrides ────────────────────────────────────────── */
/* Make sure the booking page has enough top padding (header is sticky) */
.wp-block-post-content {
	padding-top: 2rem;
}

/* Suppress WP default page title when using page.html */
.hs-page-no-title .wp-block-post-title {
	display: none;
}

/* ─── WooCommerce dark theme overrides ───────────────────────────────────── */
.woocommerce-page,
.woocommerce {
	background: var(--hs-bg) !important;
	color: var(--hs-ivory) !important;
}

.woocommerce-page form .form-row input.input-text,
.woocommerce-page form .form-row select,
.woocommerce-page form .form-row textarea {
	background: var(--hs-bg-surface) !important;
	color: var(--hs-ivory) !important;
	border-color: var(--hs-border) !important;
	border-radius: 6px !important;
}

.woocommerce-page form .form-row label,
.woocommerce-page .woocommerce-billing-fields h3,
.woocommerce-page .woocommerce-shipping-fields h3,
.woocommerce-page .order_review h3,
.woocommerce-page table.shop_table th,
.woocommerce-page table.shop_table td {
	color: var(--hs-ivory) !important;
}

.woocommerce-page table.shop_table {
	background: var(--hs-bg-card) !important;
	border-color: var(--hs-border) !important;
}
.woocommerce-page table.shop_table tr:nth-child(even) {
	background: var(--hs-bg-surface) !important;
}

.woocommerce #payment,
.woocommerce-page #payment {
	background: var(--hs-bg-surface) !important;
	border-radius: 8px !important;
}

.woocommerce #payment div.payment_box,
.woocommerce-page #payment div.payment_box {
	background: var(--hs-bg-card) !important;
	color: var(--hs-ivory-muted) !important;
}

.woocommerce #payment div.payment_box::before,
.woocommerce-page #payment div.payment_box::before {
	border-bottom-color: var(--hs-bg-card) !important;
}

.woocommerce #place_order,
.woocommerce-page #place_order,
.woocommerce button.button.alt,
.woocommerce-page button.button.alt {
	background: var(--hs-rose) !important;
	color: var(--hs-ivory) !important;
	border-radius: 100px !important;
	font-family: var(--hs-font-sans) !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	font-size: 0.8rem !important;
	transition: background 0.3s ease !important;
}
.woocommerce button.button.alt:hover,
.woocommerce-page button.button.alt:hover {
	background: var(--hs-rose-dark) !important;
}

.woocommerce-page .woocommerce-breadcrumb {
	color: var(--hs-ivory-muted) !important;
}

/* ─── General WP block overrides ─────────────────────────────────────────── */
/* Remove white backgrounds that blocks add by default */
.wp-block-group:not(.hs-theme-header):not(.hs-footer):not(.hs-footer__inner):not(.hs-footer-bottom) {
	background-color: transparent;
}

.wp-block-columns {
	gap: var(--wp--preset--spacing--50, 2rem);
}

/* Gutenberg inline notice cleanup */
.wp-block-post-title {
	color: var(--hs-ivory);
}
