/*
Theme Name: Jersey Custom Store
Theme URI: https://example.com/jersey-custom-store
Author: Jersey Custom Store
Author URI: https://example.com
Description: Soccer jersey store theme with responsive layout, WooCommerce, and inline SVG customization. PHP 7.4+. No page builder dependency.
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jersey-custom-store
Tags: e-commerce, woocommerce, custom-menu, featured-images, full-width-template, translation-ready

Jersey Custom Store stylesheet.
Breakpoints:
- Mobile: max-width 47.9375rem (767px)
- Tablet: 48rem - 74.9375rem (768px - 1199px)
- Desktop: min-width 75rem (1200px)
*/

/* -------------------------------------------------------------------------
   CSS variables and root typography (fluid clamp + rem layout)
   ------------------------------------------------------------------------- */
:root {
	--jc-color-bg: #0f1419;
	--jc-color-surface: #1a222d;
	--jc-color-surface-2: #232d3b;
	--jc-color-text: #e8edf2;
	--jc-color-muted: #9aa5b5;
	--jc-color-accent: #00c853;
	--jc-color-accent-hover: #00e676;
	--jc-color-danger: #ff5252;
	--jc-color-border: rgba(255, 255, 255, 0.08);
	--jc-font-sans: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", sans-serif;
	--jc-radius: 0.5rem;
	--jc-header-h: clamp(3.5rem, 12vw, 4.5rem);
	--jc-safe-bottom: env(safe-area-inset-bottom, 0rem);
	--jc-safe-top: env(safe-area-inset-top, 0rem);
	--jc-container: min(92vw, 72rem);
	--jc-shadow: 0 0.25rem 1.25rem rgba(0, 0, 0, 0.35);
}

html {
	font-size: clamp(14px, 2.8vw, 16px);
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

@media (min-width: 75rem) {
	html {
		font-size: 100%;
	}
}

/* -------------------------------------------------------------------------
   
   ------------------------------------------------------------------------- */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html, body {
	margin: 0;
	padding: 0;
	min-height: 100%;
}

body {
	font-family: var(--jc-font-sans);
	background: var(--jc-color-bg);
	color: var(--jc-color-text);
	line-height: 1.55;
	padding-top: var(--jc-safe-top);
	padding-bottom: 0;
}

img, svg, video {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--jc-color-accent);
	text-decoration: none;
	transition: color 0.2s ease, opacity 0.2s ease;
}

a:hover,
a:focus-visible {
	color: var(--jc-color-accent-hover);
}

a:focus-visible {
	outline: 2px solid var(--jc-color-accent);
	outline-offset: 2px;
}

button, input, select, textarea {
	font: inherit;
	color: inherit;
}

ul, ol {
	margin: 0;
	padding-left: 1.25rem;
}

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 0.75em;
	line-height: 1.2;
	font-weight: 600;
}

p {
	margin: 0 0 1em;
}

/* -------------------------------------------------------------------------
   Layout container (fluid padding; width from CSS variables)
   ------------------------------------------------------------------------- */
.jc-container {
	width: var(--jc-container);
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(0.75rem, 4vw, 1.5rem);
	padding-right: clamp(0.75rem, 4vw, 1.5rem);
}

.jc-screen-reader-text {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

/* -------------------------------------------------------------------------
   Top announcement bar
   ------------------------------------------------------------------------- */
.jc-topbar {
	background: var(--jc-color-surface);
	border-bottom: 1px solid var(--jc-color-border);
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	text-align: center;
	padding: 0.35rem clamp(0.5rem, 3vw, 1rem);
}

/* -------------------------------------------------------------------------
   Site header (sticky, blur)
   ------------------------------------------------------------------------- */
.jc-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(15, 20, 25, 0.92);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-bottom: 1px solid var(--jc-color-border);
	min-height: var(--jc-header-h);
	padding-top: var(--jc-safe-top);
}

.jc-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: clamp(0.5rem, 2vw, 1.5rem);
	min-height: calc(var(--jc-header-h) - var(--jc-safe-top));
}

.jc-logo {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 700;
	font-size: clamp(1rem, 4vw, 1.25rem);
	color: var(--jc-color-text);
	white-space: nowrap;
}

.jc-logo:hover {
	color: var(--jc-color-accent);
}

.jc-logo-mark {
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--jc-color-accent), #00695c);
	flex-shrink: 0;
}

/* Primary navigation (desktop / tablet) */
.jc-nav-primary {
	display: none;
	flex: 1;
	justify-content: center;
}

.jc-nav-primary ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: clamp(0.25rem, 1.5vw, 1.25rem);
	justify-content: center;
	align-items: center;
}

.jc-nav-primary a {
	color: var(--jc-color-text);
	padding: 0.35rem 0.5rem;
	border-radius: var(--jc-radius);
}

.jc-nav-primary a:hover,
.jc-nav-primary .current-menu-item > a {
	color: var(--jc-color-accent);
}

/* Secondary nav + more menu (tablet) */
.jc-nav-secondary-wrap {
	display: none;
}

.jc-header-actions {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-shrink: 0;
}

.jc-header-search {
	display: flex;
	align-items: stretch;
	flex: 0 1 auto;
	min-width: 0;
	max-width: min(18rem, 42vw);
	margin-left: auto;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface);
	overflow: hidden;
}

.jc-header-search-input {
	flex: 1 1 auto;
	min-width: 0;
	border: 0;
	background: transparent;
	color: var(--jc-color-text);
	padding: 0.4rem 0.5rem;
	font: inherit;
}

.jc-header-search-input::placeholder {
	color: var(--jc-color-muted);
}

.jc-header-search-input:focus {
	outline: none;
}

.jc-header-search-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	flex-shrink: 0;
	border: 0;
	border-left: 1px solid var(--jc-color-border);
	background: var(--jc-color-surface-2);
	color: var(--jc-color-muted);
	cursor: pointer;
	transition: color 0.2s, background 0.2s;
}

.jc-header-search-submit:hover,
.jc-header-search-submit:focus-visible {
	color: var(--jc-color-accent);
	background: var(--jc-color-surface);
}

.jc-fallback-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: clamp(0.25rem, 1.5vw, 1.25rem);
	justify-content: center;
	align-items: center;
}

.jc-fallback-menu a {
	color: var(--jc-color-text);
	padding: 0.35rem 0.5rem;
	border-radius: var(--jc-radius);
}

.jc-fallback-menu a:hover {
	color: var(--jc-color-accent);
}

.jc-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface);
	color: var(--jc-color-text);
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s;
}

.jc-icon-btn:hover,
.jc-icon-btn:focus-visible {
	background: var(--jc-color-surface-2);
	border-color: var(--jc-color-accent);
}

/* Header cart (matches .jc-icon-btn height) */
.jc-header-cart {
	display: inline-flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	gap: 0.4rem;
	min-height: 2.5rem;
	padding: 0 0.65rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface);
	color: var(--jc-color-text);
	text-decoration: none;
	white-space: nowrap;
	transition: background 0.2s, border-color 0.2s;
}

.jc-header-cart:hover,
.jc-header-cart:focus-visible {
	background: var(--jc-color-surface-2);
	border-color: var(--jc-color-accent);
	outline: none;
}

.jc-header-cart__icon {
	display: flex;
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	color: var(--jc-color-text);
}

.jc-header-cart__icon svg {
	display: block;
	width: 100%;
	height: 100%;
}

.jc-header-cart__label {
	font-size: 0.8125rem;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: 0.02em;
}

.jc-header-cart__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.35rem;
	height: 1.35rem;
	padding: 0 0.4rem;
	margin-left: 0.1rem;
	border-radius: 999px;
	background: var(--jc-color-accent);
	color: #041208;
	font-size: 0.65rem;
	font-weight: 700;
	line-height: 1;
}

.jc-cart-count {
	font-size: 0.7rem;
	font-weight: 700;
	margin-left: 0.15rem;
	color: var(--jc-color-accent);
}

/* Mobile menu toggle */
.jc-menu-toggle {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0.3rem;
	width: 2.75rem;
	height: 2.75rem;
	padding: 0.5rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface);
	cursor: pointer;
}

.jc-menu-toggle span {
	display: block;
	height: 2px;
	background: var(--jc-color-text);
	border-radius: 1px;
	transition: transform 0.25s, opacity 0.25s;
}

.jc-menu-toggle[aria-expanded="true"] span:nth-child(1) {
	transform: translateY(0.4rem) rotate(45deg);
}

