/*
Theme Name: Freesia Empire Child
Theme URI: https://example.com/
Description: Child theme for the Sasquatch Inn rebuild.
Author: Codex
Template: freesia-empire
 Version: 1.5.15
*/

:root {
	--sasquatch-ink: #23302a;
	--sasquatch-forest: #405140;
	--sasquatch-moss: #6f7f63;
	--sasquatch-sand: #f5f0e6;
	--sasquatch-paper: rgba(255, 250, 242, 0.92);
	--sasquatch-surface: #fffaf2;
	--sasquatch-shadow: 0 16px 40px rgba(25, 33, 28, 0.10);
	--sasquatch-body-font-family: 'Roboto', Arial, sans-serif;
	--sasquatch-heading-font-family: 'Roboto', Arial, sans-serif;
	--sasquatch-body-font-size: 15px;
	--sasquatch-heading-weight: 500;
	--sasquatch-page-title-weight: 500;
	--sasquatch-banner-color: #405140;
}

html {
	scroll-behavior: smooth;
}

body {
	color: var(--sasquatch-ink);
	font-family: var(--sasquatch-body-font-family);
	font-size: var(--sasquatch-body-font-size);
	font-weight: 400;
	line-height: 1.55;
	background-color: var(--sasquatch-sand, #efe8da);
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.72)),
		url('/wp-content/uploads/sasquatch/home/background.png');
	background-repeat: repeat;
	background-attachment: scroll;
}

a {
	text-decoration-thickness: 1.5px;
	text-underline-offset: 0.15em;
}

#page {
	overflow: hidden;
}

.top-header,
#sticky_header,
.page-header,
#content .container,
#colophon {
	backdrop-filter: blur(6px);
}

.top-header {
	background: rgba(255, 250, 242, 0.88);
	border-bottom: 1px solid rgba(70, 80, 62, 0.12);
}

.top-header .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-top: 0.35rem;
	padding-bottom: 0.35rem;
}

.header-info {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 0.35rem 0.75rem;
	float: none;
	margin: 0;
	padding-right: 0;
	padding-top: 0;
}

.top-header .header-info .widgettitle {
	display: none;
}

.top-header .header-info .widget_text {
	margin: 0;
}

.top-header .header-info .textwidget {
	margin: 0;
}

.top-header .info {
	float: none;
	padding: 0;
	font-size: 13.75px;
	line-height: 1.25;
}

.top-header .info ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.4rem 0.8rem;
}

.top-header .info ul li {
	float: none;
	margin: 0;
	display: inline-flex;
	align-items: center;
	line-height: 1.15;
}

.header-social-block {
	float: none;
	padding: 0;
}

.header-social-block .social-links ul {
	display: flex;
	align-items: center;
	gap: 0.15rem;
	margin: 0;
}

.header-social-block .social-links ul li a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	line-height: 1;
	background: rgba(64, 81, 64, 0.10);
	color: var(--sasquatch-forest);
}

.top-header .info ul li:before {
	color: var(--sasquatch-moss);
	margin-top: 0;
	margin-right: 0.2rem;
	width: auto;
	height: auto;
	line-height: 1;
	font-size: 14px;
	vertical-align: middle;
}

.top-header .info ul li a {
	color: var(--sasquatch-ink);
	line-height: 1.2;
	display: inline-flex;
	align-items: center;
	font-size: 13.75px;
}

.top-header .info ul li.address a,
.top-header .info ul li.phone-number a,
.top-header .info ul li.email a {
	display: inline-flex;
	align-items: center;
	font-size: 13.75px;
}

.top-header .info ul li a:hover,
.top-header .info ul li a:focus {
	color: var(--sasquatch-forest);
}

#sticky_header {
	background: rgba(248, 244, 236, 0.94);
	border-bottom: 1px solid rgba(70, 80, 62, 0.12);
	box-shadow: 0 6px 24px rgba(30, 40, 32, 0.08);
}

