/*
Theme Name: CreatePrint
Theme URI: https://createprint.es/
Author: CreatePrint
Description: Tema limpio para recrear CreatePrint sin dependencias de Woodmart ni Elementor.
Version: 0.1.6
Text Domain: createprint
*/

:root {
	--cp-black: #111111;
	--cp-ink: #1e1e1e;
	--cp-muted: #737373;
	--cp-line: #eaeaea;
	--cp-soft: #f8f8f6;
	--cp-paper: #ffffff;
	--cp-cream: #ffffff;
	--cp-accent: #a9ab86;
	--cp-accent-dark: #8b8d69;
	--cp-accent-soft: #f1f2ec;
	--cp-white: #ffffff;
	--cp-container: 1480px;
	--cp-ease: 160ms ease;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	color: var(--cp-ink);
	background: var(--cp-paper);
	font-family: "Montserrat", Arial, Helvetica, sans-serif;
	font-size: 15px;
	line-height: 1.55;
}

a {
	color: inherit;
	text-decoration: none;
}

a:focus-visible,
button:focus-visible,
input:focus-visible {
	outline: 1px solid var(--cp-ink);
	outline-offset: 3px;
}

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

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.cp-container {
	width: min(calc(100% - 32px), var(--cp-container));
	margin: 0 auto;
}

/* ==========================================================================
   TRANSVERSAL LAYOUT & TYPOGRAPHY UTILITIES
   ========================================================================== */

.cp-grid {
	display: grid;
	gap: 24px;
}
.cp-grid--2 { grid-template-columns: repeat(2, 1fr); }
.cp-grid--3 { grid-template-columns: repeat(3, 1fr); }
.cp-grid--4 { grid-template-columns: repeat(4, 1fr); }

.cp-section {
	padding-block: 86px;
	border-bottom: 1px solid var(--cp-line);
}
.cp-section--soft { background: var(--cp-soft); }
.cp-section--paper { background: var(--cp-paper); }
.cp-section--dark { background: var(--cp-black); color: var(--cp-white); }

.cp-card {
	border: 1px solid var(--cp-line);
	background: var(--cp-paper);
	padding: 36px 28px;
	transition: all var(--cp-ease);
}
.cp-card--lift:hover {
	border-color: var(--cp-accent);
	box-shadow: 0 12px 36px rgba(169, 171, 134, 0.08);
	transform: translateY(-4px);
}

.cp-text-center { text-align: center; }
.cp-text-muted { color: var(--cp-muted); }
.cp-text-accent { color: var(--cp-accent); }

.cp-title-tag {
	display: inline-block;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cp-accent);
	margin-bottom: 12px;
}

.cp-title-main {
	font-size: 38px;
	font-weight: 600;
	color: var(--cp-black);
	margin: 0 0 16px;
	line-height: 1.15;
	letter-spacing: 0;
}

.cp-title-sub {
	max-width: 680px;
	font-size: 15px;
	color: var(--cp-muted);
	line-height: 1.6;
	margin: 0 auto;
}

.cp-mb-1 { margin-bottom: 8px; }
.cp-mb-2 { margin-bottom: 16px; }
.cp-mb-3 { margin-bottom: 24px; }
.cp-mb-4 { margin-bottom: 32px; }
.cp-mb-5 { margin-bottom: 48px; }

.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: var(--cp-paper);
	box-shadow: 0 1px 0 rgba(36, 35, 29, 0.08);
}

.cp-topbar {
	background: var(--cp-black);
	color: var(--cp-white);
	font-size: 11px;
}

.cp-topbar__inner {
	min-height: 34px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.cp-topbar__promise {
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.cp-social {
	display: flex;
	align-items: center;
	gap: 2px;
}

.cp-social__link {
	width: 25px;
	height: 25px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	color: rgba(255, 250, 244, 0.9);
	font-size: 10px;
	font-weight: 600;
	transition: background var(--cp-ease), color var(--cp-ease);
}

.cp-social__link:hover,
.cp-social__link:focus-visible {
	background: rgba(255, 250, 244, 0.16);
	color: var(--cp-white);
}

.cp-mainbar {
	background: var(--cp-paper);
}

.cp-mainbar__inner {
	min-height: 92px;
	display: grid;
	grid-template-columns: 200px 1fr auto;
	align-items: center;
	gap: 40px;
}

.cp-logo {
	display: inline-flex;
	align-items: center;
	width: 186px;
}

.cp-logo img {
	width: 186px;
	height: auto;
}

.cp-nav {
	justify-self: center;
}

.cp-menu,
.cp-submenu,
.cp-category-menu,
.cp-mobile-menu,
.cp-nav ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.cp-menu,
.cp-nav ul {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
}

.cp-menu > li,
.cp-nav ul > li {
	position: relative;
}

.cp-menu > li > a,
.cp-nav ul > li > a {
	position: relative;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	padding: 0 12px;
	color: var(--cp-ink);
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.045em;
	white-space: nowrap;
}

.cp-menu > li.menu-item-has-children > a::after,
.cp-has-children > a::after {
	content: "";
	width: 6px;
	height: 6px;
	margin-left: 8px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	opacity: 0.6;
}

.cp-menu > li > a:hover,
.cp-menu > li > a:focus-visible,
.cp-nav ul > li > a:hover,
.cp-nav ul > li > a:focus-visible {
	color: var(--cp-black);
}

.cp-menu > li > a::before,
.cp-nav ul > li > a::before {
	content: "";
	position: absolute;
	right: 12px;
	bottom: 5px;
	left: 12px;
	height: 2px;
	background: var(--cp-accent);
	opacity: 0;
	transform: scaleX(0.6);
	transition: opacity var(--cp-ease), transform var(--cp-ease);
}

.cp-menu > li > a:hover::before,
.cp-menu > li > a:focus-visible::before,
.cp-nav ul > li > a:hover::before,
.cp-nav ul > li > a:focus-visible::before {
	opacity: 1;
	transform: scaleX(1);
}

.cp-submenu,
.cp-menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 248px;
	padding: 8px 0;
	background: var(--cp-cream);
	border: 1px solid var(--cp-line);
	box-shadow: 0 18px 38px rgba(36, 35, 29, 0.1);
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
}

.cp-menu > li:hover .cp-submenu,
.cp-menu > li:focus-within .cp-submenu,
.cp-menu > li:hover > .sub-menu,
.cp-menu > li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.cp-submenu a,
.cp-menu .sub-menu a {
	display: block;
	padding: 10px 18px;
	color: var(--cp-ink);
	font-size: 13px;
	font-weight: 500;
}

.cp-submenu a:hover,
.cp-submenu a:focus-visible,
.cp-menu .sub-menu a:hover,
.cp-menu .sub-menu a:focus-visible {
	background: var(--cp-soft);
	color: var(--cp-black);
}

.cp-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 14px;
	font-size: 12px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.035em;
}

.cp-action {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 40px;
	color: var(--cp-ink);
	white-space: nowrap;
}

.cp-action:hover,
.cp-action:focus-visible {
	color: var(--cp-black);
}

.cp-action__icon {
	width: 20px;
	height: 20px;
	display: inline-block;
	color: currentColor;
}

