/*
Theme Name: SKVN Marine
Template: generatepress
Text Domain: skvn-marine
Version: 1.3.7
Requires at least: 6.5
Requires PHP: 7.4
Update URI: false
Description: GeneratePress child theme for SKVN Marine B2B fishery/marine website.
Author: SKVN
*/

:root {
	/* -----------------------------------------------------------------------
	 * Color palette — WP preset is source of truth; hex fallback for contexts
	 * where theme.json global styles have not yet loaded (e.g. plain PHP page).
	 * Cascade: theme.json preset → these bridge vars → plugin plugin-css fallback.
	 * ----------------------------------------------------------------------- */
	--skvn-color-blue-950:  var(--wp--preset--color--skvn-blue-950,  #082f49);
	--skvn-color-blue-900:  var(--wp--preset--color--skvn-blue-900,  #0c4a6e);
	--skvn-color-blue-700:  var(--wp--preset--color--skvn-blue-700,  #0369a1);
	--skvn-color-mint-100:  var(--wp--preset--color--skvn-mint-100,  #ddfaf4);
	--skvn-color-gold-300:  var(--wp--preset--color--skvn-gold-300,  #e9c766);
	--skvn-color-teal-600:  var(--wp--preset--color--skvn-teal-600,  #0d9488);
	--skvn-color-sky-50:    var(--wp--preset--color--skvn-sky-50,    #f0f9ff);
	--skvn-color-slate-700: var(--wp--preset--color--skvn-slate-700, #334155);
	--skvn-color-slate-900: var(--wp--preset--color--skvn-slate-900, #0f172a);
	--skvn-color-white:     var(--wp--preset--color--skvn-white,     #ffffff);
	/* No WP preset equivalent — keep as hardcoded fallback */
	--skvn-color-trust-blue: #0f5c8c;
	--skvn-color-fresh-sky:  #eaf7ff;

	/* Semantic role aliases — consumed by plugin CSS and component styles */
	--skvn-color-primary: var(--skvn-color-blue-700);
	--skvn-color-navy:    var(--skvn-color-blue-950);
	--skvn-color-accent:  var(--skvn-color-teal-600);
	--skvn-color-text:    var(--skvn-color-slate-700);
	--skvn-color-surface: var(--skvn-color-sky-50);

	--skvn-accent-support: var(--skvn-color-mint-100);
	--skvn-accent-premium: var(--skvn-color-gold-300);

	/* Heading semantic tokens */
	--skvn-heading-color:          var(--skvn-color-blue-950);
	--skvn-heading-weight-display: 800;
	--skvn-heading-weight-primary: 700;
	--skvn-heading-weight-secondary: 600;

	/* Footer tokens */
	--skvn-footer-bg:          var(--skvn-color-blue-950);
	--skvn-footer-border:      rgba(255, 255, 255, 0.14);
	--skvn-footer-chip-bg:     var(--skvn-color-white);
	--skvn-footer-chip-bg-hover: rgba(255, 255, 255, 0.2);
	--skvn-footer-chip-text:   var(--skvn-footer-bg);
	--skvn-footer-heading:     var(--skvn-color-white);
	--skvn-footer-link:        rgba(255, 255, 255, 0.82);
	--skvn-footer-link-hover:  var(--skvn-color-white);
	--skvn-footer-muted:       rgba(219, 234, 254, 0.78);
	--skvn-footer-social-bg:   rgba(255, 255, 255, 0.12);
	--skvn-footer-text:        rgba(255, 255, 255, 0.78);

	/* Font tokens — baseline defaults. inc/customizer.php overrides these
	 * via wp_add_inline_style (priority 15) with the Customizer-chosen preset. */
	--skvn-font-heading: 'Instrument Serif', Georgia, serif;
	--skvn-font-body:    system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--skvn-font-ui:      var(--skvn-font-body);

	/* Component tokens */
	--skvn-radius-card:    8px;
	--skvn-shadow-card:    0 10px 30px rgba(8, 47, 73, 0.1);
	--skvn-content-width:  760px;
	--skvn-wide-width:     1200px;
}

body:not(.wp-admin) {
	color: var(--skvn-color-slate-700);
	font-family: var(--skvn-font-body);
}

.editor-styles-wrapper {
	color: var(--skvn-color-slate-700);
	font-family: var(--skvn-font-body);
}

body:not(.wp-admin) button,
body:not(.wp-admin) input,
body:not(.wp-admin) optgroup,
body:not(.wp-admin) select,
body:not(.wp-admin) textarea,
.editor-styles-wrapper button,
.editor-styles-wrapper input,
.editor-styles-wrapper optgroup,
.editor-styles-wrapper select,
.editor-styles-wrapper textarea {
	font-family: var(--skvn-font-ui);
}

body:not(.wp-admin) h1,
body:not(.wp-admin) h2,
body:not(.wp-admin) h3,
body:not(.wp-admin) h4,
body:not(.wp-admin) h5,
body:not(.wp-admin) h6,
body:not(.wp-admin) .wp-block-heading,
.editor-styles-wrapper h1,
.editor-styles-wrapper h2,
.editor-styles-wrapper h3,
.editor-styles-wrapper h4,
.editor-styles-wrapper h5,
.editor-styles-wrapper h6,
.editor-styles-wrapper .wp-block-heading {
	font-family: var(--skvn-font-heading);
	letter-spacing: 0;
	color: var(--skvn-heading-color);
}

/* 64px is Wordpress Logo in Editor */
body.block-editor-iframe__body.editor-styles-wrapper.post-type-page {
	box-sizing: border-box;
	padding-left: 64px;
}

.skvn-container {
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1rem;
	width: 100%;
}

.skvn-section {
	padding-block: 4rem;
}

.skvn-section.alignfull {
	padding-inline: 0;
}

.skvn-section > .wp-block-group__inner-container,
.skvn-section > .wp-block-columns,
.skvn-trust-strip > .wp-block-group__inner-container,
.skvn-newsletter-band > .wp-block-group__inner-container,
.skvn-pattern-hero > .wp-block-group__inner-container {
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1rem;
}

.skvn-section.alignfull > .skvn-section__eyebrow,
.skvn-section.alignfull > .skvn-section__heading,
.skvn-section.alignfull > .skvn-section__lead,
.skvn-section.alignfull > .wp-block-buttons {
	box-sizing: border-box;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1rem;
	width: 100%;
}

.skvn-section.has-skvn-sky-50-background-color,
.skvn-section--soft {
	background: var(--skvn-color-sky-50);
}

.skvn-section--support {
	background: var(--skvn-accent-support);
}

.skvn-button:not(.wp-block-button),
.wp-block-button.skvn-button > .wp-block-button__link,
.wp-block-button.is-style-skvn-primary > .wp-block-button__link {
	align-items: center;
	border-radius: 6px;
	display: inline-flex;
	font-weight: 700;
	justify-content: center;
	line-height: 1.2;
	min-height: 2.75rem;
	padding: 0.75rem 1.25rem;
	text-decoration: none;
}

.skvn-button--primary:not(.wp-block-button),
.wp-block-button.skvn-button--primary > .wp-block-button__link,
.wp-block-button.is-style-skvn-primary > .wp-block-button__link {
	background: var(--skvn-color-blue-700);
	color: var(--skvn-color-white);
}

.skvn-button--primary:not(.wp-block-button):hover,
.wp-block-button.skvn-button--primary > .wp-block-button__link:hover,
.wp-block-button.is-style-skvn-primary > .wp-block-button__link:hover {
	background: var(--skvn-color-blue-900);
	color: var(--skvn-color-white);
}

.wp-block-button.skvn-button--primary .wp-block-button__link {
	background: var(--skvn-color-blue-700);
	color: var(--skvn-color-white);
}

.wp-block-button.skvn-button--primary .wp-block-button__link:hover {
	background: var(--skvn-color-blue-900);
	color: var(--skvn-color-white);
}

.wp-block-button.skvn-button--secondary .wp-block-button__link {
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.32);
	color: var(--skvn-color-white);
}

.wp-block-button.skvn-button--secondary .wp-block-button__link:hover {
	background: rgba(255, 255, 255, 0.1);
	color: var(--skvn-color-white);
}

.skvn-button--outline:not(.wp-block-button) {
	background: transparent;
	border: 1.5px solid var(--skvn-color-blue-950, #082f49);
	color: var(--skvn-color-blue-950, #082f49);
}

.skvn-button--outline:not(.wp-block-button):hover {
	background: var(--skvn-color-sky-50);
}

.skvn-card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.14);
	border-radius: var(--skvn-radius-card);
	box-sizing: border-box;
	box-shadow: var(--skvn-shadow-card);
	padding: 1.25rem;
}

.skvn-accordion {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.14);
	border-radius: var(--skvn-radius-card);
	box-shadow: 0 8px 22px rgba(8, 47, 73, 0.06);
	margin-inline: auto;
	max-width: var(--skvn-content-width);
	padding: 1.25rem;
}

.skvn-accordion--tone-fresh {
	background: var(--skvn-color-sky-50);
	border-color: rgba(3, 105, 161, 0.16);
}

.skvn-accordion--tone-trust {
	background: var(--skvn-accent-support);
	border-color: rgba(13, 148, 136, 0.18);
}

.skvn-accordion--tone-navy {
	background: var(--skvn-color-blue-900);
	border-color: rgba(255, 255, 255, 0.16);
	color: rgba(255, 255, 255, 0.84);
}

.skvn-accordion--tone-navy .skvn-accordion__heading {
	color: var(--skvn-color-white);
}

.skvn-accordion--spacing-sm {
	padding: 0.85rem;
}

.skvn-accordion--spacing-lg {
	padding: 1.75rem;
}

.skvn-accordion--width-wide {
	max-width: var(--skvn-wide-width);
}

.skvn-accordion--width-full {
	max-width: none;
	width: 100%;
}

.skvn-accordion__heading {
	color: var(--skvn-color-blue-950);
	font-size: 1.25rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.2;
	margin-block: 0 0.85rem;
}

.skvn-accordion__panel > :first-child {
	margin-top: 0;
}

.skvn-accordion__panel > :last-child {
	margin-bottom: 0;
}

.skvn-form {
	display: grid;
	gap: 1rem;
}

.skvn-form label,
.skvn-form__label {
	color: var(--skvn-color-blue-950);
	display: grid;
	font-size: 0.88rem;
	font-weight: 800;
	gap: 0.45rem;
	letter-spacing: 0;
	line-height: 1.35;
}

.skvn-form input[type="text"],
.skvn-form input[type="email"],
.skvn-form input[type="number"],
.skvn-form input[type="tel"],
.skvn-form input[type="url"],
.skvn-form select,
.skvn-form textarea {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.2);
	border-radius: 6px;
	color: var(--skvn-color-blue-950);
	font: inherit;
	min-height: 2.75rem;
	padding: 0.75rem 0.85rem;
	width: 100%;
}

.skvn-form textarea {
	min-height: 8rem;
	resize: vertical;
}

.skvn-form input:focus,
.skvn-form select:focus,
.skvn-form textarea:focus {
	border-color: var(--skvn-color-blue-700);
	box-shadow: 0 0 0 3px rgba(3, 105, 161, 0.16);
	outline: 0;
}

.skvn-form .wpcf7-not-valid-tip {
	color: #b91c1c;
	font-size: 0.8rem;
	font-weight: 700;
	margin-top: 0.25rem;
}

.skvn-form .wpcf7-response-output {
	border-radius: 6px;
	font-size: 0.9rem;
	margin: 1rem 0 0;
	padding: 0.85rem 1rem;
}

.skvn-quote-form {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	box-shadow: var(--skvn-shadow-card);
	padding: clamp(1.25rem, 3vw, 2rem);
}

.skvn-quote-form__grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

.skvn-quote-form__row {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

.skvn-quote-form__actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 0.25rem;
}

.skvn-quote-form__note {
	color: var(--skvn-color-slate-700);
	font-size: 0.85rem;
	line-height: 1.5;
	margin: 0;
}

@media (min-width: 640px) {
	.skvn-quote-form__row {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.skvn-form .skvn-button,
.skvn-form input[type="submit"].skvn-button {
	border: 0;
	cursor: pointer;
}

.skvn-support-card {
	background: var(--skvn-accent-support);
	border: 1px solid rgba(13, 148, 136, 0.18);
	border-radius: var(--skvn-radius-card);
}

.skvn-premium-accent {
	background: var(--skvn-accent-premium);
	color: var(--skvn-color-blue-950);
}

.is-style-skvn-card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.14);
	border-radius: var(--skvn-radius-card);
	box-shadow: var(--skvn-shadow-card);
	padding: 1.25rem;
}

.is-style-skvn-rounded-media img {
	border-radius: var(--skvn-radius-card);
	display: block;
}

.skvn-site-header {
	background: rgba(255, 255, 255, 0.96);
	border-bottom: 1px solid rgba(51, 65, 85, 0.12);
	position: sticky;
	top: 0;
	z-index: 50;
}

.site-header {
	background: rgba(255, 255, 255, 0.96);
	border-bottom: 1px solid rgba(51, 65, 85, 0.12);
	position: sticky;
	top: 0;
	z-index: 50;
}

.inside-header {
	align-items: center;
	display: flex;
	gap: 1.5rem;
	justify-content: space-between;
	max-width: var(--skvn-wide-width);
	padding: 0.85rem 1rem;
}

.main-navigation {
	background: transparent;
}

.main-navigation .main-nav ul li a {
	color: var(--skvn-color-blue-950);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0;
	text-transform: uppercase;
}

.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li.current-menu-item > a {
	color: var(--skvn-color-blue-700);
}

.skvn-header-actions {
	align-items: center;
	display: flex;
	flex: 1 1 22rem;
	flex-wrap: wrap;
	gap: 0.6rem;
	justify-content: flex-end;
	min-width: min(100%, 18rem);
}

.skvn-header-actions--full {
	flex-basis: 100%;
	justify-content: flex-start;
}

.skvn-header-search {
	align-items: stretch;
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.16);
	border-radius: 6px;
	display: flex;
	min-height: 2.4rem;
	overflow: hidden;
}

.skvn-header-search select,
.skvn-header-search input[type="search"] {
	background: transparent;
	border: 0;
	color: var(--skvn-color-blue-950);
	font: inherit;
	min-width: 0;
}

.skvn-header-search select {
	border-right: 1px solid rgba(51, 65, 85, 0.12);
	font-size: 0.78rem;
	font-weight: 800;
	max-width: 7rem;
	padding-inline: 0.6rem;
}

.skvn-header-search input[type="search"] {
	inline-size: clamp(8rem, 18vw, 14rem);
	padding-inline: 0.7rem;
}

.skvn-header-search__submit {
	align-items: center;
	background: var(--skvn-color-blue-700);
	border: 0;
	color: var(--skvn-color-white);
	cursor: pointer;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 800;
	justify-content: center;
	min-width: 2.5rem;
	padding-inline: 0.7rem;
}

.skvn-header-search:focus-within {
	box-shadow: 0 0 0 3px rgba(3, 105, 161, 0.14);
}

.skvn-header-action {
	align-items: center;
	border-radius: 6px;
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 800;
	justify-content: center;
	min-height: 2.4rem;
	padding: 0.65rem 0.85rem;
	text-decoration: none;
	white-space: nowrap;
}

.skvn-header-action--contact {
	border: 1px solid rgba(3, 105, 161, 0.2);
	color: var(--skvn-color-blue-900);
}

.skvn-header-action--quote {
	background: var(--skvn-color-blue-700);
	color: var(--skvn-color-white);
}

.skvn-header-action--quote:hover,
.skvn-header-search__submit:hover {
	background: var(--skvn-color-blue-900);
	color: var(--skvn-color-white);
}

.skvn-search-page {
	background: var(--skvn-color-white);
}

.skvn-search-hero {
	background: var(--skvn-color-sky-50);
	padding-block: 3rem;
}

.skvn-search-page__form {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 1.25rem;
}

.skvn-search-page__form select,
.skvn-search-page__form input[type="search"] {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.18);
	border-radius: 6px;
	color: var(--skvn-color-blue-950);
	font: inherit;
	min-height: 2.75rem;
	padding: 0.75rem 0.85rem;
}

.skvn-search-page__form input[type="search"] {
	flex: 1 1 16rem;
	min-width: min(100%, 16rem);
}

.skvn-search-results {
	display: grid;
	gap: 3rem;
	padding-block: 3rem;
}

.skvn-search-section h2 {
	color: var(--skvn-color-blue-950);
	font-size: 1.55rem;
	font-weight: 800;
	margin-block: 0 1rem;
}

.skvn-search-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
}

.skvn-search-card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.14);
	border-radius: var(--skvn-radius-card);
	box-shadow: var(--skvn-shadow-card);
	display: grid;
	overflow: hidden;
}

.skvn-search-card__media {
	aspect-ratio: 4 / 3;
	background: var(--skvn-color-sky-50);
	display: block;
}

.skvn-search-card__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.skvn-search-card__body {
	display: grid;
	gap: 0.75rem;
	padding: 1rem;
}

.skvn-search-card h3 {
	color: var(--skvn-color-blue-950);
	font-size: 1.05rem;
	font-weight: 800;
	line-height: 1.25;
	margin: 0;
}

.skvn-search-card h3 a {
	color: inherit;
	text-decoration: none;
}

.skvn-search-card p {
	margin: 0;
}

.skvn-search-card__meta {
	color: var(--skvn-color-blue-700);
	font-size: 0.78rem;
	font-weight: 800;
}

.skvn-search-card__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
}

.skvn-button--secondary-light {
	background: var(--skvn-color-sky-50);
	border: 1px solid rgba(3, 105, 161, 0.16);
	color: var(--skvn-color-blue-900);
}

.skvn-site-footer {
	background: var(--skvn-footer-bg);
	color: var(--skvn-footer-text);
}

.footer-widgets,
.site-footer {
	background: var(--skvn-footer-bg);
	color: var(--skvn-footer-text);
	overflow-x: clip;
}

body.skvn-footer-bg-default,
body.skvn-footer-bg-deep-navy {
	--skvn-footer-bg: var(--skvn-color-blue-950);
}

body.skvn-footer-bg-trust-blue {
	--skvn-footer-bg: var(--skvn-color-trust-blue);
}

body.skvn-footer-bg-white {
	--skvn-footer-bg: var(--skvn-color-white);
	--skvn-footer-border: rgba(51, 65, 85, 0.14);
	--skvn-footer-chip-bg: var(--skvn-color-blue-950);
	--skvn-footer-chip-bg-hover: var(--skvn-color-blue-900);
	--skvn-footer-chip-text: var(--skvn-color-white);
	--skvn-footer-heading: var(--skvn-color-blue-950);
	--skvn-footer-link: var(--skvn-color-blue-900);
	--skvn-footer-link-hover: var(--skvn-color-blue-700);
	--skvn-footer-muted: var(--skvn-color-slate-700);
	--skvn-footer-social-bg: rgba(8, 47, 73, 0.08);
	--skvn-footer-text: var(--skvn-color-slate-700);
}

body.skvn-footer-bg-fresh-sky {
	--skvn-footer-bg: var(--skvn-color-fresh-sky);
	--skvn-footer-border: rgba(15, 92, 140, 0.16);
	--skvn-footer-chip-bg: var(--skvn-color-blue-950);
	--skvn-footer-chip-bg-hover: var(--skvn-color-blue-900);
	--skvn-footer-chip-text: var(--skvn-color-white);
	--skvn-footer-heading: var(--skvn-color-blue-950);
	--skvn-footer-link: var(--skvn-color-blue-900);
	--skvn-footer-link-hover: var(--skvn-color-blue-700);
	--skvn-footer-muted: var(--skvn-color-slate-700);
	--skvn-footer-social-bg: rgba(8, 47, 73, 0.08);
	--skvn-footer-text: var(--skvn-color-slate-700);
}

body.skvn-has-footer-page .site {
	background: var(--skvn-color-white);
}

.skvn-footer-page {
	background: var(--skvn-footer-bg);
	display: block;
	overflow-x: clip;
}

.skvn-footer-page > .skvn-site-footer,
.skvn-footer-page > .wp-block-group.skvn-site-footer {
	background: var(--skvn-footer-bg);
}

.skvn-footer-page > .wp-block-group,
.site-footer .skvn-site-footer {
	margin-block: 0;
}

.skvn-site-footer {
	padding-block: 3rem 1.25rem;
}

.skvn-footer-page > .wp-block-group.skvn-site-footer.alignfull {
	box-sizing: border-box;
	margin-left: 0;
	margin-right: 0;
	max-width: none;
	width: 100%;
}

.skvn-site-footer,
.skvn-site-footer p,
.skvn-site-footer li {
	font-size: 0.95rem;
	line-height: 1.6;
}

.skvn-site-footer a {
	color: var(--skvn-footer-link);
	text-decoration: none;
}

.skvn-site-footer a:hover {
	color: var(--skvn-footer-link-hover);
}

.skvn-site-footer__grid {
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1rem;
}

.skvn-footer-brand {
	display: grid;
	gap: 1rem;
}

.skvn-footer-brand__identity {
	align-items: center;
	display: flex;
	gap: 0.75rem;
}

.skvn-footer-brand__mark {
	align-items: center;
	aspect-ratio: 1;
	background: var(--skvn-footer-chip-bg);
	border-radius: 999px;
	color: var(--skvn-footer-chip-text);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 900;
	justify-content: center;
	letter-spacing: 0;
	margin: 0;
	width: 2.5rem;
}

.skvn-footer-brand__name {
	color: var(--skvn-footer-heading);
	font-size: 1.05rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1;
	margin: 0;
	text-transform: uppercase;
}

.skvn-footer-brand__tagline {
	color: var(--skvn-footer-muted);
	font-size: 0.64rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	line-height: 1.2;
	margin: 0.2rem 0 0;
	text-transform: uppercase;
}

.skvn-footer-brand h2,
.skvn-site-footer h3 {
	color: var(--skvn-footer-heading);
	font-size: clamp(1.05rem, 0.95rem + 0.55vw, 1.35rem);
	font-weight: 700;
	line-height: 1.18;
	margin-block: 0;
}

.skvn-footer-brand p,
.skvn-site-footer p {
	margin-block: 0;
}

.skvn-footer-list,
.skvn-footer-contact {
	display: grid;
	gap: 0.55rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.skvn-footer-list li,
.skvn-footer-contact li {
	margin: 0;
	padding: 0;
}

.skvn-icon-list,
.skvn-footer-social {
	--skvn-icon-list-gap: 0.65rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	margin-top: 0.25rem;
}

.skvn-icon-list > *,
.skvn-footer-social > * {
	margin: 0;
}

.skvn-icon-list > * + *,
.skvn-footer-social > * + * {
	margin-left: var(--skvn-icon-list-gap);
}

.skvn-icon-list__item,
.skvn-footer-social__link {
	align-items: center;
	background: var(--skvn-footer-social-bg);
	border-radius: 999px;
	display: inline-flex;
	font-size: 0.72rem;
	font-weight: 800;
	height: 2rem;
	justify-content: center;
	min-width: 2rem;
	padding-inline: 0.65rem;
}

.skvn-icon-list__item:hover,
.skvn-footer-social__link:hover {
	background: var(--skvn-footer-chip-bg-hover);
}

.skvn-footer-contact__label {
	color: var(--skvn-footer-muted);
	display: block;
	font-size: 0.72rem;
	font-weight: 700;
	margin-bottom: 0.15rem;
	text-transform: uppercase;
}

.skvn-footer-payments {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
	margin-top: 1rem;
}

.skvn-footer-payment {
	background: var(--skvn-footer-chip-bg);
	border-radius: 4px;
	color: var(--skvn-footer-chip-text);
	display: inline-block;
	font-size: 0.68rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1;
	padding: 0.4rem 0.5rem;
	text-transform: uppercase;
}

.skvn-site-footer__bottom {
	border-top: 1px solid var(--skvn-footer-border);
	font-size: 0.78rem;
	margin-inline: auto;
	margin-top: 2rem;
	max-width: var(--skvn-wide-width);
	padding: 1rem 1rem 0;
}

.skvn-site-footer__bottom-grid {
	display: grid;
	gap: 0.75rem;
}

.skvn-hide-header .site-header,
.skvn-hide-header .main-navigation,
.skvn-hide-header .mobile-header-navigation {
	display: none;
}

.skvn-hide-footer .site-footer,
.skvn-hide-footer .footer-widgets {
	display: none;
}

.skvn-hide-title .entry-title {
	display: none;
}

.skvn-full-width-canvas .site.grid-container,
.skvn-full-width-canvas .site-content,
.skvn-full-width-canvas .content-area,
.skvn-full-width-canvas .inside-article,
.skvn-full-width-canvas .entry-content {
	margin: 0;
	max-width: none;
	padding: 0;
	width: 100%;
}

.skvn-full-width-canvas .site-content {
	display: block;
}

.skvn-full-width-canvas .widget-area {
	display: none;
}

.skvn-full-width-canvas .entry-content > * {
	box-sizing: border-box;
	margin-left: auto;
	margin-right: auto;
	max-width: var(--skvn-content-width);
	width: 100%;
}

.skvn-full-width-canvas .entry-content > .alignwide {
	max-width: var(--skvn-wide-width);
}

/* GeneratePress compatibility: neutralize its descendant alignfull margins. */
.skvn-full-width-canvas .entry-content .alignfull {
	box-sizing: border-box;
	margin-left: 0;
	margin-right: 0;
	max-width: none;
	width: 100%;
}

.skvn-pattern-test-page {
	background: var(--skvn-color-white);
}

.skvn-pattern-test-page .entry-content {
	margin-top: 0;
}

.skvn-full-width-template {
	margin: 0;
	max-width: none;
	overflow-x: clip;
	padding: 0;
	width: 100%;
}

.skvn-full-width-page {
	margin: 0;
}

.skvn-full-width-content {
	margin: 0;
	max-width: none;
	overflow-x: clip;
	padding: 0;
	width: 100%;
}

.skvn-full-width-content > * {
	margin-left: auto;
	margin-right: auto;
	max-width: var(--skvn-content-width);
}

.skvn-full-width-content > .alignwide {
	max-width: var(--skvn-wide-width);
}

/* Legacy template variant of the GeneratePress alignfull compatibility reset. */
.skvn-full-width-template .skvn-full-width-content .alignfull {
	box-sizing: border-box;
	margin-left: 0;
	margin-right: 0;
	max-width: none;
	width: 100%;
}

.skvn-full-width-content > .alignfull + .alignfull {
	margin-top: 0;
}

.skvn-pattern-hero {
	background:
		linear-gradient(90deg, rgba(240, 249, 255, 0.98) 0%, rgba(240, 249, 255, 0.86) 48%, rgba(255, 255, 255, 0.2) 100%),
		var(--skvn-color-sky-50);
	overflow: hidden;
	padding-block: 4rem 5.5rem;
}

.skvn-pattern-hero__grid {
	align-items: center;
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
}

.skvn-pattern-hero__eyebrow {
	color: var(--skvn-color-blue-700);
	font-size: 0.85rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	margin-block: 0 0.75rem;
	text-transform: uppercase;
}

.skvn-pattern-hero h1 {
	color: var(--skvn-color-blue-950);
	font-size: 2.75rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.02;
	margin-block: 0 1rem;
	max-width: 48rem;
	text-transform: uppercase;
}

.skvn-pattern-hero p:not(.skvn-pattern-hero__eyebrow) {
	font-size: 1rem;
	line-height: 1.7;
	max-width: 36rem;
}

.skvn-pattern-hero__media img {
	aspect-ratio: 4 / 3;
	border-radius: var(--skvn-radius-card);
	box-shadow: 0 24px 60px rgba(8, 47, 73, 0.16);
	object-fit: cover;
	width: 100%;
}

.skvn-home-section {
	padding-block: 4rem;
}

.skvn-home-section__heading {
	color: var(--skvn-color-blue-950);
	font-size: 2rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.15;
	margin-block: 0 0.75rem;
	text-transform: uppercase;
}

.skvn-home-section__lead {
	font-size: 1rem;
	line-height: 1.65;
	margin-block: 0 2rem;
	max-width: 46rem;
}

.skvn-feature-grid,
.skvn-process-grid {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

.skvn-feature-card,
.skvn-process-card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	box-shadow: 0 8px 22px rgba(8, 47, 73, 0.07);
	padding: 1.25rem;
}

.skvn-feature-card__icon,
.skvn-process-card__step {
	align-items: center;
	background: var(--skvn-accent-support);
	border-radius: 999px;
	color: var(--skvn-color-blue-700);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 900;
	height: 2.5rem;
	justify-content: center;
	margin-bottom: 0.85rem;
	width: 2.5rem;
}

.skvn-feature-card h3,
.skvn-process-card h3 {
	color: var(--skvn-color-blue-950);
	font-size: 1rem;
	font-weight: 800;
	margin-block: 0 0.45rem;
	text-transform: uppercase;
}

.skvn-feature-card p,
.skvn-process-card p {
	font-size: 0.88rem;
	line-height: 1.55;
	margin-block: 0;
}

.skvn-factory-band {
	background: var(--skvn-color-sky-50);
}

.skvn-factory-band__grid {
	align-items: center;
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
}

.skvn-factory-band img {
	aspect-ratio: 16 / 10;
	border-radius: var(--skvn-radius-card);
	box-shadow: 0 18px 42px rgba(8, 47, 73, 0.14);
	object-fit: cover;
	width: 100%;
}

.skvn-product-section {
	padding-block: 4rem;
}

.skvn-product-section__header {
	margin-bottom: 2rem;
}

.skvn-product-grid .wp-block-woocommerce-product-template,
.skvn-product-grid__template {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
	list-style: none;
	margin: 0;
	padding: 0;
}

.skvn-product-grid .wc-block-grid__products {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
	list-style: none;
	margin: 0;
	padding: 0;
}

.skvn-product-grid .wc-block-grid__product,
.skvn-product-card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	box-shadow: 0 8px 24px rgba(8, 47, 73, 0.08);
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	height: 100%;
	overflow: hidden;
	padding: 0.85rem;
	position: relative;
}

.skvn-product-card img,
.skvn-product-grid .wc-block-grid__product-image img {
	aspect-ratio: 4 / 3;
	border-radius: 6px;
	object-fit: cover;
	width: 100%;
}

.skvn-product-card__title,
.skvn-product-card .wp-block-post-title,
.skvn-product-grid .wc-block-grid__product-title {
	color: var(--skvn-color-blue-950);
	font-size: 1rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.25;
	margin-block: 0;
}

.skvn-product-card__title a,
.skvn-product-card .wp-block-post-title a {
	color: inherit;
	text-decoration: none;
}

.skvn-product-card__price,
.skvn-product-card .wc-block-components-product-price,
.skvn-product-grid .price {
	color: var(--skvn-color-blue-700);
	font-size: 0.92rem;
	font-weight: 800;
	margin-block: 0;
}

.skvn-product-card__cta {
	margin-top: auto;
	opacity: 1;
	transform: none;
	transition:
		opacity 180ms ease,
		transform 180ms ease;
	visibility: visible;
}

.skvn-product-card__cta .wp-block-button__link,
.skvn-product-card__cta button,
.skvn-product-grid .wp-block-button__link,
.skvn-product-grid .button {
	background: var(--skvn-color-blue-700);
	border-radius: 6px;
	color: var(--skvn-color-white);
	display: inline-flex;
	font-size: 0.85rem;
	font-weight: 800;
	justify-content: center;
	line-height: 1.2;
	min-height: 2.5rem;
	padding: 0.7rem 1rem;
	text-decoration: none;
	width: 100%;
}

.skvn-product-category-strip {
	background: var(--skvn-color-sky-50);
	padding-block: 3rem;
}

.skvn-product-category-strip__heading {
	color: var(--skvn-color-blue-950);
	font-size: 2rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.15;
	margin-block: 0 0.5rem;
	text-transform: uppercase;
}

.skvn-product-category-strip__lead {
	margin-block: 0 1.5rem;
	max-width: 44rem;
}

.skvn-product-category-strip__list ul {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	list-style: none;
	margin: 0;
	padding: 0;
}

.skvn-product-category-strip__list li {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	box-shadow: 0 8px 22px rgba(8, 47, 73, 0.06);
	overflow: hidden;
}

.skvn-product-category-strip__list a {
	color: var(--skvn-color-blue-950);
	display: block;
	font-weight: 800;
	padding: 1rem;
	text-decoration: none;
}

.skvn-product-category-strip__list a:hover {
	color: var(--skvn-color-blue-700);
}

.skvn-trust-strip {
	background: var(--skvn-color-white);
	margin-top: -3rem;
	padding-block: 0 3rem;
	position: relative;
	z-index: 2;
}

.skvn-trust-strip__grid {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.1);
	border-radius: var(--skvn-radius-card);
	box-shadow: var(--skvn-shadow-card);
	display: grid;
	gap: 0;
	grid-template-columns: 1fr;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	overflow: hidden;
	width: calc(100% - 2rem);
}