.jc-menu-toggle[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
}

.jc-menu-toggle[aria-expanded="true"] span:nth-child(3) {
	transform: translateY(-0.4rem) rotate(-45deg);
}

/* Full-screen mobile nav panel (top set by JS from .jc-header bottom; fallback below) */
.jc-mobile-panel {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	top: calc(var(--jc-header-h) + var(--jc-safe-top));
	background: var(--jc-color-bg);
	z-index: 110;
	padding: 1rem;
	padding-bottom: calc(1rem + var(--jc-safe-bottom));
	transform: translateX(100%);
	visibility: hidden;
	transition: transform 0.3s ease, visibility 0.3s;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.jc-mobile-panel.is-open {
	transform: translateX(0);
	visibility: visible;
}

.jc-mobile-panel nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.jc-mobile-panel nav a {
	display: block;
	padding: 0.85rem 0;
	border-bottom: 1px solid var(--jc-color-border);
	color: var(--jc-color-text);
	font-size: 1.05rem;
}

.jc-mobile-panel nav a:hover {
	color: var(--jc-color-accent);
}

.jc-mobile-panel nav .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0 0 0 0.75rem;
	border-left: 1px solid var(--jc-color-border);
}

.jc-mobile-panel nav .sub-menu a {
	font-size: 0.98rem;
	padding-top: 0.55rem;
	padding-bottom: 0.55rem;
}

/* -------------------------------------------------------------------------
   Site footer
   ------------------------------------------------------------------------- */
.jc-footer {
	background: var(--jc-color-surface);
	border-top: 1px solid var(--jc-color-border);
	margin-top: clamp(2rem, 8vw, 4rem);
	padding-top: clamp(1.5rem, 5vw, 2.5rem);
	padding-bottom: calc(clamp(1.5rem, 5vw, 2.5rem) + var(--jc-safe-bottom));
}

.jc-footer-grid {
	display: grid;
	gap: clamp(1.25rem, 4vw, 2rem);
}

.jc-footer-col h3 {
	font-size: 0.95rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--jc-color-muted);
	margin-bottom: 0.75rem;
}

.jc-footer-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.jc-footer-col li {
	margin-bottom: 0.45rem;
}

.jc-footer-col a {
	color: var(--jc-color-text);
}

.jc-footer-bottom {
	margin-top: clamp(1.25rem, 4vw, 2rem);
	padding-top: 1rem;
	border-top: 1px solid var(--jc-color-border);
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	text-align: center;
}

.jc-footer-newsletter {
	margin-top: clamp(1.5rem, 4vw, 2.25rem);
	padding-top: clamp(1.25rem, 4vw, 2rem);
	border-top: 1px solid var(--jc-color-border);
}

.jc-footer-newsletter-inner {
	display: grid;
	gap: clamp(1.5rem, 4vw, 2.25rem);
	align-items: start;
}

.jc-footer-brand-heading {
	font-size: 1.05rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--jc-color-text);
	margin: 0 0 0.5rem;
}

.jc-footer-brand-desc {
	margin: 0;
	max-width: 36rem;
	color: var(--jc-color-muted);
	font-size: 0.9375rem;
	line-height: 1.55;
}

.jc-footer-newsletter-panel {
	width: 100%;
	min-width: 0;
}

.jc-footer-newsletter-heading {
	font-size: 0.95rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--jc-color-muted);
	margin: 0 0 0.35rem;
}

.jc-footer-newsletter-desc {
	margin: 0 0 1rem;
	color: var(--jc-color-text);
	font-size: 0.9375rem;
}

@media (min-width: 48rem) {
	.jc-footer-newsletter-inner {
		grid-template-columns: minmax(0, 1fr) minmax(0, 22rem);
		gap: clamp(1.5rem, 4vw, 3rem);
		align-items: start;
	}

	.jc-footer-newsletter-panel {
		justify-self: end;
		max-width: 28rem;
	}
}

.jc-edm-form {
	max-width: 32rem;
}

.jc-footer-newsletter-panel .jc-edm-form {
	max-width: none;
	width: 100%;
}

.jc-edm-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: stretch;
	margin-bottom: 0.65rem;
}

.jc-edm-input {
	flex: 1 1 12rem;
	min-width: 0;
	padding: 0.5rem 0.75rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-bg);
	color: var(--jc-color-text);
	font: inherit;
}

.jc-edm-submit {
	flex: 0 0 auto;
}

.jc-edm-consent {
	display: flex;
	gap: 0.5rem;
	align-items: flex-start;
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	line-height: 1.45;
	cursor: pointer;
}

.jc-edm-consent input {
	margin-top: 0.2rem;
	flex-shrink: 0;
}

.jc-edm-hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.jc-edm {
	position: relative;
}

.jc-edm-title {
	font-weight: 600;
	margin: 0 0 0.75rem;
}

.jc-edm-message {
	margin: 0.75rem 0 0;
	font-size: 0.875rem;
	color: var(--jc-color-accent);
}

.jc-edm-message--error {
	color: var(--jc-color-danger);
}

.jc-edm-notice {
	position: fixed;
	left: 50%;
	top: calc(var(--jc-header-h) + var(--jc-safe-top) + 0.5rem);
	transform: translateX(-50%);
	z-index: 200;
	max-width: min(92vw, 28rem);
	padding: 0.75rem 1rem;
	border-radius: var(--jc-radius);
	font-size: 0.875rem;
	box-shadow: var(--jc-shadow);
}

.jc-edm-notice--ok {
	background: var(--jc-color-surface-2);
	border: 1px solid var(--jc-color-accent);
	color: var(--jc-color-text);
}

.jc-edm-notice--warn {
	background: var(--jc-color-surface-2);
	border: 1px solid var(--jc-color-danger);
	color: var(--jc-color-text);
}

/* -------------------------------------------------------------------------
   
   ------------------------------------------------------------------------- */
.jc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 0.65rem 1.25rem;
	border-radius: var(--jc-radius);
	border: none;
	cursor: pointer;
	font-weight: 600;
	transition: background 0.2s, transform 0.15s;
	touch-action: manipulation;
}

.jc-btn:active {
	transform: scale(0.98);
}

.jc-btn-primary {
	background: var(--jc-color-accent);
	color: #041208;
}

.jc-btn-primary:hover {
	background: var(--jc-color-accent-hover);
}

.jc-btn-outline {
	background: transparent;
	border: 1px solid var(--jc-color-border);
	color: var(--jc-color-text);
}

.jc-btn-outline:hover {
	border-color: var(--jc-color-accent);
	color: var(--jc-color-accent);
}

input[type="text"],
input[type="search"],
input[type="number"],
input[type="email"],
input[type="url"],
select,
textarea {
	width: 100%;
	max-width: 100%;
	padding: 0.6rem 0.75rem;
	border-radius: var(--jc-radius);
	border: 1px solid var(--jc-color-border);
	background: var(--jc-color-surface);
	color: var(--jc-color-text);
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 2px solid var(--jc-color-accent);
	outline-offset: 1px;
}

/* -------------------------------------------------------------------------
   
   ------------------------------------------------------------------------- */
.jc-main {
	padding-top: clamp(1rem, 4vw, 2rem);
	padding-bottom: clamp(2rem, 6vw, 3rem);
	min-height: 50vh;
}

.jc-page-header {
	margin-bottom: clamp(1rem, 4vw, 2rem);
}

.jc-page-title {
	font-size: clamp(1.5rem, 5vw, 2.25rem);
}

.jc-post-list {
	display: grid;
	gap: clamp(1rem, 3vw, 1.5rem);
}

.jc-post-card {
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	overflow: hidden;
	box-shadow: var(--jc-shadow);
}

.jc-post-card-body {
	padding: 1rem 1.15rem 1.25rem;
}

.jc-post-card-meta {
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	margin: 0 0 0.5rem;
}

.jc-post-card-meta time {
	font-variant-numeric: tabular-nums;
}

.jc-post-meta {
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	margin-bottom: 0.35rem;
}

.jc-post-card-title {
	font-size: clamp(1.05rem, 3vw, 1.2rem);
	margin: 0 0 0.5rem;
	line-height: 1.3;
}

.jc-post-card-title a {
	color: inherit;
	text-decoration: none;
}

.jc-post-card-title a:hover {
	color: var(--jc-color-accent);
}

.jc-post-card-thumb {
	display: block;
	overflow: hidden;
}