.cp-action__icon svg {
	width: 100%;
	height: 100%;
	stroke: currentColor;
	fill: none;
	stroke-width: 1.55;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.cp-mobile-toggle {
	display: none;
	width: 44px;
	height: 44px;
	align-items: center;
	justify-content: center;
	border: 0;
	background: transparent;
	color: var(--cp-ink);
	cursor: pointer;
}

.cp-mobile-toggle span,
.cp-mobile-toggle::before,
.cp-mobile-toggle::after {
	content: "";
	width: 23px;
	height: 2px;
	display: block;
	background: currentColor;
	position: absolute;
	transition: transform 160ms ease, opacity 160ms ease;
}

.cp-mobile-toggle {
	position: relative;
}

.cp-mobile-toggle::before {
	transform: translateY(-7px);
}

.cp-mobile-toggle::after {
	transform: translateY(7px);
}

.cp-mobile-toggle[aria-expanded="true"] span {
	opacity: 0;
}

.cp-mobile-toggle[aria-expanded="true"]::before {
	transform: rotate(45deg);
}

.cp-mobile-toggle[aria-expanded="true"]::after {
	transform: rotate(-45deg);
}

.cp-catbar {
	background: var(--cp-paper);
	border-top: 1px solid var(--cp-line);
	border-bottom: 1px solid var(--cp-line);
}

.cp-catbar__inner {
	min-height: 56px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.cp-categories {
	position: relative;
	height: 100%;
	display: flex;
	align-items: center;
}

.cp-categories__button {
	width: 100%;
	min-height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	border: 1.5px solid var(--cp-accent);
	padding: 0 16px;
	background: transparent;
	color: var(--cp-ink);
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.045em;
	cursor: pointer;
	transition: all var(--cp-ease);
}

.cp-categories__button:hover,
.cp-categories__button:focus-visible {
	background: var(--cp-accent);
	border-color: var(--cp-accent);
	color: var(--cp-white);
}

.cp-categories__button::before {
	content: "";
	width: 18px;
	height: 12px;
	border-top: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	box-shadow: 0 5px 0 currentColor;
}

.cp-categories__button::after {
	content: "";
	width: 7px;
	height: 7px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
}

.cp-category-menu {
	position: absolute;
	top: calc(100% + 1px);
	left: 0;
	width: 100%;
	min-width: 300px;
	max-height: calc(100vh - 210px);
	overflow: visible;
	padding: 8px 0;
	background: var(--cp-cream);
	border: 1px solid var(--cp-line);
	box-shadow: 0 20px 42px rgba(36, 35, 29, 0.12);
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
}

.cp-categories:hover .cp-category-menu,
.cp-categories:focus-within .cp-category-menu,
.cp-categories.is-open .cp-category-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.cp-category-menu a {
	display: block;
	padding: 9px 16px;
	font-size: 13px;
	font-weight: 500;
	color: var(--cp-ink);
}

.cp-category-menu a:hover,
.cp-category-menu a:focus-visible {
	background: var(--cp-soft);
	color: var(--cp-black);
}

.cp-category-menu > li {
	position: relative;
}

.cp-category-menu > li > .cp-submenu {
	position: absolute;
	top: -8px;
	left: 100%;
	width: 600px;
	background: var(--cp-cream);
	border: 1px solid var(--cp-line);
	box-shadow: 0 20px 42px rgba(36, 35, 29, 0.12);
	padding: 24px;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px 20px;
	opacity: 0;
	visibility: hidden;
	transform: translateX(8px);
	transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
	z-index: 10;
}

.cp-category-menu > li:hover > .cp-submenu {
	opacity: 1;
	visibility: visible;
	transform: translateX(0);
}

.cp-category-menu > li > .cp-submenu > li {
	display: block;
}

.cp-category-menu > li > .cp-submenu > li > a {
	display: block;
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--cp-ink);
	padding: 0 0 6px 0;
	border-bottom: 1px solid var(--cp-line);
	margin-bottom: 8px;
	pointer-events: auto;
}

.cp-category-menu > li > .cp-submenu > li > a:hover {
	color: var(--cp-black);
	background: transparent;
}

.cp-category-menu > li > .cp-submenu > li > .cp-submenu {
	position: static;
	opacity: 1;
	visibility: visible;
	transform: none;
	box-shadow: none;
	border: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
	background: transparent;
}

.cp-category-menu > li > .cp-submenu > li > .cp-submenu > li {
	display: block;
}

.cp-category-menu > li > .cp-submenu > li > .cp-submenu a {
	display: block;
	font-size: 12px;
	font-weight: 500;
	color: var(--cp-muted);
	padding: 3px 0;
	text-transform: none;
	letter-spacing: normal;
}

.cp-category-menu > li > .cp-submenu > li > .cp-submenu a:hover {
	color: var(--cp-accent);
	background: transparent;
	padding-left: 2px;
	transition: padding-left var(--cp-ease), color var(--cp-ease);
}

.cp-search {
	display: flex;
	align-items: center;
	height: 40px;
	border: 1px solid var(--cp-line);
	background: var(--cp-paper);
	border-radius: 999px;
	overflow: hidden;
	transition: border-color var(--cp-ease), box-shadow var(--cp-ease);
}

.cp-search--header {
	max-width: 680px;
	margin: 0 auto;
	width: 100%;
}

.cp-search:focus-within {
	border-color: var(--cp-accent);
	box-shadow: 0 0 0 3px rgba(169, 171, 134, 0.18);
}

.cp-search label {
	flex: 1;
}

.cp-search input {
	width: 100%;
	height: 38px;
	border: 0;
	padding: 0 16px;
	font: inherit;
	font-size: 13px;
	font-weight: 400;
	outline: none;
}

.cp-search input::placeholder {
	color: #9a968d;
}

.cp-search button {
	width: 48px;
	height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 0;
	border-left: 1px solid var(--cp-line);
	background: var(--cp-paper);
	color: var(--cp-ink);
	cursor: pointer;
}

.cp-search button:hover,
.cp-search button:focus-visible {
	background: var(--cp-soft);
	color: var(--cp-black);
}

.cp-service-links {
	display: flex;
	align-items: center;
	gap: 18px;
	color: var(--cp-muted);
	font-size: 12px;
	font-weight: 500;
	white-space: nowrap;
}

.cp-service-links span {
	display: inline-flex;
	align-items: center;
	gap: 7px;
}

.cp-service-links span::before {
	content: "";
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--cp-accent);
}

.cp-mobile-panel {
	display: none;
	border-top: 1px solid var(--cp-line);
	background: var(--cp-paper);
}

.cp-mobile-panel.is-open {
	display: block;
}

.cp-mobile-panel__inner {
	padding: 12px 0 18px;
}

.cp-mobile-menu a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 46px;
	padding: 0 4px;
	border-bottom: 1px solid var(--cp-line);
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.cp-mobile-menu ul {
	list-style: none;
	margin: 0;
	padding: 0 0 0 14px;
}

.cp-mobile-menu ul a {
	color: var(--cp-muted);
	font-size: 13px;
	font-weight: 500;
}

.cp-page {
	min-height: 55vh;
}

.cp-placeholder {
	width: min(calc(100% - 32px), 980px);
	margin: 56px auto;
	padding: 38px 0;
	background: transparent;
	border: 0;
}

.cp-placeholder h1 {
	margin: 0 0 16px;
	font-family: "Montserrat", Arial, Helvetica, sans-serif;
	font-size: 38px;
	line-height: 1.15;
	font-weight: 600;
	color: var(--cp-black);
	letter-spacing: 0;
}

.cp-placeholder p {
	margin: 0 0 20px;
	color: var(--cp-muted);
	line-height: 1.7;
	font-size: 14px;
}

.cp-placeholder h2 {
	font-size: 24px;
	font-weight: 700;
	margin: 36px 0 16px;
	color: var(--cp-black);
}

.cp-placeholder h3 {
	font-size: 18px;
	font-weight: 700;
	margin: 28px 0 12px;
	color: var(--cp-black);
}

.cp-placeholder ul,
.cp-placeholder ol {
	margin: 0 0 20px 24px;
	color: var(--cp-muted);
	line-height: 1.7;
	font-size: 14px;
}

.cp-placeholder li {
	margin-bottom: 8px;
}

.cp-placeholder a {
	color: var(--cp-accent);
	text-decoration: underline;
}

.cp-placeholder a:hover {
	color: var(--cp-black);
}

.site-footer {
	background: var(--cp-paper);
	color: var(--cp-ink);
}

.cp-footer-cta {
	border-top: 1px solid var(--cp-line);
	background: var(--cp-paper);
}

.cp-footer-cta__inner {
	min-height: 230px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: end;
	gap: 28px;
	padding-top: 42px;
	padding-bottom: 42px;
}

.cp-footer-cta__eyebrow,
.cp-footer-cta__title {
	margin: 0;
	color: var(--cp-ink);
	font-family: Georgia, "Times New Roman", serif;
	line-height: 0.93;
}

.cp-footer-cta__eyebrow {
	margin-bottom: 8px;
	font-size: 34px;
	font-style: italic;
}

.cp-footer-cta__title {
	max-width: 760px;
	font-size: 86px;
	text-transform: uppercase;
}

.cp-footer-cta__link {
	min-width: 220px;
	min-height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1.5px solid var(--cp-accent);
	border-radius: 999px;
	padding: 0 24px;
	color: var(--cp-ink);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.045em;
	text-transform: uppercase;
	transition: all var(--cp-ease);
}

.cp-footer-cta__link:hover,
.cp-footer-cta__link:focus-visible {
	background: var(--cp-accent);
	border-color: var(--cp-accent);
	color: var(--cp-white);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(169, 171, 134, 0.24);
}

.cp-footer-main {
	background: var(--cp-black);
	color: var(--cp-white);
}

.cp-footer-main__inner {
	display: grid;
	grid-template-columns: minmax(240px, 1.4fr) repeat(4, minmax(140px, 1fr));
	gap: 46px 32px;
	padding-top: 58px;
	padding-bottom: 52px;
}

.cp-footer-brand {
	max-width: 430px;
}

.cp-footer-logo {
	display: inline-flex;
	margin-bottom: 20px;
	width: 190px;
}

.cp-footer-logo img {
	width: 190px;
	height: auto;
}

.cp-footer-brand p,
.cp-footer-contact li,
.cp-footer-bottom p {
	margin: 0;
	color: rgba(255, 254, 250, 0.72);
	font-size: 13px;
	line-height: 1.75;
}

