/*
Theme Name: Garrison Portfolio
Theme URI: https://garrisonmartin.com/
Author: Garrison Martin
Description: A standalone portfolio theme with a masonry work grid, centered project pages, Font Library typography controls, and a full-screen mobile menu.
Version: 1.1.39
Requires at least: 6.4
Requires PHP: 7.4
Text Domain: garrison-portfolio
*/

:root {
	--gp-accent: #f02f2f;
	--gp-text: #111;
	--gp-background: #fff;
	--gp-border: #1d1d1d;
	--gp-body-font: "GP Stack Sans Text", "Stack Sans Text", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--gp-heading-font: "GP Cal Sans", "Cal Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--gp-ui-font: "GP Cal Sans", "Cal Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--gp-body-size: 17px;
	--gp-body-size-mobile: 14px;
	--gp-content-heading-size: 20px;
	--gp-content-heading-size-mobile: 18px;
	--gp-preview-title-size: 24px;
	--gp-preview-title-size-mobile: 18px;
	--gp-nav-size: 22px;
	--gp-nav-size-mobile: 24px;
	--gp-preview-gap-desktop: 40px;
	--gp-preview-gap-mobile: 28px;
	--gp-grid-columns: 3;
	--gp-grid-gutter: 40px;
	--gp-grid-item-width: calc((100% - 80px) / 3);
	--gp-loader-width: 180px;
	--gp-loader-space-desktop: 40px;
	--gp-loader-space-mobile: 60px;
	--gp-footer-space-desktop: 70px;
	--gp-footer-space-mobile: 50px;
	--gp-footer-border-width: 2px;
	--gp-footer-padding-top: 30px;
	--gp-footer-padding-bottom: 30px;
	--gp-mobile-menu-gutter: 18px;
	--gp-mobile-menu-nav-space: 24px;
	--gp-content-nav-space-desktop: 40px;
	--gp-content-nav-space-mobile: 30px;
	--gm-squiggle-speed: 0.75s;
	--gp-shell-width: 1348px;
	--gp-content-width: 756px;
}

* {
	box-sizing: border-box;
}

html {
	font-size: 62.5%;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	background: var(--gp-background);
	color: var(--gp-text);
	font-family: var(--gp-body-font);
	font-size: var(--gp-body-size);
	font-weight: 400;
	line-height: 1.42;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	font-synthesis: none;
}

body.gp-menu-open {
	overflow: hidden;
}

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

button,
input,
textarea,
select {
	font: inherit;
}

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

a:hover,
a:focus-visible {
	color: var(--gp-accent);
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background: #fff;
	clip: auto !important;
	clip-path: none;
	color: #000;
	display: block;
	font-size: 1.4rem;
	height: auto;
	left: 12px;
	padding: 12px 16px;
	top: 12px;
	width: auto;
	z-index: 100000;
}

.gp-shell {
	width: min(calc(100% - 76px), var(--gp-shell-width));
	margin-inline: auto;
}

.gp-content-shell {
	width: min(calc(100% - 36px), var(--gp-content-width));
	margin-inline: auto;
}

.site-header {
	position: relative;
	z-index: 1200;
	padding: 18px 0 19px;
	border-bottom: 2px dashed var(--gp-border);
	background: #fff;
}

body.gp-sticky-header .site-header {
	position: sticky;
	top: 0;
}

@media (min-width: 1020px) {
	body.gp-hide-work-menu-desktop .primary-navigation .gp-menu-item-work,
	body.gp-hide-shopify-menu-desktop .primary-navigation .gp-menu-item-shopify {
		display: none;
	}
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
}

.site-branding {
	min-width: 0;
}

.custom-logo-link,
.site-title-link {
	display: inline-block;
	text-decoration: none;
}

.custom-logo {
	width: clamp(220px, 19vw, 272px);
	max-height: 58px;
	object-fit: contain;
	object-position: left center;
}

.site-title {
	margin: 0;
	font-family: var(--gp-heading-font);
	font-size: clamp(3.4rem, 4.8vw, 6.2rem);
	font-weight: 400;
	line-height: .9;
	letter-spacing: 0;
}

.primary-navigation ul,
.mobile-navigation ul,
.reset-list-style {
	list-style: none;
	margin: 0;
	padding: 0;
}

.primary-navigation ul {
	display: flex;
	align-items: center;
	gap: 31px;
}

.primary-navigation a {
	position: relative;
	display: inline-block;
	font-family: var(--gp-ui-font);
	font-size: var(--gp-nav-size);
	line-height: 1;
	text-decoration: none;
}

.primary-navigation .current-menu-item > a,
.primary-navigation .current_page_item > a,
.primary-navigation .current-menu-ancestor > a,
.primary-navigation .current_page_parent > a,
.primary-navigation .gp-is-current > a,
.primary-navigation a[aria-current="page"] {
	color: var(--gp-accent);
}

.primary-navigation .main-menu li > a,
.primary-navigation a {
	position: relative;
	padding-bottom: 8px;
}

.primary-navigation .main-menu li > a::before,
.primary-navigation a::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 9px;
	background-color: currentColor;
	opacity: 0;
	pointer-events: none;
	transition: opacity .16s ease;
	-webkit-mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 9' preserveAspectRatio='none'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-width='2' d='M0 4.5 C2.5 .5 7.5 .5 10 4.5 S17.5 8.5 20 4.5 C22.5 .5 27.5 .5 30 4.5 S37.5 8.5 40 4.5'/%3E%3C/svg%3E");
	-webkit-mask-position: 0 100%;
	-webkit-mask-repeat: repeat-x;
	-webkit-mask-size: 40px 9px;
	mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 9' preserveAspectRatio='none'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-width='2' d='M0 4.5 C2.5 .5 7.5 .5 10 4.5 S17.5 8.5 20 4.5 C22.5 .5 27.5 .5 30 4.5 S37.5 8.5 40 4.5'/%3E%3C/svg%3E");
	mask-position: 0 100%;
	mask-repeat: repeat-x;
	mask-size: 40px 9px;
}

.primary-navigation .main-menu li > a:hover::before,
.primary-navigation .main-menu li > a:focus-visible::before,
.primary-navigation .main-menu .current-menu-item > a::before,
.primary-navigation .main-menu .current_page_item > a::before,
.primary-navigation .main-menu .current-menu-ancestor > a::before,
.primary-navigation .main-menu .current_page_parent > a::before,
.primary-navigation .main-menu .gp-is-current > a::before,
.primary-navigation .main-menu a[aria-current="page"]::before,
.primary-navigation a:hover::before,
.primary-navigation a:focus-visible::before {
	opacity: 1;
	animation: gm-squiggle-flow var(--gm-squiggle-speed) linear infinite;
}

@keyframes gm-squiggle-flow {
	from {
		-webkit-mask-position: 0 100%;
		mask-position: 0 100%;
	}
	to {
		-webkit-mask-position: -40px 100%;
		mask-position: -40px 100%;
	}
}

.menu-toggle {
	display: none;
	position: relative;
	z-index: 1500;
	width: 30px;
	height: 30px;
	padding: 7px;
	border: 0;
	background: transparent;
	color: #111;
	cursor: pointer;
}

.menu-toggle__icon {
	display: block;
	position: relative;
	width: 16px;
	height: 16px;
	margin: 0 auto;
}

.menu-toggle__bar {
	display: block;
	position: absolute;
	left: 0;
	width: 16px;
	height: 2px;
	margin: 0;
	background: currentColor;
	transform-origin: 50% 50%;
	transition: top .18s ease, transform .2s ease, opacity .12s ease;
}

.menu-toggle__bar:nth-child(1) { top: 2px; }
.menu-toggle__bar:nth-child(2) { top: 7px; }
.menu-toggle__bar:nth-child(3) { top: 12px; }

body.gp-menu-open .menu-toggle {
	color: #fff;
}

body.gp-menu-open .menu-toggle__bar:nth-child(1) {
	top: 7px;
	transform: rotate(45deg);
}

body.gp-menu-open .menu-toggle__bar:nth-child(2) {
	opacity: 0;
}

body.gp-menu-open .menu-toggle__bar:nth-child(3) {
	top: 7px;
	transform: rotate(-45deg);
}

.mobile-menu-overlay {
	position: fixed;
	inset: 0;
	z-index: 1400;
	background: #000;
	color: #fff;
	overflow-y: auto;
}

.mobile-menu-overlay[hidden] {
	display: none;
}

.mobile-menu-overlay.is-opening {
	animation: gp-fade-in .16s ease both;
}

@keyframes gp-fade-in {
	from { opacity: 0; }
	to { opacity: 1; }
}

.mobile-menu-inner {
	min-height: 100%;
	padding: 0 var(--gp-mobile-menu-gutter) 48px;
}

.mobile-menu-header {
	display: flex;
	align-items: center;
	height: 67px;
	padding-right: 48px;
	border-bottom: 2px dashed rgba(255,255,255,.09);
}

.mobile-menu-brand,
.mobile-menu-brand a {
	display: block;
}

.mobile-menu-brand img {
	width: min(58vw, 162px);
	max-height: 35px;
	object-fit: contain;
	object-position: left center;
}

.mobile-menu-brand__title {
	margin: 0;
	font-family: var(--gp-heading-font);
	font-size: clamp(3rem, 11vw, 5.2rem);
	font-weight: 400;
	line-height: .9;
	letter-spacing: 0;
}

.mobile-navigation {
	margin-top: var(--gp-mobile-menu-nav-space);
}

.mobile-navigation li + li {
	margin-top: 7px;
}

.mobile-navigation a {
	display: inline-block;
	font-family: var(--gp-ui-font);
	font-size: var(--gp-nav-size-mobile);
	line-height: 1.08;
	text-decoration: none;
}

.mobile-navigation .current-menu-item > a,
.mobile-navigation .current_page_item > a,
.mobile-navigation .current-menu-ancestor > a {
	color: #fff;
}



.site-main {
	padding: var(--gp-content-nav-space-desktop) 0 0;
}

.gp-grid {
	display: grid;
	grid-template-columns: 1fr;
	column-gap: var(--gp-grid-gutter);
	row-gap: var(--gp-preview-gap-mobile);
	position: relative;
	min-height: 1px;
}

.gp-grid-sizer,
.gp-gutter-sizer {
	display: none;
}

.gp-card {
	position: relative;
	width: 100%;
	min-width: 0;
	margin: 0;
}

.gp-card__inner {
	min-width: 0;
}

/*
 * Progressive enhancement: the page begins as a normal CSS grid. JavaScript
 * applies this class and all final positions in one synchronous layout pass,
 * so a delayed script never leaves a blank or one-column desktop page.
 */
.gp-grid.is-masonry {
	display: block;
}

.gp-grid.is-masonry .gp-card {
	margin-bottom: var(--gp-preview-gap-desktop);
	will-change: transform;
}

.gp-grid.is-masonry.is-masonry-settled .gp-card {
	transition: transform .28s cubic-bezier(.2,.75,.25,1);
}

.gp-card--incoming.is-positioning {
	visibility: hidden;
	pointer-events: none;
}

.gp-grid.is-masonry.is-masonry-settled .gp-card--incoming.is-positioning {
	transition: none !important;
}

.gp-card--incoming .gp-card__inner {
	opacity: 0;
	transform: translateY(8px);
}

.gp-card--incoming.is-revealed .gp-card__inner {
	opacity: 1;
	transform: translateY(0);
	transition:
		opacity .32s cubic-bezier(.2,.75,.25,1),
		transform .4s cubic-bezier(.2,.75,.25,1);
	transition-delay: var(--gp-reveal-delay, 0ms);
}

.gp-card__image-link {
	position: relative;
	display: block;
	overflow: hidden;
	background: #f2f2f0;
	text-decoration: none;
}