.jc-post-card-thumb img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: middle;
}

.jc-blog-home-intro {
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--jc-color-muted);
	max-width: 48rem;
}

.jc-blog-home-intro p:last-child {
	margin-bottom: 0;
}

.jc-blog-home-lead {
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--jc-color-muted);
	max-width: 42rem;
	margin: 0;
}

.jc-blog-empty {
	color: var(--jc-color-muted);
}

.jc-single-post .jc-entry-content {
	max-width: 48rem;
}

.jc-post-tags {
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	margin: 1.5rem 0 0;
}

.jc-post-tags-label {
	margin-right: 0.35rem;
}

.jc-related-posts {
	margin-top: clamp(2rem, 5vw, 3rem);
	padding-top: clamp(1.5rem, 4vw, 2rem);
	border-top: 1px solid var(--jc-color-border);
}

.jc-related-posts-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

@media (min-width: 36rem) {
	.jc-related-posts-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 56rem) {
	.jc-related-posts-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.jc-related-posts-link {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	text-decoration: none;
	color: inherit;
	height: 100%;
	padding: 0.75rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface);
	transition: border-color 0.2s, box-shadow 0.2s;
}

.jc-related-posts-link:hover {
	border-color: var(--jc-color-accent);
	box-shadow: var(--jc-shadow);
	color: inherit;
}

.jc-related-posts-thumb img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: calc(var(--jc-radius) - 2px);
}

.jc-related-posts-title {
	font-weight: 600;
	font-size: 0.9375rem;
	line-height: 1.35;
}

.jc-post-comments {
	margin-top: clamp(1.5rem, 4vw, 2.5rem);
	padding-top: 1.5rem;
	border-top: 1px solid var(--jc-color-border);
}

.jc-post-comments .comments-title {
	font-size: 1.1rem;
	margin-bottom: 1rem;
}

.jc-post-nav {
	margin-top: 1.5rem;
}

.jc-pagination .page-numbers {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	align-items: center;
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
}

.jc-pagination a.page-numbers,
.jc-pagination span.page-numbers {
	padding: 0.35rem 0.65rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	text-decoration: none;
	color: inherit;
}

.jc-pagination a.page-numbers:hover {
	border-color: var(--jc-color-accent);
	color: var(--jc-color-accent);
}

.jc-pagination span.page-numbers.current {
	background: var(--jc-color-accent);
	color: #041208;
	border-color: transparent;
	font-weight: 600;
}

/* -------------------------------------------------------------------------
   WooCommerce 
   ------------------------------------------------------------------------- */
/* Breadcrumb: list layout, responsive (see .jc-bc__* below) */
.woocommerce .jc-main .woocommerce-breadcrumb.jc-bc,
.woocommerce-breadcrumb.jc-bc {
	margin-bottom: 0;
}

.woocommerce .jc-main .woocommerce-breadcrumb.jc-bc a.jc-bc__link,
.woocommerce-breadcrumb.jc-bc a.jc-bc__link {
	color: var(--jc-color-muted);
}

.woocommerce .button,
.woocommerce button.button,
.woocommerce a.button {
	background: var(--jc-color-accent) !important;
	color: #041208 !important;
	border-radius: var(--jc-radius) !important;
	font-weight: 600 !important;
	padding: 0.65rem 1.15rem !important;
	border: none !important;
}

.woocommerce .button.alt {
	background: var(--jc-color-accent) !important;
}

/* Checkout: dark inputs (avoid bright browser/WC defaults) + readable Pay button */
.jc-checkout-form .woocommerce-billing-fields__field-wrapper .form-row input.input-text,
.jc-checkout-form .woocommerce-billing-fields__field-wrapper .form-row select,
.jc-checkout-form .woocommerce-billing-fields__field-wrapper .form-row textarea,
.jc-checkout-form .woocommerce-shipping-fields__field-wrapper .form-row input.input-text,
.jc-checkout-form .woocommerce-shipping-fields__field-wrapper .form-row select,
.jc-checkout-form .woocommerce-shipping-fields__field-wrapper .form-row textarea,
.jc-checkout-form .woocommerce-additional-fields__field-wrapper .form-row input.input-text,
.jc-checkout-form .woocommerce-additional-fields__field-wrapper .form-row textarea,
.jc-checkout-form #customer_details .form-row input.input-text,
.jc-checkout-form #customer_details .form-row select,
.jc-checkout-form #customer_details .form-row textarea {
	background-color: var(--jc-color-surface-2) !important;
	color: var(--jc-color-text) !important;
	border-color: var(--jc-color-border) !important;
	box-shadow: none !important;
}

.jc-checkout-form #customer_details .form-row input.input-text::placeholder,
.jc-checkout-form #customer_details .form-row textarea::placeholder {
	color: var(--jc-color-muted);
	opacity: 0.92;
}

.jc-checkout-form #place_order,
.jc-checkout-form button#place_order,
.woocommerce-checkout.jc-checkout-form #place_order {
	background: var(--jc-color-accent) !important;
	color: #041208 !important;
	font-weight: 700 !important;
	font-size: 1.05rem !important;
	padding: 0.9rem 1.35rem !important;
	border: none !important;
	border-radius: var(--jc-radius) !important;
	box-shadow: none !important;
	text-shadow: none !important;
	letter-spacing: 0.02em;
}

.jc-checkout-form #place_order:hover,
.jc-checkout-form #place_order:focus,
.jc-checkout-form button#place_order:hover,
.jc-checkout-form button#place_order:focus {
	background: var(--jc-color-accent-hover) !important;
	color: #041208 !important;
	outline: none !important;
}

.jc-checkout-form #place_order:focus-visible,
.jc-checkout-form button#place_order:focus-visible {
	outline: 2px solid var(--jc-color-accent) !important;
	outline-offset: 2px !important;
}

body.woocommerce-checkout .select2-container--default .select2-selection--single {
	background-color: var(--jc-color-surface-2) !important;
	border-color: var(--jc-color-border) !important;
	min-height: 2.75rem;
	padding: 0.2rem 0.5rem;
}

body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
	color: var(--jc-color-text);
	line-height: 2.35rem;
	padding-left: 0.25rem;
}

body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 2.65rem;
}

body.woocommerce-checkout .select2-dropdown {
	background-color: var(--jc-color-surface-2);
	border-color: var(--jc-color-border);
	color: var(--jc-color-text);
}

body.woocommerce-checkout .select2-container--default .select2-results__option--highlighted[aria-selected],
body.woocommerce-checkout .select2-container--default .select2-results__option--highlighted[data-selected] {
	background-color: var(--jc-color-accent) !important;
	color: #041208 !important;
}

/* Block-based checkout (if enabled): match dark fields + Pay button contrast */
body.woocommerce-checkout .wc-block-components-text-input input,
body.woocommerce-checkout .wc-block-components-combobox .wc-blocks-components-select__container {
	background-color: var(--jc-color-surface-2) !important;
	color: var(--jc-color-text) !important;
	border-color: var(--jc-color-border) !important;
}

body.woocommerce-checkout .wc-block-checkout__actions .wc-block-components-button:not(.is-link) {
	background-color: var(--jc-color-accent) !important;
	color: #041208 !important;
	font-weight: 700 !important;
	border: none !important;
}

body.woocommerce-checkout .wc-block-checkout__actions .wc-block-components-button:not(.is-link):hover {
	background-color: var(--jc-color-accent-hover) !important;
	color: #041208 !important;
}

/* Blocks checkout order summary: per-line remove link (theme enables via jc-checkout-blocks-remove-item.js) */
body.woocommerce-checkout .wc-block-components-order-summary .wc-block-components-cart-item__remove-link,
body.wc-block-checkout .wc-block-components-order-summary .wc-block-components-cart-item__remove-link {
	color: var(--jc-color-danger) !important;
	text-decoration: underline;
}

/*
 * Blocks checkout: Country / Region use Combobox + Select (not plain .input-text).
 * Override default white panel + low-contrast floating labels.
 */