.cp-footer-main h2 {
	margin: 0 0 18px;
	color: var(--cp-accent);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cp-footer-menu,
.cp-footer-contact ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cp-footer-menu a,
.cp-footer-contact a,
.cp-footer-social__links a,
.cp-footer-bottom a {
	color: rgba(255, 254, 250, 0.72);
	font-size: 13px;
	line-height: 1.9;
	transition: color var(--cp-ease);
}

.cp-footer-menu a:hover,
.cp-footer-menu a:focus-visible,
.cp-footer-contact a:hover,
.cp-footer-contact a:focus-visible,
.cp-footer-social__links a:hover,
.cp-footer-social__links a:focus-visible,
.cp-footer-bottom a:hover,
.cp-footer-bottom a:focus-visible {
	color: var(--cp-white);
}

.cp-footer-social__links {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 24px;
}

.cp-footer-social__link {
	width: 38px;
	height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1px solid rgba(255, 254, 250, 0.18);
	color: rgba(255, 254, 250, 0.72);
	transition: all var(--cp-ease);
}

.cp-footer-social__link svg {
	width: 16px;
	height: 16px;
}

.cp-footer-social__link:hover {
	background: var(--cp-accent);
	color: var(--cp-white);
	border-color: var(--cp-accent);
	transform: translateY(-2px);
	box-shadow: 0 8px 16px rgba(169, 171, 134, 0.25);
}

.cp-footer-bottom {
	min-height: 62px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	border-top: 1px solid rgba(255, 254, 250, 0.14);
	padding-top: 16px;
}

.cp-footer-bottom nav {
	display: flex;
	align-items: center;
	gap: 18px;
}

.cp-footer-payment img {
	max-width: 260px;
	height: auto;
	opacity: 0.85;
	transition: opacity var(--cp-ease);
}

.cp-footer-payment img:hover {
	opacity: 1;
}

@media (max-width: 1180px) {
	.cp-mainbar__inner {
		grid-template-columns: auto 1fr auto;
		gap: 18px;
	}

	.cp-menu > li > a {
		padding: 0 8px;
		font-size: 11px;
	}

	.cp-action__text {
		display: none;
	}

	.cp-footer-main__inner {
		grid-template-columns: 1.5fr repeat(2, 1fr);
		gap: 38px 24px;
	}
}

@media (max-width: 1024px) {
	.site-header {
		position: sticky;
	}

	.cp-topbar__inner {
		justify-content: center;
		text-align: center;
	}

	.cp-social,
	.cp-nav,
	.cp-catbar,
	.cp-actions .cp-account {
		display: none;
	}

	.cp-mainbar__inner {
		min-height: auto;
		padding-block: 12px;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
	}

	.cp-mobile-toggle {
		order: 1;
		display: inline-flex;
	}

	.cp-logo {
		order: 2;
		margin: 0 auto;
		width: 150px;
		justify-self: center;
	}

	.cp-logo img {
		width: 150px;
	}

	.cp-actions {
		order: 3;
		justify-self: end;
	}

	.cp-search--header {
		order: 4;
		flex: 0 0 100%;
		width: 100%;
		margin-top: 4px;
	}

	.cp-action {
		min-height: 44px;
	}

	.cp-footer-cta__inner {
		grid-template-columns: 1fr;
		align-items: start;
	}

	.cp-footer-cta__title {
		font-size: 64px;
	}

	.cp-footer-cta__link {
		justify-self: start;
	}

	.cp-footer-main__inner {
		grid-template-columns: 1fr 1fr;
		gap: 38px 24px;
	}

	.cp-footer-brand {
		grid-column: 1 / 3;
	}
}

@media (max-width: 640px) {
	.cp-container {
		width: min(calc(100% - 24px), var(--cp-container));
	}

	.cp-topbar {
		font-size: 10px;
	}

	.cp-topbar__inner {
		min-height: 34px;
	}

	.cp-mainbar__inner {
		min-height: 66px;
	}

	.cp-logo {
		width: 148px;
	}

	.cp-logo img {
		width: 148px;
	}

	.cp-placeholder {
		margin: 32px auto;
		padding: 24px 0;
	}

	.cp-placeholder h1 {
		font-size: 36px;
	}

	.cp-footer-cta__inner {
		min-height: 0;
		padding-top: 34px;
		padding-bottom: 36px;
	}

	.cp-footer-cta__eyebrow {
		font-size: 25px;
	}

	.cp-footer-cta__title {
		font-size: 42px;
	}

	.cp-footer-cta__link {
		width: 100%;
		min-width: 0;
	}

	.cp-footer-main__inner {
		grid-template-columns: 1fr;
		gap: 32px;
		padding-top: 42px;
		padding-bottom: 36px;
	}

	.cp-footer-bottom {
		align-items: center;
		text-align: center;
		flex-direction: column;
		gap: 16px;
		padding-top: 24px;
		padding-bottom: 24px;
	}

	.cp-footer-bottom nav {
		flex-wrap: wrap;
		justify-content: center;
	}
}

/* ==========================================================================
   HOMEPAGE B2B WIREFRAME STYLES & COMPONENTS
   ========================================================================== */

/* Button styles */
.cp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 28px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	transition: all var(--cp-ease);
	cursor: pointer;
}

.cp-btn--primary {
	background: var(--cp-black);
	color: var(--cp-white);
	border: 1.5px solid var(--cp-black);
}

.cp-btn--primary:hover {
	background: var(--cp-accent);
	border-color: var(--cp-accent);
	color: var(--cp-white);
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(170, 171, 134, 0.15);
}

.cp-btn--outline {
	background: transparent;
	color: var(--cp-black);
	border: 1.5px solid var(--cp-black);
}

.cp-btn--outline:hover {
	background: var(--cp-black);
	color: var(--cp-white);
	transform: translateY(-2px);
}

.cp-btn--dark {
	background: var(--cp-black);
	color: var(--cp-white);
	border: 1.5px solid var(--cp-black);
	text-decoration: none;
}

.cp-btn--dark:hover {
	background: var(--cp-paper);
	color: var(--cp-black);
	transform: translateY(-2px);
}

/* Contrast overrides for dark slide blocks */
.cp-slide__col-text--dark .cp-btn--primary {
	background: var(--cp-white);
	color: var(--cp-black);
	border-color: var(--cp-white);
}

.cp-slide__col-text--dark .cp-btn--primary:hover {
	background: var(--cp-accent);
	color: var(--cp-white);
	border-color: var(--cp-accent);
}

.cp-slide__col-text--dark .cp-btn--outline {
	color: var(--cp-white);
	border-color: var(--cp-white);
}

.cp-slide__col-text--dark .cp-btn--outline:hover {
	background: var(--cp-white);
	color: var(--cp-black);
	border-color: var(--cp-white);
}

/* 1. Hero Split Layout */
.cp-hero {
	border-bottom: 1px solid var(--cp-line);
	background: var(--cp-paper);
}

.cp-hero__inner {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	min-height: 520px;
}

.cp-hero__col {
	display: flex;
	align-items: center;
	padding: 64px 48px;
	position: relative;
}

.cp-hero__col--merchandising {
	background: var(--cp-black);
	color: var(--cp-white);
}

.cp-hero__col--merchandising .cp-hero__title {
	color: var(--cp-white);
}

.cp-hero__col--merchandising .cp-hero__desc {
	color: rgba(255, 255, 255, 0.76);
}

.cp-hero__col--uniforms {
	background: var(--cp-soft);
	color: var(--cp-ink);
}

.cp-hero__col--uniforms .cp-hero__title-sub {
	color: var(--cp-black);
	font-size: 42px;
	font-weight: 700;
	margin: 0 0 20px;
	line-height: 1.15;
}

.cp-hero__content {
	max-width: 480px;
}

.cp-hero__tag {
	display: inline-block;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cp-accent);
	margin-bottom: 16px;
}

.cp-hero__title {
	font-size: 42px;
	font-weight: 600;
	margin: 0 0 20px;
	line-height: 1.15;
	letter-spacing: 0;
}

.cp-hero__desc {
	font-size: 14px;
	line-height: 1.65;
	margin: 0 0 32px;
}

/* 2. USP Bar */
.cp-usps {
	border-bottom: 1px solid var(--cp-line);
	background: var(--cp-paper);
}

.cp-usps__inner {
	padding-top: 48px;
	padding-bottom: 48px;
}

.cp-usp-card {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.cp-usp-card__icon {
	color: var(--cp-accent);
	margin-bottom: 18px;
}

.cp-usp-card__title {
	font-size: 16px;
	font-weight: 600;
	color: var(--cp-black);
	margin: 0 0 8px;
}

.cp-usp-card__desc {
	font-size: 13px;
	color: var(--cp-muted);
	margin: 0;
	line-height: 1.6;
}

/* 3. Product Worlds specific animations */
.cp-world-card {
	padding: 42px 32px;
}

.cp-world-card__image-placeholder {
	color: var(--cp-muted);
	margin-bottom: 32px;
	transition: color var(--cp-ease), transform var(--cp-ease);
}

.cp-world-card__title {
	font-size: 18px;
	font-weight: 600;
	color: var(--cp-black);
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.cp-world-card__title span {
	font-size: 16px;
	color: var(--cp-accent);
	transition: transform var(--cp-ease);
}

.cp-world-card:hover .cp-world-card__image-placeholder {
	color: var(--cp-accent);
	transform: scale(1.05);
}

.cp-world-card:hover .cp-world-card__title span {
	transform: translateX(4px);
}

/* 4. Marketing Collections */
.cp-collection-card {
	background: var(--cp-paper);
	border: 1px solid var(--cp-line);
	display: flex;
	flex-direction: column;
	transition: transform var(--cp-ease), box-shadow var(--cp-ease);
}

.cp-collection-card__image {
	width: 100%;
	height: auto;
	border-bottom: 1px solid var(--cp-line);
	overflow: hidden;
}

.cp-collection-card__image svg {
	width: 100%;
	display: block;
	transition: transform 300ms ease;
}

.cp-collection-card__body {
	padding: 28px 24px;
	flex: 1;
}

.cp-collection-card__title {
	font-size: 16px;
	font-weight: 600;
	color: var(--cp-black);
	margin: 0 0 10px;
}

.cp-collection-card__desc {
	font-size: 13px;
	color: var(--cp-muted);
	margin: 0;
	line-height: 1.6;
}

.cp-collection-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 36px rgba(17, 17, 17, 0.04);
}

.cp-collection-card:hover .cp-collection-card__image svg {
	transform: scale(1.03);
}

/* 5. Customization Techniques specific styles */
.cp-tech-card__num {
	font-size: 12px;
	font-weight: 700;
	color: var(--cp-accent);
	margin-bottom: 14px;
	letter-spacing: 0.1em;
}

.cp-tech-card__title {
	font-size: 18px;
	font-weight: 600;
	color: var(--cp-black);
	margin: 0 0 10px;
}

.cp-tech-card__desc {
	font-size: 13px;
	color: var(--cp-muted);
	margin: 0;
	line-height: 1.65;
}

/* 6. Step-by-Step B2B Workflow */
.cp-step-card {
	position: relative;
}

.cp-step-card__header {
	margin-bottom: 20px;
}

.cp-step-card__step {
	display: inline-block;
	background: var(--cp-accent-soft);
	color: var(--cp-accent-dark);
	font-size: 10px;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 4px;
	letter-spacing: 0.05em;
}

.cp-step-card__title {
	font-size: 15px;
	font-weight: 600;
	color: var(--cp-black);
	margin: 0 0 10px;
}

.cp-step-card__desc {
	font-size: 13px;
	color: var(--cp-muted);
	margin: 0;
	line-height: 1.6;
}

/* 7. Blog / Publications */
.cp-post-card__body {
	padding: 28px 24px;
	display: flex;
	flex-direction: column;
	min-height: 240px;
}

.cp-post-card__date {
	font-size: 10px;
	font-weight: 600;
	color: var(--cp-accent);
	text-transform: uppercase;
	margin-bottom: 12px;
	letter-spacing: 0.05em;
}

.cp-post-card__title {
	font-size: 14px;
	font-weight: 600;
	color: var(--cp-black);
	line-height: 1.5;
	margin: 0 0 24px;
	flex: 1;
}

.cp-post-card__title a:hover {
	color: var(--cp-accent);
}

.cp-post-card__more {
	font-size: 11px;
	font-weight: 600;
	color: var(--cp-black);
	text-transform: uppercase;
}

/* 8. FAQs Accordion */
.cp-faqs__inner {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 48px;
	max-width: 1100px;
	margin: 0 auto;
}

.cp-faq-group-title {
	font-size: 18px;
	font-weight: 600;
	color: var(--cp-black);
	margin: 0 0 24px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--cp-line);
}