#site-branding {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 0.75rem 0;
}

#site-branding .custom-logo-link {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
}

#site-logo {
	max-height: 84px;
	width: auto;
	height: auto;
	object-fit: contain;
	filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.08));
}

#site-detail {
	padding-top: 0.1rem;
}

#site-title a {
	color: var(--sasquatch-ink);
	letter-spacing: 0.02em;
}

#site-description {
	color: var(--sasquatch-moss);
	font-size: 0.98rem;
}

.page-header {
	background: var(--sasquatch-banner-color);
	color: #fff;
	padding: 1.85rem 0 1.55rem;
	box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.12);
}

.page-header .container {
	width: 100%;
	max-width: 58rem;
	display: block;
	text-align: center;
}

.page-header .page-title {
	color: inherit;
	float: none;
	display: block;
	margin: 0;
	font-family: var(--sasquatch-heading-font-family);
	font-size: clamp(2.2rem, 5.5vw, 4.8rem);
	font-weight: 600;
	line-height: 1.02;
	letter-spacing: 0.02em;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.12);
}

.page-header.sasquatch-home-banner {
	padding: 2.35rem 0 2rem;
	text-align: center;
	min-height: clamp(12rem, 20vw, 17rem);
}

.page-header.sasquatch-home-banner .sasquatch-banner-inner {
	display: grid;
	justify-items: center;
	gap: 0.75rem;
}

.page-header.sasquatch-home-banner .page-title,
.page-header.sasquatch-home-banner .sasquatch-banner-eyebrow,
.page-header.sasquatch-home-banner .sasquatch-banner-subtitle,
.page-header.sasquatch-home-banner .sasquatch-banner-copy {
	float: none;
	display: block;
}

.page-header.sasquatch-home-banner .sasquatch-banner-eyebrow {
	margin: 0 0 0.55rem;
	color: rgba(255, 255, 255, 0.92);
	font-size: 0.88rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.page-header.sasquatch-home-banner .page-title.sasquatch-banner-title {
	font-size: clamp(2.4rem, 6vw, 4.8rem);
	font-weight: 600;
	letter-spacing: 0.02em;
	margin: 0;
	line-height: 1.02;
}

.page-header.sasquatch-home-banner .sasquatch-banner-subtitle {
	margin: 0;
	max-width: 46rem;
	color: rgba(255, 255, 255, 0.96);
	font-family: var(--sasquatch-heading-font-family);
	font-size: 1.18rem;
	font-weight: 500;
	line-height: 1.38;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.12);
}

.page-header.sasquatch-home-banner .sasquatch-banner-copy {
	margin: 0;
	max-width: 46rem;
	color: var(--sasquatch-ink);
	font-family: var(--sasquatch-heading-font-family);
	font-size: 1.18rem;
	font-weight: 500;
	line-height: 1.38;
	letter-spacing: 0.02em;
	text-shadow: none;
}

.page-header.sasquatch-home-banner-duplicate .sasquatch-banner-copy-line {
	display: block;
}

.page-header.sasquatch-home-banner-duplicate .sasquatch-banner-copy-line-keep {
	white-space: nowrap;
}

.page-header.sasquatch-home-banner-duplicate {
	background: var(--sasquatch-sand);
	color: var(--sasquatch-ink);
	padding: 0.25rem 0 0.4rem;
	box-shadow: none;
}

.page-header.sasquatch-home-banner-duplicate .container {
	max-width: 52rem;
	background: #fff;
	border: 1px solid rgba(70, 80, 62, 0.12);
	border-radius: 16px;
	box-shadow: 0 12px 28px rgba(25, 33, 28, 0.08);
	padding: 1rem 1.5rem 0.55rem;
}

.page-header.sasquatch-home-banner-duplicate .sasquatch-banner-inner {
	gap: 0;
}