body.woocommerce-checkout .wc-block-components-combobox,
body.woocommerce-checkout .wc-block-components-combobox .wc-block-components-combobox-control,
body.woocommerce-checkout .wc-block-components-combobox .wc-block-components-combobox-control input,
body.woocommerce-checkout .wc-block-components-combobox .wc-block-components-combobox__input,
body.woocommerce-checkout .wc-block-components-combobox button[aria-haspopup="listbox"],
body.woocommerce-checkout .wc-blocks-components-select,
body.woocommerce-checkout .wc-blocks-components-select__container,
body.woocommerce-checkout .wc-blocks-components-select .components-custom-select-control__button,
body.woocommerce-checkout .wc-blocks-components-select button.components-custom-select-control__button,
body.woocommerce-checkout .wc-block-components-address-form .wc-blocks-components-select__container {
	background-color: var(--jc-color-surface-2) !important;
	background: var(--jc-color-surface-2) !important;
	color: var(--jc-color-text) !important;
	border-color: var(--jc-color-border) !important;
	box-shadow: none !important;
}

body.woocommerce-checkout .wc-block-components-combobox .wc-block-components-combobox-control input::placeholder,
body.woocommerce-checkout .wc-block-components-combobox .wc-block-components-combobox__input::placeholder {
	color: var(--jc-color-muted) !important;
	opacity: 0.95;
}

body.woocommerce-checkout .wc-block-components-combobox label,
body.woocommerce-checkout .wc-block-components-combobox .wc-block-components-combobox__label,
body.woocommerce-checkout .wc-blocks-components-select label {
	color: var(--jc-color-muted) !important;
}

body.woocommerce-checkout .wc-block-components-combobox [role="listbox"],
body.woocommerce-checkout .wc-block-components-combobox .wc-block-components-combobox__listbox,
body.woocommerce-checkout .wc-block-components-dropdown__content,
body.woocommerce-checkout .components-popover__content {
	background-color: var(--jc-color-surface-2) !important;
	border-color: var(--jc-color-border) !important;
	color: var(--jc-color-text) !important;
}

body.woocommerce-checkout .wc-block-components-combobox [role="option"]:hover,
body.woocommerce-checkout .wc-block-components-combobox [role="option"][data-active-item="true"] {
	background-color: var(--jc-color-surface) !important;
	color: var(--jc-color-text) !important;
}

/* Classic shortcode checkout: country/state often use native select + SelectWoo */
body.woocommerce-checkout form.woocommerce-checkout select.country_select,
body.woocommerce-checkout form.woocommerce-checkout select.state_select,
body.woocommerce-checkout form.woocommerce-checkout #billing_country,
body.woocommerce-checkout form.woocommerce-checkout #billing_state,
body.woocommerce-checkout form.woocommerce-checkout #shipping_country,
body.woocommerce-checkout form.woocommerce-checkout #shipping_state {
	background-color: var(--jc-color-surface-2) !important;
	color: var(--jc-color-text) !important;
	border-color: var(--jc-color-border) !important;
	color-scheme: dark;
}

/* Ariakit / newer Blocks: combobox wrapper + input[role=combobox] */
body.woocommerce-checkout .wc-block-components-address-form [role="combobox"],
body.woocommerce-checkout .wc-block-components-address-form input[role="combobox"],
body.woocommerce-checkout .wc-block-components-address-form .wc-block-components-combobox-wrapper,
body.woocommerce-checkout .wc-block-components-address-form div[class*="Combobox"] {
	background-color: var(--jc-color-surface-2) !important;
	background: var(--jc-color-surface-2) !important;
	color: var(--jc-color-text) !important;
	border-color: var(--jc-color-border) !important;
}

body.woocommerce-checkout .wc-block-components-address-form .wc-block-components-form-row--country .wc-block-components-combobox,
body.woocommerce-checkout .wc-block-components-address-form .wc-block-components-form-row--state .wc-block-components-combobox {
	background: transparent !important;
}

body.woocommerce-checkout .wc-block-components-address-form .wc-block-components-form-row--country .wc-block-components-combobox-control,
body.woocommerce-checkout .wc-block-components-address-form .wc-block-components-form-row--state .wc-block-components-combobox-control {
	background-color: var(--jc-color-surface-2) !important;
	border-color: var(--jc-color-border) !important;
}

body.wc-block-checkout .wc-block-components-combobox,
body.wc-block-checkout .wc-block-components-combobox-control,
body.wc-block-checkout .wc-block-components-combobox .wc-block-components-combobox-control input {
	background-color: var(--jc-color-surface-2) !important;
	color: var(--jc-color-text) !important;
	border-color: var(--jc-color-border) !important;
}

body.wc-block-checkout .components-custom-select-control__button {
	background-color: var(--jc-color-surface-2) !important;
	color: var(--jc-color-text) !important;
	border-color: var(--jc-color-border) !important;
}

.woocommerce span.onsale {
	background: var(--jc-color-danger);
	color: #fff;
	border-radius: var(--jc-radius);
	min-height: auto;
	line-height: 1.2;
	padding: 0.25rem 0.5rem;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--jc-color-accent);
	font-size: 1.35rem;
	font-weight: 700;
}

/* -------------------------------------------------------------------------
   Tablet: 768px - 1199px (48rem - 74.9375rem)
   ------------------------------------------------------------------------- */
@media (min-width: 48rem) and (max-width: 74.9375rem) {
	.jc-footer-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.jc-nav-primary {
		display: flex;
	}

	/* Primary: show first 5 top-level items */
	.jc-nav-primary > ul > li:nth-child(n+6) {
		display: none;
	}

	.jc-nav-secondary-wrap {
		display: block;
		position: relative;
	}

	.jc-nav-secondary-toggle {
		font-size: 0.8125rem;
		padding: 0.35rem 0.6rem;
		border: 1px solid var(--jc-color-border);
		border-radius: var(--jc-radius);
		background: var(--jc-color-surface);
		color: var(--jc-color-text);
		cursor: pointer;
	}

	.jc-nav-secondary-dropdown {
		display: none;
		position: absolute;
		right: 0;
		top: 100%;
		margin-top: 0.35rem;
		min-width: 12rem;
		background: var(--jc-color-surface-2);
		border: 1px solid var(--jc-color-border);
		border-radius: var(--jc-radius);
		box-shadow: var(--jc-shadow);
		z-index: 50;
	}

	.jc-nav-secondary-dropdown.is-open {
		display: block;
	}

	.jc-nav-secondary-dropdown ul {
		list-style: none;
		margin: 0;
		padding: 0.35rem 0;
	}

	.jc-nav-secondary-dropdown a {
		display: block;
		padding: 0.5rem 0.85rem;
		color: var(--jc-color-text);
	}

	/* Dropdown: hide first 5 (already in bar), show rest */
	.jc-nav-secondary-dropdown > ul > li {
		display: none;
	}

	.jc-nav-secondary-dropdown > ul > li:nth-child(n+6) {
		display: block;
	}

	.jc-menu-toggle {
		display: none;
	}

	.jc-mobile-panel {
		display: none;
	}
}

/* -------------------------------------------------------------------------
   Desktop: >= 1200px (75rem)
   ------------------------------------------------------------------------- */
