/*
Theme Name: WPFlow Canary A Oceanwp Child
Description: Governed WPFlow child theme scaffold adopted automatically during onboarding for vendor-parent safety.
Version: 1.0.1
Template: oceanwp
Text Domain: wpflow-canary-a-oceanwp-child
*/

:root {
	--wpflow-cta-background: #d63b3b;
	--wpflow-cta-background-hover: #c93434;
	--wpflow-cta-text: #ffffff;
	--wpflow-cta-focus-ring: rgba(214, 59, 59, 0.2);
	--wpflow-cta-shadow: 0 14px 30px rgba(201, 52, 52, 0.16);
	--wpflow-surface-soft: #f7f4ef;
	--wpflow-surface-border: #e6ddd1;
	--wpflow-copy-strong: #333333;
	--wpflow-copy-muted: #666666;
}

/* Shared CTA lift for the sitewide button surfaces that currently render as low-contrast links. */
body .elementor-widget-button .elementor-button,
body .woocommerce a.button,
body .woocommerce button.button,
body .woocommerce input.button,
body .woocommerce #respond input#submit,
body .wpforms-form button[type='submit'],
body .wpforms-form input[type='submit'],
body .oew-newsletter-form button[type='submit'],
body a.added_to_cart.wc-forward {
	background-color: var(--wpflow-cta-background) !important;
	border: 1px solid var(--wpflow-cta-background) !important;
	border-radius: 999px;
	box-shadow: var(--wpflow-cta-shadow);
	color: var(--wpflow-cta-text) !important;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
}

body .woocommerce a.button,
body .woocommerce button.button,
body .woocommerce input.button,
body .woocommerce #respond input#submit,
body .wpforms-form button[type='submit'],
body .wpforms-form input[type='submit'],
body .oew-newsletter-form button[type='submit'],
body a.added_to_cart.wc-forward {
	padding: 0.95em 1.85em;
}

body .elementor-widget-button .elementor-button:hover,
body .elementor-widget-button .elementor-button:focus,
body .elementor-widget-button .elementor-button:active,
body .woocommerce a.button:hover,
body .woocommerce a.button:focus,
body .woocommerce a.button:active,
body .woocommerce button.button:hover,
body .woocommerce button.button:focus,
body .woocommerce button.button:active,
body .woocommerce input.button:hover,
body .woocommerce input.button:focus,
body .woocommerce input.button:active,
body .woocommerce #respond input#submit:hover,
body .woocommerce #respond input#submit:focus,
body .woocommerce #respond input#submit:active,
body .wpforms-form button[type='submit']:hover,
body .wpforms-form button[type='submit']:focus,
body .wpforms-form button[type='submit']:active,
body .wpforms-form input[type='submit']:hover,
body .wpforms-form input[type='submit']:focus,
body .wpforms-form input[type='submit']:active,
body .oew-newsletter-form button[type='submit']:hover,
body .oew-newsletter-form button[type='submit']:focus,
body .oew-newsletter-form button[type='submit']:active,
body a.added_to_cart.wc-forward:hover,
body a.added_to_cart.wc-forward:focus,
body a.added_to_cart.wc-forward:active {
	background-color: var(--wpflow-cta-background-hover) !important;
	border-color: var(--wpflow-cta-background-hover) !important;
	box-shadow: 0 18px 34px rgba(201, 52, 52, 0.2);
	color: var(--wpflow-cta-text) !important;
}

body .elementor-widget-button .elementor-button:focus-visible,
body .woocommerce a.button:focus-visible,
body .woocommerce button.button:focus-visible,
body .woocommerce input.button:focus-visible,
body .woocommerce #respond input#submit:focus-visible,
body .wpforms-form button[type='submit']:focus-visible,
body .wpforms-form input[type='submit']:focus-visible,
body .oew-newsletter-form button[type='submit']:focus-visible,
body a.added_to_cart.wc-forward:focus-visible {
	outline: 3px solid var(--wpflow-cta-focus-ring);
	outline-offset: 3px;
}

@media (prefers-reduced-motion: no-preference) {
	body .elementor-widget-button .elementor-button,
	body .woocommerce a.button,
	body .woocommerce button.button,
	body .woocommerce input.button,
	body .woocommerce #respond input#submit,
	body .wpforms-form button[type='submit'],
	body .wpforms-form input[type='submit'],
	body .oew-newsletter-form button[type='submit'],
	body a.added_to_cart.wc-forward {
		transition:
			background-color 180ms ease,
			border-color 180ms ease,
			box-shadow 180ms ease,
			color 180ms ease;
	}
}

/* Replace the stock WPForms success box with a branded next-step card. */
body div.wpforms-confirmation-container-full {
	margin: 0 !important;
	padding: 0 !important;
	background: none !important;
	border: 0 !important;
	color: inherit !important;
}