.skvn-trust-strip__item {
	align-items: center;
	display: grid;
	gap: 0.35rem 1.25rem;
	grid-template-columns: 4.5rem minmax(0, 1fr);
	min-height: 8.5rem;
	padding: 1.5rem;
}

.skvn-trust-strip__item h3,
.skvn-trust-strip__item p {
	margin-block: 0;
}

.skvn-trust-strip__item h3 {
	color: var(--skvn-color-blue-950);
	font-size: 1.1rem;
	font-weight: 800;
	grid-column: 2;
	line-height: 1.15;
}

.skvn-trust-strip__item p:not(.skvn-trust-strip__icon) {
	color: var(--skvn-color-slate-700);
	font-size: 0.86rem;
	grid-column: 2;
	line-height: 1.35;
}

.skvn-trust-strip__icon {
	align-items: center;
	background: var(--skvn-accent-support);
	border: 1px solid rgba(15, 92, 140, 0.16);
	border-radius: 999px;
	color: var(--skvn-color-blue-700);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 800;
	grid-row: 1 / span 2;
	height: 4.5rem;
	justify-content: center;
	width: 4.5rem;
}

.skvn-newsletter-band {
	background: var(--skvn-color-blue-900);
	color: var(--skvn-color-white);
	margin-block: 3rem;
	overflow: visible;
	padding-block: 2rem;
}