@media (min-width: 75rem) {
	.jc-nav-primary {
		display: flex;
	}

	.jc-nav-primary .menu-item-depth-0 {
		display: block;
	}

	.jc-nav-secondary-wrap {
		display: none;
	}

	.jc-menu-toggle {
		display: none;
	}

	.jc-mobile-panel {
		display: none;
	}

	.jc-footer-grid {
		grid-template-columns: repeat(4, 1fr);
	}

	.jc-post-list {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* -------------------------------------------------------------------------
   Mobile: <= 767px (max 47.9375rem)
   ------------------------------------------------------------------------- */
@media (max-width: 47.9375rem) {
	:root {
		--jc-header-h: clamp(5.75rem, 22vw, 6.75rem);
	}

	.jc-nav-primary {
		display: none;
	}

	.jc-header-inner {
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		grid-template-areas:
			"logo actions"
			"search search";
		align-items: center;
		column-gap: 0.5rem;
		row-gap: 0.5rem;
		width: 100%;
		max-width: 100%;
		min-width: 0;
	}

	.jc-logo {
		grid-area: logo;
		min-width: 0;
		max-width: none;
		align-self: center;
	}

	.jc-logo > span:last-child {
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.jc-header-search {
		grid-area: search;
		width: 100%;
		max-width: none;
		min-width: 0;
		margin-left: 0;
		flex: none;
	}

	.jc-header-search-input {
		min-width: 0;
	}

	.jc-header-actions {
		grid-area: actions;
		display: flex;
		flex-wrap: nowrap;
		justify-content: flex-end;
		align-items: center;
		gap: 0.35rem;
		justify-self: end;
		min-width: 0;
	}

	.jc-currency-switcher {
		gap: 0.1rem;
	}

	.jc-currency-switcher .jc-icon-btn {
		min-width: 1.85rem;
		width: auto;
		height: 2.35rem;
		padding: 0 0.2rem;
		font-size: 0.58rem;
	}

	.jc-header-cart {
		padding: 0 0.4rem;
		gap: 0.2rem;
		position: relative;
	}

	.jc-header-cart__label {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}

	.jc-menu-toggle {
		width: 2.5rem;
		height: 2.5rem;
		padding: 0.45rem;
	}

	.jc-header-actions:empty {
		display: none;
	}

	.jc-header-inner:has(.jc-header-actions:empty) {
		grid-template-columns: 1fr;
		grid-template-areas:
			"logo"
			"search";
	}

	.jc-footer-grid {
		grid-template-columns: 1fr;
	}

	.jc-post-list {
		grid-template-columns: 1fr;
	}

	/*
	 * Fallback when JS has not run: two-row header + slack. Prefer footer inline top from .jc-header.getBoundingClientRect().bottom.
	 */
	.jc-mobile-panel {
		top: calc(max(var(--jc-header-h), 9.25rem) + var(--jc-safe-top));
	}
}

/* -------------------------------------------------------------------------
   
   ------------------------------------------------------------------------- */
.jc-section {
	margin-bottom: clamp(2rem, 7vw, 3.5rem);
}

.jc-section-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: clamp(0.75rem, 3vw, 1.25rem);
}

.jc-section-title {
	font-size: clamp(1.15rem, 4vw, 1.5rem);
	margin: 0;
}

.jc-link-all {
	font-size: 0.875rem;
	white-space: nowrap;
}

/* Banner  */
.jc-hero {
	position: relative;
	border-radius: var(--jc-radius);
	overflow: hidden;
	background: var(--jc-color-surface);
	min-height: clamp(12rem, 45vw, 22rem);
}

.jc-hero-slides {
	position: relative;
	width: 100%;
	min-height: inherit;
}

.jc-hero-slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 0.6s ease;
	pointer-events: none;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(1rem, 5vw, 3rem);
	background-size: cover;
	background-position: center;
}

.jc-hero-slide.is-active {
	opacity: 1;
	pointer-events: auto;
	z-index: 1;
}

.jc-hero-content {
	max-width: 36rem;
	text-align: center;
}

.jc-hero-content h2 {
	font-size: clamp(1.35rem, 6vw, 2.5rem);
	text-shadow: 0 0.15rem 0.75rem rgba(0, 0, 0, 0.6);
}

.jc-hero-dots {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem;
	position: relative;
	z-index: 2;
}

.jc-hero-dot {
	width: 0.5rem;
	height: 0.5rem;
	border-radius: 50%;
	border: none;
	padding: 0;
	background: var(--jc-color-muted);
	cursor: pointer;
	opacity: 0.5;
}

.jc-hero-dot.is-active {
	opacity: 1;
	background: var(--jc-color-accent);
	transform: scale(1.15);
}

.jc-hero--single .jc-hero-slide {
	position: relative;
}

.jc-hero-content--conversion {
	max-width: 42rem;
	margin-left: auto;
	margin-right: auto;
}

.jc-hero-content--conversion h2 {
	line-height: 1.25;
	margin-bottom: 1.25rem;
}

.jc-hero-cta--bar {
	display: block;
	width: 100%;
	max-width: 22rem;
	margin-left: auto;
	margin-right: auto;
	font-weight: 700;
	letter-spacing: 0.02em;
	box-shadow: 0 0.35rem 1.5rem rgba(0, 200, 83, 0.45);
	border: 2px solid rgba(255, 255, 255, 0.95);
}

.jc-social-proof {
	margin-bottom: clamp(1rem, 3vw, 1.75rem);
}

.jc-social-proof-inner {
	text-align: center;
	padding: clamp(0.85rem, 3vw, 1.25rem) 1rem;
	background: linear-gradient(90deg, rgba(0, 200, 83, 0.08), rgba(10, 22, 40, 0.35), rgba(0, 200, 83, 0.08));
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
}

.jc-social-proof-line {
	margin: 0;
	font-size: 0.875rem;
	color: var(--jc-color-muted);
}

.jc-social-proof-line--primary {
	font-size: clamp(1rem, 2.5vw, 1.15rem);
	font-weight: 700;
	color: var(--jc-color-text);
	margin-bottom: 0.35rem;
}

.jc-card-badge--hot {
	background: #e65100;
	color: #fff;
}

.jc-card-badge--new {
	background: #1565c0;
	color: #fff;
}

.jc-exit-modal {
	position: fixed;
	inset: 0;
	z-index: 230;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	padding-bottom: calc(1rem + var(--jc-safe-bottom));
}

.jc-exit-modal.is-open {
	display: flex;
}

.jc-exit-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
}

.jc-exit-modal__panel {
	position: relative;
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	padding: 1.5rem;
	max-width: 22rem;
	width: 100%;
	box-shadow: var(--jc-shadow);
}

.jc-exit-modal__close {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	border: none;
	background: transparent;
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	color: var(--jc-color-muted);
	padding: 0.25rem 0.5rem;
}

.jc-exit-modal__close:hover {
	color: var(--jc-color-text);
}

.jc-exit-modal__title {
	margin: 0 0 0.75rem;
	font-size: 1.15rem;
	padding-right: 2rem;
}

.jc-exit-modal__text {
	margin: 0 0 0.75rem;
	font-size: 0.875rem;
	color: var(--jc-color-muted);
	line-height: 1.5;
}

.jc-exit-modal__label {
	display: block;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--jc-color-muted);
	margin-bottom: 0.35rem;
}

.jc-exit-modal__field {
	display: flex;
	gap: 0.5rem;
	margin-bottom: 1rem;
}

.jc-exit-modal__input {
	flex: 1;
	min-width: 0;
	padding: 0.5rem 0.65rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-bg);
	color: var(--jc-color-text);
	font-size: 0.9375rem;
	font-weight: 600;
}

.jc-exit-modal__copy {
	flex-shrink: 0;
	white-space: nowrap;
}

.jc-exit-modal__actions {
	margin: 0;
}

/*  */
.jc-cat-strip {
	display: flex;
	gap: 0.75rem;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 0.35rem;
	scroll-snap-type: x mandatory;
}

.jc-cat-strip::-webkit-scrollbar {
	height: 4px;
}

.jc-cat-chip {
	flex: 0 0 auto;
	scroll-snap-align: start;
	padding: 0.5rem 1rem;
	border-radius: 999px;
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	color: var(--jc-color-text);
	font-size: 0.875rem;
	white-space: nowrap;
}

.jc-cat-chip:hover {
	border-color: var(--jc-color-accent);
	color: var(--jc-color-accent);
}

/*  */
.jc-product-grid {
	display: grid;
	gap: clamp(0.75rem, 3vw, 1.25rem);
}

.jc-product-card {
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: border-color 0.2s, transform 0.2s;
}

.jc-product-card:hover {
	border-color: rgba(0, 200, 83, 0.35);
}

@media (hover: hover) and (pointer: fine) {
	.jc-product-card:hover {
		transform: translateY(-2px);
	}
}

.jc-product-card a.jc-product-thumb {
	display: block;
	aspect-ratio: 3 / 4;
	background: var(--jc-color-surface-2);
	overflow: hidden;
}