.cp-faq-item {
	border-bottom: 1px solid var(--cp-line);
	padding: 18px 0;
}

.cp-faq-item__question {
	font-size: 14px;
	font-weight: 600;
	color: var(--cp-black);
	cursor: pointer;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.cp-faq-item__question::-webkit-details-marker {
	display: none;
}

.cp-faq-item__question::after {
	content: "+";
	font-size: 18px;
	font-weight: 400;
	color: var(--cp-accent);
	transition: transform var(--cp-ease);
}

.cp-faq-item[open] .cp-faq-item__question::after {
	content: "−";
}

.cp-faq-item__answer {
	padding-top: 12px;
	font-size: 13px;
	color: var(--cp-muted);
	line-height: 1.6;
}

.cp-faq-item__answer p {
	margin: 0;
}

/* ==========================================================================
   RESPONSIVE LAYOUT OVERRIDES (TARGETING UTILITIES)
   ========================================================================== */

@media (max-width: 1024px) {
	.cp-grid--3 {
		grid-template-columns: repeat(2, 1fr);
	}
	.cp-grid--4 {
		grid-template-columns: repeat(2, 1fr);
		gap: 32px;
	}
	.cp-hero__inner {
		grid-template-columns: 1fr;
	}
	.cp-hero__col {
		padding: 56px 32px;
	}
	.cp-usps__inner {
		grid-template-columns: 1fr;
		gap: 28px;
	}
	.cp-collections__grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.cp-faqs__inner {
		grid-template-columns: 1fr;
		gap: 36px;
	}
}

@media (max-width: 640px) {
	.cp-grid--2,
	.cp-grid--3,
	.cp-grid--4 {
		grid-template-columns: 1fr;
	}
	.cp-hero__title,
	.cp-hero__col--merchandising .cp-hero__title,
	.cp-hero__col--uniforms .cp-hero__title-sub {
		font-size: 32px;
	}
	.cp-title-main {
		font-size: 28px;
	}
}

/* ==========================================================================
   DYNAMIC HERO SLIDER STYLES
   ========================================================================== */

.cp-hero-slider {
	border-bottom: 1px solid var(--cp-line);
	background: var(--cp-paper);
}

.cp-slider {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.cp-slider__track {
	display: flex;
	transition: transform 450ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
	width: 100%;
}

.cp-slide {
	flex: 0 0 100%;
	width: 100%;
	min-height: 520px;
	display: flex;
	position: relative;
	overflow: hidden;
}

.cp-slide__content-wrapper {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	width: 100%;
}

.cp-slide__col-text {
	display: flex;
	align-items: center;
	padding: 64px 48px;
	background: var(--cp-soft);
	color: var(--cp-ink);
}

.cp-slide__col-text--dark {
	background: var(--cp-black) !important;
	color: var(--cp-white) !important;
}

.cp-slide__col-text--dark .cp-hero__title {
	color: var(--cp-white);
}

.cp-slide__col-text--dark .cp-hero__desc {
	color: rgba(255, 255, 255, 0.76);
}

.cp-slide__col-image {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 100%;
}

.cp-slide__full-link {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 520px;
}

.cp-slide__full-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Dots pagination */
.cp-slider__dots {
	position: absolute;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 12px;
	z-index: 10;
}

.cp-slider__dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(17, 17, 17, 0.2);
	border: none;
	cursor: pointer;
	padding: 0;
	transition: background var(--cp-ease), transform var(--cp-ease);
}

.cp-slider__dot--active {
	background: var(--cp-accent);
	transform: scale(1.2);
}

/* Responsive Slider */
@media (max-width: 1024px) {
	.cp-slide__content-wrapper {
		grid-template-columns: 1fr;
	}
	.cp-slide {
		min-height: auto;
	}
	.cp-slide__col-text {
		padding: 48px 24px;
	}
	.cp-slide__col-image {
		min-height: 300px;
	}
	.cp-slide__full-link {
		min-height: 320px;
	}
}

/* ==========================================================================
   WOOCOMMERCE FEATURED PRODUCTS CARD
   ========================================================================== */
.cp-product-card-item {
	display: flex;
	flex-direction: column;
	padding: 0 !important;
	overflow: hidden;
	background: var(--cp-paper);
	border: 1px solid var(--cp-line);
}

.cp-product-card-item__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none !important;
}

.cp-product-card-item__image {
	width: 100%;
	aspect-ratio: 1 / 1;
	background-size: cover;
	background-position: center;
	background-color: var(--cp-soft);
	border-bottom: 1px solid var(--cp-line);
	transition: transform 300ms ease;
}

.cp-product-card-item:hover .cp-product-card-item__image {
	transform: scale(1.02);
}

.cp-product-card-item__body {
	padding: 16px 20px 20px;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

.cp-product-card-item__title {
	font-size: 14px;
	font-weight: 600;
	color: var(--cp-black);
	margin: 0 0 8px;
	line-height: 1.4;
}

.cp-product-card-item__price {
	font-size: 13px;
	font-weight: 700;
	color: var(--cp-accent);
	margin-top: auto;
}

/* ==========================================================================
   SUSTAINABILITY & PARTNER BRANDS SECTIONS
   ========================================================================== */
.cp-sustain-banner {
	position: relative;
	width: 100%;
	min-height: 380px;
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	padding: 56px;
	overflow: hidden;
}

.cp-sustain-banner__overlay {
	position: absolute;
	top: 0; left: 0; right: 0; bottom: 0;
	background: linear-gradient(90deg, rgba(17,17,17,0.85) 0%, rgba(17,17,17,0.4) 60%, rgba(17,17,17,0.1) 100%);
	z-index: 1;
}

.cp-sustain-banner__content {
	position: relative;
	z-index: 2;
	max-width: 580px;
	color: var(--cp-white);
}

.cp-sustain-banner__tag {
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--cp-accent);
	margin-bottom: 12px;
}

.cp-sustain-banner__title {
	font-size: 42px;
	font-weight: 800;
	line-height: 1.05;
	text-transform: uppercase;
	margin: 0 0 16px;
	color: var(--cp-white);
}

.cp-sustain-banner__desc {
	font-size: 14px;
	line-height: 1.6;
	color: rgba(255,255,255,0.8);
	margin: 0;
}

/* Brands Grid Layout */
.cp-brands-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 1px;
	background: var(--cp-line);
	border: 1px solid var(--cp-line);
}

.cp-brand-card {
	background: var(--cp-white);
	height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
	transition: background var(--cp-ease);
}

.cp-brand-card:hover {
	background: var(--cp-soft);
}

.cp-brand-name {
	user-select: none;
	text-align: center;
	display: inline-block;
}

/* Individual Brand Typographies mimicking original logos */
.cp-brand-name--camelbak {
	font-family: Impact, "Arial Black", sans-serif;
	font-weight: 900;
	font-size: 16px;
	letter-spacing: 0;
	text-transform: uppercase;
	color: #111;
}

.cp-brand-name--caselogic {
	font-family: Arial, sans-serif;
	font-weight: 800;
	font-size: 14px;
	letter-spacing: 0;
	color: #333;
	border-bottom: 2px solid #333;
}

.cp-brand-name--chipolo {
	font-family: "Century Gothic", Arial, sans-serif;
	font-weight: 600;
	font-size: 18px;
	color: #000;
	text-transform: lowercase;
}

.cp-brand-name--citizengreen {
	font-family: "Garamond", Georgia, serif;
	font-style: italic;
	font-weight: 600;
	font-size: 15px;
	color: #2e7d32;
}

.cp-brand-name--elevate {
	font-family: "Arial Black", sans-serif;
	font-weight: 900;
	font-size: 14px;
	letter-spacing: 0.2em;
	color: #000;
}

.cp-brand-name--herschel {
	font-family: "Courier New", monospace;
	font-weight: 900;
	border: 1.5px solid #111;
	padding: 3px 8px;
	font-size: 9px;
	text-transform: uppercase;
	color: #111;
}

.cp-brand-name--karst {
	font-family: "Century Gothic", sans-serif;
	font-weight: 300;
	font-size: 15px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	border-bottom: 1.2px solid #111;
	padding-bottom: 2px;
}

.cp-brand-name--kooduu {
	font-family: "Century Gothic", sans-serif;
	font-weight: 400;
	font-size: 18px;
	letter-spacing: 0.05em;
	color: #111;
}

.cp-brand-name--larq {
	font-family: "Century Gothic", sans-serif;
	font-weight: 300;
	font-size: 16px;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: #000;
}