body .wpflow-form-confirmation {
	background: linear-gradient(180deg, #ffffff 0%, #f7f4ef 100%);
	border: 1px solid #e6ddd1;
	border-radius: 28px;
	box-shadow: 0 22px 48px rgba(27, 27, 27, 0.08);
	color: #333333;
	padding: 32px;
}

body .wpflow-form-confirmation__eyebrow {
	margin: 0 0 12px;
	color: #fe5252;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
}

body .wpflow-form-confirmation__title {
	margin: 0 0 16px;
	color: #333333;
	font-size: 34px;
	font-weight: 300;
	line-height: 1.18;
}

body .wpflow-form-confirmation__message {
	color: #5c5c5c;
	font-size: 16px;
	line-height: 1.8;
}

body .wpflow-form-confirmation__message p:last-child {
	margin-bottom: 0;
}

body .wpflow-form-confirmation__next-steps {
	margin: 22px 0 0;
	padding: 0;
	list-style: none;
}

body .wpflow-form-confirmation__next-steps li {
	position: relative;
	margin: 0;
	padding: 0 0 0 28px;
	color: #4a4a4a;
	font-size: 15px;
	line-height: 1.7;
}

body .wpflow-form-confirmation__next-steps li + li {
	margin-top: 12px;
}

body .wpflow-form-confirmation__next-steps li::before {
	content: '';
	position: absolute;
	top: 0.7em;
	left: 0;
	width: 12px;
	height: 12px;
	border-radius: 999px;
	background: var(--wpflow-cta-background);
	box-shadow: 0 0 0 6px rgba(214, 59, 59, 0.12);
	transform: translateY(-50%);
}

body .wpflow-form-confirmation__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 28px;
}

body .wpflow-form-confirmation__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 0.9em 1.7em;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
}

body .wpflow-form-confirmation__button--primary {
	background: var(--wpflow-cta-background);
	border: 1px solid var(--wpflow-cta-background);
	box-shadow: var(--wpflow-cta-shadow);
	color: var(--wpflow-cta-text);
}

body .wpflow-form-confirmation__button--primary:hover,
body .wpflow-form-confirmation__button--primary:focus {
	background: var(--wpflow-cta-background-hover);
	border-color: var(--wpflow-cta-background-hover);
	color: var(--wpflow-cta-text);
}

body .wpflow-form-confirmation__button--secondary {
	background: transparent;
	border: 1px solid #d9cec1;
	color: #333333;
}

body .wpflow-form-confirmation__button--secondary:hover,
body .wpflow-form-confirmation__button--secondary:focus {
	border-color: var(--wpflow-cta-background);
	color: var(--wpflow-cta-background);
}

body .wpflow-form-confirmation__button:focus-visible {
	outline: 3px solid var(--wpflow-cta-focus-ring);
	outline-offset: 3px;
}

/* Improve WPForms completion on phones without changing desktop form layouts. */
@media (max-width: 767px) {
	body .wpforms-container .wpforms-form {
		--wpflow-form-control-min-height: 52px;
	}

	body .wpforms-container .wpforms-form .wpforms-field {
		margin-bottom: 18px;
	}

	body .wpforms-container .wpforms-form .wpforms-field-label {
		margin-bottom: 8px;
		font-size: 15px;
		line-height: 1.4;
	}

	body .wpforms-container .wpforms-form .wpforms-field-row,
	body .wpforms-container .wpforms-form .wpforms-field-row-block,
	body .wpforms-container .wpforms-form .wpforms-one-half,
	body .wpforms-container .wpforms-form .wpforms-one-third,
	body .wpforms-container .wpforms-form .wpforms-two-thirds,
	body .wpforms-container .wpforms-form .wpforms-inline-fields {
		width: 100% !important;
		max-width: 100%;
		margin-left: 0 !important;
		float: none !important;
	}

	body .wpforms-container .wpforms-form .wpforms-field-row-block {
		margin-bottom: 12px;
	}

	body .wpforms-container .wpforms-form input[type='text'],
	body .wpforms-container .wpforms-form input[type='email'],
	body .wpforms-container .wpforms-form input[type='tel'],
	body .wpforms-container .wpforms-form input[type='url'],
	body .wpforms-container .wpforms-form input[type='number'],
	body .wpforms-container .wpforms-form select,
	body .wpforms-container .wpforms-form textarea {
		width: 100%;
		min-height: var(--wpflow-form-control-min-height);
		padding: 14px 16px;
		font-size: 16px;
		line-height: 1.4;
		border-radius: 14px;
		box-sizing: border-box;
	}

	body .wpforms-container .wpforms-form textarea {
		min-height: 160px;
	}

	body .wpforms-container .wpforms-form .wpforms-field-sublabel {
		margin-top: 6px;
		font-size: 13px;
		line-height: 1.4;
	}

	body .wpforms-container .wpforms-form .wpforms-submit-container {
		padding-top: 8px;
	}

	body .wpforms-container .wpforms-form .wpforms-submit-container button,
	body .wpforms-container .wpforms-form .wpforms-submit-container input[type='submit'] {
		display: block;
		width: 100%;
		padding: 1em 1.5em;
		text-align: center;
	}

	body .wpflow-form-confirmation {
		padding: 24px 20px;
		border-radius: 22px;
	}

	body .wpflow-form-confirmation__title {
		font-size: 28px;
	}

	body .wpflow-form-confirmation__actions {
		flex-direction: column;
	}

	body .wpflow-form-confirmation__button {
		width: 100%;
	}
}