.gp-card__image-link--ratio {
	aspect-ratio: var(--gp-media-aspect);
}

.gp-card__image-link img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 0;
}

.gp-card__image-link--ratio img {
	height: 100%;
	object-fit: cover;
}

.gp-card__image-link.is-image-retrying {
	background-image: linear-gradient(110deg, #f2f2f0 8%, #fafafa 18%, #f2f2f0 33%);
	background-size: 200% 100%;
	animation: gp-image-retry 1.1s linear infinite;
}

.gp-card__image-link.is-image-error img {
	display: none;
}

@keyframes gp-image-retry {
	to { background-position-x: -200%; }
}

.gp-card__title {
	margin: 13px 0 0;
	font-family: var(--gp-heading-font);
	font-size: var(--gp-preview-title-size-mobile);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: 0;
}

.gp-card__title a {
	text-decoration: none;
}



.gp-pagination {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

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

.gp-load-more[hidden] {
	display: none;
}

.gp-loader {
	display: none;
	width: min(100%, var(--gp-loader-width));
	margin: 0 auto var(--gp-loader-space-mobile);
}

.gp-loader.is-visible {
	display: block;
}

.gp-loader img {
	width: 100%;
	height: auto;
}

.gp-pagination__status {
	margin: 10px 0 var(--gp-loader-space-mobile);
}



.entry-content {
	font-size: 1em;
}

.entry-content::after {
	content: "";
	display: table;
	clear: both;
}

.entry-content > * {
	margin-top: 0;
	margin-bottom: .8em;
}

.entry-content > :last-child {
	margin-bottom: 0;
}

.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
	font-family: var(--gp-heading-font);
	font-size: var(--gp-content-heading-size-mobile);
	font-weight: 400;
	line-height: 1.12;
	letter-spacing: 0;
}

.entry-content a {
	color: var(--gp-accent);
	text-decoration: none;
	background-image:
		linear-gradient(90deg, transparent 0 1%, currentColor 4% 96%, transparent 99%),
		linear-gradient(90deg, transparent 0 3%, currentColor 6% 94%, transparent 97%);
	background-position: 0 55%, 0 63%;
	background-repeat: no-repeat;
	background-size: 0 .12em, 0 .07em;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
	transition: background-size .24s cubic-bezier(.2,.8,.2,1), color .16s ease;
}

.entry-content a:hover,
.entry-content a:focus-visible {
	color: var(--gp-accent);
	background-size: 100% .12em, 100% .07em;
}

.entry-content figure,
.entry-content .wp-block-image,
.entry-content p:has(> img:only-child) {
	margin-top: 1.45em;
	margin-bottom: 1.45em;
}

.entry-content figure img,
.entry-content .wp-block-image img,
.entry-content p > img:only-child {
	width: 100%;
}

.entry-content .alignwide,
.entry-content .alignfull {
	width: 100%;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
}

.gp-related {
	position: relative;
	margin-top: clamp(5.2rem, 8vw, 9rem);
	padding-top: 24px;
	border-top: 2px dashed var(--gp-border);
}

.gp-related__title {
	margin: 0 0 22px;
	font-family: var(--gp-heading-font);
	font-size: var(--gp-preview-title-size-mobile);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: 0;
}

/* Floating 2010s-style back-to-top link. It appears after the reader
   reaches the related-posts area and stays outside the related section. */
.gp-back-top {
	position: fixed;
	right: clamp(18px, 4vw, 44px);
	bottom: clamp(18px, 4vw, 34px);
	z-index: 1150;
	display: inline-block;
	padding: 9px 11px 8px;
	border: 2px dashed var(--gp-border);
	background: var(--gp-background);
	color: var(--gp-text);
	font-family: var(--gp-ui-font);
	font-size: 1.3rem;
	line-height: 1;
	text-transform: uppercase;
	text-decoration: none;
	opacity: 0;
	pointer-events: none;
	transform: translateY(8px);
	transition:
		opacity .18s ease,
		transform .18s ease,
		color .16s ease,
		border-color .16s ease;
}

.gp-back-top.is-visible {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.gp-back-top:hover,
.gp-back-top:focus-visible {
	color: var(--gp-accent);
	border-color: currentColor;
}

.gp-related__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
}

.gp-related-card {
	min-width: 0;
}

.gp-related-card__image-link {
	position: relative;
	display: block;
	overflow: hidden;
	background: #f2f2f0;
	text-decoration: none;
}

.gp-related-card__image-link--ratio {
	aspect-ratio: var(--gp-related-media-aspect);
}

.gp-related-card__image-link img {
	display: block;
	width: 100%;
	height: auto;
}

.gp-related-card__image-link--ratio img {
	height: 100%;
	object-fit: cover;
}

.gp-related-card__title {
	margin: 12px 0 0;
	font-family: var(--gp-heading-font);
	font-size: var(--gp-preview-title-size-mobile);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: 0;
}

.gp-related-card__title a {
	text-decoration: none;
}


.gp-single-utility {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px 18px;
	margin-top: 3.4rem;
	font-family: var(--gp-ui-font);
	font-size: 1.5rem;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
}

.gp-single-utility a {
	position: relative;
	display: inline-block;
	padding-bottom: 8px;
	color: #676767;
	text-decoration: none;
}

.gp-single-utility a:hover,
.gp-single-utility a:focus-visible {
	color: var(--gp-accent);
}

.gp-single-utility a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 7px;
	background-color: currentColor;
	opacity: 0;
	-webkit-mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 9' preserveAspectRatio='none'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-width='2' d='M0 4.5 C2.5 .5 7.5 .5 10 4.5 S17.5 8.5 20 4.5 C22.5 .5 27.5 .5 30 4.5 S37.5 8.5 40 4.5'/%3E%3C/svg%3E");
	-webkit-mask-repeat: repeat-x;
	-webkit-mask-size: 40px 7px;
	mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 9' preserveAspectRatio='none'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-width='2' d='M0 4.5 C2.5 .5 7.5 .5 10 4.5 S17.5 8.5 20 4.5 C22.5 .5 27.5 .5 30 4.5 S37.5 8.5 40 4.5'/%3E%3C/svg%3E");
	mask-repeat: repeat-x;
	mask-size: 40px 7px;
}

.gp-single-utility a:hover::after,
.gp-single-utility a:focus-visible::after {
	opacity: 1;
	animation: gm-squiggle-flow var(--gm-squiggle-speed) linear infinite;
}

.archive-header,
.search-header,
.not-found {
	width: min(100%, var(--gp-content-width));
	margin: 16px auto 38px;
}

.archive-title,
.search-title,
.not-found__title {
	margin: 0;
	font-family: var(--gp-heading-font);
	font-size: clamp(3.4rem, 7vw, 7.2rem);
	font-weight: 400;
	line-height: .96;
	letter-spacing: 0;
}

.site-footer {
	margin-top: var(--gp-footer-space-mobile);
	border-top: var(--gp-footer-border-width) dashed var(--gp-border);
}

.site-footer__inner {
	display: flex;
	justify-content: center;
	padding-top: var(--gp-footer-padding-top);
	padding-bottom: var(--gp-footer-padding-bottom);
	font-size: 1.4rem;
	text-align: center;
}

.site-footer p {
	margin: 0;
}


@keyframes gp-marching-ants {
	to {
		background-position: 100% 100%;
	}
}

@media (hover: hover) and (pointer: fine) and (min-width: 1020px) {
	.gp-card__image-link,
	.gp-related-card__image-link {
		overflow: visible;
	}

	.gp-card__image-link::after,
	.gp-related-card__image-link::after {
		content: "";
		position: absolute;
		inset: -2px;
		z-index: 2;
		border: 2px solid transparent;
		background: repeating-linear-gradient(-45deg, var(--gp-border) 0, var(--gp-border) 25%, transparent 0, transparent 50%) 0 / .6em .6em border-box;
		opacity: 0;
		pointer-events: none;
		transition: opacity .12s ease;
		-webkit-mask: linear-gradient(#000 0 0) padding-box, linear-gradient(#000 0 0);
		-webkit-mask-composite: xor;
		mask: linear-gradient(#000 0 0) padding-box, linear-gradient(#000 0 0);
		mask-composite: exclude;
	}

	.gp-card__image-link:hover::after,
	.gp-related-card__image-link:hover::after {
		opacity: 1;
		animation: gp-marching-ants 12s linear infinite;
	}
}

@media (min-width: 650px) {
	.gp-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		row-gap: var(--gp-preview-gap-desktop);
	}


	.gp-card__title {
		font-size: var(--gp-preview-title-size);
	}


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

	.gp-related__title {
		font-size: var(--gp-preview-title-size);
	}

	.gp-related-card__title {
		font-size: var(--gp-preview-title-size);
	}

	.entry-content h1,
	.entry-content h2,
	.entry-content h3,
	.entry-content h4,
	.entry-content h5,
	.entry-content h6 {
		font-size: var(--gp-content-heading-size);
	}

	.gp-loader {
		margin-bottom: var(--gp-loader-space-desktop);
	}

	.gp-pagination__status {
		margin-bottom: var(--gp-loader-space-desktop);
	}

	.site-footer {
		margin-top: var(--gp-footer-space-desktop);
	}
}

@media (min-width: 1020px) {
	.gp-grid {
		grid-template-columns: repeat(var(--gp-grid-columns), minmax(0, 1fr));
	}

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

}

@media (max-width: 1019px) {
	body {
		font-size: var(--gp-body-size-mobile);
		line-height: 1.42;
	}

	.gp-shell {
		width: calc(100% - 32px);
	}

	.site-header {
		padding: 17px 0 16px;
	}

	.custom-logo {
		width: min(53vw, 162px);
		max-height: 34px;
	}

	.site-title {
		font-size: clamp(3rem, 11vw, 4.8rem);
	}

	.primary-navigation {
		display: none;
	}

	.menu-toggle {
		display: block;
		margin-right: -7px;
	}

	body.gp-menu-open .site-branding {
		visibility: hidden;
	}

	body.gp-menu-open .site-header {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		z-index: 1500;
		border-color: transparent;
		background: transparent;
		pointer-events: none;
	}

	body.gp-menu-open .menu-toggle {
		pointer-events: auto;
	}

	.site-main {
		padding-top: var(--gp-content-nav-space-mobile);
	}

	.gp-card__title {
		margin-top: 12px;
	}
}

@media (max-width: 649px) {

	.gp-content-shell {
		width: calc(100% - 36px);
	}

	.gp-grid,
	.gp-grid.is-masonry {
		display: grid;
		grid-template-columns: 1fr;
		height: auto !important;
	}

	.gp-grid.is-masonry .gp-card {
		position: relative !important;
		left: auto !important;
		top: auto !important;
		width: 100% !important;
		margin-bottom: 0;
		transform: none !important;
		transition: none !important;
	}

	.gp-grid {
		column-gap: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		scroll-behavior: auto !important;
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
	}
}


/* Shopify Dude answer and solution library styles. */
.gp-shopify-library-hero,
.gp-shopify-archive-hero,
.gp-article-header {
	margin-top: 14px;
}

.gp-shopify-library-hero {
	margin-bottom: clamp(3rem, 5vw, 5.2rem);
}

.gp-shopify-library-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1.32fr) minmax(280px, .68fr);
	gap: clamp(2.4rem, 4vw, 5.2rem);
	align-items: center;
	padding-bottom: clamp(2.4rem, 4vw, 4.2rem);
	border-bottom: 2px dashed var(--gp-border);
}

