:root {
	--gp-b2b-primary: #004dff;
	--gp-b2b-primary-hover: #003bbb;
	--gp-b2b-bg: #f8f9fa;
	--gp-b2b-text: #333333;
	--gp-b2b-text-light: #666666;
	--gp-b2b-border: #e0e0e0;
	--gp-b2b-white: #ffffff;
}

.gp-b2b-container { max-width: 1440px; margin: 0 auto; padding: 0 20px; }

/* Override GeneratePress default grid-container max-width */
.grid-container { max-width: 1440px; }
.section-spacing { padding: 60px 0; }
@media (min-width: 768px) { .section-spacing { padding: 100px 0; } }

.gp-b2b-section-title { font-size: 28px; font-weight: 700; color: var(--gp-b2b-text); margin-bottom: 30px; }
.gp-b2b-btn { display: inline-block; font-weight: 600; padding: 12px 24px; border-radius: 0px; text-decoration: none; transition: 0.3s ease; border: none; font-size: 16px; cursor: pointer; text-align: center; font-family: 'Inter', sans-serif; }
.gp-b2b-btn--primary { background: var(--gp-b2b-primary); color: var(--gp-b2b-white); }
.gp-b2b-btn--secondary { background: var(--gp-b2b-text); color: var(--gp-b2b-white); }
.gp-b2b-btn--outline { border: 1px solid var(--gp-b2b-border); background: transparent; color: var(--gp-b2b-text); }
.gp-b2b-btn--block { display: block; width: 100%; }
.gp-b2b-btn--square { border-radius: 0 !important; font-family: 'Inter', sans-serif; }
.gp-b2b-btn--ghost { background: transparent; color: var(--gp-b2b-white); border: 1px solid var(--gp-b2b-white); }
.gp-b2b-btn--ghost:hover { background: rgba(255,255,255,0.1); color: var(--gp-b2b-white); border-color: var(--gp-b2b-white); }

.gp-b2b-img-placeholder { background: #eaeaea; border: 1px dashed #ccc; display: flex; align-items: center; justify-content: center; width: 100%; color: #999; }

/* Disable forced uppercase styling across frontend UI. */
.site :where(h1, h2, h3, h4, h5, h6, p, a, span, li, button, label, strong, em, small, dt, dd, th, td, input, textarea, select) {
	text-transform: none !important;
}

.site :where(input, textarea)::placeholder {
	text-transform: none !important;
}

[data-gp-b2b-image-preview],
.gp-b2b-image-preview-trigger {
	cursor: zoom-in;
}

.gp-b2b-image-preview-trigger:focus {
	outline: 2px solid var(--gp-b2b-primary);
	outline-offset: 3px;
}

body.gp-b2b-image-preview-open {
	overflow: hidden;
}

.gp-b2b-image-preview {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background: rgba(15, 23, 42, 0.82);
	backdrop-filter: blur(6px);
}

.gp-b2b-image-preview[hidden] {
	display: none;
}

.gp-b2b-image-preview__shell {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: min(1200px, calc(100vw - 48px));
	max-width: 100%;
	max-height: calc(100vh - 48px);
}

.gp-b2b-image-preview__img {
	display: block;
	max-width: 100%;
	max-height: calc(100vh - 48px);
	object-fit: contain;
	background: #ffffff;
	box-shadow: 0 24px 80px rgba(15, 23, 42, 0.35);
}

.gp-b2b-image-preview__close {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 1;
	width: 42px;
	height: 42px;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.35);
	border-radius: 999px;
	background: rgba(15, 23, 42, 0.72);
	color: #ffffff;
	font-size: 30px;
	line-height: 1;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.gp-b2b-image-preview__close:hover,
.gp-b2b-image-preview__close:focus {
	background: rgba(15, 23, 42, 0.92);
	border-color: rgba(255, 255, 255, 0.7);
}

@media (max-width: 767px) {
	.gp-b2b-image-preview {
		padding: 16px;
	}

	.gp-b2b-image-preview__shell,
	.gp-b2b-image-preview__img {
		max-height: calc(100vh - 32px);
	}

	.gp-b2b-image-preview__close {
		top: 8px;
		right: 8px;
		width: 38px;
		height: 38px;
		font-size: 26px;
	}
}