.skvn-newsletter-band .wp-block-button:not(.is-style-skvn-primary) .wp-block-button__link {
	background: var(--skvn-accent-support);
	color: var(--skvn-color-blue-950);
}

.skvn-newsletter-band__inner {
	align-items: center;
	gap: 1.5rem;
	margin-bottom: 0;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1.5rem;
}

.skvn-newsletter-band h3 {
	color: var(--skvn-color-white);
	font-size: 1.75rem;
	font-weight: 800;
	margin-block: 0 0.35rem;
}

.skvn-newsletter-band p {
	color: rgba(255, 255, 255, 0.82);
	margin-block: 0 1rem;
	max-width: 44rem;
}

.skvn-newsletter-media img {
	aspect-ratio: 4 / 3;
	box-shadow: var(--skvn-shadow-card);
	object-fit: cover;
	width: 100%;
}

.skvn-translated-page {
	background: var(--skvn-color-white);
	overflow-x: clip;
}

.skvn-translated-page > .alignfull {
	margin-top: 0;
}

.skvn-translated-hero {
	background:
		linear-gradient(90deg, rgba(8, 47, 73, 0.98), rgba(12, 74, 110, 0.95)),
		var(--skvn-color-blue-950);
	color: var(--skvn-color-white);
	padding-block: 5rem;
}

.skvn-translated-hero__grid,
.skvn-translated-split__grid,
.skvn-map-contact__grid {
	align-items: center;
	display: grid !important;
	gap: 2rem;
	grid-template-columns: 1fr;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1rem;
}

.skvn-translated-hero__content,
.skvn-translated-hero__media,
.skvn-map-contact__map,
.skvn-map-contact__card {
	min-width: 0;
}

.skvn-translated-hero__eyebrow,
.skvn-section__eyebrow {
	color: var(--skvn-color-gold-300);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	margin-block: 0 1rem;
	text-transform: uppercase;
}

.skvn-section__eyebrow {
	color: var(--skvn-color-blue-700);
}

.skvn-translated-hero__heading {
	color: var(--skvn-color-white);
	font-size: 2.25rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.05;
	margin-block: 0 1.25rem;
	max-width: 42rem;
}

.skvn-translated-hero__lead {
	color: rgba(255, 255, 255, 0.84);
	font-size: 1.05rem;
	line-height: 1.7;
	margin-block: 0 1.75rem;
	max-width: 42rem;
}

.skvn-translated-hero__actions {
	gap: 1rem;
}

.skvn-translated-hero__trust {
	align-items: center;
	display: flex !important;
	flex-wrap: nowrap;
	gap: 1rem;
	margin-block-start: 1.5rem;
}

.skvn-hashtag-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	list-style: none;
	margin: 1.25rem 0 0;
	padding: 0;
}

.skvn-hashtag-list li {
	align-items: center;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	color: rgba(255, 255, 255, 0.9);
	display: inline-flex;
	font-size: 0.9rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
	padding: 0.5rem 0.75rem;
}

.skvn-hashtag-list li::before {
	color: var(--skvn-color-gold-300);
	content: "#";
	font-weight: 900;
	margin-right: 0.25rem;
}

.skvn-avatar-stack {
	align-items: center;
	display: flex !important;
	flex: 0 0 auto;
	flex-direction: row;
	gap: 0;
	margin: 0;
}

.skvn-avatar-stack .wp-block-image,
.skvn-avatar {
	border-radius: 999px;
	flex: 0 0 auto;
	height: 2.375rem !important;
	margin: 0;
	overflow: hidden;
	width: 2.375rem !important;
}

.skvn-avatar-stack .wp-block-image + .wp-block-image,
.skvn-avatar + .skvn-avatar {
	margin-left: -0.65rem;
}

.skvn-avatar img {
	aspect-ratio: 1;
	border: 2px solid var(--skvn-color-white);
	border-radius: 999px;
	display: block;
	height: 2.375rem !important;
	object-fit: cover;
	width: 2.375rem !important;
}

.skvn-trust-text {
	color: rgba(15, 23, 42, 0.82);
	font-size: 0.95rem;
	line-height: 1.45;
	margin: 0;
}

.skvn-trust-text strong {
	color: var(--skvn-color-blue-950);
}

.skvn-translated-hero .skvn-trust-text {
	color: rgba(255, 255, 255, 0.88);
}

.skvn-translated-hero .skvn-trust-text strong {
	color: var(--skvn-color-white);
}

.skvn-translated-hero__image img,
.skvn-placeholder-media img {
	aspect-ratio: 4 / 3;
	border-radius: var(--skvn-radius-card);
	display: block;
	object-fit: cover;
	width: 100%;
}

.skvn-translated-hero__image img {
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24);
}

.skvn-placeholder-media img {
	background: #e6f2ff;
	border: 1px dashed rgba(3, 105, 161, 0.28);
}

.skvn-kpi-strip {
	background: var(--skvn-color-blue-700);
	color: var(--skvn-color-white);
	padding-block: 1.75rem;
}

.skvn-kpi-strip__grid {
	display: grid !important;
	gap: 1rem;
	grid-template-columns: 1fr;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1rem;
	text-align: center;
}

.skvn-kpi-strip__item h3 {
	color: var(--skvn-color-gold-300);
	font-size: 1.8rem;
	font-weight: 900;
	line-height: 1;
	margin-block: 0 0.35rem;
}

.skvn-kpi-strip__item p {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	margin-block: 0;
	text-transform: uppercase;
}

.skvn-section__eyebrow,
.skvn-section__heading,
.skvn-section__lead,
.skvn-translated-split > p {
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
}

.skvn-section__heading {
	color: var(--skvn-color-blue-950);
	font-size: 1.85rem;
	font-weight: 750;
	letter-spacing: 0;
	line-height: 1.12;
	margin-block: 0 1rem;
}

.skvn-section__lead {
	color: var(--skvn-color-slate-700);
	font-size: 1rem;
	line-height: 1.7;
	margin-block: 0 1rem;
}

.skvn-product-card-grid {
	box-sizing: border-box;
	display: grid !important;
	gap: 1.25rem;
	grid-template-columns: 1fr;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1rem;
	width: 100%;
}

.skvn-product-card-grid.skvn-product-card-grid--inset-none {
	padding-inline: 0;
}

.skvn-product-card-grid.skvn-product-card-grid--inset-sm {
	padding-inline: 0.75rem;
}

.skvn-product-card-grid.skvn-product-card-grid--inset-md {
	padding-inline: 1.5rem;
}

.skvn-product-card-grid.skvn-product-card-grid--inset-lg {
	padding-inline: 2rem;
}

.skvn-product-card-grid--content-left .skvn-product-card {
	text-align: left;
}