.gp-shopify-eyebrow,
.gp-article-eyebrow,
.gp-shopify-section-kicker,
.gp-solution-card__type,
.gp-shopify-topic-card span,
.gp-shopify-stage-card span,
.gp-shopify-lane-card span {
	margin: 0 0 .75em;
	font-family: var(--gp-ui-font);
	font-size: 1.4rem;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: .03em;
	color: var(--gp-accent);
}

.gp-shopify-title,
.gp-article-title {
	margin: 0;
	font-family: var(--gp-heading-font);
	font-size: clamp(3.8rem, 7vw, 6.8rem);
	font-weight: 400;
	line-height: .95;
	letter-spacing: 0;
}

.gp-shopify-intro,
.gp-article-dek {
	margin: 1.15em 0 0;
	font-size: clamp(1.7rem, 2vw, 2.1rem);
	line-height: 1.28;
}

.gp-shopify-intro > * {
	margin-top: 0;
	margin-bottom: .8em;
}

.gp-shopify-intro > :last-child {
	margin-bottom: 0;
}

.gp-shopify-library-hero__search {
	padding: 20px;
	border: 2px dashed var(--gp-border);
	background: #fff;
}

.gp-shopify-library-hero__search h2 {
	margin: 0 0 .45em;
	font-family: var(--gp-heading-font);
	font-size: clamp(2.4rem, 2.8vw, 3.2rem);
	font-weight: 400;
	line-height: 1;
}

.gp-shopify-library-hero__search p {
	margin: 0 0 1em;
}

.gp-shopify-search {
	display: flex;
	gap: 8px;
	align-items: stretch;
}

.gp-shopify-search input[type="search"] {
	min-width: 0;
	width: 100%;
	padding: 10px 12px;
	border: 2px dashed var(--gp-border);
	border-radius: 0;
	background: var(--gp-background);
	color: var(--gp-text);
	font-family: var(--gp-body-font);
	font-size: 1.5rem;
	line-height: 1.1;
}

.gp-shopify-search input[type="search"]:focus {
	outline: 2px solid var(--gp-accent);
	outline-offset: 2px;
}

.gp-shopify-search button,
.gp-shopify-section-link,
.gp-article-tags a,
.wp-block-group.is-style-gp-quick-answer .wp-block-button__link,
.wp-block-group.is-style-gp-solution-note .wp-block-button__link,
.wp-block-group.is-style-gp-common-misunderstanding .wp-block-button__link,
.wp-block-group.is-style-gp-test-checklist .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 12px 9px;
	border: 2px dashed var(--gp-border);
	border-radius: 0;
	background: transparent;
	color: var(--gp-text);
	font-family: var(--gp-ui-font);
	font-size: 1.3rem;
	line-height: 1;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
}

.gp-shopify-search button:hover,
.gp-shopify-search button:focus-visible,
.gp-shopify-section-link:hover,
.gp-shopify-section-link:focus-visible,
.gp-article-tags a:hover,
.gp-article-tags a:focus-visible {
	color: var(--gp-accent);
	border-color: currentColor;
}

.gp-shopify-library-section {
	margin-top: clamp(4.6rem, 7vw, 8.4rem);
}

.gp-shopify-library-section--topics {
	margin-top: 0;
}

.gp-shopify-section-heading {
	max-width: 760px;
	margin-bottom: 22px;
}

.gp-shopify-section-heading--row {
	display: flex;
	max-width: none;
	align-items: end;
	justify-content: space-between;
	gap: 20px;
}

.gp-shopify-section-heading h2,
.gp-shopify-empty-state h2 {
	margin: 0;
	font-family: var(--gp-heading-font);
	font-size: clamp(3rem, 6vw, 5.6rem);
	font-weight: 400;
	line-height: .96;
	letter-spacing: 0;
}

.gp-shopify-section-heading p:not(.gp-shopify-section-kicker),
.gp-shopify-empty-state p {
	margin: .7em 0 0;
	font-size: clamp(1.6rem, 1.8vw, 2rem);
	line-height: 1.28;
}

.gp-shopify-topic-grid,
.gp-shopify-stage-grid,
.gp-shopify-lane-grid,
.gp-solution-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.gp-solution-grid--compact {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.gp-shopify-stage-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.gp-shopify-lane-grid {
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.gp-shopify-topic-card,
.gp-shopify-stage-card,
.gp-shopify-lane-card,
.gp-solution-card__link {
	display: flex;
	min-height: 100%;
	flex-direction: column;
	padding: 18px;
	border: 2px dashed var(--gp-border);
	background: #fff;
	color: var(--gp-text);
	text-decoration: none;
	transition: color .16s ease, border-color .16s ease, transform .16s ease;
}

.gp-shopify-topic-card:hover,
.gp-shopify-topic-card:focus-visible,
.gp-shopify-stage-card:hover,
.gp-shopify-stage-card:focus-visible,
.gp-shopify-lane-card:hover,
.gp-shopify-lane-card:focus-visible,
.gp-solution-card__link:hover,
.gp-solution-card__link:focus-visible {
	color: var(--gp-accent);
	border-color: currentColor;
	transform: translateY(-2px);
}

.gp-shopify-stage-card {
	min-height: 250px;
	background: #f7f7f3;
}

.gp-shopify-stage-card:nth-child(2n) {
	background: #fff;
}

.gp-shopify-stage-card strong {
	font-size: clamp(2.8rem, 3.4vw, 4.8rem);
}

.gp-shopify-lane-card {
	min-height: 230px;
	background: #f7f7f3;
}

.gp-shopify-lane-card:nth-child(2n) {
	background: #fff;
}

.gp-shopify-lane-card strong {
	font-size: clamp(2.5rem, 2.8vw, 3.8rem);
}

.gp-shopify-lane-accordion {
	border-top: 2px dashed var(--gp-border);
}

.gp-shopify-lane-panel {
	border-bottom: 2px dashed var(--gp-border);
	background: #fff;
}

.gp-shopify-lane-panel:nth-child(2n) {
	background: #f7f7f3;
}

.gp-shopify-lane-panel summary {
	position: relative;
	display: grid;
	grid-template-columns: minmax(130px, .28fr) minmax(0, 1fr) auto;
	gap: 18px;
	align-items: center;
	padding: 18px 48px 18px 0;
	cursor: pointer;
	list-style: none;
}

.gp-shopify-lane-panel summary::-webkit-details-marker {
	display: none;
}

.gp-shopify-lane-panel summary::after {
	position: absolute;
	right: 6px;
	top: 50%;
	content: "+";
	font-family: var(--gp-ui-font);
	font-size: 2.6rem;
	line-height: 1;
	transform: translateY(-50%);
}

.gp-shopify-lane-panel[open] summary::after {
	content: "×";
}

.gp-shopify-lane-panel summary span {
	margin: 0;
	font-family: var(--gp-ui-font);
	font-size: 1.3rem;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: .03em;
	color: var(--gp-accent);
}

.gp-shopify-lane-panel summary strong {
	font-family: var(--gp-heading-font);
	font-size: clamp(2.3rem, 3.2vw, 4rem);
	font-weight: 400;
	line-height: .98;
}

.gp-shopify-lane-panel__body {
	max-width: 760px;
	padding: 0 48px 20px calc(28% + 18px);
}

.gp-shopify-lane-panel__body p {
	margin: 0 0 1em;
	font-size: clamp(1.6rem, 1.8vw, 2rem);
	line-height: 1.28;
}

.gp-shopify-topic-card strong,
.gp-shopify-stage-card strong,
.gp-shopify-lane-card strong,
.gp-solution-card__title {
	margin: 0;
	font-family: var(--gp-heading-font);
	font-size: clamp(2.3rem, 2.6vw, 3.4rem);
	font-weight: 400;
	line-height: .98;
	letter-spacing: 0;
}

.gp-shopify-topic-card em,
.gp-shopify-stage-card em,
.gp-shopify-lane-card em,
.gp-solution-card__excerpt {
	display: block;
	margin: .9em 0 0;
	color: var(--gp-text);
	font-style: normal;
	font-size: 1.5rem;
	line-height: 1.28;
}

.gp-solution-card__link {
	position: relative;
}

.gp-solution-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: auto;
	padding-top: 18px;
}

.gp-solution-card__tags span {
	display: inline-block;
	padding: 5px 7px 4px;
	border: 1px dashed currentColor;
	font-family: var(--gp-ui-font);
	font-size: 1.1rem;
	line-height: 1;
	text-transform: uppercase;
	color: #666;
}

.gp-solution-card__link:hover .gp-solution-card__tags span,
.gp-solution-card__link:focus-visible .gp-solution-card__tags span {
	color: var(--gp-accent);
}

.gp-shopify-empty-state {
	padding: clamp(2.4rem, 4vw, 4rem);
	border: 2px dashed var(--gp-border);
}

.gp-shopify-archive-hero {
	margin-bottom: clamp(3rem, 6vw, 5.8rem);
}

.gp-shopify-archive-hero .gp-shell {
	padding-bottom: clamp(2.8rem, 5vw, 5rem);
	border-bottom: 2px dashed var(--gp-border);
}

.gp-shopify-archive-hero .gp-shopify-search {
	max-width: 580px;
	margin-top: 2.2rem;
}

.gp-article-header {
	width: min(calc(100% - 36px), 920px);
	margin-inline: auto;
	margin-bottom: clamp(2.8rem, 5vw, 4.8rem);
	text-align: center;
}

.gp-article-title {
	font-size: clamp(4rem, 9vw, 7.6rem);
}

.gp-article-tags {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin-top: 2rem;
}

.gp-article-header + .entry-content {
	margin-top: 0;
}

.entry--shopify .entry-content h2 {
	margin-top: 1.35em;
	padding-top: .75em;
	border-top: 2px dashed var(--gp-border);
}

.entry--shopify .entry-content h2:first-child {
	margin-top: 0;
	padding-top: 0;
	border-top: 0;
}

.wp-block-group.is-style-gp-quick-answer,
.wp-block-group.is-style-gp-solution-note,
.wp-block-group.is-style-gp-common-misunderstanding,
.wp-block-group.is-style-gp-test-checklist,
.entry--shopify .entry-content .gp-answer-box,
.entry--shopify .entry-content .gp-solution-note,
.entry--shopify .entry-content .gp-common-misunderstanding,
.entry--shopify .entry-content .gp-test-checklist {
	margin: 1.35em 0;
	padding: 18px;
	border: 2px dashed var(--gp-border);
}

.wp-block-group.is-style-gp-quick-answer,
.entry--shopify .entry-content .gp-answer-box {
	border-color: var(--gp-accent);
}

.wp-block-group.is-style-gp-common-misunderstanding,
.entry--shopify .entry-content .gp-common-misunderstanding {
	background: #f7f7f3;
}

.wp-block-group.is-style-gp-test-checklist,
.entry--shopify .entry-content .gp-test-checklist {
	border-style: solid;
}

.wp-block-group.is-style-gp-quick-answer > :first-child,
.wp-block-group.is-style-gp-solution-note > :first-child,
.wp-block-group.is-style-gp-common-misunderstanding > :first-child,
.wp-block-group.is-style-gp-test-checklist > :first-child,
.entry--shopify .entry-content .gp-answer-box > :first-child,
.entry--shopify .entry-content .gp-solution-note > :first-child,
.entry--shopify .entry-content .gp-common-misunderstanding > :first-child,
.entry--shopify .entry-content .gp-test-checklist > :first-child {
	margin-top: 0;
}

.wp-block-group.is-style-gp-quick-answer > :last-child,
.wp-block-group.is-style-gp-solution-note > :last-child,
.wp-block-group.is-style-gp-common-misunderstanding > :last-child,
.wp-block-group.is-style-gp-test-checklist > :last-child,
.entry--shopify .entry-content .gp-answer-box > :last-child,
.entry--shopify .entry-content .gp-solution-note > :last-child,
.entry--shopify .entry-content .gp-common-misunderstanding > :last-child,
.entry--shopify .entry-content .gp-test-checklist > :last-child {
	margin-bottom: 0;
}

.entry--shopify .entry-content ol,
.entry--shopify .entry-content ul {
	padding-left: 1.25em;
}

.entry--shopify .entry-content li + li {
	margin-top: .25em;
}

.entry--shopify .entry-content code {
	font-size: .92em;
}

.entry--shopify .entry-content pre {
	overflow-x: auto;
	padding: 16px;
	border: 2px dashed var(--gp-border);
	background: #f7f7f3;
}

.navigation.pagination {
	margin-top: 3.4rem;
	font-family: var(--gp-ui-font);
	font-size: 1.4rem;
	text-align: center;
	text-transform: uppercase;
}

.navigation.pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
}