.page-header.sasquatch-home-banner-duplicate .sasquatch-banner-copy {
	color: var(--sasquatch-ink);
	font-family: var(--sasquatch-heading-font-family);
	font-size: 1.18rem;
	font-weight: 500;
	line-height: 1.38;
	letter-spacing: 0.02em;
	text-shadow: none;
	max-width: none;
	white-space: normal;
}

.page-header a {
	color: rgba(255, 255, 255, 0.9);
}

.home #content .container {
	margin-top: 0;
}

.home #content {
	padding-top: 0;
	margin-top: -6rem;
	background: var(--sasquatch-sand);
}

#content {
	background: var(--sasquatch-sand);
}

#content .container {
	margin-top: 1.25rem;
	margin-bottom: 1.5rem;
	background: transparent;
	backdrop-filter: none;
}

#main,
#secondary .widget {
	background: var(--sasquatch-surface);
	border: 1px solid rgba(70, 80, 62, 0.12);
	box-shadow: 0 12px 28px rgba(25, 33, 28, 0.08);
	border-radius: 16px;
}

#secondary {
	border-left: 1px solid rgba(70, 80, 62, 0.10);
}

#main {
	padding: 1.65rem;
}

.home #main {
	padding-top: 0;
}

.home .entry-content > .wp-block-group:first-child {
	margin-top: 0;
}

#secondary .widget {
	padding: 1.05rem 1.1rem;
	margin-bottom: 1rem;
}

.entry-content {
	font-size: 1rem;
	line-height: 1.65;
}

.entry-content > h1,
.entry-content > h2,
.entry-content > h3,
.entry-content > h4 {
	color: var(--sasquatch-forest);
	font-family: var(--sasquatch-heading-font-family);
	font-weight: var(--sasquatch-heading-weight);
	margin-top: 1.5rem;
}

.entry-content > h1:first-child,
.entry-content > h2:first-child,
.entry-content > h3:first-child {
	margin-top: 0;
}

.entry-content p {
	margin-bottom: 0.95rem;
}

.entry-content .sasquatch-home-intro {
	max-width: 50rem;
	margin: 0.1rem auto 1.05rem;
	padding: 0.2rem 1rem 0;
	text-align: center;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
}

.entry-content .sasquatch-home-intro p {
	margin: 0;
	color: var(--sasquatch-ink);
	font-size: 0.98rem;
	line-height: 1.6;
	letter-spacing: 0.02em;
}

.entry-content .sasquatch-hero {
	max-width: 56rem;
	margin: 0 auto 1.5rem;
	padding: 1.75rem 1.35rem 1.6rem;
	text-align: center;
	background: linear-gradient(180deg, var(--sasquatch-surface), var(--sasquatch-surface));
	border: 1px solid rgba(70, 80, 62, 0.11);
	border-radius: 20px;
	box-shadow: 0 16px 34px rgba(25, 33, 28, 0.08);
}

.entry-content .sasquatch-hero .sasquatch-hero-eyebrow {
	margin: 0 0 0.55rem;
	color: var(--sasquatch-moss);
	font-size: 0.86rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.entry-content .sasquatch-hero .sasquatch-hero-title {
	margin: 0;
	color: var(--sasquatch-ink);
	font-family: var(--sasquatch-heading-font-family);
	font-size: clamp(2.1rem, 4.7vw, 4.1rem);
	font-weight: 600;
	line-height: 0.98;
	letter-spacing: 0.015em;
}

.entry-content .sasquatch-hero .sasquatch-hero-subtitle {
	margin: 0.85rem 0 0;
	color: var(--sasquatch-forest);
	font-size: 1.12rem;
	font-weight: 500;
	line-height: 1.45;
}

.entry-content .sasquatch-hero .sasquatch-hero-blurb {
	margin: 0.8rem auto 0;
	max-width: 42rem;
	color: var(--sasquatch-ink);
	font-size: 1.02rem;
	line-height: 1.6;
}

.entry-content > div[id^="ESW_GEN_ID"] {
	display: contents;
}

.entry-content .imp-wrapper-match2 {
	background: rgba(255, 255, 255, 0.94) !important;
	border: 1px solid rgba(64, 81, 64, 0.12);
	border-radius: 14px;
	box-shadow: 0 14px 34px rgba(25, 33, 28, 0.08);
	padding: 0.95rem 1rem;
	overflow-x: auto;
}

.entry-content .imp-menu {
	min-width: 760px;
}

.entry-content #imp-love {
	display: block;
	margin: 1rem auto 0;
	max-width: 140px;
}