.cp-brand-name--luxe {
	font-family: "Times New Roman", Times, serif;
	font-style: italic;
	font-weight: 700;
	font-size: 18px;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

.cp-brand-name--marksman {
	font-family: "Impact", sans-serif;
	font-weight: 900;
	font-size: 16px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: #222;
}

.cp-brand-name--mepal {
	font-family: Arial, sans-serif;
	font-weight: 900;
	font-size: 17px;
	letter-spacing: 0;
	text-transform: uppercase;
	color: #111;
}

.cp-brand-name--moleskine {
	font-family: Georgia, serif;
	font-weight: 700;
	font-size: 11px;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: #111;
}

.cp-brand-name--oceanbottle {
	font-family: Arial, sans-serif;
	font-weight: 600;
	font-size: 15px;
	text-transform: lowercase;
	color: #00838f;
}

.cp-brand-name--originhome {
	font-family: "Courier New", monospace;
	font-weight: 500;
	font-size: 13px;
	color: #4e342e;
}

.cp-brand-name--parker {
	font-family: "Georgia", serif;
	font-weight: 400;
	font-size: 14px;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: #111;
}

.cp-brand-name--prixton {
	font-family: "Arial Black", sans-serif;
	font-weight: 900;
	font-size: 14px;
	text-transform: uppercase;
	color: #000;
}

.cp-brand-name--roly {
	font-family: "Trebuchet MS", sans-serif;
	font-weight: 900;
	font-size: 17px;
	letter-spacing: 0;
	text-transform: uppercase;
	color: #111;
}

.cp-brand-name--rolywrk {
	font-family: "Trebuchet MS", sans-serif;
	font-weight: 900;
	font-size: 14px;
	letter-spacing: 0;
	text-transform: uppercase;
	color: #d84315;
}

.cp-brand-name--scx {
	font-family: "Impact", sans-serif;
	font-weight: 900;
	font-size: 18px;
	letter-spacing: 0.05em;
	color: #111;
}

.cp-brand-name--seasons {
	font-family: "Didot", Georgia, serif;
	font-weight: 400;
	font-size: 13px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.cp-brand-name--stanley {
	font-family: "Impact", sans-serif;
	font-weight: 900;
	font-size: 18px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #000;
}

.cp-brand-name--tekio {
	font-family: monospace;
	font-weight: 700;
	font-size: 14px;
	letter-spacing: 0.25em;
	text-transform: uppercase;
}

.cp-brand-name--thule {
	font-family: "Arial Black", sans-serif;
	font-weight: 900;
	font-size: 13px;
	letter-spacing: 0;
	font-style: italic;
	background: #000;
	color: #fff;
	padding: 4px 10px;
	text-transform: uppercase;
}

.cp-brand-name--waterman {
	font-family: "Times New Roman", Times, serif;
	font-style: italic;
	font-weight: 600;
	font-size: 16px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.cp-brand-name--wellmark {
	font-family: "Courier New", monospace;
	font-weight: 400;
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.cp-brand-name--xtorm {
	font-family: Arial, sans-serif;
	font-weight: 900;
	font-size: 17px;
	color: #e65100;
	text-transform: lowercase;
}

.cp-brand-name--zens {
	font-family: "Century Gothic", sans-serif;
	font-weight: 300;
	font-size: 17px;
	text-transform: lowercase;
	color: #111;
}

/* Certifications badges row */
.cp-certifications-row {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 36px;
	padding: 24px 0 0;
}

.cp-cert-badge {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--cp-muted);
}

.cp-cert-badge svg {
	opacity: 0.6;
	width: 20px;
	height: 20px;
}

.cp-cert-badge span {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Responsive overrides for marcas y sostenibilidad */
@media (max-width: 1024px) {
	.cp-brands-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

@media (max-width: 640px) {
	.cp-brands-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.cp-sustain-banner {
		padding: 32px 24px;
		min-height: 280px;
	}
	.cp-sustain-banner__title {
		font-size: 28px;
	}
}

/* ==========================================================================
   STANDARD PAGES AND SINGLE POSTS TYPOGRAPHY & LAYOUTS
   ========================================================================== */
.cp-container--narrow {
	max-width: 800px;
	margin: 0 auto;
}

.cp-page-header, .cp-post-header {
	background: var(--cp-soft);
	border-bottom: 1px solid var(--cp-line);
	padding: 80px 0 60px;
	text-align: center;
}

.cp-page-header__inner, .cp-post-header__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}

.cp-page-header__tag {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.15em;
	color: var(--cp-accent);
	text-transform: uppercase;
}

.cp-page-header__title, .cp-post-header__title {
	font-size: 38px;
	font-weight: 600;
	line-height: 1.2;
	color: var(--cp-black);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0;
}

.cp-page-header__intro {
	max-width: 780px;
	margin: 6px auto 0;
	color: var(--cp-muted);
	font-size: 16px;
	line-height: 1.75;
}

.cp-post-meta {
	display: flex;
	align-items: center;
	gap: 16px;
	font-size: 11px;
	font-weight: 700;
	color: var(--cp-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.cp-post-category a {
	color: var(--cp-accent);
	text-decoration: none;
}

.cp-post-category a:hover {
	text-decoration: underline;
}

.cp-post-featured-image {
	padding-top: 48px;
}

.cp-post-featured-image__wrapper {
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	border-radius: 8px;
	border: 1px solid var(--cp-line);
	background: var(--cp-soft);
}

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

.cp-entry-content {
	font-size: 15px;
	line-height: 1.8;
	color: var(--cp-ink);
	overflow-wrap: anywhere;
}

.cp-entry-content p {
	margin: 0 0 24px;
}

.cp-entry-content h2, .cp-entry-content h3, .cp-entry-content h4 {
	font-family: 'Montserrat', sans-serif;
	color: var(--cp-black);
	font-weight: 600;
	line-height: 1.3;
	margin: 48px 0 20px;
}

.cp-entry-content h2 { font-size: 24px; }
.cp-entry-content h3 { font-size: 20px; }
.cp-entry-content h4 { font-size: 17px; }

.cp-entry-content ul, .cp-entry-content ol {
	margin: 0 0 24px;
	padding-left: 24px;
}

.cp-entry-content li {
	margin-bottom: 8px;
}

.cp-entry-content a {
	color: var(--cp-black);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 4px;
}

.cp-entry-content a:hover {
	color: var(--cp-accent-dark);
}

.cp-entry-content img,
.cp-entry-content video,
.cp-entry-content iframe {
	max-width: 100%;
	height: auto;
}

.cp-entry-content table {
	width: 100%;
	border-collapse: collapse;
	margin: 32px 0;
	font-size: 14px;
}

.cp-entry-content th,
.cp-entry-content td {
	padding: 14px 16px;
	border: 1px solid var(--cp-line);
	text-align: left;
	vertical-align: top;
}

.cp-entry-content th {
	background: var(--cp-soft);
	font-weight: 600;
	color: var(--cp-black);
}

.cp-entry-content input,
.cp-entry-content textarea,
.cp-entry-content select {
	width: 100%;
	min-height: 46px;
	border: 1px solid var(--cp-line);
	border-radius: 0;
	background: var(--cp-paper);
	padding: 12px 14px;
	color: var(--cp-ink);
	font: inherit;
}

.cp-entry-content textarea {
	min-height: 140px;
	resize: vertical;
}

.cp-entry-content button,
.cp-entry-content input[type="submit"] {
	width: auto;
	min-height: 46px;
	border: 1.5px solid var(--cp-black);
	border-radius: 999px;
	background: var(--cp-black);
	color: var(--cp-white);
	padding: 0 24px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	cursor: pointer;
}

.cp-entry-content blockquote {
	margin: 32px 0;
	padding: 16px 24px;
	border-left: 4px solid var(--cp-accent);
	background: var(--cp-soft);
	font-style: italic;
	color: var(--cp-muted);
}

.cp-entry-content [class*="elementor-"],
.cp-entry-content [class*="wd-"] {
	box-sizing: border-box;
}

.cp-entry-content .elementor-section,
.cp-entry-content .elementor-container,
.cp-entry-content .elementor-widget-wrap,
.cp-entry-content [data-element_type="container"] {
	width: 100%;
	max-width: 100%;
}

.cp-entry-content .elementor-widget:not(:last-child),
.cp-entry-content .wd-text-block:not(:last-child),
.cp-entry-content .wd-info-box:not(:last-child),
.cp-entry-content .wd-accordion:not(:last-child) {
	margin-bottom: 28px;
}

.cp-entry-content .title-wrapper,
.cp-entry-content .wd-info-box,
.cp-entry-content .wd-accordion-item,
.cp-entry-content .woocommerce,
.cp-entry-content .wp-block-woocommerce-cart,
.cp-entry-content .wp-block-woocommerce-checkout {
	margin: 28px 0;
	padding: 28px;
	border: 1px solid var(--cp-line);
	background: var(--cp-paper);
}

.cp-entry-content .title-wrapper {
	background: var(--cp-soft);
}

.cp-entry-content .wd-title,
.cp-entry-content .title {
	margin: 0 0 14px;
	font-size: 24px;
	font-weight: 600;
	line-height: 1.3;
	color: var(--cp-black);
}

.cp-entry-content .wd-accordion-title,
.cp-entry-content .wd-accordion-opener,
.cp-entry-content .elementor-heading-title {
	color: var(--cp-black);
	font-weight: 600;
}

.cp-entry-content .wd-accordion-title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	border-bottom: 1px solid var(--cp-line);
	padding-bottom: 14px;
}

.cp-entry-content .wd-accordion-content {
	padding-top: 16px;
	color: var(--cp-ink);
}

.cp-page-cta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 28px;
	margin-top: 56px;
	padding: 32px;
	border: 1px solid var(--cp-black);
	background: var(--cp-soft);
}

.cp-page-cta__tag {
	display: block;
	margin-bottom: 10px;
	color: var(--cp-accent-dark);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cp-page-cta h2 {
	margin: 0 0 10px;
	font-size: 22px;
	font-weight: 600;
	line-height: 1.3;
	color: var(--cp-black);
}

.cp-page-cta p {
	max-width: 600px;
	margin: 0;
	color: var(--cp-muted);
	line-height: 1.7;
}

.cp-post-navigation {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
}

.cp-post-nav-prev a, .cp-post-nav-next a {
	font-size: 13px;
	font-weight: 700;
	color: var(--cp-black);
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	transition: color var(--cp-ease);
}

.cp-post-nav-prev a:hover, .cp-post-nav-next a:hover {
	color: var(--cp-accent);
}

@media (max-width: 768px) {
	.cp-page-header, .cp-post-header {
		padding: 56px 20px 42px;
	}
	.cp-page-header__title, .cp-post-header__title {
		font-size: 28px;
	}
	.cp-page-header__intro {
		font-size: 14px;
	}
	.cp-page-cta {
		align-items: flex-start;
		flex-direction: column;
		padding: 24px;
	}
	.cp-entry-content .title-wrapper,
	.cp-entry-content .wd-info-box,
	.cp-entry-content .wd-accordion-item,
	.cp-entry-content .woocommerce,
	.cp-entry-content .wp-block-woocommerce-cart,
	.cp-entry-content .wp-block-woocommerce-checkout {
		padding: 22px;
	}
}

/* ==========================================================================
   STANDARD WORDPRESS ALIGNMENT AND CONTENT HELPER CLASSES
   ========================================================================== */
.aligncenter {
	display: block;
	margin: 32px auto;
	text-align: center;
}

.alignleft {
	float: left;
	margin: 0 32px 32px 0;
}

.alignright {
	float: right;
	margin: 0 0 32px 32px;
}

.wp-block-image {
	margin: 32px 0;
}

.wp-block-image img {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
	border: 1px solid var(--cp-line);
}

.wp-block-image figcaption {
	font-size: 12px;
	color: var(--cp-muted);
	text-align: center;
	margin-top: 8px;
}

/* Clearfix for floated elements */
.cp-entry-content::after {
	content: "";
	display: table;
	clear: both;
}

/* ==========================================================================
   WOOCOMMERCE SINGLE PRODUCT
   ========================================================================== */
.cp-single-product {
	background: var(--cp-paper);
}

.cp-product-hero {
	padding: 30px 0 60px;
	border-bottom: 1px solid var(--cp-line);
	background: linear-gradient(180deg, var(--cp-soft) 0, var(--cp-paper) 320px);
}

.cp-product-breadcrumb {
	margin-bottom: 24px;
	color: var(--cp-muted);
	font-size: 12px;
	font-weight: 600;
}

.cp-product-breadcrumb a {
	color: var(--cp-black);
}

.cp-product-layout {
	display: grid;
	grid-template-columns: minmax(300px, 540px) minmax(420px, 1fr);
	gap: clamp(32px, 4vw, 56px);
	align-items: start;
}

.cp-product-media {
	display: grid;
	gap: 12px;
	width: min(100%, 560px);
	align-self: start;
}

.cp-product-media__stage {
	display: flex;
	align-items: center;
	justify-content: center;
	height: clamp(360px, 38vw, 500px);
	padding: 22px;
	border: 1px solid var(--cp-line);
	border-radius: 8px;
	background: var(--cp-white);
	overflow: hidden;
}

.cp-product-media__image {
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	object-position: center;
}

.cp-product-media__image--placeholder {
	opacity: 0.55;
}

.cp-product-media__thumbs {
	display: grid;
	grid-auto-columns: 62px;
	grid-auto-flow: column;
	gap: 8px;
	overflow-x: auto;
	padding-bottom: 4px;
	scrollbar-width: thin;
}

.cp-product-media__thumb {
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 1 / 1;
	padding: 7px;
	border: 1px solid var(--cp-line);
	border-radius: 6px;
	background: var(--cp-white);
	overflow: hidden;
	transition: border-color var(--cp-ease), transform var(--cp-ease);
}

.cp-product-media__thumb:hover,
.cp-product-media__thumb:focus-visible {
	border-color: var(--cp-black);
	transform: translateY(-1px);
}

.cp-product-media__thumb img {
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.cp-product-summary {
	position: sticky;
	top: 150px;
	display: grid;
	gap: 20px;
}

.cp-product-summary__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 14px;
	color: var(--cp-muted);
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.cp-product-summary__meta span {
	display: inline-flex;
	align-items: center;
}

.cp-product-summary__meta span + span::before {
	content: "";
	width: 4px;
	height: 4px;
	margin-right: 14px;
	border-radius: 50%;
	background: var(--cp-accent);
}

.cp-product-summary__meta a:hover {
	color: var(--cp-accent-dark);
}

.cp-product-title {
	margin: 0;
	color: var(--cp-black);
	font-size: clamp(21px, 1.35vw, 25px);
	font-weight: 700;
	line-height: 1.24;
	letter-spacing: 0;
}

.cp-product-excerpt {
	color: var(--cp-muted);
	font-size: 15px;
	line-height: 1.75;
}

.cp-product-excerpt p {
	margin: 0 0 12px;
}

.cp-product-excerpt p:last-child {
	margin-bottom: 0;
}

.cp-product-price {
	display: grid;
	gap: 5px;
	padding: 18px 0;
	border-top: 1px solid var(--cp-line);
	border-bottom: 1px solid var(--cp-line);
}

.cp-product-price__label {
	color: var(--cp-muted);
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.cp-product-price .price,
.cp-product-price .mpi-price-range,
.cp-product-price .ma-price-range {
	color: var(--cp-black);
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
}

.cp-product-price p {
	margin: 0;
	color: var(--cp-muted);
	font-size: 12px;
	line-height: 1.55;
}

.cp-product-buybox {
	border: 1px solid var(--cp-line);
	border-radius: 8px;
	background: var(--cp-white);
	padding: 22px;
	box-shadow: 0 18px 50px rgba(17, 17, 17, 0.06);
}

.cp-product-buybox form.cart {
	display: grid;
	gap: 16px;
	margin: 0;
}

.cp-product-buybox .variations {
	width: 100%;
	border-collapse: collapse;
	margin: 0;
}

.cp-product-buybox .variations tbody {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.cp-product-buybox .variations tr {
	display: grid;
	gap: 7px;
	margin-bottom: 0;
}

.cp-product-buybox .variations th,
.cp-product-buybox .variations td {
	display: block;
	padding: 0;
	border: 0;
	background: transparent;
	text-align: left;
}

.cp-product-buybox label {
	display: block;
	margin: 0 0 7px;
	color: var(--cp-black);
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.cp-product-buybox select,
.cp-product-buybox input[type="number"],
.cp-product-buybox input[type="text"],
.cp-product-buybox input[type="email"],
.cp-product-buybox input[type="file"] {
	width: 100%;
	min-height: 46px;
	border: 1px solid var(--cp-line);
	border-radius: 6px;
	background: var(--cp-paper);
	padding: 0 13px;
	color: var(--cp-ink);
	font: inherit;
}

.cp-product-buybox select:focus,
.cp-product-buybox input:focus {
	border-color: var(--cp-black);
	outline: none;
	box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.08);
}

.cp-product-buybox .quantity {
	width: 104px;
	max-width: 100%;
}

.cp-product-live-total {
	display: grid;
	gap: 1px;
	min-width: 176px;
	padding: 6px 16px;
	border-left: 1px solid var(--cp-line);
}

.cp-product-live-total__label {
	color: var(--cp-muted);
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.2;
	text-transform: uppercase;
}

.cp-product-live-total__amount {
	color: var(--cp-black);
	font-size: 17px;
	font-weight: 750;
	line-height: 1.2;
	white-space: nowrap;
}

.cp-product-live-total__meta {
	color: var(--cp-muted);
	font-size: 11px;
	line-height: 1.35;
}

.cp-product-buybox .single_variation_wrap {
	display: grid;
	gap: 14px;
}

.cp-product-buybox .woocommerce-variation {
	color: var(--cp-muted);
	font-size: 13px;
}

.cp-product-buybox .woocommerce-variation-price .price {
	color: var(--cp-black);
	font-size: 20px;
	font-weight: 700;
}

.cp-product-buybox .woocommerce-variation-add-to-cart,
.cp-product-buybox form.cart:not(.variations_form) {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}

.cp-product-buybox .single_add_to_cart_button,
.cp-product-buybox .button {
	min-height: 46px;
	border: 1.5px solid var(--cp-black);
	border-radius: 999px;
	background: var(--cp-black);
	color: var(--cp-white);
	padding: 0 24px;
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: background var(--cp-ease), border-color var(--cp-ease), transform var(--cp-ease);
}

.cp-single-product .cp-product-buybox button.single_add_to_cart_button.button.alt,
.cp-single-product .cp-product-buybox .single_add_to_cart_button.button.alt {
	border-color: var(--cp-black) !important;
	background: var(--cp-black) !important;
	color: var(--cp-white) !important;
}

.cp-product-buybox .single_add_to_cart_button:hover,
.cp-product-buybox .button:hover {
	background: var(--cp-accent-dark);
	border-color: var(--cp-accent-dark);
	transform: translateY(-1px);
}

.cp-single-product .cp-product-buybox button.single_add_to_cart_button.button.alt:hover,
.cp-single-product .cp-product-buybox .single_add_to_cart_button.button.alt:hover {
	border-color: var(--cp-accent-dark) !important;
	background: var(--cp-accent-dark) !important;
}

.cp-product-buybox .single_add_to_cart_button.disabled,
.cp-product-buybox .single_add_to_cart_button:disabled {
	opacity: 0.45;
	cursor: not-allowed;
	transform: none;
}

.cp-product-buybox .stock {
	margin: 0;
	color: var(--cp-accent-dark);
	font-size: 12px;
	font-weight: 700;
}

.cp-product-buybox .reset_variations {
	display: inline-flex;
	margin-top: 8px;
	color: var(--cp-muted);
	font-size: 12px;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.cp-product-buybox .mpi-personalization {
	margin: 4px 0 0;
	border-color: var(--cp-line);
	border-radius: 8px;
	padding: 12px;
}

.cp-product-buybox .mpi-personalization__header h3 {
	font-size: 14px;
}

.cp-product-buybox .mpi-personalization__header p {
	font-size: 11px;
	line-height: 1.35;
}

.cp-product-buybox .mpi-personalization__toggle {
	min-height: 30px;
	padding: 0 9px;
	border: 1px solid var(--cp-line);
	border-radius: 999px;
	background: var(--cp-soft);
	font-size: 11px;
	font-weight: 700;
}

.cp-product-buybox .mpi-personalization__body {
	display: grid;
	gap: 10px;
	margin-top: 10px;
}

.cp-product-buybox .mpi-personalization__body[hidden] {
	display: none !important;
}

.cp-product-buybox .mpi-personalization__grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
}

.cp-product-buybox .mpi-personalization__grid label:last-child {
	grid-column: 1 / -1;
}

.cp-product-buybox .mpi-personalization__grid label,
.cp-product-buybox .mpi-personalization__details label {
	font-size: 11px;
	gap: 5px;
}

.cp-product-buybox .mpi-personalization__grid select,
.cp-product-buybox .mpi-personalization__details textarea,
.cp-product-buybox .mpi-personalization__details input[type="file"] {
	min-height: 36px;
	padding: 7px 9px;
	font-size: 12px;
}

.cp-product-buybox .mpi-personalization__details {
	grid-template-columns: minmax(0, 1fr) minmax(180px, 0.72fr);
	gap: 8px;
}

.cp-product-buybox .mpi-personalization__details textarea {
	min-height: 64px;
}

.cp-product-buybox .mpi-personalization__details span {
	font-size: 10px;
	line-height: 1.3;
}

.cp-product-buybox .mpi-personalization__summary {
	border-radius: 6px;
	background: var(--cp-soft);
	display: grid;
	gap: 0;
	padding: 8px 10px;
	font-size: 11px;
	line-height: 1.35;
}

.cp-product-buybox .mpi-personalization__summary-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 4px 0;
	border-bottom: 1px solid rgba(17, 17, 17, 0.06);
}

.cp-product-buybox .mpi-personalization__summary-row:last-child {
	border-bottom: 0;
}

.cp-product-buybox .mpi-personalization__summary-label {
	color: var(--cp-muted);
}

.cp-product-buybox .mpi-personalization__summary-value {
	color: var(--cp-black);
	font-weight: 800;
	text-align: right;
	white-space: nowrap;
}

.cp-product-buybox .mpi-personalization__notice {
	margin-top: 0;
	font-size: 11px;
	line-height: 1.4;
}

.cp-product-assurance {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1px;
	border: 1px solid var(--cp-line);
	background: var(--cp-line);
}

.cp-product-assurance div {
	display: grid;
	gap: 5px;
	min-height: 112px;
	padding: 16px;
	background: var(--cp-white);
}

.cp-product-assurance strong {
	color: var(--cp-black);
	font-size: 13px;
	font-weight: 700;
}

.cp-product-assurance span {
	color: var(--cp-muted);
	font-size: 12px;
	line-height: 1.55;
}

.cp-product-detail {
	padding: 68px 0;
}

.cp-product-detail__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	gap: 52px;
	align-items: start;
}

.cp-product-content {
	display: grid;
	gap: 42px;
}

.cp-product-section h2,
.cp-product-panel h2 {
	margin: 0 0 18px;
	color: var(--cp-black);
	font-size: 18px;
	font-weight: 700;
	line-height: 1.25;
}

.cp-product-section .cp-entry-content {
	max-width: 920px;
}

.cp-product-specs {
	display: grid;
	border-top: 1px solid var(--cp-line);
}

.cp-product-specs__row {
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);
	gap: 24px;
	padding: 16px 0;
	border-bottom: 1px solid var(--cp-line);
}

.cp-product-specs dt {
	color: var(--cp-black);
	font-size: 13px;
	font-weight: 700;
}

.cp-product-specs dd {
	margin: 0;
	color: var(--cp-muted);
	font-size: 13px;
	line-height: 1.6;
}

.cp-product-sidebar {
	position: sticky;
	top: 150px;
	display: grid;
	gap: 18px;
}

.cp-product-panel {
	border: 1px solid var(--cp-line);
	border-radius: 8px;
	background: var(--cp-soft);
	padding: 24px;
}

.cp-product-panel p {
	margin: 0 0 16px;
	color: var(--cp-muted);
	font-size: 13px;
	line-height: 1.65;
}

.cp-product-tech-list,
.cp-product-steps {
	margin: 0;
	padding-left: 18px;
	color: var(--cp-ink);
	font-size: 13px;
	line-height: 1.65;
}

.cp-product-tech-list li,
.cp-product-steps li {
	margin-bottom: 8px;
}

.cp-product-related {
	padding: 68px 0 86px;
	border-top: 1px solid var(--cp-line);
	background: var(--cp-soft);
}

.cp-product-related__header {
	margin-bottom: 28px;
}

.cp-product-related__header .cp-title-main {
	font-size: clamp(22px, 2vw, 30px);
	font-weight: 650;
}

.cp-product-related__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.cp-product-mini {
	display: grid;
	grid-template-rows: auto 1fr;
	border: 1px solid var(--cp-line);
	border-radius: 8px;
	background: var(--cp-white);
	overflow: hidden;
	transition: border-color var(--cp-ease), transform var(--cp-ease), box-shadow var(--cp-ease);
}

.cp-product-mini:hover,
.cp-product-mini:focus-visible {
	border-color: var(--cp-accent);
	box-shadow: 0 14px 36px rgba(17, 17, 17, 0.07);
	transform: translateY(-3px);
}

.cp-product-mini__image {
	aspect-ratio: 1 / 1;
	border-bottom: 1px solid var(--cp-line);
	background: var(--cp-white);
}

.cp-product-mini__image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 18px;
}

.cp-product-mini__body {
	display: grid;
	gap: 10px;
	padding: 16px;
}

.cp-product-mini h3 {
	margin: 0;
	color: var(--cp-black);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.4;
}

.cp-product-mini span {
	color: var(--cp-accent-dark);
	font-size: 13px;
	font-weight: 800;
}

.woocommerce-notices-wrapper,
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
	margin-bottom: 18px;
}

.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
	border: 1px solid var(--cp-line);
	border-radius: 8px;
	background: var(--cp-white);
	padding: 14px 16px;
	color: var(--cp-ink);
}

.woocommerce-error {
	border-color: #d8a1a1;
	color: #8a1f1f;
}

.woocommerce-message .button,
.woocommerce-info .button {
	float: right;
	margin-left: 12px;
	color: var(--cp-accent-dark);
	font-weight: 700;
}

@media (max-width: 1180px) {
	.cp-product-layout,
	.cp-product-detail__grid {
		grid-template-columns: 1fr;
	}

	.cp-product-summary,
	.cp-product-sidebar {
		position: static;
	}
}

@media (max-width: 900px) {
	.cp-product-hero {
		padding: 24px 0 48px;
	}

	.cp-product-layout {
		gap: 34px;
	}

	.cp-product-media {
		width: 100%;
	}

	.cp-product-media__stage {
		height: clamp(320px, 64vw, 460px);
		padding: 18px;
	}

	.cp-product-assurance,
	.cp-product-related__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.cp-product-detail {
		padding: 48px 0;
	}
}

@media (max-width: 640px) {
	.cp-product-title {
		font-size: 22px;
	}

	.cp-product-media__stage {
		height: clamp(280px, 92vw, 380px);
		padding: 14px;
	}

	.cp-product-price .price,
	.cp-product-price .mpi-price-range,
	.cp-product-price .ma-price-range {
		font-size: 21px;
	}

	.cp-product-buybox {
		padding: 18px;
	}

	.cp-product-buybox .variations tbody,
	.cp-product-buybox .mpi-personalization__grid,
	.cp-product-buybox .mpi-personalization__details {
		grid-template-columns: 1fr;
	}

	.cp-product-buybox .mpi-personalization__grid label:last-child {
		grid-column: auto;
	}

	.cp-product-buybox .woocommerce-variation-add-to-cart,
	.cp-product-buybox form.cart:not(.variations_form) {
		display: grid;
		grid-template-columns: 1fr;
	}

	.cp-product-buybox .quantity {
		width: 100%;
	}

	.cp-product-live-total {
		min-width: 0;
		width: 100%;
		border-left: 0;
		border-top: 1px solid var(--cp-line);
		border-bottom: 1px solid var(--cp-line);
		padding: 12px 0;
	}

	.cp-product-buybox .single_add_to_cart_button,
	.cp-product-buybox .button {
		width: 100%;
	}

	.cp-product-assurance,
	.cp-product-related__grid {
		grid-template-columns: 1fr;
	}

	.cp-product-specs__row {
		grid-template-columns: 1fr;
		gap: 6px;
	}
}

/* ==========================================================================
   FRONTPAGE EDITORIAL REFRESH
   ========================================================================== */

.cp-btn span {
	margin-left: 8px;
}

.cp-btn--glass {
	min-height: 42px;
	color: var(--cp-white);
	border: 1px solid rgba(255, 255, 255, 0.52);
	background: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(12px);
}

.cp-btn--glass:hover {
	background: rgba(255, 255, 255, 0.24);
	color: var(--cp-white);
	transform: translateY(-2px);
}

.cp-front-hero {
	border-bottom: 0;
	background: var(--cp-black);
}

.cp-front-hero .cp-slider {
	height: clamp(560px, calc(100vh - 72px), 760px);
	min-height: 560px;
}

.cp-front-slide {
	min-height: 100%;
	align-items: stretch;
	isolation: isolate;
	background: #191919;
}

.cp-front-slide__media,
.cp-front-slide__shade {
	position: absolute;
	inset: 0;
}

.cp-front-slide__media {
	z-index: -3;
	background-size: cover;
	background-position: center;
}

.cp-front-slide__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.66) 0%, rgba(0, 0, 0, 0.28) 48%, rgba(0, 0, 0, 0.12) 100%);
}