.navigation.pagination a,
.navigation.pagination span {
	display: inline-block;
	padding: 8px 10px 7px;
	border: 2px dashed var(--gp-border);
	text-decoration: none;
}

.navigation.pagination .current,
.navigation.pagination a:hover,
.navigation.pagination a:focus-visible {
	color: var(--gp-accent);
	border-color: currentColor;
}

@media (max-width: 1190px) {
	.gp-shopify-topic-grid,
	.gp-shopify-stage-grid,
	.gp-shopify-lane-grid,
	.gp-solution-grid,
	.gp-solution-grid--compact {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 780px) {
	.gp-shopify-library-hero__inner {
		grid-template-columns: 1fr;
		align-items: start;
	}

	.gp-shopify-lane-panel summary {
		display: block;
		padding-right: 42px;
	}

	.gp-shopify-lane-panel summary strong {
		display: block;
		margin-top: .35em;
	}

	.gp-shopify-lane-panel__body {
		padding-right: 42px;
		padding-left: 0;
	}

	.gp-shopify-search {
		flex-direction: column;
	}

	.gp-shopify-section-heading--row {
		display: block;
	}

	.gp-shopify-section-link {
		margin-top: 1.4rem;
	}

	.gp-shopify-topic-grid,
	.gp-shopify-stage-grid,
	.gp-shopify-lane-grid,
	.gp-solution-grid,
	.gp-solution-grid--compact {
		grid-template-columns: 1fr;
	}
}


/* Breadcrumbs, article media, and source-friendly article polish. */
.gp-breadcrumbs {
	margin-top: 0;
	margin-bottom: clamp(2.4rem, 4vw, 4.4rem);
	font-family: var(--gp-ui-font);
	font-size: 1.25rem;
	line-height: 1.2;
	text-transform: uppercase;
}

.gp-breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
	align-items: center;
	margin: 0;
	padding: 0;
	list-style: none;
}

.gp-breadcrumbs li {
	display: inline-flex;
	align-items: center;
	gap: 7px;
}

.gp-breadcrumbs li + li::before {
	content: "/";
	color: var(--gp-accent);
}

.gp-breadcrumbs a {
	color: inherit;
	text-decoration: none;
}

.gp-breadcrumbs a:hover,
.gp-breadcrumbs a:focus-visible {
	color: var(--gp-accent);
}

.gp-breadcrumbs [aria-current="page"] {
	color: #666;
}

.gp-article-meta {
	margin-top: 1.4rem;
	font-family: var(--gp-ui-font);
	font-size: 1.25rem;
	line-height: 1.2;
	text-transform: uppercase;
	color: #666;
}

.gp-article-featured-image {
	margin: clamp(2.4rem, 4vw, 4rem) auto 0;
}

.gp-article-featured-image img {
	display: block;
	width: 100%;
	height: auto;
	border: 2px dashed var(--gp-border);
}

.gp-solution-card__media {
	display: block;
	margin: -18px -18px 16px;
	border-bottom: 2px dashed var(--gp-border);
	background: #f7f7f3;
}

.gp-solution-card__media img {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 10;
	height: auto;
	object-fit: cover;
}

/* Backward compatibility for early Shopify Dude imports that used older block style class names. */
.entry--shopify .entry-content .is-style-quick-answer-box,
.entry--shopify .entry-content .is-style-solution-note,
.entry--shopify .entry-content .is-style-common-misunderstanding,
.entry--shopify .entry-content .is-style-test-checklist {
	margin: 1.35em 0;
	padding: 18px;
	border: 2px dashed var(--gp-border);
}

.entry--shopify .entry-content .is-style-quick-answer-box {
	border-color: var(--gp-accent);
}

.entry--shopify .entry-content .is-style-common-misunderstanding,
.entry--shopify .entry-content .is-style-solution-note {
	background: #f7f7f3;
}

.entry--shopify .entry-content .is-style-test-checklist {
	border-style: solid;
}

.entry--shopify .entry-content .is-style-quick-answer-box > :first-child,
.entry--shopify .entry-content .is-style-solution-note > :first-child,
.entry--shopify .entry-content .is-style-common-misunderstanding > :first-child,
.entry--shopify .entry-content .is-style-test-checklist > :first-child {
	margin-top: 0;
}

.entry--shopify .entry-content .is-style-quick-answer-box > :last-child,
.entry--shopify .entry-content .is-style-solution-note > :last-child,
.entry--shopify .entry-content .is-style-common-misunderstanding > :last-child,
.entry--shopify .entry-content .is-style-test-checklist > :last-child {
	margin-bottom: 0;
}

.entry--shopify .entry-content h2 + p,
.entry--shopify .entry-content h3 + p {
	margin-top: .45em;
}

.entry--shopify .entry-content a[href^="http"]:not([href*="garrisonmartin.com"])::after {
	content: " ↗";
	font-size: .82em;
}

.entry--shopify .entry-content h2[id] {
	scroll-margin-top: 120px;
}

@media (max-width: 780px) {
	.gp-breadcrumbs {
		margin-bottom: 2.4rem;
		font-size: 1.15rem;
	}

	.gp-article-meta {
		font-size: 1.15rem;
	}
}

/* Shopify Dude v1.1.30: answer-library article cues. */
.gp-article-info-row {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(130px, .55fr) minmax(150px, .55fr);
	gap: 10px;
	margin: clamp(2rem, 3vw, 3rem) auto 0;
	text-align: left;
}

.gp-article-info-row > div {
	padding: 12px 14px;
	border: 2px dashed var(--gp-border);
	background: #fff;
}

.gp-article-info-row span,
.gp-article-toc > p {
	display: block;
	margin: 0 0 .45em;
	font-family: var(--gp-ui-font);
	font-size: 1.15rem;
	line-height: 1;
	letter-spacing: .03em;
	text-transform: uppercase;
	color: var(--gp-accent);
}

.gp-article-info-row strong {
	display: block;
	font-family: var(--gp-body-font);
	font-size: 1.35rem;
	font-weight: 400;
	line-height: 1.25;
	color: var(--gp-text);
}

.gp-article-toc {
	width: min(calc(100% - 36px), 760px);
	margin: 0 auto clamp(2.4rem, 4vw, 4rem);
	padding: 18px 20px;
	border: 2px dashed var(--gp-border);
	background: #fff;
}