.wp-block-gallery,
.entry-content .wp-block-gallery {
	gap: 0.85rem;
}

.wp-block-gallery .blocks-gallery-item {
	margin: 0;
}

.wp-block-gallery figure {
	margin: 0;
}

.wp-block-gallery img {
	border-radius: 12px;
}

.entry-content img {
	border-radius: 12px;
	box-shadow: 0 10px 24px rgba(25, 33, 28, 0.10);
}

.entry-content blockquote {
	background: rgba(250, 248, 242, 0.92);
	border-left: 5px solid var(--sasquatch-moss);
	border-radius: 12px;
	margin: 1.25rem 0;
	padding: 1rem 1.1rem;
}

.entry-content ul,
.entry-content ol {
	padding-left: 1.2rem;
}

.entry-content li + li {
	margin-top: 0.35rem;
}

.wpcf7 {
	margin-top: 0.4rem;
}

.wpcf7 form {
	display: grid;
	gap: 0.85rem;
}

.wpcf7 label {
	display: block;
	font-weight: 600;
	color: var(--sasquatch-forest);
}

.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 textarea {
	width: 100%;
	max-width: 36rem;
	border: 1px solid rgba(70, 80, 62, 0.22);
	border-radius: 10px;
	padding: 0.8rem 0.9rem;
	background: #fff;
	box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.04);
}

.wpcf7 textarea {
	max-width: 48rem;
	min-height: 170px;
}

.wpcf7 input[type="submit"],
.wpcf7 .wpcf7-submit {
	background: var(--sasquatch-forest);
	border: 0;
	border-radius: 999px;
	color: #fff;
	font-weight: 700;
	letter-spacing: 0.02em;
	padding: 0.8rem 1.3rem;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.wpcf7 input[type="submit"]:hover,
.wpcf7 .wpcf7-submit:hover,
.wpcf7 input[type="submit"]:focus,
.wpcf7 .wpcf7-submit:focus {
	background: #304031;
	box-shadow: 0 10px 22px rgba(48, 64, 49, 0.25);
	transform: translateY(-1px);
}

.widget a {
	color: var(--sasquatch-forest);
}

#secondary .widget_text .textwidget,
#secondary .widget_custom_html .textwidget {
	font-size: 0.98rem;
	line-height: 1.6;
}

#secondary .widget iframe {
	display: block;
	width: 100%;
	max-width: 100%;
	border: 0;
	margin-top: 0.5rem;
	border-radius: 10px;
	overflow: hidden;
}

#secondary .widget ul {
	padding-left: 1rem;
}

#secondary .widget li + li {
	margin-top: 0.4rem;
}