/* Dedicated page canvas for campaign landing pages that should omit the site chrome. */
body.page-template-template-wpflow-landing-page {
	background-color: #ffffff;
}

body.page-template-template-wpflow-landing-page .wpflow-landing-page-template__site {
	min-height: 100vh;
}

body.page-template-template-wpflow-landing-page .wpflow-landing-page-template__main,
body.page-template-template-wpflow-landing-page .wpflow-landing-page-template__article,
body.page-template-template-wpflow-landing-page .wpflow-landing-page-template__article .entry-content {
	margin: 0;
	max-width: none;
	padding: 0;
	width: 100%;
}

body.page-template-template-wpflow-landing-page .wpflow-landing-page-template__article {
	border: 0;
}

body.page-template-template-wpflow-landing-page .wpflow-landing-page-template__article .entry-content::after {
	display: none;
}

body.page-template-template-wpflow-landing-page .wpflow-landing-page-template__article > .entry-content > .elementor {
	width: 100%;
}

/* Refresh the editorial archive without changing the broader storefront layout. */
body.wpflow-editorial-archive #blog-entries {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 32px;
}

body.wpflow-editorial-archive #blog-entries::before,
body.wpflow-editorial-archive #blog-entries::after {
	display: none;
}

body.wpflow-editorial-archive #blog-entries .blog-entry {
	float: none !important;
	width: auto !important;
	max-width: none;
	margin: 0 !important;
	padding: 0 !important;
	display: flex;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-inner {
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 100%;
	background: #ffffff;
	border: 1px solid var(--wpflow-surface-border);
	border-radius: 28px;
	box-shadow: 0 20px 44px rgba(27, 27, 27, 0.08);
	overflow: hidden;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-media,
body.wpflow-editorial-archive #blog-entries .thumbnail {
	margin: 0;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-media a,
body.wpflow-editorial-archive #blog-entries .thumbnail a,
body.wpflow-editorial-archive #blog-entries .blog-entry-media img,
body.wpflow-editorial-archive #blog-entries .thumbnail img {
	display: block;
	width: 100%;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-media img,
body.wpflow-editorial-archive #blog-entries .thumbnail img {
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-content {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 16px;
	padding: 28px;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-content ul.meta {
	padding-left: 0;
	padding-right: 0;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-content .blog-entry-readmore {
	margin-top: auto;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-header,
body.wpflow-editorial-archive #blog-entries .blog-entry-inner > ul.meta,
body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-summary,
body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-readmore {
	padding-left: 28px;
	padding-right: 28px;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-header {
	padding-top: 28px;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-inner > ul.meta,
body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-summary {
	margin-top: 16px;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-readmore {
	margin-top: auto;
	padding-bottom: 28px;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-header {
	margin: 0;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-header h1,
body.wpflow-editorial-archive #blog-entries .blog-entry-header h2,
body.wpflow-editorial-archive #blog-entries .blog-entry-header h3,
body.wpflow-editorial-archive #blog-entries .blog-entry-header h4,
body.wpflow-editorial-archive #blog-entries .blog-entry-header .entry-title {
	margin: 0;
	color: var(--wpflow-copy-strong);
	font-size: clamp(1.5rem, 2vw, 2rem);
	font-weight: 300;
	line-height: 1.18;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-header a {
	color: inherit;
}

body.wpflow-editorial-archive #blog-entries ul.meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 16px;
	margin-bottom: 0;
	list-style: none;
	color: #7a746b;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

body.wpflow-editorial-archive #blog-entries ul.meta li {
	margin: 0;
}

body.wpflow-editorial-archive #blog-entries ul.meta li::after,
body.wpflow-editorial-archive #blog-entries ul.meta li::before {
	display: none !important;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-summary,
body.wpflow-editorial-archive #blog-entries .blog-entry-content p {
	color: var(--wpflow-copy-muted);
	font-size: 15px;
	line-height: 1.8;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-summary p:last-child,
body.wpflow-editorial-archive #blog-entries .blog-entry-content p:last-child {
	margin-bottom: 0;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-readmore a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0.9em 1.6em;
	background: var(--wpflow-cta-background);
	border: 1px solid var(--wpflow-cta-background);
	border-radius: 999px;
	box-shadow: var(--wpflow-cta-shadow);
	color: var(--wpflow-cta-text);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
}

body.wpflow-editorial-archive .page-header {
	margin-bottom: 36px;
}

body.wpflow-editorial-archive .oceanwp-pagination .page-numbers,
body.wpflow-editorial-archive .page-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 40px;
}

body.wpflow-editorial-archive .oceanwp-pagination .page-numbers li,
body.wpflow-editorial-archive .page-links > span,
body.wpflow-editorial-archive .page-links > a {
	margin: 0;
	list-style: none;
}

body.wpflow-editorial-archive .oceanwp-pagination .page-numbers a,
body.wpflow-editorial-archive .oceanwp-pagination .page-numbers span,
body.wpflow-editorial-archive .page-links > span,
body.wpflow-editorial-archive .page-links > a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 46px;
	min-height: 46px;
	padding: 0 16px;
	background: #ffffff;
	border: 1px solid var(--wpflow-surface-border);
	border-radius: 999px;
	color: var(--wpflow-copy-strong);
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
}

body.wpflow-has-custom-related-posts.single-post #related-posts {
	display: none;
}

body.wpflow-editorial-single .wpflow-related-posts {
	margin-top: 56px;
	padding: 40px;
	background: linear-gradient(180deg, #ffffff 0%, var(--wpflow-surface-soft) 100%);
	border: 1px solid var(--wpflow-surface-border);
	border-radius: 32px;
	box-shadow: 0 22px 48px rgba(27, 27, 27, 0.08);
}

body.wpflow-editorial-single .wpflow-related-posts__header {
	margin-bottom: 28px;
}

body.wpflow-editorial-single .wpflow-related-posts__eyebrow {
	margin: 0 0 12px;
	color: var(--wpflow-cta-background);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
}

body.wpflow-editorial-single .wpflow-related-posts__title {
	margin: 0;
	color: var(--wpflow-copy-strong);
	font-size: clamp(2rem, 4vw, 2.6rem);
	font-weight: 300;
	line-height: 1.15;
}

body.wpflow-editorial-single .wpflow-related-posts__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
}

body.wpflow-editorial-single .wpflow-related-posts__card {
	display: flex;
	flex-direction: column;
	min-height: 100%;
	background: #ffffff;
	border: 1px solid rgba(230, 221, 209, 0.85);
	border-radius: 24px;
	box-shadow: 0 14px 32px rgba(27, 27, 27, 0.06);
	overflow: hidden;
}

body.wpflow-editorial-single .wpflow-related-posts__media,
body.wpflow-editorial-single .wpflow-related-posts__image,
body.wpflow-editorial-single .wpflow-related-posts__media-fallback {
	display: block;
	width: 100%;
}

body.wpflow-editorial-single .wpflow-related-posts__image,
body.wpflow-editorial-single .wpflow-related-posts__media-fallback {
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

body.wpflow-editorial-single .wpflow-related-posts__media-fallback {
	background:
		radial-gradient(circle at top left, rgba(214, 59, 59, 0.16), transparent 55%),
		linear-gradient(135deg, #ffffff 0%, var(--wpflow-surface-soft) 100%);
}

body.wpflow-editorial-single .wpflow-related-posts__content {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 14px;
	padding: 24px;
}

body.wpflow-editorial-single .wpflow-related-posts__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0;
}

body.wpflow-editorial-single .wpflow-related-posts__topic,
body.wpflow-editorial-single .wpflow-related-posts__date {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

body.wpflow-editorial-single .wpflow-related-posts__topic {
	padding: 0 12px;
	background: var(--wpflow-surface-soft);
	color: var(--wpflow-cta-background);
}

body.wpflow-editorial-single .wpflow-related-posts__date {
	color: #7a746b;
}

body.wpflow-editorial-single .wpflow-related-posts__heading {
	margin: 0;
	color: var(--wpflow-copy-strong);
	font-size: 24px;
	font-weight: 300;
	line-height: 1.2;
}

body.wpflow-editorial-single .wpflow-related-posts__heading a {
	color: inherit;
}

/* Rebalance the contact page form/details section without touching shared builder data. */
body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) > .elementor-container,
body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) > .elementor-row {
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
	gap: clamp(28px, 4vw, 52px);
	align-items: start;
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column {
	float: none;
	width: auto;
	min-width: 0;
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column > .elementor-element-populated {
	height: 100%;
	margin: 0;
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:has(.wpforms-container) > .elementor-element-populated,
body.wpflow-contact-page .entry-content > .wpforms-container {
	padding: clamp(24px, 3vw, 40px);
	background: #ffffff;
	border: 1px solid var(--wpflow-surface-border);
	border-radius: 28px;
	box-shadow: 0 22px 48px rgba(27, 27, 27, 0.07);
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) > .elementor-element-populated {
	padding: clamp(24px, 3vw, 40px);
	background: linear-gradient(180deg, #ffffff 0%, var(--wpflow-surface-soft) 100%);
	border: 1px solid var(--wpflow-surface-border);
	border-radius: 28px;
	box-shadow: 0 18px 40px rgba(27, 27, 27, 0.06);
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-widget-wrap {
	align-content: start;
	gap: 18px;
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-widget-icon-box .elementor-icon-box-wrapper {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 14px;
	align-items: start;
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-widget-icon-box + .elementor-widget-icon-box,
body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-widget-icon-box + .elementor-widget-text-editor,
body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-widget-heading + .elementor-widget-text-editor,
body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-widget-text-editor + .elementor-widget-text-editor {
	padding-top: 18px;
	border-top: 1px solid rgba(230, 221, 209, 0.9);
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-widget-heading .elementor-heading-title,
body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-icon-box-title {
	color: var(--wpflow-copy-strong);
	line-height: 1.25;
}

body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-widget-text-editor,
body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) .elementor-icon-box-description {
	color: var(--wpflow-copy-muted);
	line-height: 1.8;
}

body.wpflow-contact-page .wpforms-container,
body.wpflow-contact-page .elementor-widget-wpforms .elementor-widget-container {
	margin: 0;
}

body.wpflow-contact-page .wpforms-container .wpforms-form .wpforms-field {
	margin-bottom: 18px;
}

body.wpflow-contact-page .wpforms-container .wpforms-form .wpforms-field-label {
	margin-bottom: 8px;
	color: var(--wpflow-copy-strong);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1.45;
	text-transform: uppercase;
}

body.wpflow-contact-page .wpforms-container .wpforms-form input[type='text'],
body.wpflow-contact-page .wpforms-container .wpforms-form input[type='email'],
body.wpflow-contact-page .wpforms-container .wpforms-form input[type='tel'],
body.wpflow-contact-page .wpforms-container .wpforms-form input[type='url'],
body.wpflow-contact-page .wpforms-container .wpforms-form input[type='number'],
body.wpflow-contact-page .wpforms-container .wpforms-form select,
body.wpflow-contact-page .wpforms-container .wpforms-form textarea {
	width: 100%;
	padding: 14px 16px;
	background: #ffffff;
	border: 1px solid #d9cec1;
	border-radius: 16px;
	box-sizing: border-box;
	color: var(--wpflow-copy-strong);
	font-size: 16px;
	line-height: 1.45;
}

body.wpflow-contact-page .wpforms-container .wpforms-form textarea {
	min-height: 180px;
}

body.wpflow-contact-page .wpforms-container .wpforms-form .wpforms-field-description,
body.wpflow-contact-page .wpforms-container .wpforms-form .wpforms-field-sublabel {
	color: #7a746b;
	font-size: 13px;
	line-height: 1.55;
}

body.wpflow-contact-page .wpforms-container .wpforms-form .wpforms-submit-container {
	margin-top: 10px;
	padding-top: 14px;
	border-top: 1px solid rgba(230, 221, 209, 0.9);
}

@media (max-width: 1024px) {
	body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) > .elementor-container,
	body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) > .elementor-row {
		grid-template-columns: minmax(0, 1fr);
	}
}

@media (max-width: 767px) {
	body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:has(.wpforms-container) > .elementor-element-populated,
	body.wpflow-contact-page .elementor-section:has(.wpforms-container):not(.elementor-inner-section) .elementor-column:not(:has(.wpforms-container)) > .elementor-element-populated,
	body.wpflow-contact-page .entry-content > .wpforms-container {
		padding: 22px 20px;
		border-radius: 22px;
	}
}

body.wpflow-editorial-single .wpflow-related-posts__excerpt {
	margin: 0;
	color: var(--wpflow-copy-muted);
	font-size: 15px;
	line-height: 1.75;
}

body.wpflow-editorial-single .wpflow-related-posts__cta {
	margin-top: auto;
	color: var(--wpflow-cta-background);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
}

body.wpflow-editorial-archive #blog-entries .blog-entry-header a:hover,
body.wpflow-editorial-archive #blog-entries .blog-entry-header a:focus,
body.wpflow-editorial-single .wpflow-related-posts__heading a:hover,
body.wpflow-editorial-single .wpflow-related-posts__heading a:focus,
body.wpflow-editorial-single .wpflow-related-posts__cta:hover,
body.wpflow-editorial-single .wpflow-related-posts__cta:focus {
	color: var(--wpflow-cta-background);
}

body.wpflow-editorial-archive #blog-entries .blog-entry-readmore a:focus-visible,
body.wpflow-editorial-single .wpflow-related-posts__cta:focus-visible,
body.wpflow-editorial-single .wpflow-related-posts__heading a:focus-visible {
	outline: 3px solid var(--wpflow-cta-focus-ring);
	outline-offset: 3px;
}

@media (prefers-reduced-motion: no-preference) {
	body.wpflow-editorial-archive #blog-entries .blog-entry-inner,
	body.wpflow-editorial-archive #blog-entries .blog-entry-media img,
	body.wpflow-editorial-archive #blog-entries .thumbnail img,
	body.wpflow-editorial-archive #blog-entries .blog-entry-readmore a,
	body.wpflow-editorial-single .wpflow-related-posts__card,
	body.wpflow-editorial-single .wpflow-related-posts__image {
		transition:
			transform 180ms ease,
			box-shadow 180ms ease,
			background-color 180ms ease,
			border-color 180ms ease,
			color 180ms ease;
	}

	body.wpflow-editorial-archive #blog-entries .blog-entry-inner:hover,
	body.wpflow-editorial-archive #blog-entries .blog-entry-inner:focus-within,
	body.wpflow-editorial-single .wpflow-related-posts__card:hover,
	body.wpflow-editorial-single .wpflow-related-posts__card:focus-within {
		transform: translateY(-4px);
		box-shadow: 0 24px 48px rgba(27, 27, 27, 0.1);
	}

	body.wpflow-editorial-archive #blog-entries .blog-entry-inner:hover .blog-entry-media img,
	body.wpflow-editorial-archive #blog-entries .blog-entry-inner:hover .thumbnail img,
	body.wpflow-editorial-single .wpflow-related-posts__card:hover .wpflow-related-posts__image {
		transform: scale(1.03);
	}

	body.wpflow-editorial-archive #blog-entries .blog-entry-readmore a:hover,
	body.wpflow-editorial-archive #blog-entries .blog-entry-readmore a:focus {
		background: var(--wpflow-cta-background-hover);
		border-color: var(--wpflow-cta-background-hover);
	}
}

@media (max-width: 959px) {
	body.wpflow-editorial-archive #blog-entries {
		grid-template-columns: 1fr;
	}

	body.wpflow-editorial-single .wpflow-related-posts {
		padding: 32px 24px;
	}
}

@media (max-width: 767px) {
	body.wpflow-editorial-archive #blog-entries {
		gap: 24px;
	}

	body.wpflow-editorial-archive #blog-entries .blog-entry-content,
	body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-header,
	body.wpflow-editorial-archive #blog-entries .blog-entry-inner > ul.meta,
	body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-summary,
	body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-readmore {
		padding-left: 22px;
		padding-right: 22px;
	}

	body.wpflow-editorial-archive #blog-entries .blog-entry-content,
	body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-header {
		padding-top: 22px;
	}

	body.wpflow-editorial-archive #blog-entries .blog-entry-inner > .blog-entry-readmore {
		padding-bottom: 22px;
	}

	body.wpflow-editorial-single .wpflow-related-posts {
		margin-top: 40px;
		padding: 28px 20px;
		border-radius: 24px;
	}

	body.wpflow-editorial-single .wpflow-related-posts__grid {
		grid-template-columns: 1fr;
	}

	body.wpflow-editorial-single .wpflow-related-posts__heading {
		font-size: 22px;
	}
}

/* Trim the stock footer on phones and promote the real navigation links as tap targets. */
@media (max-width: 767px) {
	body .site-footer #footer-widgets {
		padding-top: 36px;
		padding-bottom: 12px;
	}

	body .site-footer #footer-widgets .footer-widgets-inner {
		display: flex;
		flex-direction: column;
		gap: 14px;
	}

	body .site-footer #footer-widgets .footer-box {
		float: none;
		width: 100%;
		margin: 0;
	}

	body .site-footer #footer-widgets .footer-widget {
		margin-bottom: 0;
	}

	body .site-footer #footer-widgets .widget-title {
		margin-bottom: 12px;
	}

	body .site-footer .widget-oceanwp-recent-posts {
		display: none;
	}

	body .site-footer .contact-info-widget .text {
		display: none;
	}

	body .site-footer .contact-info-widget li,
	body .site-footer .widget_nav_menu li,
	body .site-footer .widget_pages li,
	body .site-footer .widget_archive li,
	body .site-footer .widget_categories li,
	body .site-footer .widget_meta li,
	body .site-footer .widget_recent_entries li,
	body .site-footer .widget_product_categories li,
	body .site-footer .widget_links li,
	body .site-footer #footer-bottom-menu li,
	body .site-footer .footer-menu li {
		margin: 0;
	}

	body .site-footer .contact-info-widget li + li,
	body .site-footer .widget_nav_menu li + li,
	body .site-footer .widget_pages li + li,
	body .site-footer .widget_archive li + li,
	body .site-footer .widget_categories li + li,
	body .site-footer .widget_meta li + li,
	body .site-footer .widget_recent_entries li + li,
	body .site-footer .widget_product_categories li + li,
	body .site-footer .widget_links li + li {
		margin-top: 8px;
	}

	body .site-footer .widget_nav_menu a,
	body .site-footer .widget_pages a,
	body .site-footer .widget_archive a,
	body .site-footer .widget_categories a,
	body .site-footer .widget_meta a,
	body .site-footer .widget_recent_entries a,
	body .site-footer .widget_product_categories a,
	body .site-footer .widget_links a,
	body .site-footer .contact-info-widget a,
	body .site-footer #footer-bottom-menu a,
	body .site-footer .footer-menu a {
		display: flex;
		align-items: center;
		min-height: 44px;
		padding: 10px 0;
		line-height: 1.4;
	}

	body .site-footer .contact-info-widget .oceanwp-contact-text a {
		overflow-wrap: anywhere;
	}

	body .site-footer #footer-bottom #footer-bottom-menu,
	body .site-footer #footer-bottom .footer-menu {
		display: flex;
		flex-wrap: wrap;
		gap: 10px;
		justify-content: center;
	}

	body .site-footer #footer-bottom-menu a,
	body .site-footer .footer-menu a {
		padding: 10px 14px;
		border: 1px solid rgba(255, 255, 255, 0.18);
		border-radius: 999px;
	}

	body .site-footer .widget_nav_menu a:focus-visible,
	body .site-footer .widget_pages a:focus-visible,
	body .site-footer .widget_archive a:focus-visible,
	body .site-footer .widget_categories a:focus-visible,
	body .site-footer .widget_meta a:focus-visible,
	body .site-footer .widget_recent_entries a:focus-visible,
	body .site-footer .widget_product_categories a:focus-visible,
	body .site-footer .widget_links a:focus-visible,
	body .site-footer .contact-info-widget a:focus-visible,
	body .site-footer #footer-bottom-menu a:focus-visible,
	body .site-footer .footer-menu a:focus-visible {
		outline: 3px solid rgba(255, 255, 255, 0.26);
		outline-offset: 3px;
	}
}