.cp-front-slide__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0;
}

.cp-front-slide__shade {
	z-index: -2;
	background: linear-gradient(0deg, rgba(0, 0, 0, 0.38) 0%, rgba(0, 0, 0, 0.03) 42%);
}

.cp-front-slide__content {
	position: relative;
	z-index: 1;
	display: flex;
	min-height: 100%;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	padding-top: 70px;
	padding-bottom: 86px;
	color: var(--cp-white);
}

.cp-front-slide__tag {
	margin-bottom: 18px;
	color: rgba(255, 255, 255, 0.82);
	font-size: 12px;
	font-weight: 700;
}

.cp-front-slide__title {
	max-width: 720px;
	margin: 0;
	color: var(--cp-white);
	font-size: clamp(44px, 6vw, 82px);
	font-weight: 700;
	line-height: 0.98;
	letter-spacing: 0;
}

.cp-front-slide__desc {
	max-width: 620px;
	margin: 20px 0 0;
	color: rgba(255, 255, 255, 0.9);
	font-size: 16px;
	line-height: 1.55;
}

.cp-front-slide__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 30px;
}

.cp-front-hero .cp-slider__dots {
	right: 38px;
	bottom: 34px;
	left: auto;
	gap: 8px;
	transform: none;
}

.cp-front-hero .cp-slider__dot {
	width: 28px;
	height: 3px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.44);
}