.menu.nav-menu > li > a {
	font-size: 15px;
	font-weight: 400;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

/* Footer cleanup and restored content styling. */
.site-footer {
	background: rgba(248, 244, 236, 0.96);
	border-top: 1px solid rgba(70, 80, 62, 0.12);
}

.site-footer .widget-wrap {
	padding: 1.8rem 0 0.9rem;
}

.site-footer .widget-area {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1.1rem;
}

.site-footer .widget-area > div {
	min-width: 0;
}

.site-footer .widget {
	background: var(--sasquatch-surface);
	border: 1px solid rgba(70, 80, 62, 0.10);
	border-radius: 14px;
	padding: 1.05rem 1.1rem;
	box-shadow: 0 10px 24px rgba(25, 33, 28, 0.05);
	height: 100%;
}

.site-footer .widget-title {
	color: var(--sasquatch-forest);
	font-family: var(--sasquatch-heading-font-family);
	font-weight: var(--sasquatch-heading-weight);
	font-size: 1rem;
	margin: 0 0 0.7rem;
}

.site-footer .widget ul {
	padding-left: 1rem;
	margin: 0;
}

.site-footer .widget li + li {
	margin-top: 0.35rem;
}

.site-footer .site-info {
	border-top: 1px solid rgba(70, 80, 62, 0.10);
	padding: 0.95rem 0 1.05rem;
}

.site-footer .site-info .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.65rem 1rem;
}

.site-footer .site-info .social-links {
	margin: 0;
}

.site-footer .site-info .social-links ul {
	margin: 0;
}

.site-footer .site-info .social-links ul li {
	margin-top: 0;
}

.site-footer .site-info .social-links ul li a {
	width: 26px;
	height: 26px;
	line-height: 26px;
}

.site-footer .copyright {
	color: var(--sasquatch-ink);
	font-size: 0.94rem;
}

.site-footer .copyright a {
	color: var(--sasquatch-forest);
}

.site-footer .go-to-top {
	display: none;
}

.site-footer iframe {
	width: 100%;
	max-width: 100%;
	height: 160px;
	border: 0;
	margin-top: 0.55rem;
	border-radius: 10px;
}

/* Generic block spacing and alignment for editor-friendly layouts. */
.entry-content .wp-block-group {
	margin: 0 0 1rem;
}

.entry-content .wp-block-group.has-background {
	background: var(--sasquatch-surface);
	border: 1px solid rgba(64, 81, 64, 0.12);
	border-radius: 14px;
	padding: 1rem 1.05rem;
	box-shadow: 0 10px 24px rgba(25, 33, 28, 0.06);
}

.entry-content .wp-block-columns {
	gap: 1rem;
	margin: 0 0 1rem;
}

.entry-content .wp-block-columns.sasquatch-columns {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
	align-items: stretch;
	width: 100%;
	max-width: 100%;
}

.entry-content .wp-block-column > *:first-child {
	margin-top: 0;
}

.entry-content .wp-block-column > *:last-child {
	margin-bottom: 0;
}

.entry-content .wp-block-image img {
	border-radius: 12px;
}

.entry-content .sasquatch-article-story figure.alignleft,
.entry-content .sasquatch-article-story figure.wp-caption.alignleft {
	float: left;
	width: 150px;
	max-width: 150px;
	margin: 0.2rem 1.05rem 0.9rem 0;
}

.entry-content .sasquatch-article-story figure.alignleft img,
.entry-content .sasquatch-article-story figure.wp-caption.alignleft img {
	display: block;
	width: 100%;
	height: auto;
}

.entry-content .sasquatch-article-story figure.alignleft figcaption,
.entry-content .sasquatch-article-story figure.wp-caption.alignleft figcaption {
	font-size: 0.72rem;
	line-height: 1.25;
	text-align: left;
	margin-top: 0.35rem;
}

.entry-content .sasquatch-article-story figure.aligncenter,
.entry-content .sasquatch-article-story figure.wp-caption.aligncenter {
	clear: both;
	margin: 1.5rem auto;
}

.entry-content .sasquatch-article-story p {
	margin-bottom: 1rem;
}

.entry-content .sasquatch-article-story h3 {
	margin-bottom: 1rem;
}

.entry-content .sasquatch-article-story::after {
	content: "";
	display: block;
	clear: both;
}

.entry-content .wp-block-list {
	padding-left: 1.2rem;
}