/* Reformat the shared footer contact widget so the key details scan cleanly on every breakpoint. */
body .site-footer .widget-oceanwp-contact-info .contact-info-widget {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget > li + li {
	margin-top: 0;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget > .text {
	display: none;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget > .phone {
	order: 1;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget > .email {
	order: 2;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget > .address {
	order: 3;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget > .web {
	order: 4;
	opacity: 0.86;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget > li:not(.text) {
	display: grid;
	grid-template-columns: 18px minmax(0, 1fr);
	align-items: start;
	column-gap: 14px;
	margin: 0;
	padding: 14px 16px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.03);
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget > li:not(.text) > i {
	margin-top: 0.35em;
	color: rgba(255, 255, 255, 0.88);
	font-size: 15px;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-info-wrap {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-title {
	display: block;
	color: rgba(255, 255, 255, 0.72);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.16em;
	line-height: 1.4;
	text-transform: uppercase;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text,
body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text a {
	color: #ffffff;
	font-size: 16px;
	font-weight: 600;
	line-height: 1.6;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text {
	overflow-wrap: anywhere;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text a {
	display: inline-flex;
	align-items: center;
	min-height: 0;
	padding: 0;
	text-decoration: none;
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.18em;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text a:hover,
body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text a:focus {
	text-decoration: underline;
}

body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text a:focus-visible {
	outline: 3px solid rgba(255, 255, 255, 0.26);
	outline-offset: 3px;
	border-radius: 4px;
}

@media (max-width: 960px) {
	body .site-footer .widget-oceanwp-contact-info .contact-info-widget > li:not(.text) {
		padding: 13px 14px;
		border-radius: 16px;
	}
}

@media (max-width: 767px) {
	body .site-footer .widget-oceanwp-contact-info .contact-info-widget {
		gap: 10px;
	}

	body .site-footer .widget-oceanwp-contact-info .contact-info-widget > li:not(.text) {
		padding: 13px 14px;
	}

	body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text,
	body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text a {
		font-size: 15px;
		line-height: 1.55;
	}

	body .site-footer .widget-oceanwp-contact-info .contact-info-widget .oceanwp-contact-text a {
		min-height: 0;
		padding: 0;
	}
}

/* Slim dismissible notice above the shared OceanWP header. */
html.wpflow-announcement-dismissed body .wpflow-announcement-bar,
body .wpflow-announcement-bar[hidden] {
	display: none !important;
}

body .wpflow-announcement-bar {
	background: var(--wpflow-surface-soft);
	border-bottom: 1px solid var(--wpflow-surface-border);
	color: var(--wpflow-copy-strong);
	font-size: 13px;
}

body .wpflow-announcement-bar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding-top: 8px;
	padding-bottom: 8px;
}

body .wpflow-announcement-bar__content {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px 12px;
	margin: 0;
	line-height: 1.4;
}

body .wpflow-announcement-bar__phone {
	color: var(--wpflow-cta-background);
	font-weight: 700;
	text-decoration: none;
}

body .wpflow-announcement-bar__phone:hover,
body .wpflow-announcement-bar__phone:focus {
	color: var(--wpflow-cta-background-hover);
	text-decoration: underline;
}

body .wpflow-announcement-bar__separator {
	color: #b8ac9d;
}

body .wpflow-announcement-bar__promo {
	color: var(--wpflow-copy-muted);
}

body .wpflow-announcement-bar__dismiss {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	width: 30px;
	height: 30px;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: transparent;
	color: var(--wpflow-copy-strong);
	cursor: pointer;
	font-size: 20px;
	line-height: 1;
}

body .wpflow-announcement-bar__dismiss:hover,
body .wpflow-announcement-bar__dismiss:focus {
	background: rgba(51, 51, 51, 0.08);
	color: var(--wpflow-cta-background);
}

body .wpflow-announcement-bar__dismiss:focus-visible {
	outline: 3px solid var(--wpflow-cta-focus-ring);
	outline-offset: 2px;
}

/* Keep the OceanWP minimal header visible while trimming its footprint. */
html {
	scroll-padding-top: 88px;
}

body #site-header.minimal-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background-color: #ffffff;
	box-shadow: 0 12px 28px rgba(27, 27, 27, 0.08);
}

body.admin-bar #site-header.minimal-header {
	top: 32px;
}

body #site-header.minimal-header #site-header-inner {
	height: auto;
	min-height: 62px;
	padding-top: 0;
	padding-bottom: 0;
}

body #site-header.minimal-header #site-logo #site-logo-inner {
	display: flex;
	align-items: center;
	height: 62px;
}

body #site-header.minimal-header #site-logo #site-logo-inner a {
	display: block;
	line-height: 0;
}

body #site-header.minimal-header #site-logo #site-logo-inner a img {
	width: auto;
	max-height: 42px;
}

body #site-header.minimal-header #site-navigation-wrap .dropdown-menu > li > a,
body #site-header.minimal-header #site-navigation-wrap .wcmenucart,
body #site-header.minimal-header #site-navigation-wrap .search-toggle-li > a {
	line-height: 62px;
}

body #site-header.minimal-header .oceanwp-mobile-menu-icon a,
body #site-header.minimal-header .oceanwp-mobile-menu-icon .wcmenucart {
	line-height: 56px;
}

body #site-header.minimal-header .oceanwp-mobile-menu-icon a i,
body #site-header.minimal-header .oceanwp-mobile-menu-icon a .oceanwp-text {
	line-height: inherit;
}

@media (max-width: 959px) {
	html {
		scroll-padding-top: 74px;
	}

	body .wpflow-announcement-bar__inner {
		align-items: flex-start;
	}

	body #site-header.minimal-header #site-header-inner {
		min-height: 56px;
	}

	body #site-header.minimal-header #site-logo #site-logo-inner {
		height: 56px;
	}

	body #site-header.minimal-header #site-logo #site-logo-inner a img {
		max-height: 36px;
	}

	body #site-header.minimal-header #site-navigation-wrap .dropdown-menu > li > a,
	body #site-header.minimal-header #site-navigation-wrap .wcmenucart,
	body #site-header.minimal-header #site-navigation-wrap .search-toggle-li > a {
		line-height: 58px;
	}
}

@media (max-width: 782px) {
	body.admin-bar #site-header.minimal-header {
		top: 46px;
	}

	body .wpflow-announcement-bar {
		font-size: 12px;
	}

	body .wpflow-announcement-bar__inner {
		gap: 10px;
		padding-top: 7px;
		padding-bottom: 7px;
	}

	body .wpflow-announcement-bar__content {
		gap: 4px 10px;
	}

	body .wpflow-announcement-bar__dismiss {
		width: 28px;
		height: 28px;
	}
}