.cp-front-hero .cp-slider__dot--active {
	background: var(--cp-white);
	transform: none;
}

.cp-front-hero__scroll {
	position: absolute;
	bottom: 26px;
	left: 50%;
	z-index: 12;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transform: translateX(-50%);
	color: rgba(255, 255, 255, 0.82);
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
}

.cp-front-hero__scroll span {
	position: relative;
	width: 18px;
	height: 28px;
	border: 1px solid rgba(255, 255, 255, 0.72);
	border-radius: 999px;
}

.cp-front-hero__scroll span::after {
	content: "";
	position: absolute;
	top: 6px;
	left: 50%;
	width: 3px;
	height: 6px;
	border-radius: 999px;
	background: var(--cp-white);
	transform: translateX(-50%);
}

.cp-front-section {
	padding-block: 74px;
	background: var(--cp-paper);
}

.cp-front-section--soft,
.cp-front-trust {
	background: #f7f7f5;
}

.cp-front-trust {
	padding-block: 36px;
}

.cp-front-trust .cp-usps__inner {
	padding-top: 0;
	padding-bottom: 0;
}

.cp-front-section--first {
	padding-top: 62px;
}

.cp-front-section--compact {
	padding-top: 36px;
}

.cp-front-heading {
	margin-bottom: 24px;
}