.gp-article-toc ol {
	display: grid;
	gap: 7px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.gp-article-toc a {
	color: var(--gp-text);
	text-decoration: none;
}

.gp-article-toc a:hover,
.gp-article-toc a:focus-visible {
	color: var(--gp-accent);
}

.gp-article-toc__item--level-3 {
	padding-left: 1.15em;
	font-size: .95em;
}

.entry--shopify .entry-content .gp-answer-box,
.entry--shopify .entry-content .is-style-quick-answer-box,
.entry--shopify .entry-content .is-style-gp-quick-answer,
.entry--shopify .entry-content .wp-block-group.is-style-quick-answer-box,
.entry--shopify .entry-content .wp-block-group.is-style-gp-quick-answer {
	padding: clamp(1.8rem, 3vw, 2.6rem);
	border: 3px solid var(--gp-accent);
	background: #fff;
	box-shadow: 8px 8px 0 #f7f7f3;
}

.entry--shopify .entry-content .gp-solution-note,
.entry--shopify .entry-content .is-style-solution-note,
.entry--shopify .entry-content .is-style-gp-solution-note,
.entry--shopify .entry-content .wp-block-group.is-style-solution-note,
.entry--shopify .entry-content .wp-block-group.is-style-gp-solution-note {
	background: #f7f7f3;
}

.entry--shopify .entry-content .gp-common-misunderstanding,
.entry--shopify .entry-content .is-style-common-misunderstanding,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding,
.entry--shopify .entry-content .wp-block-group.is-style-common-misunderstanding,
.entry--shopify .entry-content .wp-block-group.is-style-gp-common-misunderstanding {
	border-left: 8px solid var(--gp-accent);
	background: #f7f7f3;
}

.entry--shopify .entry-content .gp-test-checklist,
.entry--shopify .entry-content .is-style-test-checklist,
.entry--shopify .entry-content .is-style-gp-test-checklist,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist {
	border-style: solid;
	background: #fff;
}

.entry--shopify .entry-content .gp-sources-box,
.entry--shopify .entry-content .is-style-sources-box,
.entry--shopify .entry-content .wp-block-group.is-style-sources-box {
	margin: clamp(3rem, 5vw, 5rem) 0 0;
	padding: 18px;
	border-top: 3px solid var(--gp-border);
	border-bottom: 2px dashed var(--gp-border);
	background: #fff;
}

.entry--shopify .entry-content .gp-answer-box h2,
.entry--shopify .entry-content .gp-solution-note h2,
.entry--shopify .entry-content .gp-common-misunderstanding h2,
.entry--shopify .entry-content .gp-test-checklist h2,
.entry--shopify .entry-content .gp-sources-box h2,
.entry--shopify .entry-content .is-style-quick-answer-box h2,
.entry--shopify .entry-content .is-style-solution-note h2,
.entry--shopify .entry-content .is-style-common-misunderstanding h2,
.entry--shopify .entry-content .is-style-test-checklist h2,
.entry--shopify .entry-content .is-style-sources-box h2,
.entry--shopify .entry-content .is-style-gp-quick-answer h2,
.entry--shopify .entry-content .is-style-gp-solution-note h2,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding h2,
.entry--shopify .entry-content .is-style-gp-test-checklist h2 {
	margin-top: 0;
	padding-top: 0;
	border-top: 0;
}

.entry--shopify .entry-content .gp-answer-box h2,
.entry--shopify .entry-content .is-style-quick-answer-box h2,
.entry--shopify .entry-content .is-style-gp-quick-answer h2 {
	font-size: clamp(2.4rem, 3vw, 3.4rem);
}

@media (max-width: 700px) {
	.gp-article-info-row {
		grid-template-columns: 1fr;
	}

	.gp-article-toc {
		width: min(calc(100% - 28px), 760px);
	}
}


/* Shopify Dude v1.1.33: calmer library and article layout. */
.gp-shopify-library-hero {
	margin-bottom: clamp(3.2rem, 5vw, 5.8rem);
}

.gp-shopify-library-hero__inner {
	align-items: start;
	padding-bottom: clamp(2rem, 3.2vw, 3.4rem);
}

.gp-shopify-library-hero .gp-shopify-title {
	font-size: clamp(3.4rem, 5.6vw, 5.8rem);
}

.gp-shopify-library-hero .gp-shopify-intro {
	max-width: 780px;
	font-size: clamp(1.55rem, 1.55vw, 1.85rem);
	line-height: 1.34;
}

.gp-shopify-section-heading h2,
.gp-shopify-empty-state h2 {
	font-size: clamp(3.2rem, 5.4vw, 5.7rem);
}

.gp-shopify-library-section--topics {
	margin-top: clamp(4.2rem, 6vw, 7rem);
}

.gp-shopify-library-section--answers {
	margin-top: clamp(5rem, 7vw, 8.4rem);
}

.gp-shopify-load-more {
	margin: 2.2rem 0 0;
	text-align: right;
}

.gp-shopify-library-section--formats {
	margin-top: clamp(4rem, 6vw, 7rem);
}

.gp-shopify-format-strip {
	display: grid;
	grid-template-columns: minmax(180px, .3fr) minmax(0, 1fr);
	gap: 20px;
	align-items: start;
	padding-top: 20px;
	border-top: 2px dashed var(--gp-border);
}

.gp-shopify-format-strip h2 {
	margin: 0;
	font-family: var(--gp-heading-font);
	font-size: clamp(2.6rem, 4vw, 4.2rem);
	font-weight: 400;
	line-height: .98;
}

.gp-shopify-format-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.gp-shopify-format-links a {
	display: inline-flex;
	gap: 8px;
	align-items: baseline;
	padding: 10px 12px;
	border: 2px dashed var(--gp-border);
	background: #fff;
	text-decoration: none;
}

.gp-shopify-format-links a:hover,
.gp-shopify-format-links a:focus-visible {
	color: var(--gp-accent);
	border-color: currentColor;
}

.gp-shopify-format-links span {
	font-family: var(--gp-ui-font);
	font-size: 1.05rem;
	line-height: 1;
	letter-spacing: .03em;
	text-transform: uppercase;
	color: var(--gp-accent);
}

.gp-shopify-format-links strong {
	font-family: var(--gp-heading-font);
	font-size: 1.75rem;
	font-weight: 400;
	line-height: 1;
}

.gp-article-header {
	width: min(calc(100% - 36px), 760px);
	margin-bottom: clamp(2.2rem, 4vw, 3.8rem);
}

.gp-article-title {
	font-size: clamp(3.6rem, 6.6vw, 6.1rem);
	line-height: .98;
}

.gp-article-dek {
	font-size: clamp(1.55rem, 1.7vw, 1.95rem);
	line-height: 1.33;
}

.gp-article-tags {
	margin-top: 1.5rem;
}

.gp-article-info-row {
	grid-template-columns: 1.2fr .62fr .62fr;
	gap: 8px;
	margin-top: clamp(1.6rem, 2.4vw, 2.4rem);
}

.gp-article-info-row > div,
.gp-article-toc {
	border: 1px dashed var(--gp-border);
}

.gp-article-toc {
	margin-bottom: clamp(2rem, 3vw, 3.2rem);
	padding: 16px 18px;
}

.entry--shopify .entry-content h2 {
	margin-top: 1.55em;
	padding-top: 0;
	border-top: 0;
}

.entry--shopify .entry-content h2::before {
	content: "";
	display: block;
	width: 100%;
	margin: 0 0 .75em;
	border-top: 1px dashed var(--gp-border);
}

.entry--shopify .entry-content h2:first-child::before,
.entry--shopify .entry-content .gp-answer-box h2::before,
.entry--shopify .entry-content .gp-solution-note h2::before,
.entry--shopify .entry-content .gp-common-misunderstanding h2::before,
.entry--shopify .entry-content .gp-test-checklist h2::before,
.entry--shopify .entry-content .gp-sources-box h2::before,
.entry--shopify .entry-content .is-style-quick-answer-box h2::before,
.entry--shopify .entry-content .is-style-solution-note h2::before,
.entry--shopify .entry-content .is-style-common-misunderstanding h2::before,
.entry--shopify .entry-content .is-style-test-checklist h2::before,
.entry--shopify .entry-content .is-style-sources-box h2::before,
.entry--shopify .entry-content .is-style-gp-quick-answer h2::before,
.entry--shopify .entry-content .is-style-gp-solution-note h2::before,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding h2::before,
.entry--shopify .entry-content .is-style-gp-test-checklist h2::before {
	display: none;
}

.entry--shopify .entry-content .gp-answer-box,
.entry--shopify .entry-content .is-style-quick-answer-box,
.entry--shopify .entry-content .is-style-gp-quick-answer,
.entry--shopify .entry-content .wp-block-group.is-style-quick-answer-box,
.entry--shopify .entry-content .wp-block-group.is-style-gp-quick-answer {
	padding: clamp(1.6rem, 2.6vw, 2.3rem);
	border: 1px solid var(--gp-border);
	border-left: 6px solid var(--gp-accent);
	background: #fafaf7;
	box-shadow: none;
}

.entry--shopify .entry-content .gp-common-misunderstanding,
.entry--shopify .entry-content .is-style-common-misunderstanding,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding,
.entry--shopify .entry-content .wp-block-group.is-style-common-misunderstanding,
.entry--shopify .entry-content .wp-block-group.is-style-gp-common-misunderstanding {
	border: 1px dashed var(--gp-border);
	border-left: 6px solid var(--gp-accent);
	background: #f7f7f3;
}

.entry--shopify .entry-content .gp-test-checklist,
.entry--shopify .entry-content .is-style-test-checklist,
.entry--shopify .entry-content .is-style-gp-test-checklist,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist {
	border: 1px solid var(--gp-border);
	background: #fff;
}

@media (max-width: 780px) {
	.gp-shopify-format-strip {
		grid-template-columns: 1fr;
	}

	.gp-shopify-format-links {
		display: grid;
		grid-template-columns: 1fr;
	}

	.gp-shopify-load-more {
		text-align: left;
	}
}

/* Shopify Dude v1.1.33: tighter article scale and stronger related-answer cards. */
.gp-article-title {
	font-size: clamp(3.4rem, 5.2vw, 5rem);
	line-height: .98;
}

.gp-related--shopify {
	margin-top: clamp(4.6rem, 7vw, 7.6rem);
	padding-top: clamp(2.4rem, 3.8vw, 3.8rem);
}

.gp-related__heading-row {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 18px;
	margin-bottom: 20px;
}

.gp-related__eyebrow {
	margin: 0 0 .65em;
	font-family: var(--gp-ui-font);
	font-size: 1.25rem;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: .03em;
	color: var(--gp-accent);
}

.gp-related--shopify .gp-related__title {
	margin: 0;
	font-size: clamp(2.8rem, 4.2vw, 4.4rem);
	line-height: .98;
}

.gp-related__browse {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 12px 9px;
	border: 2px dashed var(--gp-border);
	font-family: var(--gp-ui-font);
	font-size: 1.25rem;
	line-height: 1;
	text-transform: uppercase;
	text-decoration: none;
	white-space: nowrap;
}

.gp-related__browse:hover,
.gp-related__browse:focus-visible {
	color: var(--gp-accent);
	border-color: currentColor;
}

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

.gp-related__solution-grid .gp-solution-card__link {
	min-height: 100%;
	padding: 16px;
	background: #fff;
}

.gp-related__solution-grid .gp-solution-card__title {
	font-size: clamp(2.2rem, 2.4vw, 3rem);
}

.gp-related__solution-grid .gp-solution-card__excerpt {
	font-size: 1.42rem;
	line-height: 1.3;
}

.gp-related__solution-grid .gp-solution-card__tags {
	padding-top: 16px;
}

.gp-shopify-context .gp-single-utility {
	margin-top: 2.4rem;
}

.gp-shopify-context .gp-single-utility a {
	padding: 9px 11px 8px;
	border: 1px dashed var(--gp-border);
	font-size: 1.25rem;
}

.gp-shopify-context .gp-single-utility a:hover,
.gp-shopify-context .gp-single-utility a:focus-visible {
	border-color: currentColor;
}

.gp-shopify-context .gp-single-utility a::after {
	display: none;
}

@media (max-width: 900px) {
	.gp-related__solution-grid {
		grid-template-columns: 1fr;
	}

	.gp-related__heading-row {
		align-items: start;
		flex-direction: column;
	}
}


/* Shopify Dude v1.1.34: Claude review pass — single-column hero, stronger stage cards, calmer article system. */
.gp-shopify-library-hero__inner {
	display: block;
	max-width: 900px;
	padding-bottom: clamp(2.8rem, 4vw, 4.2rem);
}

.gp-shopify-library-hero .gp-shopify-title {
	font-size: clamp(3.8rem, 6.2vw, 6rem);
}

.gp-shopify-library-hero .gp-shopify-intro {
	max-width: 760px;
	font-size: clamp(1.6rem, 1.5vw, 1.95rem);
	line-height: 1.38;
}

.gp-shopify-credential {
	margin: 1.2rem 0 2rem;
	font-family: var(--gp-ui-font);
	font-size: 1.35rem;
	line-height: 1.25;
	color: #555;
}

.gp-shopify-credential strong {
	color: var(--gp-text);
	font-weight: 400;
}

.gp-shopify-library-hero__search {
	max-width: 640px;
	margin-top: 2rem;
	padding: 0;
	border: 0;
	background: transparent;
}

.gp-shopify-library-hero__search h2 {
	margin-bottom: .35em;
	font-size: clamp(2.4rem, 3vw, 3.4rem);
}

.gp-shopify-library-hero__search p {
	max-width: 520px;
	margin-bottom: 1rem;
	font-size: 1.45rem;
	line-height: 1.35;
	color: #555;
}

.gp-shopify-search {
	max-width: 620px;
	gap: 0;
}

.gp-shopify-search input[type="search"] {
	border: 1px solid var(--gp-border);
	border-right: 0;
	padding: 11px 13px;
	background: #fafaf7;
}

.gp-shopify-search button {
	border: 1px solid var(--gp-border);
	background: var(--gp-text);
	color: #fff;
	padding-inline: 16px;
}

.gp-shopify-search button:hover,
.gp-shopify-search button:focus-visible {
	background: var(--gp-accent);
	color: #fff;
	border-color: var(--gp-accent);
}

.gp-shopify-eyebrow,
.gp-article-eyebrow,
.gp-shopify-section-kicker,
.gp-solution-card__type,
.gp-shopify-topic-card span,
.gp-shopify-stage-card span,
.gp-shopify-lane-card span {
	font-size: 1.55rem;
	font-weight: 400;
	letter-spacing: .035em;
}

.gp-shopify-library-section {
	margin-top: clamp(4.8rem, 6vw, 7.6rem);
}

.gp-shopify-library-section--stages {
	margin-top: clamp(4.8rem, 6vw, 7rem);
}

.gp-shopify-library-section--topics {
	margin-top: clamp(5rem, 7vw, 8.5rem);
}

.gp-shopify-section-heading {
	margin-bottom: 24px;
}

.gp-shopify-section-heading h2,
.gp-shopify-empty-state h2 {
	font-size: clamp(3.1rem, 5.1vw, 5.2rem);
}

.gp-shopify-section-heading p:not(.gp-shopify-section-kicker),
.gp-shopify-empty-state p {
	font-size: clamp(1.55rem, 1.55vw, 1.85rem);
	line-height: 1.36;
}

.gp-shopify-stage-grid {
	gap: 16px;
}

.gp-shopify-stage-card {
	position: relative;
	min-height: 225px;
	padding: 22px 18px 18px;
	border: 1px solid var(--gp-border);
	background: #fff;
	overflow: hidden;
}

.gp-shopify-stage-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 5px;
	background: var(--gp-border);
}