.skvn-product-card-grid--content-center .skvn-product-card {
	text-align: center;
}

.skvn-product-card-grid--content-right .skvn-product-card {
	text-align: right;
}

.skvn-product-card-grid--content-justify .skvn-product-card {
	text-align: left;
}

.skvn-product-card-grid--content-justify .skvn-product-card p {
	text-align: justify;
}

.skvn-product-card-grid--content-center .skvn-product-card__cta,
.skvn-product-card-grid--content-center .wp-block-buttons {
	justify-content: center;
}

.skvn-product-card-grid--content-right .skvn-product-card__cta,
.skvn-product-card-grid--content-right .wp-block-buttons {
	justify-content: flex-end;
}

.skvn-product-card-grid--content-justify .skvn-product-card__cta,
.skvn-product-card-grid--content-justify .wp-block-buttons,
.skvn-product-card-grid--content-left .skvn-product-card__cta,
.skvn-product-card-grid--content-left .wp-block-buttons {
	justify-content: flex-start;
}

.skvn-card-grid {
	align-items: stretch;
	display: grid !important;
	gap: 1.5rem;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	width: 100%;
}

.skvn-card-grid > .wp-block-column,
.skvn-card-grid > .wp-block-skvn-marine-card,
.skvn-card-grid > .skvn-card,
.skvn-card-grid > .wp-block-group {
	flex: unset !important;
	min-width: 0;
	width: unset !important;
}

.skvn-card-grid > .wp-block-skvn-marine-card,
.skvn-card-grid > .skvn-card,
.skvn-card-grid > .wp-block-group {
	height: 100%;
}

.skvn-card-grid.skvn-card-grid--2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.skvn-card-grid.skvn-card-grid--3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.skvn-card-grid.skvn-card-grid--4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.skvn-card-grid.skvn-card-grid--5 {
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.skvn-card-grid.skvn-card-grid--gap-sm {
	gap: 1rem;
}

.skvn-card-grid.skvn-card-grid--gap-lg {
	gap: 2rem;
}

.skvn-card-grid.skvn-card-grid--inset-none {
	padding-inline: 0;
}

.skvn-card-grid.skvn-card-grid--inset-sm {
	padding-inline: 0.75rem;
}

.skvn-card-grid.skvn-card-grid--inset-md {
	padding-inline: 1.5rem;
}

.skvn-card-grid.skvn-card-grid--inset-lg {
	padding-inline: 2rem;
}

.skvn-card-grid--content-left .skvn-card {
	text-align: left;
}

.skvn-card-grid--content-center .skvn-card {
	text-align: center;
}

.skvn-card-grid--content-right .skvn-card {
	text-align: right;
}

.skvn-card-grid--content-justify .skvn-card {
	text-align: left;
}

.skvn-card-grid--content-justify .skvn-card p {
	text-align: justify;
}

.skvn-card-grid--content-center .skvn-card .wp-block-buttons {
	justify-content: center;
}

.skvn-card-grid--content-right .skvn-card .wp-block-buttons {
	justify-content: flex-end;
}

.skvn-card-grid--content-left .skvn-card .wp-block-buttons,
.skvn-card-grid--content-justify .skvn-card .wp-block-buttons {
	justify-content: flex-start;
}

.skvn-card-grid--equal-heights .skvn-card {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.skvn-card-grid--equal-heights .skvn-card > .block-editor-inner-blocks,
.skvn-card-grid--equal-heights .skvn-card > .block-editor-inner-blocks > .block-editor-block-list__layout {
	display: flex;
	flex: 1;
	flex-direction: column;
}

.skvn-card-grid--card-style-elevated .skvn-card {
	box-shadow: var(--skvn-shadow-card-hover);
}

.skvn-card-grid--card-style-bordered .skvn-card {
	border-color: rgba(15, 92, 140, 0.28);
	box-shadow: none;
}

.skvn-card-grid--card-style-featured .skvn-card,
.skvn-card.skvn-card--featured {
	border-color: rgba(30, 121, 190, 0.4);
	box-shadow: 0 14px 34px rgba(8, 47, 73, 0.14);
}

.skvn-card.skvn-card--featured,
.skvn-card.skvn-card--featured.skvn-card--pricing {
	background: var(--skvn-color-sky-50);
}

.skvn-card.skvn-card--process-step {
	overflow: hidden;
	padding-top: 3rem;
	position: relative;
}

.skvn-card__step-number {
	color: rgba(30, 121, 190, 0.12);
	font-size: 4.5rem;
	font-weight: 900;
	inset-block-start: 0.15rem;
	inset-inline-end: 1rem;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	z-index: 0;
}

.skvn-card.skvn-card--process-step > *:not(.skvn-card__step-number) {
	position: relative;
	z-index: 1;
}

.skvn-card.skvn-card--image-full-bleed > .wp-block-image:first-child {
	margin: -1.25rem -1.25rem 1rem;
}

.skvn-card.skvn-card--image-full-bleed > .wp-block-image:first-child img {
	aspect-ratio: 4 / 3;
	border-radius: var(--skvn-radius-card) var(--skvn-radius-card) 0 0;
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.skvn-card.skvn-card--image-inset > .wp-block-image:first-child {
	margin-block: 0 1rem;
}

.skvn-card.skvn-card--image-inset > .wp-block-image:first-child img {
	aspect-ratio: 4 / 3;
	border-radius: calc(var(--skvn-radius-card) * 0.75);
	display: block;
	object-fit: cover;
	width: 100%;
}

.skvn-section__header--centered {
	margin-bottom: 3.5rem;
	margin-inline: auto;
	max-width: 640px;
	text-align: center;
}

.skvn-section__header--centered .skvn-section__eyebrow,
.skvn-section__header--centered .skvn-section__heading {
	text-align: center;
}

.skvn-stat-grid {
	display: grid !important;
	gap: 1.25rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-bottom: 1.25rem;
}

.skvn-stat-grid:last-child {
	margin-bottom: 0;
}

.skvn-stat-grid > .wp-block-column {
	flex: unset !important;
}

.skvn-stat-card {
	background: var(--skvn-color-white);
	border: 1px solid var(--skvn-border);
	border-radius: var(--skvn-radius-card);
	box-shadow: var(--skvn-shadow-card);
	padding: 2rem;
}

.skvn-stat-card__number {
	color: var(--skvn-color-blue-950);
	font-size: clamp(2rem, 4vw, 2.75rem);
	font-weight: 900;
	line-height: 1;
	margin: 0 !important;
}

.skvn-stat-card__label {
	color: #64748b;
	font-size: 0.8125rem;
	font-weight: 500;
	margin-bottom: 0 !important;
	margin-top: 0.75rem !important;
}

.skvn-translated-split--about .skvn-translated-split__grid {
	align-items: flex-start;
}

.skvn-section__subheading {
	color: var(--skvn-color-blue-950);
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 0;
	margin-top: 1.5rem;
}

.skvn-product-card .wp-block-image {
	box-sizing: border-box;
	display: block;
	margin: -0.85rem -0.85rem 0;
	max-width: none;
	width: calc(100% + 1.7rem);
}

.skvn-product-card .wp-block-image img {
	border-radius: 0;
	display: block;
	height: auto;
	max-width: none;
	width: 100%;
}

.skvn-product-card h3 {
	color: var(--skvn-color-blue-950);
	font-size: 1.15rem;
	font-weight: 800;
	line-height: 1.25;
	margin-block: 0;
}

.skvn-product-card p {
	font-size: 0.88rem;
	line-height: 1.55;
	margin-block: 0;
}

.skvn-card--testimonial {
	background: var(--skvn-color-white);
	border: 1px solid var(--skvn-border);
	border-radius: var(--skvn-radius-card);
	box-shadow: var(--skvn-shadow-card);
	height: 100%;
	padding: 1.75rem;
}

@media (prefers-reduced-motion: no-preference) {
	.skvn-card--testimonial {
		transition: box-shadow 150ms ease, transform 150ms ease;
	}

	.skvn-card--testimonial:hover {
		box-shadow: var(--skvn-shadow-card-hover);
		transform: translateY(-2px);
	}
}

.skvn-card__author {
	align-items: center;
	display: flex !important;
	gap: 0.75rem;
	margin-bottom: 1rem;
}

.skvn-card__avatar {
	border-radius: 50% !important;
	flex-shrink: 0;
	height: 48px !important;
	margin: 0 !important;
	overflow: hidden;
	width: 48px !important;
}

.skvn-card__avatar img {
	border-radius: 50%;
	height: 48px;
	object-fit: cover;
	width: 48px;
}

.skvn-card__author-name {
	color: var(--skvn-color-blue-950);
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.3;
	margin: 0 !important;
}

.skvn-card__author-role {
	color: #94a3b8;
	font-size: 0.6875rem;
	line-height: 1.3;
	margin: 0.125rem 0 0 !important;
}

.skvn-card__quote {
	color: var(--skvn-color-slate-700);
	font-size: 0.875rem;
	font-style: italic;
	line-height: 1.65;
	margin: 0 !important;
}

.skvn-pricing-grid {
	align-items: stretch !important;
	position: relative;
}

.skvn-card--pricing {
	background: var(--skvn-color-white);
	border: 1px solid var(--skvn-border);
	border-radius: var(--skvn-radius-card);
	box-shadow: var(--skvn-shadow-card);
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 2rem;
	position: relative;
}

@media (prefers-reduced-motion: no-preference) {
	.skvn-card--pricing:not(.skvn-card--pricing-featured) {
		transition: box-shadow 200ms ease;
	}

	.skvn-card--pricing:not(.skvn-card--pricing-featured):hover {
		box-shadow: var(--skvn-shadow-card-hover);
	}
}

.skvn-card--pricing-featured {
	background: var(--skvn-color-blue-950);
	border-color: var(--skvn-color-blue-950);
	box-shadow: 0 8px 24px rgba(8, 47, 73, 0.35);
}

@media (min-width: 1024px) {
	.skvn-card--pricing-featured {
		margin-bottom: 1rem;
		margin-top: -1rem;
	}
}

.skvn-pricing__plan {
	color: var(--skvn-color-blue-950);
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0 !important;
}

.skvn-card--pricing-featured .skvn-pricing__plan {
	color: var(--skvn-color-white);
}

.skvn-pricing__desc {
	color: #64748b;
	font-size: 0.8125rem;
	margin: 0.25rem 0 0 !important;
}

.skvn-card--pricing-featured .skvn-pricing__desc {
	color: rgba(255, 255, 255, 0.6);
}

.skvn-pricing__price {
	color: var(--skvn-color-blue-950);
	font-size: 2.25rem;
	font-weight: 900;
	line-height: 1;
	margin: 1.5rem 0 0 !important;
}

.skvn-card--pricing-featured .skvn-pricing__price {
	color: var(--skvn-color-white);
}

.skvn-pricing__badge {
	background: var(--skvn-color-blue-700);
	border-radius: 999px;
	color: var(--skvn-color-white);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.6;
	margin: 0 !important;
	padding: 0.25rem 0.75rem;
	position: absolute;
	right: 1.5rem;
	text-transform: uppercase;
	top: -0.75rem;
}

.skvn-pricing__features {
	flex: 1;
	list-style: none !important;
	margin: 1.5rem 0 1.5rem !important;
	padding: 0 !important;
}

.skvn-pricing__features li {
	border: none !important;
	color: var(--skvn-color-slate-700);
	font-size: 0.875rem;
	padding: 0.5rem 0 0.5rem 1.75rem;
	position: relative;
}

.skvn-card--pricing-featured .skvn-pricing__features li {
	color: rgba(255, 255, 255, 0.75);
}

.skvn-pricing__features li::before {
	background-color: #22c55e;
	content: "";
	height: 1.125rem;
	left: 0;
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E");
	mask-repeat: no-repeat;
	mask-size: contain;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 1.125rem;
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E");
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-size: contain;
}

.skvn-card--pricing .wp-block-buttons {
	margin-top: auto !important;
}

.skvn-quote-context-card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.14);
	border-radius: var(--skvn-radius-card);
	box-shadow: var(--skvn-shadow-card);
	color: var(--skvn-color-slate-700);
	padding: 1.5rem;
}

.skvn-quote-context-card h2,
.skvn-quote-surface__card h3 {
	color: var(--skvn-color-blue-950);
	font-size: 1.15rem;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.25;
	margin-block: 0 1rem;
}

.skvn-quote-context-card ul {
	margin-block: 0;
	padding-inline-start: 1rem;
}

.skvn-quote-context-list {
	margin: 0;
	padding-inline-start: 1rem;
}

.skvn-quote-context-card li + li {
	margin-block-start: 0.65rem;
}

.skvn-quote-surface__grid {
	margin-block-start: 1.5rem;
}

.skvn-quote-surface__card {
	height: 100%;
}

.skvn-product-quote-cta {
	margin-block: 1.25rem 0;
}

.skvn-product-quote-cta .skvn-button {
	width: auto;
}

.skvn-cert-strip {
	background: var(--skvn-color-white);
	border-block: 1px solid rgba(51, 65, 85, 0.12);
	padding-block: 3rem;
}

.skvn-cert-strip h3 {
	color: var(--skvn-color-blue-950);
	font-size: 1.4rem;
	font-weight: 800;
	margin-block: 0 1.5rem;
}

.skvn-cert-strip__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	padding-inline: 1rem;
}

.skvn-cert-strip__badges p {
	align-items: center;
	background: var(--skvn-color-white);
	border: 1px solid rgba(3, 105, 161, 0.5);
	border-radius: 999px;
	color: var(--skvn-color-blue-700);
	display: inline-flex;
	font-size: 0.72rem;
	font-weight: 900;
	height: 4rem;
	justify-content: center;
	margin: 0;
	width: 4rem;
}