.jc-product-card img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.jc-product-card-body {
	padding: 0.75rem 0.9rem 1rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.jc-product-card-title {
	font-size: 0.95rem;
	margin: 0 0 0.35rem;
	flex: 1;
}

.jc-product-card-title a {
	color: var(--jc-color-text);
}

.jc-product-card-title a:hover {
	color: var(--jc-color-accent);
}

.jc-product-card .price {
	color: var(--jc-color-accent);
	font-weight: 700;
	font-size: 1rem;
	margin: 0;
	text-align: center;
	width: 100%;
}

.jc-product-card-body > .jc-btn {
	white-space: nowrap;
	font-size: 0.8125rem;
	padding: 0.45rem 0.85rem;
	align-self: center;
	max-width: 100%;
	box-sizing: border-box;
}

/* Home grids: 2 columns on small screens */
@media (max-width: 47.9375rem) {
	.jc-home-hot .jc-product-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.jc-home-new .jc-product-grid {
		display: flex;
		flex-direction: row;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scroll-snap-type: x mandatory;
		gap: 0.75rem;
		padding-bottom: 0.25rem;
	}

	.jc-home-new .jc-product-card {
		flex: 0 0 min(72vw, 14rem);
		scroll-snap-align: start;
	}
}

@media (min-width: 48rem) and (max-width: 74.9375rem) {
	.jc-product-grid.cols-shop {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.jc-home-hot .jc-product-grid,
	.jc-home-new .jc-product-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (min-width: 75rem) {
	.jc-cat-strip {
		display: grid;
		grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr));
		overflow: visible;
	}

	.jc-product-grid.cols-shop {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.jc-home-hot .jc-product-grid,
	.jc-home-new .jc-product-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

.jc-home-products-empty {
	margin: 0;
	padding: 1rem 0;
	color: var(--jc-color-muted);
	font-size: 0.9375rem;
	max-width: 36rem;
}

.jc-home-blog-grid {
	display: grid;
	gap: clamp(0.75rem, 3vw, 1.25rem);
	grid-template-columns: 1fr;
}

@media (min-width: 48rem) {
	.jc-home-blog-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.jc-home-blog-card {
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.jc-home-blog-thumb {
	display: block;
	aspect-ratio: 16 / 9;
	background: var(--jc-color-surface-2);
	overflow: hidden;
}

.jc-home-blog-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.jc-home-blog-card-title {
	margin: 0;
	padding: 0.75rem 0.9rem 0.25rem;
	font-size: 1rem;
}

.jc-home-blog-card-title a {
	color: var(--jc-color-text);
}

.jc-home-blog-card-title a:hover {
	color: var(--jc-color-accent);
}

.jc-home-blog-card-meta {
	margin: 0;
	padding: 0 0.9rem 0.9rem;
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
}

.jc-contact-page .jc-contact-block {
	margin-top: 1.75rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--jc-color-border);
}

.jc-contact-page .jc-contact-block:first-of-type {
	border-top: 0;
	margin-top: 0;
	padding-top: 0;
}

.jc-contact-page .jc-contact-block-title {
	font-size: 1.05rem;
	margin: 0 0 0.5rem;
}

.jc-contact-page .jc-contact-faq {
	margin: 0;
	padding-left: 1.25rem;
	color: var(--jc-color-muted);
}

.jc-contact-page .jc-contact-editor {
	margin-top: 1.75rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--jc-color-border);
}

/* -------------------------------------------------------------------------
   Shop filters (Customizer-driven labels)
   ------------------------------------------------------------------------- */
.jc-filter-form .jc-filter-group-title {
	margin: 1rem 0 0.35rem;
	font-size: 0.8125rem;
	color: var(--jc-color-text);
}

.jc-filter-form .jc-filter-group-title:first-child {
	margin-top: 0;
}

.jc-filter-select,
.jc-filter-input {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding: 0.5rem 0.65rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface-2);
	color: var(--jc-color-text);
	font-size: 0.875rem;
}

.jc-filter-price-row {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 0.35rem;
	align-items: center;
}

.jc-filter-price-sep {
	color: var(--jc-color-muted);
	text-align: center;
}

.jc-filter-submit-wrap {
	margin: 1rem 0 0;
}

.jc-filter-submit {
	width: 100%;
}

.jc-shop-layout {
	display: grid;
	gap: clamp(1rem, 3vw, 1.5rem);
}

.jc-shop-filters-desktop {
	display: none;
}

.jc-filter-toggle-mobile {
	width: 100%;
	margin-bottom: 0.75rem;
}

.jc-filter-modal {
	position: fixed;
	inset: 0;
	z-index: 200;
	background: rgba(0, 0, 0, 0.65);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.25s, visibility 0.25s;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 0;
}

.jc-filter-modal.is-open {
	opacity: 1;
	visibility: visible;
}

.jc-filter-modal-panel {
	width: 100%;
	max-height: 88vh;
	background: var(--jc-color-surface);
	border-radius: var(--jc-radius) var(--jc-radius) 0 0;
	padding: 1rem;
	overflow-y: auto;
	transform: translateY(100%);
	transition: transform 0.3s ease;
	padding-bottom: calc(1rem + var(--jc-safe-bottom));
}

.jc-filter-modal.is-open .jc-filter-modal-panel {
	transform: translateY(0);
}

.jc-filter-close {
	position: absolute;
	right: 1rem;
	top: 1rem;
}

@media (min-width: 48rem) and (max-width: 74.9375rem) {
	.jc-shop-filters-tablet {
		margin-bottom: 1rem;
	}

	.jc-shop-filters-tablet summary {
		cursor: pointer;
		padding: 0.65rem 1rem;
		background: var(--jc-color-surface);
		border: 1px solid var(--jc-color-border);
		border-radius: var(--jc-radius);
		font-weight: 600;
	}

	.jc-shop-filters-tablet .jc-filter-body {
		margin-top: 0.75rem;
		padding: 1rem;
		border: 1px solid var(--jc-color-border);
		border-radius: var(--jc-radius);
	}
}

@media (min-width: 75rem) {
	.jc-shop-layout {
		grid-template-columns: minmax(14rem, 18vw) 1fr;
		align-items: start;
	}

	.jc-shop-filters-desktop {
		display: block;
		position: sticky;
		top: calc(var(--jc-header-h) + 1rem);
		align-self: start;
		background: var(--jc-color-surface);
		border: 1px solid var(--jc-color-border);
		border-radius: var(--jc-radius);
		padding: 1rem;
		max-height: calc(100vh - var(--jc-header-h) - 2rem);
		overflow-y: auto;
	}

	.jc-filter-toggle-mobile,
	.jc-shop-filters-tablet,
	.jc-filter-modal {
		display: none !important;
	}
}

/* Shop: WooCommerce ul.products grid */
.jc-shop-page ul.products {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: clamp(0.75rem, 3vw, 1.25rem);
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.jc-shop-page ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.jc-shop-page ul.products li.product a.woocommerce-LoopProduct-link {
	flex: 1;
}

.jc-shop-page ul.products li.product img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: contain;
}

.jc-shop-page ul.products li.product .price {
	display: block;
	width: 100%;
	text-align: center;
	margin-top: 0.35rem;
}

.jc-shop-page ul.products li.product .jc-loop-customize {
	margin: 0.5rem 0.75rem 0.75rem;
	align-self: center;
	text-align: center;
	font-size: 0.75rem;
	padding: 0.4rem 0.7rem;
	white-space: nowrap;
	max-width: calc(100% - 1.5rem);
	box-sizing: border-box;
}

@media (min-width: 48rem) and (max-width: 74.9375rem) {
	.jc-shop-page ul.products {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (min-width: 75rem) {
	.jc-shop-page ul.products {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

/* Pagination */
.jc-pagination,
.woocommerce nav.woocommerce-pagination {
	margin-top: clamp(1.5rem, 4vw, 2rem);
}

.woocommerce nav.woocommerce-pagination ul {
	border: none;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	justify-content: center;
}

.woocommerce nav.woocommerce-pagination ul li {
	border: none;
	display: inline-block;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: inline-flex;
	min-width: 2.25rem;
	height: 2.25rem;
	align-items: center;
	justify-content: center;
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	color: var(--jc-color-text);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--jc-color-accent);
	color: #041208;
	border-color: transparent;
}

/* -------------------------------------------------------------------------
   404
   ------------------------------------------------------------------------- */
.jc-404 {
	text-align: center;
	padding: clamp(2rem, 10vw, 5rem) 0;
}

.jc-404 h1 {
	font-size: clamp(3rem, 18vw, 6rem);
	color: var(--jc-color-muted);
	margin-bottom: 0.5rem;
}

/* Generic page article */
.jc-page-article {
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	padding: clamp(1rem, 4vw, 2rem);
	margin-bottom: 2rem;
}

.jc-entry-content {
	max-width: 48rem;
}

/* Cart: thumbnail + inline preview SVG */
.jc-cart-table .product-thumbnail {
	vertical-align: top;
}

.jc-cart-table .product-thumbnail .jc-cart-thumb-svg {
	margin-top: 0.35rem;
	max-width: 5rem;
}

.jc-cart-table .product-thumbnail .jc-cart-thumb-svg svg {
	width: 100%;
	height: auto;
	display: block;
}

.jc-mini-line-svg {
	margin-top: 0.35rem;
	max-width: 4rem;
}

.jc-mini-line-svg svg {
	width: 100%;
	height: auto;
	display: block;
}

.jc-cart-edit-actions {
	margin-top: 0.5rem;
}

.jc-cart-custom-modal {
	position: fixed;
	inset: 0;
	z-index: 210;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(0.75rem, 4vw, 1.5rem);
	padding-bottom: calc(clamp(0.75rem, 4vw, 1.5rem) + var(--jc-safe-bottom));
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s, visibility 0.2s;
}

.jc-cart-custom-modal.is-open {
	opacity: 1;
	visibility: visible;
}

.jc-cart-custom-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
}

.jc-cart-custom-modal__panel {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 22rem;
	max-height: min(90vh, 32rem);
	overflow-y: auto;
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	padding: 1.25rem;
	box-shadow: var(--jc-shadow);
}

.jc-cart-custom-modal__close {
	position: absolute;
	right: 0.65rem;
	top: 0.65rem;
}

.jc-cart-custom-modal__title {
	margin: 0 0 0.5rem;
	padding-right: 2rem;
	font-size: 1.1rem;
}

.jc-cart-custom-modal__hint {
	margin: 0 0 1rem;
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
}

.jc-cart-custom-modal__label {
	display: block;
	font-size: 0.875rem;
}

.jc-cart-custom-modal__label input[type='text'],
.jc-cart-custom-modal__label input[type='color'],
.jc-cart-custom-modal__label select {
	width: 100%;
	margin-top: 0.25rem;
	box-sizing: border-box;
}

.jc-cart-custom-modal__actions {
	margin-top: 1rem;
	margin-bottom: 0;
}

.jc-cart-custom-modal__save {
	width: 100%;
}

.jc-order-review .woocommerce-checkout-review-order-table .jc-cart-thumb-svg,
.woocommerce-checkout-review-order-table .jc-cart-thumb-svg {
	display: block;
	margin-top: 0.35rem;
	max-width: 4.5rem;
}

.jc-myaccount-jersey-previews {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.jc-myaccount-custom-block {
	padding: 1rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface-2);
}

.jc-myaccount-custom-list {
	margin: 0.5rem 0 0;
	padding-left: 1.2rem;
	font-size: 0.875rem;
}

.jc-myaccount-svg svg {
	max-width: 8rem;
	height: auto;
}

/* -------------------------------------------------------------------------
   Cart: sticky checkout bar (mobile)
   ------------------------------------------------------------------------- */
.jc-cart-sticky-actions {
	display: none;
}

@media (max-width: 47.9375rem) {
	.jc-cart-sticky-actions {
		display: block;
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 90;
		background: var(--jc-color-surface);
		border-top: 1px solid var(--jc-color-border);
		padding: 0.75rem clamp(0.75rem, 4vw, 1.5rem);
		padding-bottom: calc(0.75rem + var(--jc-safe-bottom));
		box-shadow: 0 -0.25rem 1rem rgba(0, 0, 0, 0.3);
	}

	.jc-cart-sticky-actions .jc-btn {
		width: 100%;
	}

	.jc-cart-page .jc-main {
		padding-bottom: calc(5rem + var(--jc-safe-bottom));
	}
}

/*  CTA */
.jc-hero-cta {
	padding: 0.85rem 2rem;
	font-size: 1.05rem;
}

/* Trust / feature modules (home) */
.jc-trust-modules {
	margin-bottom: clamp(1.5rem, 5vw, 2.5rem);
}

.jc-trust-modules-grid {
	list-style: none;
	margin: 0 auto;
	padding: 0;
	display: grid;
	gap: clamp(0.75rem, 2vw, 1rem);
	grid-template-columns: repeat(2, minmax(0, 1fr));
	max-width: min(100%, 36rem);
	justify-content: center;
}

@media (max-width: 61.9375rem) {
	.jc-trust-module-link {
		align-items: center;
		text-align: center;
	}

	.jc-trust-module-icon {
		margin-inline: auto;
	}
}

@media (min-width: 62rem) {
	.jc-trust-modules-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		max-width: none;
	}

	.jc-trust-module-link {
		align-items: flex-start;
		text-align: left;
	}

	.jc-trust-module-icon {
		margin-inline: 0;
	}
}

.jc-trust-module {
	margin: 0;
}

.jc-trust-module-link {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.35rem;
	height: 100%;
	padding: 1rem 1.1rem;
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	color: inherit;
	text-decoration: none;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.jc-trust-module-link:hover {
	border-color: var(--jc-color-accent);
	box-shadow: var(--jc-shadow);
	color: inherit;
}

.jc-trust-module-icon {
	color: var(--jc-color-accent);
	line-height: 0;
}

.jc-trust-module-title {
	font-size: 0.9375rem;
	margin: 0;
	color: var(--jc-color-text);
}

.jc-trust-module-desc {
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	line-height: 1.45;
}

/* Home hub cards and category blocks */
.jc-hub-section {
	margin-bottom: clamp(1rem, 4vw, 2rem);
}

.jc-hub-cards {
	display: grid;
	gap: clamp(0.75rem, 2vw, 1.25rem);
	grid-template-columns: 1fr;
}

@media (min-width: 48rem) {
	.jc-hub-cards {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.jc-hub-card {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: clamp(1rem, 3vw, 1.35rem);
	background: linear-gradient(145deg, var(--jc-color-surface) 0%, var(--jc-color-surface-2) 100%);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	text-decoration: none;
	color: inherit;
	transition: border-color 0.2s, transform 0.2s;
}

.jc-hub-card:hover {
	border-color: var(--jc-color-accent);
	color: inherit;
	transform: translateY(-2px);
}

.jc-hub-card-kicker {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--jc-color-muted);
}

.jc-hub-card-title {
	font-size: 1.15rem;
	margin: 0;
	color: var(--jc-color-text);
}

.jc-hub-card-desc {
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	line-height: 1.45;
}

.jc-promo-sale .jc-promo-inner {
	background: linear-gradient(135deg, #1b5e20 0%, #0d3d2e 100%);
	border-radius: var(--jc-radius);
	padding: clamp(1rem, 4vw, 2rem);
	border: 1px solid var(--jc-color-border);
}

.jc-cat-tiered {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.jc-cat-group-title {
	font-size: 1rem;
	margin: 0 0 0.5rem;
}

.jc-cat-style-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
	margin-top: 1rem;
}

.jc-cat-style-label {
	font-size: 0.875rem;
	color: var(--jc-color-muted);
}

/*  */
.jc-product-thumb {
	position: relative;
}

.jc-card-badges {
	position: absolute;
	top: 0.35rem;
	left: 0.35rem;
	right: 0.35rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	pointer-events: none;
}

.jc-card-badge {
	font-size: 0.65rem;
	padding: 0.15rem 0.4rem;
	border-radius: 0.25rem;
	background: rgba(0, 0, 0, 0.65);
	color: #fff;
}

.jc-card-badge--sale {
	background: var(--jc-color-danger);
}

.jc-card-badge--stock {
	background: var(--jc-color-accent);
	color: #041208;
}

.jc-card-badge--pre {
	background: #6a1b9a;
}

/*  */
.jc-footer-payments {
	margin-top: 1rem;
	padding-top: 0.75rem;
	border-top: 1px solid var(--jc-color-border);
	text-align: center;
}

.jc-pay-icons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	font-size: 0.75rem;
	color: var(--jc-color-muted);
	justify-content: center;
}

.jc-pay-icons span {
	padding: 0.25rem 0.5rem;
	border: 1px solid var(--jc-color-border);
	border-radius: 0.25rem;
}

/* Footer: legal links (responsive grid) + IP disclaimer */
.jc-footer-compliance {
	margin-top: 1.25rem;
	padding-top: 1rem;
	padding-bottom: 1rem;
	border-top: 1px solid var(--jc-color-border);
	font-size: 0.8125rem;
}

.jc-footer-legal {
	width: 100%;
}

.jc-compliance-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.jc-compliance-links--responsive {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.35rem 0.75rem;
	justify-items: center;
	text-align: center;
}

@media (min-width: 22rem) {
	.jc-compliance-links--responsive {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		justify-items: stretch;
	}
}

@media (min-width: 40rem) {
	.jc-compliance-links--responsive {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (min-width: 62rem) {
	.jc-compliance-links--responsive {
		grid-template-columns: repeat(5, minmax(0, 1fr));
		gap: 0.5rem 1rem;
		align-items: center;
	}
}

.jc-compliance-links--responsive a {
	display: block;
	padding: 0.4rem 0.25rem;
	color: var(--jc-color-text);
	text-decoration: none;
	border-radius: var(--jc-radius);
}

.jc-compliance-links--responsive a:hover {
	color: var(--jc-color-accent);
	text-decoration: underline;
}

.jc-compliance-links--stack {
	flex-direction: column;
	align-items: stretch;
	text-align: center;
	gap: 0.65rem;
}

.jc-footer-ip {
	padding-bottom: calc(1rem + var(--jc-safe-bottom));
	border-top: 1px solid var(--jc-color-border);
	padding-top: 1rem;
	margin-top: 0;
}

.jc-ip-disclaimer {
	margin: 0;
	color: var(--jc-color-muted);
	line-height: 1.55;
	font-size: 0.75rem;
}

.jc-ip-disclaimer__text {
	margin: 0;
	text-align: center;
	max-width: 56rem;
	margin-left: auto;
	margin-right: auto;
}

.jc-ip-disclaimer--checkout {
	margin-bottom: 1rem;
	padding: 0.75rem 1rem;
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	background: var(--jc-color-surface-2);
}

.jc-ip-disclaimer--checkout .jc-ip-disclaimer__text {
	text-align: left;
	font-size: 0.8125rem;
}

.jc-ip-disclaimer--product {
	margin-top: 1.25rem;
	padding-top: 1rem;
	border-top: 1px solid var(--jc-color-border);
}

/* GDPR / cookie consent overlay */
.jc-gdpr-cookie {
	position: fixed;
	z-index: 220;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	padding: clamp(0.75rem, 4vw, 1.5rem);
	padding-bottom: calc(clamp(0.75rem, 4vw, 1.5rem) + var(--jc-safe-bottom));
	background: rgba(0, 0, 0, 0.55);
}

.jc-gdpr-cookie.is-visible {
	display: flex;
}

@media (min-width: 48rem) {
	.jc-gdpr-cookie {
		inset: auto;
		left: auto;
		right: 1rem;
		bottom: calc(1rem + var(--jc-safe-bottom));
		top: auto;
		background: transparent;
		align-items: flex-end;
		justify-content: flex-end;
		padding: 0;
		max-width: none;
	}

	.jc-gdpr-cookie.is-visible {
		display: flex;
	}
}

.jc-gdpr-cookie__panel {
	width: 100%;
	max-width: 26rem;
	max-height: min(90vh, 32rem);
	overflow-y: auto;
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	padding: clamp(1rem, 3vw, 1.35rem);
	box-shadow: var(--jc-shadow);
}

@media (min-width: 48rem) {
	.jc-gdpr-cookie__panel {
		max-width: min(34rem, 94vw);
		max-height: 85vh;
	}
}

.jc-gdpr-cookie__title {
	margin: 0 0 0.65rem;
	font-size: 1.05rem;
}

.jc-gdpr-cookie__text {
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	line-height: 1.5;
	margin-bottom: 1rem;
}

.jc-gdpr-cookie__text p {
	margin: 0 0 0.65rem;
}

.jc-gdpr-cookie__text a {
	color: var(--jc-color-accent);
}

.jc-gdpr-cookie__actions {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

@media (min-width: 36rem) {
	.jc-gdpr-cookie__actions {
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
	}
}

@media (min-width: 48rem) {
	.jc-gdpr-cookie__actions {
		gap: 0.4rem;
	}
}

.jc-gdpr-cookie__actions .jc-btn {
	width: 100%;
	padding-bottom: calc(0.65rem + env(safe-area-inset-bottom, 0rem) * 0.25);
}

@media (min-width: 36rem) {
	.jc-gdpr-cookie__actions .jc-btn {
		width: auto;
		flex: 1 1 9.5rem;
		min-width: min(100%, 9.5rem);
	}
}

.jc-whatsapp-fab {
	position: fixed;
	right: 1rem;
	bottom: calc(1rem + var(--jc-safe-bottom));
	z-index: 95;
	width: 3rem;
	height: 3rem;
	border-radius: 50%;
	background: #25d366;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 0.75rem;
	box-shadow: var(--jc-shadow);
}

.jc-currency-switcher {
	display: flex;
	gap: 0.15rem;
}

.jc-currency-switcher .jc-icon-btn {
	width: auto;
	min-width: 2.25rem;
	padding: 0 0.35rem;
	font-size: 0.65rem;
}

.jc-breadcrumb-outer {
	padding: 0.2rem 0 0;
	max-width: 100%;
	width: 100%;
	box-sizing: border-box;
}

.jc-bc {
	margin: 0 0 0.5rem;
	padding: 0.5rem clamp(0.85rem, 3vw, 1.25rem);
	max-width: 100%;
	box-sizing: border-box;
	color: var(--jc-color-muted);
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
}

.jc-bc__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.25rem 0.45rem;
	font-size: 0.8125rem;
	line-height: 1.45;
	max-width: 100%;
}

.jc-bc__item {
	display: inline-flex;
	align-items: center;
	max-width: 100%;
	min-width: 0;
	flex-shrink: 0;
}

.jc-bc__item:not(:last-child)::after {
	content: "";
	display: inline-block;
	width: 0.28rem;
	height: 0.28rem;
	margin-left: 0.35rem;
	border-right: 1px solid currentColor;
	border-bottom: 1px solid currentColor;
	transform: rotate(-45deg);
	opacity: 0.38;
	flex-shrink: 0;
	align-self: center;
}

.jc-bc__item--current {
	flex-shrink: 1;
	min-width: 0;
}

.jc-bc__link {
	color: var(--jc-color-muted);
	text-decoration: none;
	transition: color 0.15s ease;
}

.jc-bc__link:hover {
	color: var(--jc-color-accent);
}

.jc-bc__link:focus-visible {
	color: var(--jc-color-accent);
	outline: none;
	box-shadow: 0 0 0 2px var(--jc-color-surface), 0 0 0 4px var(--jc-color-accent);
	border-radius: 2px;
}

.jc-bc__current {
	color: var(--jc-color-text);
	font-weight: 600;
	display: block;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 100%;
}

.jc-bc__text {
	opacity: 0.88;
}

@media (max-width: 47.99rem) {
	.jc-bc {
		padding: 0.45rem clamp(0.75rem, 3.5vw, 1rem);
		margin-bottom: 0.45rem;
	}

	.jc-bc__list {
		flex-wrap: nowrap;
		overflow-x: auto;
		overflow-y: hidden;
		gap: 0.2rem 0.35rem;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: thin;
		overscroll-behavior-x: contain;
	}

	.jc-bc__item--current {
		max-width: min(100%, 70vw);
	}
}

@media (min-width: 48rem) and (max-width: 74.9375rem) {
	.jc-bc__list {
		font-size: 0.84375rem;
	}
}

@media (min-width: 75rem) {
	.jc-bc {
		padding: 0.5rem clamp(1rem, 2vw, 1.35rem);
		margin-bottom: 0.55rem;
	}

	.jc-bc__list {
		font-size: 0.875rem;
	}
}

.jc-bc-sep {
	margin: 0 0.35rem;
	opacity: 0.5;
}

/*  */
.jc-added-modal {
	position: fixed;
	inset: 0;
	z-index: 210;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 1rem;
}

.jc-added-modal.is-open {
	display: flex;
}

.jc-added-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
}

.jc-added-modal__panel {
	position: relative;
	background: var(--jc-color-surface);
	border: 1px solid var(--jc-color-border);
	border-radius: var(--jc-radius);
	padding: 1.5rem;
	max-width: 22rem;
	width: 100%;
	box-shadow: var(--jc-shadow);
}

.jc-added-modal__title {
	margin: 0 0 1rem;
}

.jc-legal-page .jc-legal-content {
	line-height: 1.65;
	max-width: 48rem;
	margin-left: auto;
	margin-right: auto;
}

.jc-legal-page .jc-legal-content h2 {
	margin: 1.75rem 0 0.75rem;
	font-size: clamp(1.05rem, 2.5vw, 1.2rem);
}

.jc-legal-page .jc-legal-content h2:first-child {
	margin-top: 0;
}

.jc-legal-page .jc-legal-content p,
.jc-legal-page .jc-legal-content ul {
	margin: 0 0 1rem;
}

.jc-legal-page .jc-legal-content ul {
	padding-left: 1.25rem;
}

.jc-legal-page .jc-legal-content .jc-legal-meta {
	font-size: 0.8125rem;
	color: var(--jc-color-muted);
	margin-bottom: 1.25rem;
}