.gp-shopify-stage-card--1::before { background: #2563eb; }
.gp-shopify-stage-card--2::before { background: #16823a; }
.gp-shopify-stage-card--3::before { background: #c06a00; }
.gp-shopify-stage-card--4::before { background: #c92525; }

.gp-shopify-stage-card--1 span { color: #2563eb; }
.gp-shopify-stage-card--2 span { color: #16823a; }
.gp-shopify-stage-card--3 span { color: #c06a00; }
.gp-shopify-stage-card--4 span { color: #c92525; }

.gp-shopify-stage-card strong {
	font-size: clamp(2.8rem, 3.1vw, 4.2rem);
}

.gp-shopify-stage-card em {
	font-size: 1.45rem;
	line-height: 1.35;
}

.gp-shopify-stage-card b {
	display: block;
	margin-top: auto;
	padding-top: 1.4rem;
	font-family: var(--gp-ui-font);
	font-size: 1.25rem;
	line-height: 1;
	font-weight: 400;
	text-transform: uppercase;
	color: #666;
}

.gp-shopify-stage-card:hover b,
.gp-shopify-stage-card:focus-visible b {
	color: var(--gp-accent);
}

.gp-shopify-topic-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.gp-shopify-topic-card {
	padding: 18px;
	border: 1px solid var(--gp-border);
	background: #fafaf7;
}

.gp-shopify-topic-card strong {
	font-size: clamp(2.3rem, 2.45vw, 3.2rem);
}

.gp-shopify-topic-card em {
	font-size: 1.42rem;
	line-height: 1.34;
	color: #333;
}

.gp-shopify-topic-card--featured {
	border-color: #85b7eb;
	background: #f1f7fc;
}

.gp-shopify-topic-card--featured span,
.gp-shopify-topic-card--featured strong {
	color: #185fa5;
}

.gp-solution-card__tags span,
.gp-article-tags a {
	font-size: 1.15rem;
	border-style: solid;
	color: #333;
}

.gp-shopify-context .entry-content a[href^="http"]:not([href*="garrisonmartin.com"]) {
	color: inherit;
	text-decoration-color: var(--gp-accent);
	text-decoration-thickness: 1px;
	text-underline-offset: .18em;
}

.gp-shopify-context .entry-content a[href^="http"]:not([href*="garrisonmartin.com"]):hover,
.gp-shopify-context .entry-content a[href^="http"]:not([href*="garrisonmartin.com"]):focus-visible {
	color: var(--gp-accent);
}

.gp-article-eyebrow {
	color: #555;
}

.gp-article-title {
	font-size: clamp(3.5rem, 5.4vw, 5rem);
}

.gp-article-dek {
	max-width: 720px;
	margin-inline: auto;
}

.gp-article-info-row > div {
	border: 1px solid var(--gp-border);
}

.gp-article-toc {
	border: 1px dashed var(--gp-border);
	background: #fff;
}

.entry--shopify .entry-content h2 {
	margin-top: 1.75em;
	padding-top: 1.05em;
	border-top: 1px solid rgba(0,0,0,.2);
	font-size: clamp(2.2rem, 2.6vw, 3rem);
}

.entry--shopify .entry-content h2::before {
	display: none;
}

.entry--shopify .entry-content h3 {
	margin-top: 1.35em;
	font-size: clamp(1.8rem, 2vw, 2.3rem);
}

.entry--shopify .entry-content .gp-answer-box,
.entry--shopify .entry-content .is-style-quick-answer-box,
.entry--shopify .entry-content .is-style-gp-quick-answer,
.entry--shopify .entry-content .wp-block-group.is-style-quick-answer-box,
.entry--shopify .entry-content .wp-block-group.is-style-gp-quick-answer {
	position: relative;
	padding: clamp(1.7rem, 2.6vw, 2.4rem);
	border: 1px solid var(--gp-border);
	border-left: 5px solid var(--gp-border);
	background: #f7f7f3;
}

.entry--shopify .entry-content .gp-answer-box::before,
.entry--shopify .entry-content .is-style-quick-answer-box::before,
.entry--shopify .entry-content .is-style-gp-quick-answer::before,
.entry--shopify .entry-content .wp-block-group.is-style-quick-answer-box::before,
.entry--shopify .entry-content .wp-block-group.is-style-gp-quick-answer::before {
	content: "TL;DR";
	display: block;
	margin-bottom: .65em;
	font-family: var(--gp-ui-font);
	font-size: 1.2rem;
	line-height: 1;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: #666;
}

.entry--shopify .entry-content .gp-answer-box h2,
.entry--shopify .entry-content .is-style-quick-answer-box h2,
.entry--shopify .entry-content .is-style-gp-quick-answer h2 {
	font-size: clamp(2.2rem, 2.4vw, 3rem);
}

.entry--shopify .entry-content .gp-common-misunderstanding,
.entry--shopify .entry-content .is-style-common-misunderstanding,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding,
.entry--shopify .entry-content .wp-block-group.is-style-common-misunderstanding,
.entry--shopify .entry-content .wp-block-group.is-style-gp-common-misunderstanding {
	border: 1px solid #d99022;
	border-left: 5px solid #d99022;
	background: #fbf0df;
}

.entry--shopify .entry-content .gp-common-misunderstanding::before,
.entry--shopify .entry-content .is-style-common-misunderstanding::before,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding::before,
.entry--shopify .entry-content .wp-block-group.is-style-common-misunderstanding::before,
.entry--shopify .entry-content .wp-block-group.is-style-gp-common-misunderstanding::before {
	content: "Common misunderstanding";
	display: block;
	margin-bottom: .65em;
	font-family: var(--gp-ui-font);
	font-size: 1.2rem;
	line-height: 1;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: #854f0b;
}

.entry--shopify .entry-content .gp-test-checklist,
.entry--shopify .entry-content .is-style-test-checklist,
.entry--shopify .entry-content .is-style-gp-test-checklist,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist {
	border: 1px solid #7fad39;
	border-left: 5px solid #7fad39;
	background: #eef6e4;
}

.entry--shopify .entry-content .gp-test-checklist::before,
.entry--shopify .entry-content .is-style-test-checklist::before,
.entry--shopify .entry-content .is-style-gp-test-checklist::before,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist::before,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist::before {
	content: "How to test this";
	display: block;
	margin-bottom: .65em;
	font-family: var(--gp-ui-font);
	font-size: 1.2rem;
	line-height: 1;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: #3f7011;
}

.entry--shopify .entry-content .gp-test-checklist ul,
.entry--shopify .entry-content .is-style-test-checklist ul,
.entry--shopify .entry-content .is-style-gp-test-checklist ul,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist ul,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist ul {
	list-style: none;
	padding-left: 0;
}

.entry--shopify .entry-content .gp-test-checklist li,
.entry--shopify .entry-content .is-style-test-checklist li,
.entry--shopify .entry-content .is-style-gp-test-checklist li,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist li,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist li {
	position: relative;
	padding-left: 1.25em;
}

.entry--shopify .entry-content .gp-test-checklist li::before,
.entry--shopify .entry-content .is-style-test-checklist li::before,
.entry--shopify .entry-content .is-style-gp-test-checklist li::before,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist li::before,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist li::before {
	content: "→";
	position: absolute;
	left: 0;
	color: #3f7011;
}

.entry--shopify .entry-content .gp-common-misunderstanding > h2:first-child,
.entry--shopify .entry-content .gp-test-checklist > h2:first-child,
.entry--shopify .entry-content .gp-answer-box > h2:first-child,
.entry--shopify .entry-content .is-style-common-misunderstanding > h2:first-child,
.entry--shopify .entry-content .is-style-test-checklist > h2:first-child,
.entry--shopify .entry-content .is-style-quick-answer-box > h2:first-child,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding > h2:first-child,
.entry--shopify .entry-content .is-style-gp-test-checklist > h2:first-child,
.entry--shopify .entry-content .is-style-gp-quick-answer > h2:first-child {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
	border: 0;
}

.gp-related--shopify {
	border-top: 1px solid rgba(0,0,0,.25);
}

@media (max-width: 1190px) {
	.gp-shopify-topic-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 780px) {
	.gp-shopify-library-hero__search {
		max-width: none;
	}

	.gp-shopify-search {
		gap: 8px;
	}

	.gp-shopify-search input[type="search"] {
		border-right: 1px solid var(--gp-border);
	}

	.gp-shopify-topic-grid,
	.gp-shopify-stage-grid {
		grid-template-columns: 1fr;
	}
}


/* Shopify Dude v1.1.35: unify landing width, restore dashed card language, remove featured fill. */
.gp-shopify-library-hero__inner {
	max-width: none;
}

.gp-shopify-library-hero__copy {
	max-width: 920px;
}

.gp-shopify-stage-card,
.gp-shopify-topic-card {
	border: 2px dashed var(--gp-border);
	background: #fff;
}

.gp-shopify-stage-card::before {
	top: -2px;
	left: -2px;
	right: -2px;
	height: 5px;
}

.gp-shopify-stage-card:hover,
.gp-shopify-stage-card:focus-visible,
.gp-shopify-topic-card:hover,
.gp-shopify-topic-card:focus-visible {
	border-color: var(--gp-accent);
	color: var(--gp-accent);
	transform: none;
}

.gp-shopify-stage-card:hover em,
.gp-shopify-stage-card:focus-visible em,
.gp-shopify-topic-card:hover em,
.gp-shopify-topic-card:focus-visible em {
	color: var(--gp-text);
}

.gp-shopify-topic-card--featured {
	border-color: var(--gp-border);
	background: #fff;
}

.gp-shopify-topic-card--featured span,
.gp-shopify-topic-card--featured strong {
	color: inherit;
}

.gp-shopify-topic-card--featured span {
	color: var(--gp-accent);
}

.gp-shopify-library-section--stages,
.gp-shopify-library-section--topics,
.gp-shopify-library-section--answers,
.gp-shopify-library-section--formats {
	width: 100%;
}

.gp-shopify-format-links a,
.gp-solution-card__link {
	border-style: dashed;
}


/* Shopify Dude v1.1.36: design system foundation.
   Keep the Garrison dashed language, but make the library components consistent. */
:root {
	--gp-ds-surface: #fff;
	--gp-ds-surface-soft: #fafaf7;
	--gp-ds-text-muted: #555;
	--gp-ds-rule: 2px dashed var(--gp-border);
	--gp-ds-rule-light: 1px dashed var(--gp-border);
	--gp-ds-card-pad: clamp(1.6rem, 2vw, 2.2rem);
	--gp-ds-section-gap: clamp(5.2rem, 7vw, 8.8rem);
	--gp-ds-section-gap-tight: clamp(3.8rem, 5.5vw, 6.4rem);
	--gp-ds-grid-gap: clamp(1.4rem, 1.8vw, 1.8rem);
	--gp-ds-text-measure: 780px;
	--gp-ds-hero-measure: 920px;
	--gp-stage-launch: #2563eb;
	--gp-stage-grow: #16823a;
	--gp-stage-optimize: #c06a00;
	--gp-stage-scale: #c92525;
	--gp-callout-warning-bg: #fff6e8;
	--gp-callout-warning-border: #c06a00;
	--gp-callout-warning-text: #804700;
	--gp-callout-action-bg: #f3faef;
	--gp-callout-action-border: #4b7d22;
	--gp-callout-action-text: #3f7011;
}

/* Page shell rules */
.gp-shopify-library-hero__inner,
.gp-shopify-library-section > .gp-shell {
	width: min(calc(100% - 76px), var(--gp-shell-width));
	margin-inline: auto;
}

.gp-shopify-library-hero__inner {
	max-width: none;
}

.gp-shopify-library-hero__copy {
	width: min(100%, var(--gp-ds-hero-measure));
	max-width: var(--gp-ds-hero-measure);
}

.gp-shopify-library-section {
	margin-top: var(--gp-ds-section-gap);
}

.gp-shopify-library-section--stages,
.gp-shopify-library-section--topics {
	margin-top: var(--gp-ds-section-gap-tight);
}

.gp-shopify-library-hero__inner,
.gp-shopify-format-strip {
	border-bottom: var(--gp-ds-rule);
}

/* Typography scale rules */
.gp-shopify-eyebrow,
.gp-shopify-section-kicker,
.gp-solution-card__type,
.gp-shopify-topic-card span,
.gp-shopify-stage-card span,
.gp-shopify-format-links span {
	font-family: var(--gp-ui-font);
	font-size: clamp(1.15rem, .9vw, 1.35rem);
	line-height: 1;
	letter-spacing: .035em;
	text-transform: uppercase;
	color: var(--gp-accent);
}

.gp-shopify-title {
	font-size: clamp(4rem, 5.8vw, 6rem);
	line-height: .98;
}

.gp-shopify-intro {
	max-width: var(--gp-ds-text-measure);
	font-size: clamp(1.65rem, 1.55vw, 1.95rem);
	line-height: 1.36;
}

.gp-shopify-credential {
	margin: 1rem 0 2.2rem;
	font-family: var(--gp-body-font);
	font-size: 1.35rem;
	line-height: 1.35;
	color: var(--gp-ds-text-muted);
}

.gp-shopify-credential strong {
	font-family: var(--gp-body-font);
	font-weight: 600;
	color: var(--gp-text);
}

.gp-shopify-section-heading {
	max-width: var(--gp-ds-text-measure);
	margin-bottom: clamp(1.8rem, 2.2vw, 2.8rem);
}

.gp-shopify-section-heading h2,
.gp-shopify-empty-state h2 {
	font-size: clamp(3.2rem, 5.2vw, 5.4rem);
	line-height: .98;
}

.gp-shopify-section-heading p:not(.gp-shopify-section-kicker),
.gp-shopify-empty-state p {
	font-size: clamp(1.55rem, 1.55vw, 1.85rem);
	line-height: 1.36;
}

/* Card system: dashed is structural. Color is an accent, never a full topic-card fill. */
.gp-shopify-stage-grid,
.gp-shopify-topic-grid,
.gp-solution-grid,
.gp-solution-grid--compact,
.gp-related__solution-grid {
	gap: var(--gp-ds-grid-gap);
}

.gp-shopify-stage-card,
.gp-shopify-topic-card,
.gp-solution-card__link,
.gp-shopify-format-links a,
.gp-related__browse,
.gp-shopify-section-link {
	border: var(--gp-ds-rule);
	background: var(--gp-ds-surface);
	box-shadow: none;
}

.gp-shopify-stage-card,
.gp-shopify-topic-card,
.gp-solution-card__link {
	padding: var(--gp-ds-card-pad);
}

.gp-shopify-stage-card,
.gp-shopify-topic-card {
	min-height: 100%;
}

.gp-shopify-stage-card::before {
	top: -2px;
	left: -2px;
	right: -2px;
	height: 5px;
}

.gp-shopify-stage-card--1::before { background: var(--gp-stage-launch); }
.gp-shopify-stage-card--2::before { background: var(--gp-stage-grow); }
.gp-shopify-stage-card--3::before { background: var(--gp-stage-optimize); }
.gp-shopify-stage-card--4::before { background: var(--gp-stage-scale); }
.gp-shopify-stage-card--1 span { color: var(--gp-stage-launch); }
.gp-shopify-stage-card--2 span { color: var(--gp-stage-grow); }
.gp-shopify-stage-card--3 span { color: var(--gp-stage-optimize); }
.gp-shopify-stage-card--4 span { color: var(--gp-stage-scale); }

.gp-shopify-topic-card--featured,
.gp-shopify-topic-card--featured span,
.gp-shopify-topic-card--featured strong {
	background: var(--gp-ds-surface);
	border-color: var(--gp-border);
	color: inherit;
}

.gp-shopify-topic-card--featured span {
	color: var(--gp-accent);
}

.gp-shopify-stage-card:hover,
.gp-shopify-stage-card:focus-visible,
.gp-shopify-topic-card:hover,
.gp-shopify-topic-card:focus-visible,
.gp-solution-card__link:hover,
.gp-solution-card__link:focus-visible,
.gp-shopify-format-links a:hover,
.gp-shopify-format-links a:focus-visible {
	color: var(--gp-accent);
	border-color: currentColor;
	transform: none;
}

.gp-shopify-stage-card:hover em,
.gp-shopify-stage-card:focus-visible em,
.gp-shopify-topic-card:hover em,
.gp-shopify-topic-card:focus-visible em,
.gp-solution-card__link:hover .gp-solution-card__excerpt,
.gp-solution-card__link:focus-visible .gp-solution-card__excerpt {
	color: var(--gp-text);
}

.gp-shopify-stage-card strong {
	font-size: clamp(2.8rem, 3.1vw, 4.2rem);
}

.gp-shopify-topic-card strong {
	font-size: clamp(2.4rem, 2.5vw, 3.2rem);
}

.gp-shopify-stage-card em,
.gp-shopify-topic-card em,
.gp-solution-card__excerpt {
	color: #333;
}

/* Search is an input component, so it stays solid instead of dashed. */
.gp-shopify-library-hero__search {
	max-width: 640px;
	margin-top: 2rem;
	padding: 0;
	border: 0;
	background: transparent;
}

.gp-shopify-search input[type="search"] {
	border: 1px solid var(--gp-border);
	border-right: 0;
	background: var(--gp-ds-surface-soft);
}

.gp-shopify-search button {
	border: 1px solid var(--gp-border);
	background: var(--gp-text);
	color: #fff;
}

/* Article callout system: three roles, three treatments. */
.entry--shopify .entry-content .gp-answer-box,
.entry--shopify .entry-content .is-style-quick-answer-box,
.entry--shopify .entry-content .is-style-gp-quick-answer,
.entry--shopify .entry-content .wp-block-group.is-style-quick-answer-box,
.entry--shopify .entry-content .wp-block-group.is-style-gp-quick-answer {
	border: 1px solid var(--gp-border);
	border-left: 5px solid var(--gp-border);
	background: var(--gp-ds-surface-soft);
}

.entry--shopify .entry-content .gp-common-misunderstanding,
.entry--shopify .entry-content .is-style-common-misunderstanding,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding,
.entry--shopify .entry-content .wp-block-group.is-style-common-misunderstanding,
.entry--shopify .entry-content .wp-block-group.is-style-gp-common-misunderstanding {
	border: 1px solid var(--gp-callout-warning-border);
	border-left: 5px solid var(--gp-callout-warning-border);
	background: var(--gp-callout-warning-bg);
}

.entry--shopify .entry-content .gp-common-misunderstanding::before,
.entry--shopify .entry-content .is-style-common-misunderstanding::before,
.entry--shopify .entry-content .is-style-gp-common-misunderstanding::before,
.entry--shopify .entry-content .wp-block-group.is-style-common-misunderstanding::before,
.entry--shopify .entry-content .wp-block-group.is-style-gp-common-misunderstanding::before {
	color: var(--gp-callout-warning-text);
}

.entry--shopify .entry-content .gp-test-checklist,
.entry--shopify .entry-content .is-style-test-checklist,
.entry--shopify .entry-content .is-style-gp-test-checklist,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist {
	border: 1px solid var(--gp-callout-action-border);
	background: var(--gp-callout-action-bg);
}

.entry--shopify .entry-content .gp-test-checklist::before,
.entry--shopify .entry-content .is-style-test-checklist::before,
.entry--shopify .entry-content .is-style-gp-test-checklist::before,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist::before,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist::before,
.entry--shopify .entry-content .gp-test-checklist li::before,
.entry--shopify .entry-content .is-style-test-checklist li::before,
.entry--shopify .entry-content .is-style-gp-test-checklist li::before,
.entry--shopify .entry-content .wp-block-group.is-style-test-checklist li::before,
.entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist li::before {
	color: var(--gp-callout-action-text);
}

/* Compact responsive grid rules. */
@media (max-width: 1190px) {
	.gp-shopify-topic-grid,
	.gp-solution-grid,
	.gp-solution-grid--compact {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 780px) {
	.gp-shopify-library-hero__inner,
	.gp-shopify-library-section > .gp-shell {
		width: min(calc(100% - 36px), var(--gp-shell-width));
	}

	.gp-shopify-stage-grid,
	.gp-shopify-topic-grid,
	.gp-solution-grid,
	.gp-solution-grid--compact,
	.gp-related__solution-grid {
		grid-template-columns: 1fr;
	}

	.gp-shopify-search {
		gap: 8px;
	}

	.gp-shopify-search input[type="search"] {
		border-right: 1px solid var(--gp-border);
	}
}

/* Shopify Dude v1.1.38: hand-drawn library polish inspired by the landing mockups. */
:root {
	--gp-doodle-font: "Patrick Hand", "Comic Sans MS", "Segoe Print", cursive;
	--gp-doodle-red: #f52323;
	--gp-stage-launch: #2563eb;
	--gp-stage-grow: #16823a;
	--gp-stage-optimize: #f06f0b;
	--gp-stage-scale: #f52323;
}

/* Hero becomes a designed two-column panel, not a narrow text column. */
.gp-shopify-library-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, .9fr) minmax(260px, .62fr);
	gap: clamp(3rem, 6vw, 8rem);
	align-items: center;
	padding-bottom: clamp(3.4rem, 5vw, 5.4rem);
}

.gp-shopify-library-hero__copy {
	width: 100%;
	max-width: 720px;
}

.gp-shopify-hero-art {
	position: relative;
	justify-self: end;
	width: min(100%, 480px);
	margin: 0;
}

.gp-shopify-hero-art img {
	display: block;
	width: 100%;
	height: auto;
}

.gp-shopify-hero-art::after {
	content: "Real answers. No fluff.";
	position: absolute;
	right: 2%;
	bottom: 6%;
	max-width: 18ch;
	padding: .65rem .9rem .55rem;
	border: 2px dashed var(--gp-border);
	background: rgba(255,255,255,.94);
	font-family: var(--gp-doodle-font);
	font-size: clamp(1.6rem, 1.9vw, 2.3rem);
	line-height: .95;
	letter-spacing: .02em;
	transform: rotate(-4deg);
	box-shadow: 0 8px 20px rgba(0,0,0,.08);
}

.gp-shopify-title {
	position: relative;
	display: inline-block;
	text-decoration-line: underline;
	text-decoration-style: wavy;
	text-decoration-color: var(--gp-doodle-red);
	text-decoration-thickness: .055em;
	text-underline-offset: .16em;
}

.gp-shopify-eyebrow,
.gp-shopify-section-kicker {
	font-family: var(--gp-doodle-font);
	font-size: clamp(1.55rem, 1.25vw, 1.9rem);
	letter-spacing: .045em;
}

.gp-shopify-credential {
	font-size: 1.45rem;
	margin-top: 1.3rem;
}

.gp-shopify-credential strong {
	text-decoration-line: underline;
	text-decoration-style: wavy;
	text-decoration-color: var(--gp-doodle-red);
	text-decoration-thickness: .1em;
	text-underline-offset: .19em;
}

.gp-shopify-library-hero__search {
	margin-top: clamp(2.8rem, 3vw, 3.8rem);
}

.gp-shopify-library-hero__search h2 {
	font-size: clamp(2.8rem, 3.2vw, 4.2rem);
}

.gp-shopify-search {
	max-width: 700px;
}

.gp-shopify-search input[type="search"] {
	min-height: 5rem;
	padding-left: 4.6rem;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23666666' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: 1.55rem 50%;
	background-size: 2rem 2rem;
}

.gp-shopify-search button {
	min-height: 5rem;
	padding-inline: 2.4rem;
}

/* Stage cards are primary navigation: dashed, colored, icon-led, clearly clickable. */
.gp-shopify-stage-card {
	position: relative;
	min-height: 220px;
	padding: clamp(2rem, 2.2vw, 2.8rem);
	overflow: hidden;
	border-width: 2px;
	border-style: dashed;
	background: #fff;
}

.gp-shopify-stage-card::before {
	top: -2px;
	left: -2px;
	right: -2px;
	height: 4px;
}

.gp-shopify-stage-card::after {
	content: "";
	position: absolute;
	right: clamp(1.4rem, 1.8vw, 2rem);
	top: clamp(1.8rem, 2vw, 2.6rem);
	width: clamp(4rem, 4.2vw, 5.8rem);
	height: clamp(4rem, 4.2vw, 5.8rem);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	opacity: .95;
}

.gp-shopify-stage-card--1 { border-color: var(--gp-stage-launch); }
.gp-shopify-stage-card--2 { border-color: var(--gp-stage-grow); }
.gp-shopify-stage-card--3 { border-color: var(--gp-stage-optimize); }
.gp-shopify-stage-card--4 { border-color: var(--gp-stage-scale); }

.gp-shopify-stage-card--1::after { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none' stroke='%232563eb' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M34 8c12 3 19 10 22 22L37 49 15 27 34 8Z'/%3E%3Cpath d='M19 32 8 43l13-2m11 4-2 13 11-11'/%3E%3Ccircle cx='39' cy='25' r='5'/%3E%3Cpath d='M15 49c6-1 10-4 12-10'/%3E%3C/svg%3E"); }
.gp-shopify-stage-card--2::after { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none' stroke='%2316823a' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 50h48'/%3E%3Cpath d='M14 50V35h8v15m8 0V25h8v25m8 0V14h8v36'/%3E%3Cpath d='M14 29c9 1 18-3 25-14l5 5 8-11'/%3E%3C/svg%3E"); }
.gp-shopify-stage-card--3::after { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none' stroke='%23f06f0b' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M28 8h8l2 8 7 3 7-4 5 7-5 6 1 8 7 5-3 8-8-1-6 5-1 8h-8l-3-8-7-3-7 4-5-7 5-6-1-8-7-5 3-8 8 1 6-5 1-8Z'/%3E%3Ccircle cx='32' cy='32' r='8'/%3E%3C/svg%3E"); }
.gp-shopify-stage-card--4::after { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none' stroke='%23f52323' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 48 25 32l10 9 20-25'/%3E%3Cpath d='M43 16h12v12'/%3E%3C/svg%3E"); }

.gp-shopify-stage-card span {
	font-family: var(--gp-ui-font);
	font-size: clamp(1.2rem, 1vw, 1.35rem);
	letter-spacing: .045em;
}

.gp-shopify-stage-card strong {
	max-width: calc(100% - 6rem);
}

.gp-shopify-stage-card em {
	max-width: 20ch;
}

.gp-shopify-stage-card b {
	margin-top: auto;
	font-family: var(--gp-ui-font);
	font-size: 1.25rem;
	text-transform: none;
	letter-spacing: .01em;
}

.gp-shopify-stage-card--1 b { color: var(--gp-stage-launch); }
.gp-shopify-stage-card--2 b { color: var(--gp-stage-grow); }
.gp-shopify-stage-card--3 b { color: var(--gp-stage-optimize); }
.gp-shopify-stage-card--4 b { color: var(--gp-stage-scale); }

/* Topic and answer cards get the mockup's explicit arrow affordance. */
.gp-shopify-topic-card,
.gp-solution-card__link {
	position: relative;
	padding-right: clamp(4.6rem, 5vw, 5.8rem);
}

.gp-shopify-topic-card::after,
.gp-solution-card__link::after {
	content: "→";
	position: absolute;
	right: clamp(1.6rem, 1.8vw, 2.2rem);
	bottom: clamp(1.4rem, 1.8vw, 2rem);
	font-family: var(--gp-heading-font);
	font-size: 2.6rem;
	line-height: 1;
	color: var(--gp-text);
	transition: transform .16s ease, color .16s ease;
}

.gp-shopify-topic-card:hover::after,
.gp-shopify-topic-card:focus-visible::after,
.gp-solution-card__link:hover::after,
.gp-solution-card__link:focus-visible::after {
	color: var(--gp-accent);
	transform: translateX(4px);
}

.gp-shopify-topic-card--featured,
.gp-shopify-topic-card--featured span,
.gp-shopify-topic-card--featured strong {
	background: #fff;
}

.gp-shopify-topic-card--featured {
	border-color: var(--gp-border);
}

/* Answer cards from the mockups: roomy, readable, with slightly stronger labels. */
.gp-solution-card__type {
	font-size: clamp(1.1rem, .9vw, 1.25rem);
}

.gp-solution-card__title {
	font-size: clamp(2.35rem, 2.3vw, 3.3rem);
}

.gp-solution-card__tags span {
	font-size: 1.08rem;
	border-style: solid;
	border-color: #999;
	color: #333;
}

/* Answer type chips are compact tools, not another giant card grid. */
.gp-shopify-format-strip {
	display: grid;
	grid-template-columns: minmax(190px, .28fr) minmax(0, 1fr);
	gap: clamp(2rem, 4vw, 4rem);
	align-items: start;
	padding-block: clamp(2.6rem, 4vw, 4.6rem);
}

.gp-shopify-format-links {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.2rem;
}

.gp-shopify-format-links a {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: center;
	gap: .9rem 1.1rem;
	padding: 1.1rem 1.3rem;
	min-height: 0;
}

.gp-shopify-format-links a::before {
	content: "▣";
	grid-row: 1 / span 2;
	font-family: var(--gp-doodle-font);
	font-size: 2.6rem;
	line-height: 1;
	color: var(--gp-text);
}

.gp-shopify-format-links a:nth-child(1)::before { content: "▤"; }
.gp-shopify-format-links a:nth-child(2)::before { content: "!?"; }
.gp-shopify-format-links a:nth-child(3)::before { content: "✓"; }
.gp-shopify-format-links a:nth-child(4)::before { content: "⚖"; }
.gp-shopify-format-links a:nth-child(5)::before { content: "⚒"; }
.gp-shopify-format-links a:nth-child(6)::before { content: "⌕"; }

.gp-shopify-format-links span {
	font-size: 1rem;
	line-height: 1;
}

.gp-shopify-format-links strong {
	font-size: clamp(1.35rem, 1.15vw, 1.65rem);
	line-height: 1.05;
}

/* Keep the whole Shopify landing page breathing as one continuous system. */
.gp-shopify-library-section--stages,
.gp-shopify-library-section--topics {
	margin-top: clamp(4.2rem, 5.5vw, 7rem);
}

.gp-shopify-section-heading--row {
	max-width: none;
}

.gp-shopify-section-link,
.gp-shopify-load-more a {
	font-size: 1.15rem;
}

@media (max-width: 1020px) {
	.gp-shopify-library-hero__inner {
		grid-template-columns: 1fr;
	}
	.gp-shopify-hero-art {
		justify-self: start;
		width: min(100%, 390px);
		margin-top: -1rem;
	}
	.gp-shopify-format-strip {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 780px) {
	.gp-shopify-title {
		text-decoration-thickness: .045em;
	}
	.gp-shopify-hero-art {
		display: none;
	}
	.gp-shopify-stage-card strong {
		max-width: calc(100% - 5rem);
	}
	.gp-shopify-format-links {
		grid-template-columns: 1fr;
	}
	.gp-shopify-search input[type="search"] {
		padding-left: 4.2rem;
	}
}


/* Shopify Dude v1.1.38: simplify hero accents and make hero art optional. */
:root {
	--gp-doodle-font: var(--gp-ui-font);
}

.gp-shopify-library-hero__inner.has-no-hero-art {
	display: block;
}

.gp-shopify-library-hero__inner.has-no-hero-art .gp-shopify-library-hero__copy {
	max-width: 760px;
}

.gp-shopify-title {
	text-decoration: none;
}

.gp-shopify-credential strong {
	text-decoration: none;
}

.gp-shopify-eyebrow,
.gp-shopify-section-kicker {
	font-family: var(--gp-ui-font);
	font-size: clamp(1.25rem, 1vw, 1.45rem);
	letter-spacing: .035em;
}

.gp-shopify-hero-art::after {
	content: none;
}

.gp-shopify-hero-art {
	width: min(100%, 440px);
}

.gp-shopify-stage-card::after,
.gp-shopify-format-links a::before {
	font-family: var(--gp-ui-font);
}

/* Shopify Dude v1.1.39: article polish after landing-page system lockup. */
.gp-sticky-header .gp-back-top {
	display: none !important;
}

.gp-shopify-context .gp-breadcrumbs {
	margin-bottom: clamp(2rem, 3vw, 3.4rem);
}

.gp-shopify-context .entry--shopify {
	margin-top: 0;
}

.gp-shopify-context .gp-article-header {
	padding-bottom: clamp(1.6rem, 3vw, 2.8rem);
}

.gp-shopify-context .gp-article-eyebrow {
	color: var(--gp-accent);
	font-size: clamp(1.25rem, .95vw, 1.45rem);
}

.gp-shopify-context .gp-article-dek {
	font-size: clamp(1.65rem, 1.55vw, 2rem);
	line-height: 1.32;
}

.gp-shopify-context .gp-article-tags a,
.gp-shopify-context .gp-solution-card__tags span {
	border: 1px solid #777;
	background: #fff;
	line-height: 1;
}

.gp-shopify-context .gp-article-info-row > div,
.gp-shopify-context .gp-article-toc,
.gp-shopify-context .gp-related__browse,
.gp-shopify-context .gp-single-utility a {
	border-style: dashed;
	border-width: 2px;
}

.gp-shopify-context .entry--shopify .entry-content {
	font-size: clamp(1.6rem, 1.28vw, 1.78rem);
	line-height: 1.55;
}

.gp-shopify-context .entry--shopify .entry-content h2 {
	font-size: clamp(2.55rem, 2.7vw, 3.35rem);
	line-height: 1.08;
}

.gp-shopify-context .entry--shopify .entry-content h3 {
	font-size: clamp(2rem, 1.9vw, 2.45rem);
	line-height: 1.15;
}

.gp-shopify-context .entry--shopify .entry-content .gp-answer-box,
.gp-shopify-context .entry--shopify .entry-content .is-style-quick-answer-box,
.gp-shopify-context .entry--shopify .entry-content .is-style-gp-quick-answer,
.gp-shopify-context .entry--shopify .entry-content .wp-block-group.is-style-quick-answer-box,
.gp-shopify-context .entry--shopify .entry-content .wp-block-group.is-style-gp-quick-answer {
	border-width: 2px;
	border-left-width: 6px;
	box-shadow: none;
}

.gp-shopify-context .entry--shopify .entry-content .gp-common-misunderstanding,
.gp-shopify-context .entry--shopify .entry-content .is-style-common-misunderstanding,
.gp-shopify-context .entry--shopify .entry-content .is-style-gp-common-misunderstanding,
.gp-shopify-context .entry--shopify .entry-content .wp-block-group.is-style-common-misunderstanding,
.gp-shopify-context .entry--shopify .entry-content .wp-block-group.is-style-gp-common-misunderstanding,
.gp-shopify-context .entry--shopify .entry-content .gp-test-checklist,
.gp-shopify-context .entry--shopify .entry-content .is-style-test-checklist,
.gp-shopify-context .entry--shopify .entry-content .is-style-gp-test-checklist,
.gp-shopify-context .entry--shopify .entry-content .wp-block-group.is-style-test-checklist,
.gp-shopify-context .entry--shopify .entry-content .wp-block-group.is-style-gp-test-checklist {
	border-width: 2px;
	border-left-width: 6px;
}

.gp-shopify-context .gp-related--shopify {
	border-top: 2px dashed var(--gp-border);
}

.gp-shopify-context .gp-single-utility {
	display: flex;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
}