.skvn-map-contact {
	background: var(--skvn-color-sky-50);
}

.skvn-map-contact__grid {
	align-items: stretch;
}

.skvn-map-contact__map iframe {
	border: 0;
	border-radius: var(--skvn-radius-card);
	display: block;
	min-height: 22rem;
	width: 100%;
}

.skvn-map-contact__card {
	background: var(--skvn-color-blue-900);
	border-radius: var(--skvn-radius-card);
	color: var(--skvn-color-white);
	padding: 2rem;
}

.skvn-map-contact__card h2 {
	color: var(--skvn-color-white);
	font-size: 2rem;
	font-weight: 800;
	line-height: 1.15;
	margin-block: 0 1rem;
}

.skvn-map-contact__card p {
	color: rgba(255, 255, 255, 0.84);
	margin-block: 0 1rem;
}

.skvn-button--text .wp-block-button__link {
	align-items: center;
	background: transparent !important;
	color: var(--skvn-color-blue-950);
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: 600;
	gap: 0.375rem;
	padding: 0;
	text-decoration: none;
}

.skvn-button--text .wp-block-button__link:hover {
	color: var(--skvn-color-blue-700);
}

.skvn-cta-band {
	padding-block: 5rem;
}

.skvn-cta-band__inner {
	text-align: center;
}

.skvn-cta-band__heading {
	color: var(--skvn-color-white) !important;
	font-size: clamp(1.5rem, 3vw, 2.25rem) !important;
	font-weight: 700 !important;
	margin-bottom: 0.75rem !important;
}

.skvn-cta-band__lead {
	color: rgba(255, 255, 255, 0.8);
	font-size: 1.0625rem;
	margin-bottom: 2rem !important;
}

.skvn-button--white .wp-block-button__link {
	background: var(--skvn-color-white) !important;
	border-radius: 0.625rem;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	color: var(--skvn-color-blue-700) !important;
	font-weight: 600;
	padding: 0.875rem 2rem;
}

.skvn-button--white .wp-block-button__link:hover {
	background: var(--skvn-color-sky-50) !important;
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.skvn-portfolio__header.wp-block-columns {
	align-items: flex-end;
	display: flex !important;
	flex-wrap: wrap;
	gap: 1.5rem;
	justify-content: center;
	margin-bottom: 3rem;
	position: relative;
	text-align: center;
	width: 100%;
}

.skvn-portfolio__header .wp-block-column:first-child {
	flex: 1 1 100% !important;
	min-width: 0;
	width: 100%;
}

.skvn-portfolio__header .wp-block-column:last-child {
	flex: 0 0 auto !important;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: auto !important;
}

.skvn-portfolio-grid.wp-block-gallery {
	display: grid !important;
	gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	width: 100%;
}

.skvn-portfolio-grid .wp-block-image {
	aspect-ratio: 1 / 1;
	border-radius: var(--skvn-radius-card);
	margin: 0 !important;
	overflow: hidden;
	position: relative;
	width: 100% !important;
}

.skvn-portfolio-grid .wp-block-image img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.skvn-portfolio-grid .wp-block-image img[src*="HACCP"],
.skvn-portfolio-grid .wp-block-image img[src*="haccp"],
.skvn-portfolio-grid .wp-block-image img[src*="FDA"],
.skvn-portfolio-grid .wp-block-image img[src*="fda"],
.skvn-portfolio-grid .wp-block-image img[alt*="HACCP"],
.skvn-portfolio-grid .wp-block-image img[alt*="haccp"],
.skvn-portfolio-grid .wp-block-image img[alt*="FDA"],
.skvn-portfolio-grid .wp-block-image img[alt*="fda"] {
	background: var(--skvn-color-white);
	object-fit: contain;
	padding: 0.5rem;
}

.skvn-portfolio-grid .wp-block-image figcaption {
	background: rgba(8, 47, 73, 0.8);
	color: var(--skvn-color-white);
	display: flex;
	flex-direction: column;
	font-size: 0.875rem;
	font-weight: 600;
	inset: 0;
	justify-content: flex-end;
	margin: 0;
	opacity: 0;
	padding: 1.25rem;
	position: absolute;
}

@media (prefers-reduced-motion: no-preference) {
	.skvn-portfolio-grid .wp-block-image figcaption {
		transition: opacity 200ms ease;
	}

	.skvn-portfolio-grid .wp-block-image:hover figcaption {
		opacity: 1;
	}
}

@media (hover: none) {
	.skvn-portfolio-grid .wp-block-image figcaption {
		opacity: 1;
	}
}

@media (max-width: 1024px) {
	.skvn-portfolio__header .wp-block-column:last-child {
		position: static;
		transform: none;
	}

	.skvn-portfolio-grid.wp-block-gallery {
		grid-template-columns: repeat(auto-fit, minmax(7.5rem, 1fr));
	}
}

@media (max-width: 640px) {
	.skvn-portfolio-grid.wp-block-gallery {
		grid-template-columns: repeat(auto-fit, minmax(7rem, 1fr));
	}
}

@media (min-width: 768px) {
	.skvn-container {
		padding-inline: 1.5rem;
	}

	.skvn-section > .wp-block-group__inner-container,
	.skvn-section > .wp-block-columns,
	.skvn-trust-strip > .wp-block-group__inner-container,
	.skvn-newsletter-band > .wp-block-group__inner-container,
	.skvn-pattern-hero > .wp-block-group__inner-container {
		padding-inline: 1.5rem;
	}

	.skvn-section.alignfull {
		padding-inline: 0;
	}

	.skvn-section.alignfull > .skvn-section__eyebrow,
	.skvn-section.alignfull > .skvn-section__heading,
	.skvn-section.alignfull > .skvn-section__lead,
	.skvn-section.alignfull > .wp-block-buttons {
		padding-inline: 1.5rem;
	}

	.skvn-trust-strip__grid {
		width: calc(100% - 3rem);
	}

	.inside-header {
		padding-inline: 1.5rem;
	}

	.skvn-section {
		padding-block: 5rem;
	}

	.skvn-pattern-hero h1 {
		font-size: 3.75rem;
	}

	.skvn-trust-strip__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.skvn-feature-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.skvn-product-grid .wp-block-woocommerce-product-template,
	.skvn-product-grid__template,
	.skvn-product-grid .wc-block-grid__products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.skvn-product-category-strip__list ul {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.skvn-newsletter-media--overhang {
		margin-block: -2.5rem;
	}

	.skvn-translated-hero__grid,
	.skvn-translated-split__grid,
	.skvn-map-contact__grid,
	.skvn-kpi-strip__grid,
	.skvn-product-card-grid {
		padding-inline: 1.5rem;
	}

	.skvn-kpi-strip__grid {
		grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
	}

	.skvn-product-card-grid {
		grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
	}

	.skvn-translated-hero__heading {
		font-size: 3.25rem;
	}

	.skvn-section__heading {
		font-size: 2.35rem;
	}
}

@media (max-width: 1024px) {
	.skvn-card-grid.skvn-card-grid--3,
	.skvn-card-grid.skvn-card-grid--4,
	.skvn-card-grid.skvn-card-grid--5 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.skvn-card-grid,
	.skvn-card-grid.skvn-card-grid--2,
	.skvn-card-grid.skvn-card-grid--3,
	.skvn-card-grid.skvn-card-grid--4,
	.skvn-card-grid.skvn-card-grid--5 {
		grid-template-columns: 1fr;
	}

	.skvn-card-grid.skvn-card-grid--mobile-2 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.skvn-trust-strip__item {
		grid-template-columns: 3.75rem minmax(0, 1fr);
		min-height: 7.25rem;
		padding: 1.25rem;
	}

	.skvn-trust-strip__icon {
		height: 3.75rem;
		width: 3.75rem;
	}
}

@media (min-width: 1024px) {
	.skvn-pattern-hero__grid {
		grid-template-columns: minmax(0, 1fr) minmax(22rem, 0.72fr);
	}

	.skvn-pattern-hero h1 {
		font-size: 4.5rem;
	}

	.skvn-trust-strip__grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.skvn-site-footer__grid {
		grid-template-columns: minmax(0, 1.3fr) repeat(3, minmax(0, 0.8fr));
		padding-inline: 1.5rem;
	}

	.skvn-site-footer__bottom {
		padding-inline: 1.5rem;
	}

	.skvn-site-footer__bottom-grid {
		grid-template-columns: minmax(0, 1fr) auto;
	}

	.skvn-feature-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.skvn-product-grid .wp-block-woocommerce-product-template,
	.skvn-product-grid__template,
	.skvn-product-grid .wc-block-grid__products {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.skvn-product-category-strip__list ul {
		grid-template-columns: repeat(6, minmax(0, 1fr));
	}

	.skvn-process-grid {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}

	.skvn-factory-band__grid {
		grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	}

	.skvn-trust-strip__item + .skvn-trust-strip__item {
		border-left: 1px solid rgba(51, 65, 85, 0.1);
	}

	.skvn-translated-hero__grid {
		grid-template-columns: minmax(0, 1.05fr) minmax(20rem, 0.85fr);
	}

	.skvn-translated-split__grid {
		grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
	}

	.skvn-map-contact__grid {
		grid-template-columns: minmax(0, 1.15fr) minmax(20rem, 0.85fr);
	}

	.skvn-translated-hero__heading {
		font-size: 4.25rem;
	}

	.skvn-section__heading {
		font-size: 3rem;
	}
}

@media (hover: hover) {
	.skvn-product-card:hover .skvn-product-card__cta {
		opacity: 1;
		transform: translateY(-2px);
	}
}

@media (max-width: 767px) {
	.site-header.has-inline-mobile-toggle .inside-header {
		align-items: center;
		min-height: 88px;
		padding-block: 0.5rem;
		row-gap: 0.75rem;
	}

	.skvn-header-actions {
		flex-basis: 100%;
		justify-content: stretch;
		order: 20;
	}

	.skvn-header-search,
	.skvn-header-action {
		width: 100%;
	}

	.skvn-header-search input[type="search"] {
		flex: 1 1 auto;
		inline-size: auto;
	}

	.skvn-header-search select {
		max-width: 6.5rem;
	}

	.site-header .site-branding {
		align-items: center;
		align-self: center;
		display: flex;
		min-width: 0;
	}

	.site-header .main-title {
		align-items: center;
		display: flex;
		font-size: 1.45rem;
		line-height: 1.15;
		margin: 0;
		min-height: 48px;
	}

	.site-header .main-title a {
		align-items: center;
		color: inherit;
		display: inline-flex;
		text-decoration: none;
	}

	.site-header .mobile-menu-control-wrapper {
		flex: 0 0 auto;
	}

	.site-header .menu-toggle {
		align-items: center;
		display: inline-flex;
		height: 48px;
		justify-content: center;
		line-height: 1;
		min-height: 48px;
		min-width: 48px;
		padding: 0.65rem;
	}

	.site-header .menu-toggle .gp-icon {
		align-items: center;
		display: inline-flex;
		justify-content: center;
	}

	.skvn-product-card__cta {
		opacity: 1;
		transform: none;
		visibility: visible;
	}

	.skvn-newsletter-media--overhang {
		margin-block: 0;
	}

	.skvn-translated-hero {
		padding-block: 3.5rem;
	}

	.skvn-map-contact__card {
		padding: 1.5rem;
	}
}
.skvn-b2b-showcase-pattern {
	background: #0d151d;
	color: #f8fbff;
	padding: clamp(2rem, 4vw, 4rem);
}

.skvn-b2b-showcase-pattern__grid {
	gap: clamp(2rem, 5vw, 4rem);
	margin-inline: auto;
	max-width: var(--skvn-wide-width);
	width: 100%;
}

.skvn-b2b-showcase-pattern.is-layout-constrained
	> .skvn-b2b-showcase-pattern__grid {
	max-width: var(--skvn-wide-width);
}

.skvn-b2b-editorial {
	display: flex;
	flex-direction: column;
	min-height: 30rem;
	padding-block: clamp(0.5rem, 2vw, 1.5rem);
}

.skvn-b2b-editorial__eyebrow,
.skvn-b2b-editorial__meta-label {
	color: #59a8ff;
	font-size: 0.75rem;
	letter-spacing: 0.18em;
	line-height: 1.4;
	margin: 0 0 1rem;
	text-transform: uppercase;
}

.skvn-b2b-editorial__heading {
	color: #fff;
	font-size: clamp(2.75rem, 5vw, 4.75rem);
	font-weight: 300;
	letter-spacing: 0;
	line-height: 0.98;
	margin: 0;
}

.skvn-b2b-editorial__heading-accent {
	color: #dcecff;
	font-weight: 700;
}

.skvn-b2b-editorial__copy {
	border-top: 1px solid rgba(148, 163, 184, 0.45);
	color: #a8b6c8;
	font-size: 0.95rem;
	line-height: 1.8;
	margin: 1.75rem 0 0;
	padding-block-start: 1.75rem;
}

.skvn-b2b-editorial__meta {
	margin-block-start: auto;
	padding-block-start: 2rem;
}

.skvn-b2b-editorial__meta-text {
	color: #a8b6c8;
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 0;
	text-transform: uppercase;
}

.skvn-b2b-showcase-pattern__panels {
	min-width: 0;
}

@media (max-width: 781px) {
	.skvn-b2b-showcase-pattern {
		padding: 2.5rem 1rem;
	}

	.skvn-b2b-showcase-pattern__grid {
		gap: 2.5rem;
	}

	.skvn-b2b-editorial {
		min-height: 32rem;
	}

	.skvn-b2b-editorial__heading {
		font-size: clamp(2.75rem, 15vw, 4.25rem);
	}
}

/* ==========================================================================
   Archive — Style C Hybrid (1.3.5)
   Layout owner: .skvn-archive-layout (grid). Width flows from GP page canvas.
   No 100vw, no margin-50vw, no overflow-x hide.
   ========================================================================== */

.skvn-archive-wrap {
	--skvn-page-gutter: 1rem;
	max-width: var(--skvn-wide-width);
	margin-inline: auto;
	padding-inline: var(--skvn-page-gutter);
	padding-block: 2.5rem 4rem;
}

/* Archive banner */
.skvn-archive-banner {
	background: linear-gradient(to right, var(--skvn-color-blue-950), var(--skvn-color-trust-blue));
	color: var(--skvn-color-white);
	padding-block: 3rem;
}

.skvn-archive-banner__inner {
	max-width: var(--skvn-wide-width);
	margin-inline: auto;
	padding-inline: 1rem;
}

.skvn-archive-banner__eyebrow {
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--skvn-color-mint-100);
	margin-bottom: 0.625rem;
}

.skvn-archive-banner__title {
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	color: var(--skvn-color-white);
	margin-bottom: 0.5rem;
}

.skvn-archive-banner__desc {
	color: rgba(255, 255, 255, 0.65);
	font-size: 0.875rem;
	font-weight: 300;
}

/* Featured post — 2-col: image | content */
.skvn-archive-featured {
	display: grid;
	grid-template-columns: 1fr 1fr;
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	overflow: hidden;
	margin-bottom: 2rem;
}

.skvn-archive-featured__thumb {
	min-height: 16rem;
	background: var(--skvn-color-blue-900);
	overflow: hidden;
}

.skvn-archive-featured__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.skvn-archive-featured__placeholder {
	width: 100%;
	height: 100%;
	min-height: 16rem;
	background: linear-gradient(135deg, var(--skvn-color-blue-950), var(--skvn-color-blue-900));
}

.skvn-archive-featured__body {
	padding: 2rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.skvn-archive-featured__label {
	display: inline-block;
	font-size: 0.5625rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--skvn-color-gold-300);
	background: var(--skvn-color-blue-950);
	padding: 0.2rem 0.625rem;
	border-radius: 2px;
	margin-bottom: 0.875rem;
}

.skvn-archive-featured__cat {
	font-size: 0.5938rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--skvn-color-teal-600);
	margin-bottom: 0.625rem;
}

.skvn-archive-featured__title {
	font-size: clamp(1rem, 2.5vw, 1.375rem);
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: var(--skvn-color-slate-900);
	margin-bottom: 0.75rem;
}

.skvn-archive-featured__title a {
	color: inherit;
	text-decoration: none;
}

.skvn-archive-featured__title a:hover {
	color: var(--skvn-color-blue-700);
}

.skvn-archive-featured__excerpt {
	font-size: 0.84375rem;
	color: var(--skvn-color-slate-700);
	line-height: 1.65;
	font-weight: 300;
	margin-bottom: 1.25rem;
}

.skvn-archive-featured__btn {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	background: var(--skvn-color-blue-950);
	color: var(--skvn-color-white);
	font-size: 0.6875rem;
	font-weight: 600;
	padding: 0.5625rem 1.125rem;
	border-radius: 5px;
	text-decoration: none;
	align-self: flex-start;
}

@media (prefers-reduced-motion: no-preference) {
	.skvn-archive-featured__btn {
		transition: background 0.2s;
	}
}

.skvn-archive-featured__btn:hover {
	background: var(--skvn-color-blue-900);
	color: var(--skvn-color-white);
}

/* Archive layout: main + sidebar */
.skvn-archive-layout {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 2.5rem;
	align-items: start;
}

/* Post card grid */
.skvn-archive-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.25rem;
}