@media (max-width: 900px) {
	#main,
	#secondary .widget {
		border-radius: 12px;
	}

	#main {
		padding: 1.2rem;
	}

	#site-branding {
		gap: 0.75rem;
	}

	#site-logo {
		max-height: 60px;
	}

	.page-header.sasquatch-home-banner {
		padding: 1.5rem 0 1.35rem;
		min-height: auto;
	}

	.page-header.sasquatch-home-banner .sasquatch-banner-copy {
		font-size: 1rem;
	}

	.page-header.sasquatch-home-banner-duplicate {
		padding: 0.7rem 0 0.2rem;
	}

	.page-header.sasquatch-home-banner-duplicate .container {
		padding: 1rem 1rem 0.9rem;
	}

	.page-header.sasquatch-home-banner-duplicate .sasquatch-banner-copy-line-keep {
		white-space: normal;
	}

	.entry-content .sasquatch-home-intro {
		margin-top: 0;
		padding: 0.15rem 0.75rem 0;
	}

	.entry-content .wp-block-columns {
		gap: 0.9rem;
	}

	.entry-content .sasquatch-hero {
		padding: 1.45rem 1.1rem 1.35rem;
	}
}

@media (max-width: 782px) {
	#content .container,
	#primary,
	#secondary,
	#main {
		width: 100% !important;
	}

	.top-header .container {
		flex-direction: column;
		align-items: center;
		gap: 0.55rem;
		padding-top: 0.65rem;
		padding-bottom: 0.55rem;
	}

	#site-branding {
		width: 100%;
		justify-content: center;
		padding: 0;
	}

	#site-logo {
		max-height: 54px;
	}

	.header-info {
		width: 100%;
		justify-content: center;
		gap: 0.35rem 0.55rem;
		flex-wrap: wrap;
	}

	.header-social-block {
		justify-content: center;
	}

	.top-header .info {
		width: 100%;
	}

	.top-header .info ul {
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 0.15rem;
	}

	.top-header .info ul li {
		width: 100%;
		justify-content: center;
		font-size: 12px;
	}

	#primary,
	#secondary {
		float: none !important;
	}

	#primary {
		margin-bottom: 1rem;
	}

	.page-header .container {
		padding-left: 0.75rem;
		padding-right: 0.75rem;
	}

	.page-header .page-title {
		font-size: clamp(1.35rem, 6vw, 2.05rem);
		line-height: 1.08;
		max-width: 100%;
	}

	.page-header.sasquatch-home-banner .page-title.sasquatch-banner-title {
		font-size: clamp(1.8rem, 8vw, 2.6rem);
	}

	.entry-content .wp-block-columns.sasquatch-columns {
		display: block !important;
		grid-template-columns: none !important;
		width: 100% !important;
	}

	.entry-content .wp-block-columns.sasquatch-columns > .wp-block-column {
		display: block !important;
		width: 100% !important;
		margin: 0 0 0.9rem !important;
	}

	.entry-content .wp-block-gallery.columns-3 {
		display: block !important;
		column-count: 2;
		column-gap: 0.75rem;
	}

	.entry-content .wp-block-gallery.columns-3 .blocks-gallery-item {
		display: inline-block;
		width: 100% !important;
		margin: 0 0 0.75rem !important;
		break-inside: avoid;
		page-break-inside: avoid;
	}

	.entry-content .wp-block-gallery.columns-3 img {
		width: 100%;
		height: auto;
	}

	.entry-content .imp-wrapper-match2 {
		padding: 0.8rem 0.75rem;
	}

	.entry-content .sasquatch-hero .sasquatch-hero-title {
		font-size: clamp(1.9rem, 8vw, 3rem);
	}

	.entry-content .sasquatch-hero .sasquatch-hero-subtitle {
		font-size: 1rem;
	}

	.site-footer .widget-area {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 782px) {
	.site-footer .widget-area {
		grid-template-columns: 1fr;
	}

	.site-footer .site-info .container {
		justify-content: center;
		text-align: center;
	}

	.site-footer .site-info .social-links ul {
		justify-content: center;
	}
}