.cp-front-heading .cp-title-main {
	margin-bottom: 0;
	font-size: clamp(32px, 3.2vw, 48px);
	line-height: 1.08;
}

.cp-front-heading--row,
.cp-front-heading--split {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 28px;
}

.cp-front-heading--split p {
	max-width: 430px;
	margin: 0 0 10px;
	color: var(--cp-muted);
	font-size: 14px;
	line-height: 1.7;
}

.cp-text-link {
	margin-bottom: 10px;
	color: var(--cp-black);
	font-size: 12px;
	font-weight: 700;
	text-decoration: underline;
	text-underline-offset: 5px;
}

.cp-text-link:hover {
	color: var(--cp-accent-dark);
}

.cp-need-strip,
.cp-sector-row,
.cp-product-rail {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(170px, 1fr);
	gap: 12px;
	overflow-x: auto;
	overscroll-behavior-inline: contain;
	scroll-snap-type: inline mandatory;
	padding-bottom: 4px;
}

.cp-sector-row {
	grid-auto-columns: minmax(260px, 1fr);
}

.cp-product-rail {
	grid-auto-columns: minmax(210px, 1fr);
}

.cp-image-card {
	position: relative;
	display: flex;
	overflow: hidden;
	min-height: 260px;
	border-radius: 8px;
	background: var(--cp-black);
	color: var(--cp-white);
	scroll-snap-align: start;
	isolation: isolate;
}

.cp-image-card::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.02) 0%, rgba(0, 0, 0, 0.72) 100%);
}

.cp-image-card img {
	position: absolute;
	inset: 0;
	z-index: -2;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 340ms ease, opacity 340ms ease;
}

.cp-image-card:hover img {
	transform: scale(1.045);
	opacity: 0.9;
}

.cp-need-card {
	aspect-ratio: 3 / 4;
	align-items: end;
	padding: 22px;
}

.cp-need-card span {
	max-width: 140px;
	font-size: 21px;
	font-weight: 700;
	line-height: 1.08;
}

.cp-need-card i {
	position: absolute;
	right: 16px;
	bottom: 16px;
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--cp-white);
	color: var(--cp-black);
	font-style: normal;
	font-weight: 700;
}

.cp-sector-card {
	min-height: 270px;
	align-items: end;
	justify-content: center;
	padding: 24px;
}

.cp-sector-card span {
	font-size: 18px;
	font-weight: 700;
	text-align: center;
}

.cp-solution-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.cp-solution-card {
	overflow: hidden;
	border: 1px solid var(--cp-line);
	border-radius: 8px;
	background: #f6f6f4;
}

.cp-solution-card__label,
.cp-solution-card__body {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cp-solution-card__label {
	border-bottom: 1px solid var(--cp-line);
	background: var(--cp-paper);
	color: var(--cp-muted);
	font-size: 10px;
	font-weight: 800;
	text-transform: uppercase;
}

.cp-solution-card__label span {
	padding: 12px 14px;
}

.cp-solution-card__label span + span,
.cp-solution-card__body div + div {
	border-left: 1px solid var(--cp-line);
}

.cp-solution-card__body img {
	width: 100%;
	aspect-ratio: 1 / 0.82;
	object-fit: cover;
	background: var(--cp-soft);
}

.cp-solution-card__body p {
	min-height: 52px;
	margin: 0;
	padding: 12px 14px 16px;
	color: var(--cp-black);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.25;
	text-align: center;
}

.cp-project-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.cp-project-card {
	min-height: 210px;
	flex-direction: column;
	justify-content: end;
	padding: 24px;
}

.cp-project-card strong {
	font-size: 16px;
}

.cp-project-card span {
	max-width: 260px;
	margin-top: 7px;
	color: rgba(255, 255, 255, 0.86);
	font-size: 13px;
	line-height: 1.45;
}

.cp-front-product {
	display: block;
	padding: 0 !important;
	border-radius: 8px;
	scroll-snap-align: start;
}

.cp-front-product .cp-product-card-item__image {
	display: block;
}

.cp-front-product .cp-product-card-item__body {
	display: block;
}

.cp-advice-section {
	background: #f7f7f5;
}

.cp-advice-header {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 28px;
	margin-bottom: 26px;
}

.cp-advice-header .cp-title-sub {
	margin-left: 0;
}

.cp-advice-controls {
	display: flex;
	gap: 8px;
}

.cp-advice-control {
	width: 42px;
	height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--cp-line);
	border-radius: 50%;
	background: var(--cp-white);
	color: var(--cp-black);
	cursor: pointer;
	transition: background var(--cp-ease), color var(--cp-ease), opacity var(--cp-ease);
}

.cp-advice-control:hover {
	background: var(--cp-black);
	color: var(--cp-white);
}

.cp-advice-control:disabled {
	opacity: 0.38;
	cursor: not-allowed;
}

.cp-advice-slider {
	overflow: hidden;
}

.cp-advice-track {
	display: flex;
	gap: 18px;
	transition: transform 280ms ease;
}

.cp-advice-slide {
	flex: 0 0 calc((100% - 36px) / 3);
	min-height: 230px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	border: 1px solid var(--cp-line);
	border-radius: 8px;
	background: var(--cp-white);
	padding: 26px;
}

.cp-advice-slide--dark {
	background: var(--cp-black);
	color: var(--cp-white);
}

.cp-advice-slide--accent {
	background: var(--cp-accent-soft);
}

.cp-advice-slide__step {
	color: var(--cp-accent-dark);
	font-size: 12px;
	font-weight: 800;
}

.cp-advice-slide--dark .cp-advice-slide__step {
	color: var(--cp-accent);
}

.cp-advice-slide h3 {
	margin: auto 0 12px;
	color: inherit;
	font-size: 22px;
	line-height: 1.1;
}

.cp-advice-slide p {
	margin: 0;
	color: var(--cp-muted);
	font-size: 13px;
	line-height: 1.6;
}

.cp-advice-slide--dark p {
	color: rgba(255, 255, 255, 0.74);
}

.cp-front-cta {
	padding-block: 0 44px;
}

.cp-front-sustain {
	padding-block: 40px;
}

.cp-front-cta__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: center;
	gap: 30px;
	padding: 44px 58px;
	border-radius: 8px;
	background: #f4f4f2;
}

.cp-front-cta h2 {
	margin: 0;
	color: var(--cp-black);
	font-size: clamp(32px, 4.2vw, 58px);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: 0;
}

.cp-front-cta p {
	max-width: 310px;
	margin: 14px 0 0;
	color: var(--cp-muted);
	font-size: 13px;
	line-height: 1.5;
	text-align: center;
}

@media (max-width: 1180px) {
	.cp-front-hero .cp-slider {
		height: 640px;
	}

	.cp-solution-grid,
	.cp-project-grid {
		grid-template-columns: 1fr;
	}

	.cp-project-card {
		min-height: 260px;
	}
}

@media (max-width: 1024px) {
	.cp-front-slide__content {
		padding-top: 58px;
	}

	.cp-front-heading--row,
	.cp-front-heading--split,
	.cp-front-cta__inner {
		display: grid;
		grid-template-columns: 1fr;
		align-items: start;
	}

	.cp-front-cta__inner {
		padding: 36px 26px;
	}

	.cp-front-cta p {
		text-align: left;
	}

	.cp-advice-header {
		display: grid;
		grid-template-columns: 1fr;
		align-items: start;
	}

	.cp-advice-slide {
		flex-basis: calc((100% - 18px) / 2);
	}
}

@media (max-width: 640px) {
	.cp-front-hero .cp-slider {
		height: 560px;
		min-height: 560px;
	}

	.cp-front-slide__media::after {
		background: linear-gradient(90deg, rgba(0, 0, 0, 0.72) 0%, rgba(0, 0, 0, 0.42) 100%);
	}

	.cp-front-slide__title {
		font-size: 42px;
	}

	.cp-front-slide__desc {
		font-size: 14px;
	}

	.cp-front-slide__actions {
		width: 100%;
	}

	.cp-front-slide__actions .cp-btn {
		width: 100%;
	}

	.cp-front-hero .cp-slider__dots {
		right: 18px;
		bottom: 22px;
	}

	.cp-front-hero__scroll {
		display: none;
	}

	.cp-front-section {
		padding-block: 48px;
	}

	.cp-need-strip,
	.cp-sector-row,
	.cp-product-rail {
		grid-auto-columns: minmax(74%, 1fr);
	}

	.cp-image-card {
		min-height: 230px;
	}

	.cp-need-card span {
		font-size: 20px;
	}

	.cp-solution-card__label {
		font-size: 8px;
	}

	.cp-advice-slide {
		flex-basis: 100%;
	}
}