.skvn-post-card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

@media (prefers-reduced-motion: no-preference) {
	.skvn-post-card {
		transition: box-shadow 0.2s;
	}
}

.skvn-post-card:hover {
	box-shadow: 0 8px 24px rgba(8, 47, 73, 0.1);
}

.skvn-post-card__thumb {
	aspect-ratio: 3 / 2;
	background: var(--skvn-color-blue-900);
	overflow: hidden;
	flex-shrink: 0;
}

.skvn-post-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.skvn-post-card__placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, var(--skvn-color-blue-950), var(--skvn-color-blue-900));
}

.skvn-post-card__body {
	padding: 1.125rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.skvn-post-card__meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.625rem;
}

.skvn-post-card__cat a {
	font-size: 0.59375rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-teal-600);
	text-decoration: none;
}

.skvn-post-card__cat a:hover {
	color: var(--skvn-color-blue-700);
}

.skvn-post-card__dot {
	width: 3px;
	height: 3px;
	border-radius: 50%;
	background: rgba(51, 65, 85, 0.25);
	flex-shrink: 0;
}

.skvn-post-card__date {
	font-size: 0.59375rem;
	color: var(--skvn-color-slate-700);
}

.skvn-post-card__title {
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.4;
	letter-spacing: -0.01em;
	color: var(--skvn-color-slate-900);
	margin-bottom: 0.5rem;
}

.skvn-post-card__title a {
	color: inherit;
	text-decoration: none;
}

.skvn-post-card__title a:hover {
	color: var(--skvn-color-blue-700);
}

.skvn-post-card__excerpt {
	font-size: 0.78125rem;
	color: var(--skvn-color-slate-700);
	line-height: 1.6;
	font-weight: 300;
	flex: 1;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.skvn-post-card__foot {
	margin-top: 0.875rem;
	padding-top: 0.75rem;
	border-top: 1px solid rgba(51, 65, 85, 0.1);
}

.skvn-post-card__link {
	font-size: 0.59375rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-blue-700);
	text-decoration: none;
}

.skvn-post-card__link:hover {
	color: var(--skvn-color-blue-950);
}

.skvn-archive-empty {
	color: var(--skvn-color-slate-700);
	padding-block: 2rem;
}

/* Pagination */
.skvn-archive-pagination {
	margin-top: 2.5rem;
	display: flex;
	justify-content: center;
}

.skvn-archive-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.25rem;
	height: 2.25rem;
	padding-inline: 0.5rem;
	border: 1px solid rgba(51, 65, 85, 0.2);
	border-radius: 6px;
	font-size: 0.75rem;
	color: var(--skvn-color-slate-700);
	text-decoration: none;
	background: var(--skvn-color-white);
	margin-inline: 0.1875rem;
}

.skvn-archive-pagination .page-numbers.current,
.skvn-archive-pagination .page-numbers:hover {
	background: var(--skvn-color-blue-950);
	color: var(--skvn-color-white);
	border-color: var(--skvn-color-blue-950);
}

/* Archive sidebar */
.skvn-archive-sidebar {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	position: sticky;
	top: 2rem;
}

/* Island (sidebar box) — shared for archive + product + post sidebars */
.skvn-island {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	padding: 1rem;
}

.skvn-island--navy {
	background: var(--skvn-color-blue-950);
	border-color: transparent;
	color: var(--skvn-color-white);
}

/* CTA island — colors driven by inline preset vars from plugin settings.
   Button hover auto-derives by swapping base/text (guaranteed contrast). */
.skvn-island--cta {
	background: var(--skvn-cta-bg, var(--skvn-color-blue-950));
	border-color: transparent;
	color: var(--skvn-cta-fg, var(--skvn-color-white));
}

.skvn-island--cta .skvn-island__eyebrow {
	color: var(--skvn-cta-fg, var(--skvn-color-white));
	opacity: 0.7;
}

.skvn-island--cta .skvn-island__heading {
	color: var(--skvn-cta-fg, var(--skvn-color-white));
}

.skvn-island--cta .skvn-island__note {
	color: var(--skvn-cta-fg, var(--skvn-color-white));
	opacity: 0.5;
}

.skvn-island--cta .skvn-island__cta {
	background: var(--skvn-cta-btn-base, var(--skvn-color-gold-300));
	color: var(--skvn-cta-btn-text, var(--skvn-color-blue-950));
}

.skvn-island--cta .skvn-island__cta:hover {
	background: var(--skvn-cta-btn-text, var(--skvn-color-blue-950));
	color: var(--skvn-cta-btn-base, var(--skvn-color-gold-300));
}

.skvn-island__eyebrow {
	font-size: 0.5625rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--skvn-color-mint-100);
	margin-bottom: 0.5rem;
}

.skvn-island__label {
	font-size: 0.59375rem;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--skvn-color-slate-700);
	margin-bottom: 0.75rem;
}

.skvn-island--navy .skvn-island__label {
	color: rgba(255, 255, 255, 0.5);
}

.skvn-island__heading {
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.4;
	color: var(--skvn-color-white);
	margin-bottom: 0.875rem;
}

.skvn-island__cta {
	display: block;
	text-align: center;
	background: var(--skvn-color-gold-300);
	color: var(--skvn-color-blue-950);
	font-weight: 700;
	font-size: 0.75rem;
	padding: 0.625rem;
	border-radius: 6px;
	text-decoration: none;
}

.skvn-island__cta:hover {
	background: #f0d060;
	color: var(--skvn-color-blue-950);
}

.skvn-island__note {
	display: block;
	text-align: center;
	font-size: 0.5625rem;
	color: rgba(255, 255, 255, 0.35);
	margin-top: 0.5rem;
}

.skvn-island__cat-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.skvn-island__cat-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-block: 0.3125rem;
	border-bottom: 1px solid rgba(51, 65, 85, 0.08);
}

.skvn-island__cat-row:last-child {
	border-bottom: none;
}

.skvn-island__cat-row a {
	font-size: 0.78125rem;
	color: var(--skvn-color-slate-700);
	text-decoration: none;
}

.skvn-island__cat-row a:hover {
	color: var(--skvn-color-blue-700);
}

.skvn-island__cat-count {
	font-size: 0.625rem;
	color: var(--skvn-color-slate-700);
}

.skvn-island__cert-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.skvn-island__cert-row {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding-block: 0.3125rem;
}

.skvn-island__cert-icon {
	width: 1.125rem;
	height: 1.125rem;
	background: var(--skvn-color-teal-600);
	border-radius: 3px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	font-size: 0.625rem;
	color: var(--skvn-color-white);
}

.skvn-island__cert-row span:last-child {
	font-size: 0.75rem;
	color: var(--skvn-color-slate-700);
}

/* Mobile — page gutter + flat sidebar islands (archive + single) */
@media (max-width: 900px) {
	.skvn-archive-wrap,
	.skvn-single-wrap {
		--skvn-page-gutter: 0.75rem;
		padding-inline: var(--skvn-page-gutter);
	}

	.skvn-archive-sidebar,
	.skvn-single-sidebar {
		gap: 0;
	}

	.skvn-island:not(.skvn-island--navy) {
		background: transparent;
		border: none;
		border-radius: 0;
		padding: 0;
		padding-block-end: 1.25rem;
		border-bottom: 1px solid rgba(51, 65, 85, 0.12);
	}

	.skvn-island--navy {
		margin-inline: calc(-1 * var(--skvn-page-gutter));
		padding: 1.25rem var(--skvn-page-gutter);
		border-radius: 0;
	}

	/* Single post: mobile chỉ hiện CTA, ẩn các island còn lại. */
	.skvn-single-sidebar > .skvn-island:not(.skvn-island--cta) {
		display: none;
	}

	.skvn-single-sidebar .skvn-island--cta {
		margin-inline: calc(-1 * var(--skvn-page-gutter));
		padding: 1.25rem var(--skvn-page-gutter);
		border-radius: 0;
	}

	.skvn-archive-sidebar > .skvn-island:last-child,
	.skvn-single-sidebar > .skvn-island:last-child {
		border-bottom: none;
		padding-block-end: 0;
	}
}

@media (max-width: 600px) {
	.skvn-archive-wrap,
	.skvn-single-wrap {
		--skvn-page-gutter: 0.5rem;
	}
}

/* Archive — responsive */
@media (max-width: 900px) {
	.skvn-archive-featured {
		grid-template-columns: 1fr;
	}

	.skvn-archive-featured__thumb {
		min-height: 12rem;
	}

	.skvn-archive-layout {
		grid-template-columns: 1fr;
	}

	.skvn-archive-sidebar {
		position: static;
	}

	.skvn-archive-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 600px) {
	.skvn-archive-grid {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Single Product — Style C (1.3.5)
   WooCommerce visual layer. Cascade sits above WC default styles.
   No hardcoded px/em for layout sizing — fr/% only.
   ========================================================================== */

/* Single product island — rounded card, đồng bộ với .skvn-post-body */
.woocommerce-page.single-product .inside-article {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	overflow: hidden;
}

/* Product page: 2-col hero (gallery | summary), full-width below */
.woocommerce div.product,
.skvn-product-layout {
	--skvn-page-gutter: 1rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 3rem;
	row-gap: 2.5rem;
	align-items: start;
	max-width: var(--skvn-wide-width);
	margin-inline: auto;
	padding-inline: var(--skvn-page-gutter);
	padding-block: 2.5rem;
}

/* Tabs, upsells, related products — span full width below hero */
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .up-sells,
.woocommerce div.product .related {
	grid-column: 1 / -1;
}

/* Hide GP sidebar on single product page */
body.single-product .widget-area {
	display: none !important;
}

/* Override GP site-level layout: make content area full width */
body.single-product .site-content {
	grid-template-columns: 1fr !important;
	display: block !important;
}

body.single-product #primary,
body.single-product .content-area {
	width: 100% !important;
	max-width: 100% !important;
	float: none !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* WooCommerce default product gallery — reset WC floats, let grid own the layout */
.woocommerce #content div.product div.images,
.woocommerce div.product div.images,
.woocommerce-page #content div.product div.images,
.woocommerce-page div.product div.images {
	float: none;
	width: auto;
}

.woocommerce #content div.product div.summary,
.woocommerce div.product div.summary,
.woocommerce-page #content div.product div.summary,
.woocommerce-page div.product div.summary {
	float: none;
	width: auto;
	clear: none;
}

/* GP/WC compat: wrap images and summary into a 2-col inner grid */
.woocommerce .product-images-summary-wrap {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	margin-bottom: 3rem;
}

/* Product placeholder (WC placeholder override) */
.skvn-product-placeholder {
	aspect-ratio: 1 / 1;
	background: linear-gradient(135deg, var(--skvn-color-blue-950) 0%, var(--skvn-color-trust-blue) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--skvn-radius-card);
}

.skvn-product-placeholder span {
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: rgba(255, 255, 255, 0.25);
}

/* WooCommerce gallery thumbnails */
.woocommerce div.product div.images .flex-control-thumbs {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.5rem;
	padding: 0;
	margin: 0;
	list-style: none;
}

.woocommerce div.product div.images .flex-control-thumbs li {
	margin: 0;
}

.woocommerce div.product div.images .flex-control-thumbs li img {
	border-radius: 6px;
	border: 2px solid transparent;
	cursor: pointer;
	aspect-ratio: 1 / 1;
	object-fit: cover;
}

.woocommerce div.product div.images .flex-control-thumbs li img.flex-active {
	border-color: var(--skvn-color-blue-700);
}

/* Product category tags */
.woocommerce div.product .posted_in a,
.skvn-product-cat-tag {
	display: inline-block;
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-teal-600);
	background: var(--skvn-color-mint-100);
	border: 1px solid rgba(13, 148, 136, 0.2);
	padding: 0.1875rem 0.625rem;
	border-radius: 3px;
	text-decoration: none;
	margin-inline-end: 0.25rem;
}

/* Product meta (SKU + stock) */
.woocommerce div.product .product_meta {
	font-size: 0.6875rem;
	color: var(--skvn-color-slate-700);
}

.woocommerce div.product .product_meta .sku_wrapper,
.woocommerce div.product .product_meta .posted_in {
	display: block;
}

/* Product short description */
.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: 0.90625rem;
	color: var(--skvn-color-slate-700);
	line-height: 1.65;
	margin-bottom: 1.5rem;
}

.woocommerce div.product .woocommerce-product-details__short-description ul {
	padding-left: 1.25rem;
}

.woocommerce div.product .woocommerce-product-details__short-description li {
	margin-bottom: 0.375rem;
}

/* Quote CTA zone — full-width primary */
.skvn-product-cta-zone {
	margin-bottom: 1rem;
}

.skvn-product-cta-primary {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	width: 100%;
	background: var(--skvn-color-blue-950);
	color: var(--skvn-color-white);
	font-size: 0.9375rem;
	font-weight: 700;
	padding: 1rem 1.5rem;
	border-radius: 8px;
	text-decoration: none;
	letter-spacing: -0.01em;
}

@media (prefers-reduced-motion: no-preference) {
	.skvn-product-cta-primary {
		transition: background 0.15s;
	}
}

.skvn-product-cta-primary:hover {
	background: var(--skvn-color-blue-900);
	color: var(--skvn-color-white);
}

.skvn-product-cta-secondary {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	width: 100%;
	background: transparent;
	color: var(--skvn-color-blue-950);
	font-size: 0.8125rem;
	font-weight: 600;
	padding: 0.625rem 1.5rem;
	border-radius: 8px;
	border: 1.5px solid var(--skvn-color-blue-950);
	text-decoration: none;
	margin-top: 0.5rem;
}

@media (prefers-reduced-motion: no-preference) {
	.skvn-product-cta-secondary {
		transition: background 0.15s;
	}
}

.skvn-product-cta-secondary:hover {
	background: var(--skvn-color-sky-50);
	color: var(--skvn-color-blue-950);
}

.skvn-product-cta-note {
	font-size: 0.625rem;
	color: var(--skvn-color-slate-700);
	text-align: center;
	margin-top: 0.5rem;
}

/* Product title — prevent oversized h1 from wrapping in narrow summary column */
.woocommerce div.product .product_title {
	font-size: clamp(1.25rem, 3vw, 1.75rem);
	line-height: 1.25;
	word-break: break-word;
	margin-bottom: 0.75rem;
}

/* CTA buttons — prevent text wrap */
.skvn-product-cta-primary,
.skvn-product-cta-secondary {
	white-space: nowrap;
}

/* Trust signals */
.skvn-product-trust {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.5rem;
	margin-top: 1.25rem;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(51, 65, 85, 0.12);
}

.skvn-product-trust__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.25rem;
	padding: 0.625rem 0.375rem;
	background: var(--skvn-color-sky-50);
	border: 1px solid rgba(3, 105, 161, 0.12);
	border-radius: 6px;
	text-align: center;
}

.skvn-product-trust__icon {
	font-size: 1.125rem;
	line-height: 1;
}

.skvn-product-trust__label {
	font-size: 0.5625rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--skvn-color-blue-700);
	line-height: 1.3;
}

/* Product tabs — override WooCommerce default tab styles */
.woocommerce div.product .woocommerce-tabs {
	margin-top: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	border-bottom: 1px solid rgba(51, 65, 85, 0.15);
	padding: 0;
	margin: 0;
	list-style: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent;
	border: none;
	border-radius: 0;
	margin: 0;
	padding: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: block;
	padding: 0.875rem 1.5rem;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--skvn-color-slate-700);
	border-bottom: 2px solid transparent;
	text-decoration: none;
	background: transparent;
}

@media (prefers-reduced-motion: no-preference) {
	.woocommerce div.product .woocommerce-tabs ul.tabs li a {
		transition: color 0.15s;
	}
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--skvn-color-slate-900);
	border-bottom: 2px solid var(--skvn-color-teal-600);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
	color: var(--skvn-color-slate-900);
}


.woocommerce div.product .woocommerce-tabs .panel {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-top: none;
	border-radius: 0 0 var(--skvn-radius-card) var(--skvn-radius-card);
	padding: 2rem 2.5rem;
	margin: 0;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
	font-size: 1rem;
	font-weight: 700;
	color: var(--skvn-color-slate-900);
	margin-bottom: 0.75rem;
}

.woocommerce div.product .woocommerce-tabs .panel p {
	font-size: 0.90625rem;
	color: var(--skvn-color-slate-700);
	margin-bottom: 0.875rem;
}

.woocommerce div.product .woocommerce-tabs .panel ul {
	padding-left: 1.25rem;
	color: var(--skvn-color-slate-700);
	font-size: 0.90625rem;
}

.woocommerce div.product .woocommerce-tabs .panel ul li {
	margin-bottom: 0.375rem;
}

/* ── Tab nav: mobile horizontal scroll ─────────────────────────────────── */
@media (max-width: 600px) {
	.woocommerce div.product .woocommerce-tabs ul.tabs {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		flex-wrap: nowrap;
		scrollbar-width: none;
	}
	.woocommerce div.product .woocommerce-tabs ul.tabs::-webkit-scrollbar {
		display: none;
	}
	.woocommerce div.product .woocommerce-tabs ul.tabs li {
		flex-shrink: 0;
	}
}

/* ── Shared tab utility ─────────────────────────────────────────────────── */
.skvn-tab-section-heading {
	font-size: 0.8125rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--skvn-color-slate-700);
	margin: 0 0 1rem;
}

/* ── Tab 0: Product Info — 3-col desktop layout ─────────────────────────── */
.skvn-tab-product-info {
	display: grid;
	grid-template-columns: 1fr 280px;
	gap: 2.5rem;
	align-items: start;
}

.skvn-tab-product-info__description {
	margin-bottom: 2rem;
	font-size: 0.90625rem;
	color: var(--skvn-color-slate-700);
	line-height: 1.7;
}

.skvn-tab-product-info__description p { margin-bottom: 0.875rem; }

.skvn-tab-product-info__specs { margin-top: 0; }

.skvn-tab-sidebar-card {
	background: var(--skvn-color-sky-50);
	border: 1px solid rgba(51, 65, 85, 0.1);
	border-radius: var(--skvn-radius-card);
	padding: 1.125rem 1.25rem;
	margin-bottom: 1rem;
}

.skvn-tab-sidebar-card--highlight {
	background: var(--skvn-color-white);
	border-color: var(--skvn-color-teal-600);
}

.skvn-tab-sidebar-card__heading {
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-teal-600);
	margin: 0 0 0.625rem;
}

.skvn-tab-sidebar-card__list {
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: 0.8125rem;
	color: var(--skvn-color-slate-700);
}

.skvn-tab-sidebar-card__list li {
	padding: 0.25rem 0;
	border-bottom: 1px solid rgba(51, 65, 85, 0.07);
}

.skvn-tab-sidebar-card__list li:last-child { border-bottom: none; }

.skvn-tab-sidebar-card__yield {
	font-size: 2rem;
	font-weight: 700;
	color: var(--skvn-color-teal-600);
	margin: 0 0 0.375rem;
	font-family: 'Instrument Serif', Georgia, serif;
}

.skvn-tab-sidebar-card__yield-note {
	font-size: 0.75rem;
	color: var(--skvn-color-slate-700);
	line-height: 1.5;
	margin: 0;
}

@media (max-width: 900px) {
	.skvn-tab-product-info {
		grid-template-columns: 1fr;
	}
}

/* ── Tab 1: Certifications & Docs ───────────────────────────────────────── */
.skvn-tab-documents__cert-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.875rem;
	margin-bottom: 2rem;
}

.skvn-cert-card {
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	padding: 1rem;
	background: var(--skvn-color-white);
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.skvn-cert-card__badge {
	display: inline-block;
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--skvn-color-white);
	background: var(--skvn-color-teal-600);
	padding: 0.2rem 0.5rem;
	border-radius: 4px;
	align-self: flex-start;
}

.skvn-cert-card__body strong {
	display: block;
	font-size: 0.8125rem;
	color: var(--skvn-color-slate-900);
	margin-bottom: 0.2rem;
}

.skvn-cert-card__body span {
	font-size: 0.75rem;
	color: var(--skvn-color-slate-700);
}

@media (max-width: 600px) {
	.skvn-tab-documents__cert-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.skvn-doc-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.8125rem;
	margin-bottom: 1rem;
}

.skvn-doc-table th {
	text-align: left;
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--skvn-color-slate-700);
	padding: 0.5rem 0.75rem;
	background: var(--skvn-color-sky-50);
	border-bottom: 1px solid rgba(51, 65, 85, 0.12);
}

.skvn-doc-table td {
	padding: 0.625rem 0.75rem;
	color: var(--skvn-color-slate-700);
	border-bottom: 1px solid rgba(51, 65, 85, 0.07);
	vertical-align: top;
}

.skvn-doc-table tr:last-child td { border-bottom: none; }

.skvn-doc-status {
	display: inline-block;
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 0.2rem 0.5rem;
	border-radius: 4px;
	white-space: nowrap;
}

.skvn-doc-status--current    { background: #dcfce7; color: #166534; }
.skvn-doc-status--nda        { background: #fef9c3; color: #854d0e; }
.skvn-doc-status--per-shipment { background: #e0f2fe; color: #0369a1; }
.skvn-doc-status--passed     { background: #dcfce7; color: #166534; }

.skvn-tab-documents__custom-note {
	font-size: 0.8125rem;
	color: var(--skvn-color-slate-700);
	margin: 0.875rem 0 1.5rem;
}

.skvn-tab-documents__cta {
	border-top: 1px solid rgba(51, 65, 85, 0.1);
	padding-top: 1.5rem;
	display: flex;
	align-items: center;
	gap: 1.25rem;
}

.skvn-tab-documents__cta p {
	font-size: 0.8125rem;
	color: var(--skvn-color-slate-700);
	margin: 0;
}

/* ── Tab 2: Packaging & Cold Chain ──────────────────────────────────────── */
.skvn-tab-packaging__photo-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.75rem;
	margin-bottom: 0.75rem;
}

.skvn-packaging-photo-placeholder {
	aspect-ratio: 4 / 3;
	background: var(--skvn-color-sky-50);
	border: 1px dashed rgba(51, 65, 85, 0.2);
	border-radius: var(--skvn-radius-card);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	color: rgba(51, 65, 85, 0.35);
	font-size: 0.6875rem;
}

@media (max-width: 600px) {
	.skvn-tab-packaging__photo-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.skvn-tab-packaging__assets-note {
	font-size: 0.8125rem;
	color: var(--skvn-color-slate-700);
	margin: 0 0 1.75rem;
}

.skvn-cold-chain-banner {
	background: var(--skvn-color-blue-950, #082f49);
	border-radius: var(--skvn-radius-card);
	padding: 1.75rem 2rem;
	margin-bottom: 1.5rem;
	color: var(--skvn-color-white);
}

.skvn-cold-chain-banner__heading {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-teal-600);
	margin: 0 0 1.25rem;
}

.skvn-cold-chain-banner__specs {
	display: flex;
	gap: 2rem;
	flex-wrap: wrap;
}

.skvn-cold-chain-spec {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.skvn-cold-chain-spec__value {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--skvn-color-white);
	font-family: 'Instrument Serif', Georgia, serif;
}

.skvn-cold-chain-spec__label {
	font-size: 0.6875rem;
	color: rgba(255, 255, 255, 0.6);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.skvn-tab-packaging__cta { margin-top: 0.5rem; }

/* ── Tab 3: Related Articles ─────────────────────────────────────────────── */
.skvn-article-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
}

@media (max-width: 600px) {
	.skvn-article-grid {
		grid-template-columns: 1fr;
	}
}

.skvn-article-card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	padding: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

@media (prefers-reduced-motion: no-preference) {
	.skvn-article-card {
		transition: box-shadow 0.15s;
	}
}

.skvn-article-card:hover {
	box-shadow: var(--skvn-shadow-card);
}

.skvn-article-card__meta {
	display: flex;
	align-items: center;
	gap: 0.625rem;
	flex-wrap: wrap;
}

.skvn-article-card__cat {
	font-size: 0.625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-white);
	background: var(--skvn-color-teal-600);
	padding: 0.2rem 0.5rem;
	border-radius: 4px;
}

.skvn-article-card__date {
	font-size: 0.6875rem;
	color: var(--skvn-color-slate-700);
}

.skvn-article-card__title {
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--skvn-color-slate-900);
	line-height: 1.35;
	margin: 0;
}

.skvn-article-card__title a {
	color: inherit;
	text-decoration: none;
}

.skvn-article-card__title a:hover {
	color: var(--skvn-color-teal-600);
}

.skvn-article-card__excerpt {
	font-size: 0.8125rem;
	color: var(--skvn-color-slate-700);
	line-height: 1.6;
	margin: 0;
	flex: 1;
}

.skvn-article-card__link {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--skvn-color-teal-600);
	text-decoration: none;
	margin-top: 0.25rem;
}

/* ── Legacy documents tab ────────────────────────────────────────────────── */

/* WooCommerce additional information (specs table) */
.woocommerce div.product .woocommerce-tabs #tab-additional_information h2 {
	display: none;
}

.woocommerce table.shop_attributes {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.84375rem;
}

.woocommerce table.shop_attributes tr {
	border-bottom: 1px solid rgba(51, 65, 85, 0.1);
}

.woocommerce table.shop_attributes tr:last-child {
	border-bottom: none;
}

.woocommerce table.shop_attributes th {
	font-weight: 600;
	color: var(--skvn-color-slate-900);
	padding: 0.625rem 0.75rem;
	width: 40%;
	background: var(--skvn-color-sky-50);
	text-align: left;
}

.woocommerce table.shop_attributes td {
	color: var(--skvn-color-slate-700);
	padding: 0.625rem 0.75rem;
}

/* Related products */
.woocommerce div.product .related.products {
	margin-top: 3rem;
}

.woocommerce div.product .related.products > h2 {
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--skvn-color-slate-700);
	font-weight: 400;
	margin-bottom: 1.25rem;
}

.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.woocommerce ul.products li.product {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	overflow: hidden;
}

@media (prefers-reduced-motion: no-preference) {
	.woocommerce ul.products li.product {
		transition: box-shadow 0.2s;
	}
}

.woocommerce ul.products li.product:hover {
	box-shadow: var(--skvn-shadow-card);
}

.woocommerce ul.products li.product a img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	display: block;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--skvn-color-slate-900);
	padding: 0.875rem 0.875rem 0;
	line-height: 1.35;
}

.woocommerce ul.products li.product .woocommerce-loop-category__title {
	font-size: 0.59375rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-teal-600);
	padding: 0.875rem 0.875rem 0;
}

.woocommerce ul.products li.product .button {
	display: block;
	text-align: center;
	font-size: 0.6875rem;
	font-weight: 600;
	color: var(--skvn-color-blue-950);
	border: 1px solid var(--skvn-color-blue-950);
	padding: 0.375rem;
	border-radius: 5px;
	text-decoration: none;
	margin: 0.625rem 0.875rem 0.875rem;
	background: transparent;
}

.woocommerce ul.products li.product .button:hover {
	background: var(--skvn-color-sky-50);
}

/* Product page — responsive */
@media (max-width: 900px) {
	.woocommerce div.product,
	.skvn-product-layout {
		--skvn-page-gutter: 0.75rem;
		padding-inline: var(--skvn-page-gutter);
		grid-template-columns: 1fr;
	}

	.woocommerce ul.products {
		grid-template-columns: repeat(2, 1fr);
	}

	.woocommerce div.product .woocommerce-tabs .panel {
		padding: 1.25rem;
	}
}

@media (max-width: 600px) {
	.woocommerce div.product,
	.skvn-product-layout {
		--skvn-page-gutter: 0.5rem;
	}

	.skvn-product-trust {
		grid-template-columns: 1fr;
	}

	.woocommerce ul.products {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Single Post — Style C (1.3.5)
   Layout owner: .skvn-single-layout (grid). Width flows from GP page canvas.
   Hero uses position:relative within the content flow — no 100vw breakout.
   ========================================================================== */

/* Post hero — 16:9 frame; original attachment + CSS crop (ThumbPress-safe). */
.skvn-post-hero {
	aspect-ratio: 16 / 9;
	width: 100%;
	position: relative;
	background: var(--skvn-color-blue-900);
	overflow: hidden;
}

.skvn-post-hero__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

.skvn-post-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(8, 47, 73, 0.92) 0%, rgba(8, 47, 73, 0.4) 60%, transparent 100%);
}

.skvn-post-hero__placeholder {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--skvn-color-blue-950) 0%, var(--skvn-color-trust-blue) 100%);
}

.skvn-post-hero__content {
	position: absolute;
	inset-inline: 0;
	bottom: 0;
	z-index: 1;
	padding: 0 var(--skvn-single-inset-inline) 2.25rem;
	width: 100%;
	box-sizing: border-box;
}

.skvn-post-hero__meta {
	display: flex;
	align-items: center;
	gap: 0.625rem;
	margin-bottom: 0.875rem;
}

.skvn-post-hero__cat {
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	background: var(--skvn-color-teal-600);
	color: var(--skvn-color-white);
	padding: 0.1875rem 0.625rem;
	border-radius: 3px;
	text-decoration: none;
}

.skvn-post-hero__date {
	font-size: 0.625rem;
	color: rgba(255, 255, 255, 0.55);
}

.skvn-post-hero__title {
	font-family: var(--skvn-font-heading);
	font-size: clamp(1.5rem, 3.5vw, 2.4rem);
	font-weight: 800;
	color: white !important;
	letter-spacing: -0.03em;
	line-height: 1.2;
	max-width: 42.5rem;
}

/* Single post outer wrap + layout */
.skvn-single-wrap {
	--skvn-page-gutter: 16px;
	--skvn-single-gap: 1.5rem;
	--skvn-single-inset-inline: 3rem;
	max-width: var(--skvn-wide-width);
	margin-inline: auto;
	padding-inline: var(--skvn-page-gutter);
	padding-block: var(--skvn-single-gap) 4rem;
}

.skvn-single-layout {
	display: grid;
	grid-template-columns: minmax(0, 3fr) minmax(0, 1fr);
	grid-template-rows: auto 1fr;
	column-gap: var(--skvn-single-gap);
	row-gap: 0;
	align-items: start;
}

/* Grid placement: hero row 1, main row 2, sidebar spans both */
.skvn-single-layout > .skvn-post-hero {
	grid-column: 1;
	grid-row: 1;
	border-radius: var(--skvn-radius-card);
	overflow: hidden;
}

.skvn-single-layout > .skvn-single-main {
	grid-column: 1;
	grid-row: 2;
}

.skvn-single-sidebar {
	grid-column: 2;
	grid-row: 1 / 3;
}

/* Post body card — one --skvn-single-gap unit below hero (same as column gap) */
.skvn-post-body {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	padding: 0 var(--skvn-single-inset-inline) 2.5rem;
	margin: 0;
}

.skvn-post-body > .skvn-post-author:first-child {
	padding-top: var(--skvn-single-gap);
}

/* Author row */
.skvn-post-author {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding-bottom: 1.5rem;
	margin-bottom: 1.75rem;
	border-bottom: 1px solid rgba(51, 65, 85, 0.1);
}

.skvn-post-author__avatar {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	background: var(--skvn-color-blue-900);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--skvn-color-white);
	font-weight: 700;
	font-size: 0.875rem;
	flex-shrink: 0;
}

.skvn-post-author__info {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 0.125rem;
}

.skvn-post-author__name {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--skvn-color-slate-900);
}

.skvn-post-author__role {
	font-size: 0.6875rem;
	color: var(--skvn-color-slate-700);
}

.skvn-post-author__read-time {
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-slate-700);
	flex-shrink: 0;
}

/* Post content typography */
.skvn-post-body__content {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--skvn-color-slate-700);
}

.skvn-post-body__content h2 {
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--skvn-color-slate-900);
	letter-spacing: -0.02em;
	line-height: 1.3;
	margin-top: 1.75rem;
	margin-bottom: 0.75rem;
}

.skvn-post-body__content h3 {
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--skvn-color-slate-900);
	margin-top: 1.375rem;
	margin-bottom: 0.5rem;
}

.skvn-post-body__content p {
	margin-bottom: 1rem;
}

.skvn-post-body__content ul,
.skvn-post-body__content ol {
	padding-left: 1.375rem;
	margin-bottom: 1rem;
}

.skvn-post-body__content li {
	margin-bottom: 0.375rem;
}

.skvn-post-body__content strong {
	color: var(--skvn-color-slate-900);
	font-weight: 600;
}

/* Callout block (blockquote or .wp-block-pullquote used as callout) */
.skvn-post-body__content blockquote,
.skvn-post-body__content .wp-block-quote {
	border-left: 3px solid var(--skvn-color-blue-700);
	background: var(--skvn-color-sky-50);
	padding: 0.875rem 1.125rem;
	border-radius: 0 6px 6px 0;
	margin: 1.25rem 0;
}

.skvn-post-body__content blockquote p,
.skvn-post-body__content .wp-block-quote p {
	color: var(--skvn-color-blue-950);
	margin-bottom: 0;
}

/* Post tags */
.skvn-post-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.375rem;
	margin-top: 1.75rem;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(51, 65, 85, 0.1);
}

.skvn-post-tag {
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 0.25rem 0.625rem;
	border: 1px solid rgba(51, 65, 85, 0.2);
	border-radius: 3px;
	color: var(--skvn-color-slate-700);
	background: var(--skvn-color-sky-50);
	text-decoration: none;
}

.skvn-post-tag:hover {
	border-color: var(--skvn-color-blue-700);
	color: var(--skvn-color-blue-700);
}

/* Related posts grid (below main content) */
.skvn-post-related {
	margin-top: 2.5rem;
}

.skvn-post-related__eyebrow {
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--skvn-color-slate-700);
	margin-bottom: 1rem;
}

.skvn-post-related__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}

.skvn-post-related__card {
	background: var(--skvn-color-white);
	border: 1px solid rgba(51, 65, 85, 0.12);
	border-radius: var(--skvn-radius-card);
	overflow: hidden;
}

.skvn-post-related__thumb {
	aspect-ratio: 3 / 2;
	background: var(--skvn-color-blue-900);
	overflow: hidden;
}

.skvn-post-related__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.skvn-post-related__placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, var(--skvn-color-blue-950), var(--skvn-color-blue-900));
}

.skvn-post-related__body {
	padding: 0.875rem;
}

.skvn-post-related__cat {
	font-size: 0.59375rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--skvn-color-teal-600);
	margin-bottom: 0.375rem;
}

.skvn-post-related__title {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--skvn-color-slate-900);
	line-height: 1.4;
}

.skvn-post-related__title a {
	color: inherit;
	text-decoration: none;
}

.skvn-post-related__title a:hover {
	color: var(--skvn-color-blue-700);
}

/* Single post sidebar */
.skvn-single-sidebar {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	position: sticky;
	top: 2rem;
}

/* Sidebar related posts list */
.skvn-island__post-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.skvn-island__post-item {
	display: flex;
	gap: 0.625rem;
	padding-block: 0.5rem;
	border-bottom: 1px solid rgba(51, 65, 85, 0.08);
}

.skvn-island__post-item:last-child {
	border-bottom: none;
}

.skvn-island__post-thumb {
	width: 3.25rem;
	height: 2.5rem;
	border-radius: 4px;
	background: var(--skvn-color-blue-900);
	overflow: hidden;
	flex-shrink: 0;
}

.skvn-island__post-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.skvn-island__post-info {
	flex: 1;
	min-width: 0;
}

.skvn-island__post-cat {
	font-size: 0.5625rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--skvn-color-teal-600);
	display: block;
}

.skvn-island__post-title {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--skvn-color-slate-900);
	line-height: 1.35;
	margin-top: 0.125rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.skvn-island__post-title a {
	color: inherit;
	text-decoration: none;
}

.skvn-island__post-title a:hover {
	color: var(--skvn-color-blue-700);
}

/* Single post — responsive */
@media (max-width: 900px) {
	.skvn-single-wrap {
		--skvn-page-gutter: 12px;
		padding-top: 0;
		padding-bottom: 2.5rem;
	}

	.skvn-single-layout {
		grid-template-columns: 1fr;
		grid-template-rows: auto;
		gap: 0;
	}

	.skvn-single-layout > .skvn-post-hero,
	.skvn-single-layout > .skvn-single-main,
	.skvn-single-sidebar {
		grid-column: 1;
		grid-row: auto;
	}

	.skvn-single-sidebar {
		position: static;
		margin-top: 1.5rem;
	}

	.skvn-single-layout > .skvn-post-hero {
		border-radius: 0;
		/* width:100% + grid clips right bleed — expand then pull both sides. */
		box-sizing: border-box;
		width: calc(100% + 2 * var(--skvn-page-gutter));
		max-width: none;
		margin-inline: calc(-1 * var(--skvn-page-gutter));
	}

	.skvn-single-layout > .skvn-post-hero .skvn-post-hero__content {
		padding-inline: var(--skvn-page-gutter);
	}

	.skvn-post-body {
		background: transparent;
		border: none;
		border-radius: 0;
		padding: 1rem 0 1.5rem;
	}

	.skvn-post-related__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 600px) {
	.skvn-single-wrap {
		--skvn-page-gutter: 8px;
	}

	.skvn-post-related__grid {
		grid-template-columns: 1fr;
	}
}
