/* =========================================================================
   DigitalChillMart Dark — main stylesheet
   1. Tokens & root
   2. Reset & base
   3. Utilities
   4. Header
   5. Off-canvas drawer
   6. Search panel & form
   7. Layout / sidebar / widgets
   8. Typography & prose
   9. Buttons & forms
  10. Pagination, tables, comments
  11. Footer
  12. WooCommerce — global
  13. WooCommerce — shop loop
  14. WooCommerce — single product
  15. WooCommerce — cart, checkout, account, blocks
  16. 404 / empty states
  17. Reduced motion, print
   ========================================================================= */

/* 1. Tokens ----------------------------------------------------------- */
:root {
	--dcm-bg: #07080d;
	--dcm-bg-2: #0a0c14;
	--dcm-bg-elevated: #0f1118;
	--dcm-bg-card: rgba(20, 24, 34, 0.86);
	--dcm-bg-card-solid: #14161e;
	--dcm-border: rgba(120, 160, 255, 0.10);
	--dcm-border-2: rgba(120, 160, 255, 0.18);
	--dcm-border-strong: rgba(34, 211, 238, 0.32);
	--dcm-text: #e8ebf5;
	--dcm-text-soft: #c5cad9;
	--dcm-text-muted: #8b93a8;
	--dcm-text-dim: #6a7186;
	--dcm-accent: #22d3ee;
	--dcm-accent-2: #67e8f9;
	--dcm-accent-dim: #0891b2;
	--dcm-accent-glow: rgba(34, 211, 238, 0.35);
	--dcm-violet: #a78bfa;
	--dcm-violet-dim: #7c3aed;
	--dcm-success: #34d399;
	--dcm-warn: #fbbf24;
	--dcm-danger: #f87171;
	--dcm-grad-aurora: linear-gradient(135deg, #22d3ee 0%, #a78bfa 100%);
	--dcm-grad-card: linear-gradient(180deg, rgba(34, 211, 238, 0.04), rgba(167, 139, 250, 0.02));
	--dcm-font: 'Outfit', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	--dcm-mono: 'JetBrains Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;
	--dcm-radius: 14px;
	--dcm-radius-sm: 10px;
	--dcm-radius-xs: 6px;
	--dcm-radius-pill: 999px;
	--dcm-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.25);
	--dcm-shadow: 0 8px 32px rgba(0, 0, 0, 0.32);
	--dcm-shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.5);
	--dcm-shadow-glow: 0 0 0 1px rgba(34, 211, 238, 0.25), 0 12px 40px rgba(34, 211, 238, 0.18);
	--dcm-header-h: 68px;
	--dcm-header-h-mobile: 60px;
	--dcm-maxw: 1200px;
	--dcm-gutter: clamp(1rem, 4vw, 2rem);
	--dcm-transition: 200ms cubic-bezier(0.2, 0.8, 0.2, 1);
	--dcm-ease: cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* 2. Reset & base ----------------------------------------------------- */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
	scroll-behavior: smooth;
	scroll-padding-top: calc(var(--dcm-header-h) + 12px);
}

body {
	margin: 0;
	min-height: 100vh;
	min-height: 100dvh;
	display: flex;
	flex-direction: column;
	font-family: var(--dcm-font);
	font-size: clamp(0.95rem, 0.92rem + 0.15vw, 1rem);
	line-height: 1.6;
	color: var(--dcm-text);
	background: var(--dcm-bg);
	background-image:
		radial-gradient(ellipse 120% 70% at 50% -20%, rgba(34, 211, 238, 0.10), transparent 60%),
		radial-gradient(ellipse 60% 50% at 100% 0%, rgba(167, 139, 250, 0.08), transparent 50%),
		radial-gradient(ellipse 50% 40% at 0% 80%, rgba(8, 145, 178, 0.06), transparent 55%);
	background-attachment: fixed;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-wrap: break-word;
	word-wrap: break-word;
}

body.dcm-scroll-lock {
	overflow: hidden;
}

main:focus {
	outline: none;
}

img,
svg,
video,
canvas {
	display: block;
	max-width: 100%;
	height: auto;
}

a {
	color: var(--dcm-accent);
	text-decoration: none;
	transition: color var(--dcm-transition), opacity var(--dcm-transition);
}

a:hover {
	color: var(--dcm-accent-2);
}

:focus-visible {
	outline: 2px solid var(--dcm-accent);
	outline-offset: 2px;
}
button:focus-visible,
.dcm-btn:focus-visible,
.dcm-header__action:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
	outline-offset: 1px;
}

::selection {
	background: rgba(34, 211, 238, 0.35);
	color: var(--dcm-text);
}

::-webkit-scrollbar {
	width: 10px;
	height: 10px;
}
::-webkit-scrollbar-track {
	background: var(--dcm-bg);
}
::-webkit-scrollbar-thumb {
	background: rgba(120, 160, 255, 0.18);
	border-radius: 999px;
	border: 2px solid var(--dcm-bg);
}
::-webkit-scrollbar-thumb:hover {
	background: rgba(34, 211, 238, 0.4);
}

/* 3. Utilities -------------------------------------------------------- */
.dcm-container {
	width: min(100% - calc(var(--dcm-gutter) * 2), var(--dcm-maxw));
	margin-inline: auto;
}

.screen-reader-text,
.sr-only {
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	position: absolute !important;
	width: 1px;
	height: 1px;
	overflow: hidden;
	white-space: nowrap;
	margin: -1px;
	padding: 0;
	border: 0;
	word-wrap: normal !important;
}

.dcm-skip-link {
	position: absolute;
	left: -9999px;
	z-index: 100000;
	padding: 0.75rem 1rem;
	background: var(--dcm-accent);
	color: var(--dcm-bg) !important;
	font-weight: 700;
	border-radius: var(--dcm-radius-sm);
	text-decoration: none;
}
.dcm-skip-link:focus {
	left: 1rem;
	top: 1rem;
	outline: 2px solid var(--dcm-text);
	outline-offset: 2px;
}

.dcm-accent-text {
	color: var(--dcm-accent);
}

/* 4. Header ----------------------------------------------------------- */
.dcm-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	min-height: var(--dcm-header-h);
	border-bottom: 1px solid transparent;
	background: rgba(7, 8, 13, 0.6);
	backdrop-filter: saturate(140%) blur(14px);
	-webkit-backdrop-filter: saturate(140%) blur(14px);
	transition: background var(--dcm-transition), border-color var(--dcm-transition), box-shadow var(--dcm-transition);
}
.dcm-header.is-scrolled {
	background: rgba(7, 8, 13, 0.92);
	border-bottom-color: var(--dcm-border);
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.35);
}

.dcm-header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 1rem;
	min-height: var(--dcm-header-h);
	padding-block: 0.5rem;
}

.dcm-header__brand {
	display: flex;
	align-items: center;
	min-width: 0;
}

.dcm-header__logo .custom-logo-link {
	display: inline-flex;
	align-items: center;
}
.dcm-header__logo img {
	max-height: 60px;
	width: auto;
}

.dcm-header__title {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: clamp(1rem, 1.5vw, 1.2rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--dcm-text);
	white-space: nowrap;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
}
.dcm-header__title-mark {
	display: inline-block;
	color: var(--dcm-accent);
	transform: translateY(-1px);
	filter: drop-shadow(0 0 6px var(--dcm-accent-glow));
}
.dcm-header__title-text {
	background: linear-gradient(105deg, var(--dcm-text) 60%, var(--dcm-accent) 130%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.dcm-header__title:hover .dcm-header__title-text {
	background: linear-gradient(105deg, var(--dcm-text) 30%, var(--dcm-accent) 110%);
	-webkit-background-clip: text;
	background-clip: text;
}

.dcm-header__nav {
	display: flex;
	justify-content: center;
	min-width: 0;
}

.dcm-menu,
.dcm-menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.dcm-menu {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.25rem 1.5rem;
	font-size: 0.95rem;
}

.dcm-menu > li {
	position: relative;
}

.dcm-menu a {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.4rem 0.1rem;
	font-weight: 500;
	color: var(--dcm-text-soft);
	border-bottom: 2px solid transparent;
	transition: color var(--dcm-transition), border-color var(--dcm-transition);
}
.dcm-menu a:hover,
.dcm-menu .current-menu-item > a,
.dcm-menu .current-menu-ancestor > a {
	color: var(--dcm-text);
	border-bottom-color: var(--dcm-accent);
}

.dcm-menu .sub-menu {
	position: absolute;
	top: calc(100% + 6px);
	left: 50%;
	transform: translateX(-50%);
	min-width: 200px;
	padding: 0.4rem;
	border: 1px solid var(--dcm-border-2);
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-card-solid);
	box-shadow: var(--dcm-shadow);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--dcm-transition), transform var(--dcm-transition);
	z-index: 5;
}
.dcm-menu li:hover > .sub-menu,
.dcm-menu li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}
.dcm-menu .sub-menu a {
	display: block;
	padding: 0.55rem 0.75rem;
	border-radius: var(--dcm-radius-xs);
	border-bottom: none;
	font-size: 0.9rem;
}
.dcm-menu .sub-menu a:hover {
	background: rgba(34, 211, 238, 0.08);
	color: var(--dcm-accent);
}

.dcm-header__actions {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	justify-self: end;
}

.dcm-header__action {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid transparent;
	border-radius: var(--dcm-radius-sm);
	background: transparent;
	color: var(--dcm-text-soft);
	cursor: pointer;
	text-decoration: none;
	transition: background var(--dcm-transition), color var(--dcm-transition), border-color var(--dcm-transition), transform 120ms ease;
}
.dcm-header__action:hover {
	background: rgba(34, 211, 238, 0.08);
	color: var(--dcm-accent);
	border-color: var(--dcm-border-2);
}
.dcm-header__action:active {
	transform: scale(0.96);
}

.dcm-header__action--menu {
	display: none;
}

.dcm-header__badge {
	position: absolute;
	top: 4px;
	right: 4px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	font-size: 0.6875rem;
	font-weight: 700;
	font-family: var(--dcm-mono);
	line-height: 18px;
	text-align: center;
	color: var(--dcm-bg);
	background: var(--dcm-grad-aurora);
	border-radius: 9px;
	box-shadow: 0 0 10px var(--dcm-accent-glow);
	transition: opacity 150ms ease, transform 150ms ease;
}
.dcm-header__badge[data-empty] {
	opacity: 0;
	transform: scale(0.6);
	pointer-events: none;
}

@keyframes dcm-bump {
	0% { transform: scale(1); }
	30% { transform: scale(1.18); }
	60% { transform: scale(0.95); }
	100% { transform: scale(1); }
}
.dcm-header__action--cart.is-bump .dcm-header__action-icon {
	animation: dcm-bump 360ms var(--dcm-ease);
}

/* 5. Off-canvas drawer ------------------------------------------------ */
.dcm-drawer {
	position: fixed;
	inset: 0;
	z-index: 2000;
}
.dcm-drawer[hidden] { display: none; }

.dcm-drawer__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(3, 4, 8, 0.7);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	opacity: 0;
	transition: opacity 220ms var(--dcm-ease);
}
.dcm-drawer.is-open .dcm-drawer__backdrop {
	opacity: 1;
}

.dcm-drawer__panel {
	position: absolute;
	inset-block: 0;
	inset-inline-start: 0;
	width: min(86vw, 360px);
	height: 100%;
	display: flex;
	flex-direction: column;
	background: var(--dcm-bg-elevated);
	border-inline-end: 1px solid var(--dcm-border-2);
	box-shadow: var(--dcm-shadow-lg);
	transform: translateX(-100%);
	transition: transform 280ms var(--dcm-ease);
	padding-block-end: env(safe-area-inset-bottom);
}
.dcm-drawer.is-open .dcm-drawer__panel {
	transform: translateX(0);
}

.dcm-drawer__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.85rem 1rem;
	border-bottom: 1px solid var(--dcm-border);
	padding-top: calc(0.85rem + env(safe-area-inset-top));
}
.dcm-drawer__title {
	font-weight: 700;
	font-size: 0.875rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--dcm-text-muted);
}
.dcm-drawer__close {
	width: 40px;
	height: 40px;
	border: 1px solid var(--dcm-border-2);
	border-radius: var(--dcm-radius-sm);
	background: transparent;
	color: var(--dcm-text-soft);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.dcm-drawer__close:hover {
	color: var(--dcm-accent);
	border-color: var(--dcm-border-strong);
}

.dcm-drawer__body {
	flex: 1;
	overflow-y: auto;
	padding: 0.5rem 0.75rem 1.25rem;
}

.dcm-drawer__menu,
.dcm-drawer__menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.dcm-drawer__menu > li > a,
.dcm-drawer__menu .sub-menu a {
	display: block;
	padding: 0.85rem 0.75rem;
	font-size: 1.025rem;
	font-weight: 500;
	color: var(--dcm-text);
	border-radius: var(--dcm-radius-sm);
	border: 1px solid transparent;
	transition: background var(--dcm-transition), border-color var(--dcm-transition), color var(--dcm-transition);
}
.dcm-drawer__menu a:hover,
.dcm-drawer__menu .current-menu-item > a {
	background: rgba(34, 211, 238, 0.08);
	color: var(--dcm-accent);
	border-color: var(--dcm-border-2);
}
.dcm-drawer__menu .sub-menu {
	margin-inline-start: 0.5rem;
	margin-block: 0.25rem 0.5rem;
	padding-inline-start: 0.5rem;
	border-inline-start: 1px solid var(--dcm-border-2);
}
.dcm-drawer__menu .sub-menu a {
	font-size: 0.95rem;
	padding-block: 0.5rem;
	color: var(--dcm-text-muted);
}

.dcm-drawer__cta {
	display: grid;
	gap: 0.5rem;
	margin-top: 1.25rem;
	padding-top: 1rem;
	border-top: 1px solid var(--dcm-border);
}

/* 6. Search panel & form --------------------------------------------- */
.dcm-search-panel {
	border-bottom: 1px solid var(--dcm-border);
	background: rgba(10, 12, 20, 0.97);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.4);
	animation: dcm-slide 220ms var(--dcm-ease);
}
.dcm-search-panel[hidden] { display: none; }

@keyframes dcm-slide {
	from { opacity: 0; transform: translateY(-8px); }
	to { opacity: 1; transform: translateY(0); }
}

.dcm-search-panel__inner {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding-block: 1rem;
}

.dcm-search-form {
	flex: 1;
	display: flex;
	gap: 0.5rem;
	align-items: stretch;
	margin: 0;
}
.dcm-search-form .search-field,
.dcm-search-form input[type='search'] {
	flex: 1 1 auto;
	min-width: 0;
	padding: 0.85rem 1rem;
	border: 1px solid var(--dcm-border-2);
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-elevated);
	color: var(--dcm-text);
	font-family: var(--dcm-font);
	font-size: 1rem;
	outline: none;
	transition: border-color var(--dcm-transition), box-shadow var(--dcm-transition);
	-webkit-appearance: none;
	appearance: none;
}
.dcm-search-form input::placeholder {
	color: var(--dcm-text-muted);
}
.dcm-search-form input:focus {
	border-color: var(--dcm-accent);
	box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.18);
}
.dcm-search-form__submit,
.dcm-search-form button[type='submit'] {
	flex-shrink: 0;
	padding: 0.85rem 1.25rem;
	border: none;
	border-radius: var(--dcm-radius-sm);
	font-family: var(--dcm-font);
	font-weight: 700;
	font-size: 0.95rem;
	cursor: pointer;
	color: var(--dcm-bg);
	background: var(--dcm-grad-aurora);
	transition: opacity var(--dcm-transition), transform 150ms ease, box-shadow var(--dcm-transition);
}
.dcm-search-form__submit:hover {
	opacity: 0.95;
	transform: translateY(-1px);
	box-shadow: 0 8px 24px var(--dcm-accent-glow);
}

.dcm-search-panel__close {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid var(--dcm-border-2);
	border-radius: var(--dcm-radius-sm);
	background: transparent;
	color: var(--dcm-text-muted);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.dcm-search-panel__close:hover {
	border-color: var(--dcm-border-strong);
	color: var(--dcm-accent);
}

/* 7. Layout / sidebar / widgets -------------------------------------- */
.dcm-main {
	flex: 1 0 auto;
	width: 100%;
	padding-block: clamp(1.25rem, 3vw, 2.5rem) clamp(2rem, 5vw, 4rem);
}

.dcm-content {
	display: block;
}

.dcm-page-header {
	margin-block-end: 2rem;
}
.dcm-page-header .dcm-page__title {
	margin-block: 0 0.5rem;
}
.dcm-page__lede {
	color: var(--dcm-text-muted);
	max-width: 65ch;
	font-size: 1.05rem;
}

.dcm-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 2rem;
}
@media (min-width: 960px) {
	body:not(.no-sidebar) .dcm-layout {
		grid-template-columns: minmax(0, 1fr) 280px;
	}
}

.dcm-layout__main {
	min-width: 0;
}

.dcm-sidebar {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.dcm-widget {
	padding: 1.25rem;
	border: 1px solid var(--dcm-border);
	border-radius: var(--dcm-radius);
	background: var(--dcm-bg-card);
}
.dcm-widget__title {
	margin: 0 0 0.75rem;
	font-size: 0.875rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--dcm-text-muted);
}
.dcm-widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.4rem;
}
.dcm-widget li a {
	color: var(--dcm-text-soft);
}
.dcm-widget li a:hover {
	color: var(--dcm-accent);
}

/* 8. Typography & prose ---------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
	margin-block: 1.4em 0.6em;
	color: var(--dcm-text);
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1.25;
}

.dcm-page__title {
	margin-top: 0;
	font-size: clamp(1.75rem, 1.4rem + 1.6vw, 2.5rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.2;
	padding-block-end: 0.05em;
	background: linear-gradient(105deg, var(--dcm-text) 30%, var(--dcm-accent) 130%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.dcm-page__hero {
	margin: 0 0 1.5rem;
	border-radius: var(--dcm-radius);
	overflow: hidden;
	border: 1px solid var(--dcm-border);
}
.dcm-page__hero img {
	width: 100%;
	height: auto;
}

.dcm-page__foot {
	margin-top: 2rem;
	padding-top: 1.25rem;
	border-top: 1px solid var(--dcm-border);
}

.dcm-prose {
	color: var(--dcm-text-soft);
	font-size: 1.0625rem;
	line-height: 1.7;
}
.dcm-prose > * { max-width: 70ch; }
.dcm-prose > .alignwide,
.dcm-prose > .alignfull,
.dcm-prose > .wp-block-cover,
.dcm-prose > .wp-block-image,
.dcm-prose > .wp-block-gallery,
.dcm-prose > .wp-block-table,
.dcm-prose > .wp-block-embed,
.dcm-prose > figure,
.dcm-prose > .wp-block-columns {
	max-width: none;
}
.dcm-prose .alignwide {
	margin-inline: calc(50% - 50vw + var(--dcm-gutter));
	max-width: calc(100vw - var(--dcm-gutter) * 2);
	width: auto;
}
.dcm-prose .alignfull {
	margin-inline: calc(50% - 50vw);
	max-width: 100vw;
	width: 100vw;
}
.dcm-prose img {
	border-radius: var(--dcm-radius-sm);
}
.dcm-prose a {
	color: var(--dcm-accent);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	text-decoration-color: rgba(34, 211, 238, 0.45);
}
.dcm-prose a:hover {
	text-decoration-color: var(--dcm-accent);
}
.dcm-prose blockquote {
	margin: 1.5rem 0;
	padding: 1.25rem 1.5rem;
	border-inline-start: 3px solid var(--dcm-accent);
	background: rgba(34, 211, 238, 0.05);
	border-radius: 0 var(--dcm-radius-sm) var(--dcm-radius-sm) 0;
	color: var(--dcm-text);
	font-size: 1.075rem;
}
.dcm-prose blockquote cite {
	display: block;
	margin-top: 0.5rem;
	font-size: 0.875rem;
	color: var(--dcm-text-muted);
}
.dcm-prose code,
.dcm-prose kbd {
	font-family: var(--dcm-mono);
	font-size: 0.9em;
	padding: 0.15em 0.4em;
	border-radius: var(--dcm-radius-xs);
	background: var(--dcm-bg-elevated);
	border: 1px solid var(--dcm-border);
}
.dcm-prose pre {
	padding: 1rem 1.25rem;
	overflow-x: auto;
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-elevated);
	border: 1px solid var(--dcm-border);
	font-size: 0.9rem;
	line-height: 1.6;
}
.dcm-prose pre code {
	padding: 0;
	background: none;
	border: none;
}
.dcm-prose hr {
	border: 0;
	height: 1px;
	margin-block: 2.5rem;
	background: var(--dcm-border-2);
}
.dcm-prose ul,
.dcm-prose ol {
	padding-inline-start: 1.4rem;
}
.dcm-prose li + li {
	margin-top: 0.4rem;
}
.dcm-prose figure {
	margin: 1.5rem 0;
}
.dcm-prose figcaption {
	margin-top: 0.5rem;
	color: var(--dcm-text-muted);
	font-size: 0.875rem;
	text-align: center;
}

/* Cards / grid */
.dcm-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.25rem;
	margin-block-end: 2rem;
}

.dcm-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border: 1px solid var(--dcm-border);
	border-radius: var(--dcm-radius);
	background: var(--dcm-bg-card);
	background-image: var(--dcm-grad-card);
	box-shadow: var(--dcm-shadow-sm);
	transition: border-color var(--dcm-transition), transform var(--dcm-transition), box-shadow var(--dcm-transition);
}
.dcm-card:hover {
	border-color: var(--dcm-border-strong);
	transform: translateY(-2px);
	box-shadow: var(--dcm-shadow);
}
.dcm-card__media {
	display: block;
	aspect-ratio: 16 / 9;
	background: var(--dcm-bg-elevated);
	overflow: hidden;
}
.dcm-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 400ms var(--dcm-ease);
}
.dcm-card:hover .dcm-card__media img {
	transform: scale(1.04);
}
.dcm-card__body {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	padding: 1.25rem;
	flex: 1;
}
.dcm-card__title {
	margin: 0;
	font-size: 1.125rem;
	font-weight: 600;
	line-height: 1.35;
}
.dcm-card__title a {
	color: var(--dcm-text);
}
.dcm-card__title a:hover {
	color: var(--dcm-accent);
}
.dcm-card__excerpt {
	color: var(--dcm-text-muted);
	font-size: 0.95rem;
}
.dcm-card__more {
	margin: 0;
	margin-top: auto;
	padding-top: 0.5rem;
}

.dcm-link-arrow {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 600;
	color: var(--dcm-accent);
}
.dcm-link-arrow svg {
	transition: transform 200ms ease;
}
.dcm-link-arrow:hover svg {
	transform: translateX(3px);
}

.dcm-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.75rem;
	font-size: 0.85rem;
	color: var(--dcm-text-muted);
}
.dcm-meta a {
	color: var(--dcm-text-soft);
}

.dcm-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	list-style: none;
	margin: 0;
	padding: 0;
}
.dcm-tags a {
	display: inline-flex;
	align-items: center;
	padding: 0.35rem 0.7rem;
	border-radius: var(--dcm-radius-pill);
	background: rgba(34, 211, 238, 0.08);
	border: 1px solid var(--dcm-border-2);
	color: var(--dcm-text-soft);
	font-size: 0.8125rem;
}
.dcm-tags a:hover {
	border-color: var(--dcm-border-strong);
	color: var(--dcm-accent);
}

.dcm-empty {
	padding: 3rem 1.5rem;
	text-align: center;
	border: 1px dashed var(--dcm-border-2);
	border-radius: var(--dcm-radius);
	background: var(--dcm-bg-card);
}
.dcm-empty form {
	max-width: 480px;
	margin-inline: auto;
	margin-top: 1rem;
}

/* 9. Buttons & forms ------------------------------------------------- */
.dcm-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem 1.4rem;
	border: 1px solid transparent;
	border-radius: var(--dcm-radius-sm);
	font-family: var(--dcm-font);
	font-weight: 700;
	font-size: 0.95rem;
	line-height: 1;
	cursor: pointer;
	color: var(--dcm-bg) !important;
	background: var(--dcm-grad-aurora);
	box-shadow: 0 4px 18px rgba(34, 211, 238, 0.18);
	transition: opacity var(--dcm-transition), transform 150ms ease, box-shadow var(--dcm-transition);
	text-decoration: none;
}
.dcm-btn:hover {
	opacity: 0.97;
	transform: translateY(-1px);
	box-shadow: 0 8px 26px var(--dcm-accent-glow);
	color: var(--dcm-bg) !important;
}
.dcm-btn:active { transform: translateY(0); }
.dcm-btn--ghost {
	background: transparent !important;
	color: var(--dcm-text) !important;
	border-color: var(--dcm-border-2);
	box-shadow: none;
}
.dcm-btn--ghost:hover {
	background: rgba(34, 211, 238, 0.08) !important;
	color: var(--dcm-accent) !important;
	border-color: var(--dcm-border-strong);
}

input[type='text'],
input[type='email'],
input[type='url'],
input[type='password'],
input[type='search'],
input[type='number'],
input[type='tel'],
input[type='date'],
input[type='time'],
input[type='datetime-local'],
textarea,
select {
	width: 100%;
	padding: 0.7rem 0.9rem;
	border: 1px solid var(--dcm-border-2);
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-elevated);
	color: var(--dcm-text);
	font-family: var(--dcm-font);
	font-size: 1rem;
	line-height: 1.4;
	transition: border-color var(--dcm-transition), box-shadow var(--dcm-transition);
	-webkit-appearance: none;
	appearance: none;
	min-height: 44px;
}
textarea {
	min-height: 120px;
	resize: vertical;
}
input:focus,
textarea:focus,
select:focus {
	border-color: var(--dcm-accent);
	box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.18);
	outline: none;
}
input::placeholder,
textarea::placeholder {
	color: var(--dcm-text-muted);
}
select {
	background-image: linear-gradient(45deg, transparent 50%, var(--dcm-text-muted) 50%),
	                  linear-gradient(135deg, var(--dcm-text-muted) 50%, transparent 50%);
	background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 2.4rem;
}

input[type='checkbox'],
input[type='radio'] {
	width: 18px;
	height: 18px;
	min-height: 0;
	margin-inline-end: 0.5rem;
	accent-color: var(--dcm-accent);
}

label {
	color: var(--dcm-text-soft);
}

button,
input[type='submit'],
input[type='button'] {
	font-family: var(--dcm-font);
}

/* 10. Pagination, tables, comments ----------------------------------- */
.dcm-page-links {
	margin-top: 2rem;
	font-size: 0.9rem;
	color: var(--dcm-text-muted);
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	align-items: center;
}
.dcm-page-links a,
.dcm-page-links > span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	min-height: 36px;
	padding: 0 0.5rem;
	border: 1px solid var(--dcm-border-2);
	border-radius: var(--dcm-radius-sm);
}

/* ——— Pagination (WordPress + WooCommerce) ——— */
.pagination,
.navigation.pagination,
.posts-navigation,
.comment-navigation,
.woocommerce-pagination,
.woocommerce nav.woocommerce-pagination {
	margin: 2rem 0 0 !important;
	padding: 0 !important;
	border: none !important;
	text-align: center;
}

/* Container <ul> (WP outputs <div class="nav-links">; WC outputs <ul class="page-numbers">) */
.pagination .nav-links,
.navigation .nav-links,
.woocommerce-pagination ul,
.woocommerce-pagination ul.page-numbers,
.woocommerce nav.woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul.page-numbers {
	display: inline-flex !important;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 0.4rem !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	background: transparent !important;
	list-style: none;
	white-space: normal !important;
}

/* Each <li> — strip WC's segmented border-right + inline-block layout */
.woocommerce-pagination ul li,
.woocommerce nav.woocommerce-pagination ul li {
	display: inline-flex !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	border-right: 0 !important;
	background: transparent !important;
	overflow: visible !important;
	float: none !important;
}

/* Each pagination chip — apply only to anchors/spans, never to the wrapping ul.page-numbers */
.pagination .page-numbers,
.navigation .page-numbers,
.nav-links .page-numbers,
.woocommerce-pagination ul li .page-numbers,
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 0.7rem !important;
	margin: 0 !important;
	border: 1px solid var(--dcm-border-2) !important;
	border-radius: var(--dcm-radius-sm) !important;
	background: var(--dcm-bg-elevated) !important;
	color: var(--dcm-text-soft) !important;
	font-family: var(--dcm-font);
	font-size: 0.9rem;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	transition: background var(--dcm-transition), color var(--dcm-transition), border-color var(--dcm-transition), transform 120ms ease, box-shadow var(--dcm-transition);
}

.pagination .page-numbers:hover,
.navigation .page-numbers:hover,
.nav-links .page-numbers:hover,
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce-pagination ul li a.page-numbers:hover {
	background: rgba(34, 211, 238, 0.08) !important;
	border-color: var(--dcm-border-strong) !important;
	color: var(--dcm-accent) !important;
	transform: translateY(-1px);
}

/* Active / current page */
.pagination .page-numbers.current,
.navigation .page-numbers.current,
.nav-links .page-numbers.current,
.woocommerce-pagination ul li span.current,
.woocommerce-pagination ul li .page-numbers.current,
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--dcm-grad-aurora) !important;
	border-color: transparent !important;
	color: var(--dcm-bg) !important;
	box-shadow: 0 4px 14px var(--dcm-accent-glow) !important;
	cursor: default;
	transform: none !important;
}

/* Dots (…) — text only, no chip */
.pagination .page-numbers.dots,
.nav-links .page-numbers.dots,
.woocommerce-pagination ul li .page-numbers.dots,
.woocommerce nav.woocommerce-pagination ul li span.page-numbers.dots {
	min-width: auto !important;
	padding: 0 0.25rem !important;
	border: none !important;
	background: transparent !important;
	color: var(--dcm-text-muted) !important;
	letter-spacing: 0.1em;
	box-shadow: none !important;
}
.pagination .page-numbers.dots:hover,
.woocommerce-pagination ul li .page-numbers.dots:hover {
	transform: none;
	color: var(--dcm-text-muted) !important;
	background: transparent !important;
}

/* Prev / Next arrows */
.pagination .page-numbers.prev,
.pagination .page-numbers.next,
.nav-links .page-numbers.prev,
.nav-links .page-numbers.next,
.woocommerce-pagination ul li a.prev,
.woocommerce-pagination ul li a.next {
	padding: 0 1rem !important;
	font-weight: 700;
	letter-spacing: 0.02em;
}
.woocommerce-pagination ul li a.prev::before,
.woocommerce-pagination ul li a.next::after {
	display: inline-block;
}

/* Posts/comment navigation (single previous/next pair) */
.posts-navigation .nav-links,
.post-navigation .nav-links,
.comment-navigation .nav-links {
	justify-content: space-between !important;
	gap: 0.5rem !important;
}
.posts-navigation .nav-previous a,
.posts-navigation .nav-next a,
.post-navigation .nav-previous a,
.post-navigation .nav-next a {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.7rem 1rem;
	border: 1px solid var(--dcm-border-2);
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-elevated);
	color: var(--dcm-text-soft);
	font-weight: 600;
	font-size: 0.9rem;
	transition: background var(--dcm-transition), color var(--dcm-transition), border-color var(--dcm-transition);
}
.posts-navigation .nav-previous a:hover,
.posts-navigation .nav-next a:hover,
.post-navigation .nav-previous a:hover,
.post-navigation .nav-next a:hover {
	background: rgba(34, 211, 238, 0.08);
	border-color: var(--dcm-border-strong);
	color: var(--dcm-accent);
}

@media (max-width: 480px) {
	.pagination .page-numbers,
	.woocommerce-pagination ul li .page-numbers,
	.woocommerce nav.woocommerce-pagination ul li a,
	.woocommerce nav.woocommerce-pagination ul li span {
		min-width: 36px;
		height: 36px;
		padding: 0 0.55rem !important;
		font-size: 0.85rem;
	}
}

table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.95rem;
}
th, td {
	padding: 0.75rem 0.85rem;
	text-align: start;
	border-bottom: 1px solid var(--dcm-border);
}
th {
	background: rgba(255, 255, 255, 0.02);
	font-weight: 600;
	color: var(--dcm-text);
}

.dcm-comments {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid var(--dcm-border);
}
.dcm-comments__title {
	font-size: 1.25rem;
	margin-top: 0;
}
.dcm-comments__list,
.dcm-comments__list ol,
.dcm-comments__list ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.dcm-comments__list .children {
	padding-inline-start: clamp(0.75rem, 2vw, 1.5rem);
}
.dcm-comments__list .comment {
	margin-block: 1rem;
	padding: 1rem 1.25rem;
	border: 1px solid var(--dcm-border);
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-card);
}
.dcm-comments__list .comment-author {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	margin-bottom: 0.5rem;
}
.dcm-comments__list .avatar {
	border-radius: 50%;
	width: 36px;
	height: 36px;
}
.dcm-comments__list .says {
	display: none;
}
.dcm-comments__list .comment-meta {
	font-size: 0.8125rem;
	color: var(--dcm-text-muted);
}
.dcm-comment-form {
	display: grid;
	gap: 0.85rem;
	margin-top: 1.5rem;
}
.dcm-comments__reply-title {
	margin: 0 0 0.5rem;
	font-size: 1.1rem;
}
.dcm-comments__closed {
	color: var(--dcm-text-muted);
	font-style: italic;
}

/* 11. Footer ---------------------------------------------------------- */
.dcm-footer {
	margin-top: auto;
	border-top: 1px solid var(--dcm-border);
	background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.4));
}
.dcm-footer__widgets {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.5rem;
	padding-block: 2.5rem;
	border-bottom: 1px solid var(--dcm-border);
}
.dcm-footer__col .dcm-widget {
	background: transparent;
	border: none;
	padding: 0;
}
.dcm-footer__col .dcm-widget__title {
	color: var(--dcm-text);
}
.dcm-footer__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-block: 1.5rem;
}
.dcm-footer__copy {
	margin: 0;
	font-size: 0.875rem;
	color: var(--dcm-text-muted);
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	align-items: center;
}
.dcm-footer__copy a {
	color: var(--dcm-text);
	font-weight: 600;
}
.dcm-footer__sep {
	opacity: 0.4;
}
.dcm-footer__menu {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem 1.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0.875rem;
}
.dcm-footer__menu a {
	color: var(--dcm-text-muted);
}
.dcm-footer__menu a:hover {
	color: var(--dcm-accent);
}

/* 12. WooCommerce — global ------------------------------------------- */
.woocommerce-breadcrumb,
.woocommerce .woocommerce-breadcrumb {
	font-size: 0.8125rem;
	color: var(--dcm-text-muted);
	margin-block: 0 1.5rem !important;
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	align-items: center;
}
.woocommerce-breadcrumb a {
	color: var(--dcm-text-soft);
}
.woocommerce-breadcrumb a:hover {
	color: var(--dcm-accent);
}

.woocommerce .page-title,
.woocommerce-page .page-title,
.woocommerce-products-header__title {
	font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2rem) !important;
	font-weight: 800 !important;
	margin: 0 0 1rem !important;
	letter-spacing: -0.02em;
	color: var(--dcm-text);
	background: linear-gradient(105deg, var(--dcm-text) 25%, var(--dcm-accent) 130%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.woocommerce-products-header .term-description,
.term-description {
	color: var(--dcm-text-muted);
	max-width: 65ch;
	margin-bottom: 1.25rem;
}

/* Shop toolbar — replaces WooCommerce's default float layout */
.dcm-shop-toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem 1.5rem;
	margin: 0 0 1.5rem;
	padding: 0.85rem 1.1rem;
	border: 1px solid var(--dcm-border);
	border-radius: var(--dcm-radius);
	background: var(--dcm-bg-card);
	background-image: var(--dcm-grad-card);
}

.woocommerce .woocommerce-result-count,
.dcm-shop-toolbar .woocommerce-result-count {
	float: none !important;
	margin: 0 !important;
	color: var(--dcm-text-muted);
	font-size: 0.8125rem;
	letter-spacing: 0.02em;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.woocommerce .woocommerce-result-count::before,
.dcm-shop-toolbar .woocommerce-result-count::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--dcm-accent);
	box-shadow: 0 0 8px var(--dcm-accent-glow);
}

.woocommerce .woocommerce-ordering,
.dcm-shop-toolbar .woocommerce-ordering {
	float: none !important;
	margin: 0 !important;
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	position: relative;
}
.woocommerce .woocommerce-ordering::before {
	content: 'Sort by';
	color: var(--dcm-text-muted);
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 600;
}

/* Modernised orderby select (works with WC's bare <select>) */
.woocommerce .woocommerce-ordering .orderby,
.woocommerce-ordering select.orderby,
.woocommerce-ordering select {
	width: auto !important;
	max-width: 100%;
	min-width: 200px;
	min-height: 40px;
	padding: 0.5rem 2.4rem 0.5rem 0.9rem !important;
	border: 1px solid var(--dcm-border-2) !important;
	border-radius: var(--dcm-radius-pill) !important;
	background: var(--dcm-bg-elevated) !important;
	color: var(--dcm-text) !important;
	font-family: var(--dcm-font) !important;
	font-size: 0.875rem !important;
	font-weight: 500;
	line-height: 1.2;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2322d3ee' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") !important;
	background-repeat: no-repeat !important;
	background-position: right 0.85rem center !important;
	background-size: 14px 14px !important;
	transition: border-color var(--dcm-transition), box-shadow var(--dcm-transition), background-color var(--dcm-transition);
}
.woocommerce-ordering select:hover {
	border-color: var(--dcm-border-strong) !important;
	background-color: rgba(34, 211, 238, 0.05) !important;
}
.woocommerce-ordering select:focus {
	border-color: var(--dcm-accent) !important;
	box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.18);
	outline: none;
}
.woocommerce-ordering select option {
	background: var(--dcm-bg-card-solid);
	color: var(--dcm-text);
}

.price {
	font-family: var(--dcm-mono) !important;
	font-weight: 600 !important;
	color: var(--dcm-accent) !important;
}
.price del {
	color: var(--dcm-text-dim) !important;
	opacity: 0.85;
	font-weight: 400;
	margin-inline-end: 0.4rem;
}
.price ins {
	background: none;
	color: var(--dcm-accent);
	text-decoration: none;
}

.star-rating {
	color: var(--dcm-warn);
}
.star-rating::before {
	color: rgba(251, 191, 36, 0.25);
}

/* Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notice {
	padding: 0.95rem 1.1rem !important;
	margin: 0 0 1rem !important;
	border-radius: var(--dcm-radius-sm) !important;
	border: 1px solid var(--dcm-border-2) !important;
	background: rgba(34, 211, 238, 0.08) !important;
	color: var(--dcm-text) !important;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.85rem;
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
	color: var(--dcm-accent) !important;
}
.woocommerce-error {
	background: rgba(248, 113, 113, 0.12) !important;
	border-color: rgba(248, 113, 113, 0.28) !important;
}
.woocommerce-error::before {
	color: var(--dcm-danger) !important;
}
.woocommerce-message a.button,
.woocommerce-info a.button {
	margin-inline-start: auto;
}

/* Buttons (WooCommerce default `.button` & alt) */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .button,
.woocommerce #respond input#submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	padding: 0.7rem 1.2rem !important;
	border: 1px solid var(--dcm-border-2) !important;
	border-radius: var(--dcm-radius-sm) !important;
	background: rgba(34, 211, 238, 0.1) !important;
	color: var(--dcm-accent) !important;
	font-family: var(--dcm-font) !important;
	font-weight: 700 !important;
	font-size: 0.95rem !important;
	line-height: 1 !important;
	min-height: 44px;
	cursor: pointer;
	transition: background var(--dcm-transition), color var(--dcm-transition), border-color var(--dcm-transition), box-shadow var(--dcm-transition), transform 120ms ease !important;
	text-shadow: none !important;
	text-decoration: none !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce .button:hover {
	background: rgba(34, 211, 238, 0.18) !important;
	border-color: var(--dcm-border-strong) !important;
	color: var(--dcm-accent-2) !important;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce .button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce-page .button.alt {
	background: var(--dcm-grad-aurora) !important;
	color: var(--dcm-bg) !important;
	border: none !important;
	box-shadow: 0 4px 18px rgba(34, 211, 238, 0.2) !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce .button.alt:hover {
	transform: translateY(-1px);
	box-shadow: 0 8px 28px var(--dcm-accent-glow) !important;
	color: var(--dcm-bg) !important;
}
.woocommerce a.button.disabled,
.woocommerce button.button:disabled,
.woocommerce .button:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/*
 * Horizontal overflow / iOS Safari — WC scripts often set intrinsic slide widths or
 * large images bypass parent bounds. Flex/grid children need min-width: 0 so text/
 * gallery cells can shrink; clip x-overflow on storefront chrome only.
 */
.dcm-main,
.dcm-layout__main,
.dcm-content,
.dcm-content--woocommerce {
	max-width: 100%;
}

.dcm-layout__main,
.dcm-layout,
.dcm-sidebar {
	min-inline-size: 0;
}

@supports (overflow: clip) {
	.dcm-main {
		overflow-x: clip;
	}
}

@media (max-width: 782px) {
	/*
		Safari <16.5: no clip; avoid horizontal page scroll rather than cropping focus.
		Use hidden only on narrow viewports where the issue reports came from.
	*/
	.dcm-main {
		overflow-x: hidden;
	}
}

/* Embed / prose inside product summaries & tabs — never widen past viewport */
.woocommerce-page .woocommerce,
.woocommerce .product .summary .woocommerce-product-details__short-description,
.woocommerce-tabs .woocommerce-Tabs-panel,
.woocommerce-Tabs-panel,
.woocommerce-product-details__short-description,
#reviews .comment-text,
.woocommerce-Reviews .woocommerce-review__description {
	overflow-wrap: anywhere;
	word-break: break-word;
}

.woocommerce-product-details__short-description a,
.woocommerce-Tabs-panel a {
	overflow-wrap: anywhere;
	word-break: break-word;
}

.woocommerce .product .summary iframe,
.woocommerce .product .summary video,
.woocommerce-tabs .woocommerce-Tabs-panel iframe,
.woocommerce-tabs .woocommerce-Tabs-panel video {
	max-width: 100% !important;
	height: auto !important;
}

.woocommerce .product .summary pre,
.woocommerce-tabs .woocommerce-Tabs-panel pre {
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

/* Long tables inside description / reviews — horizontal scroll strip */
.woocommerce-Tabs-panel,
.woocommerce-product-details__short-description {
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}

.woocommerce-Tabs-panel table,
.woocommerce-product-details__short-description table {
	width: auto !important;
	min-width: 100%;
	max-width: none !important;
}

/* 13. WooCommerce — shop loop ---------------------------------------- */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 1.25rem;
	list-style: none;
	margin: 0 !important;
	padding: 0 !important;
	clear: none !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after {
	display: none !important;
	content: none !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	width: auto !important;
	float: none !important;
	clear: none !important;
	margin: 0 !important;
	padding: 1rem !important;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	position: relative;
	min-width: 0;
	max-width: 100%;
	border-radius: var(--dcm-radius);
	border: 1px solid var(--dcm-border);
	background: var(--dcm-bg-card);
	background-image: var(--dcm-grad-card);
	box-shadow: var(--dcm-shadow-sm);
	transition: border-color var(--dcm-transition), box-shadow var(--dcm-transition), transform var(--dcm-transition);
}
.woocommerce ul.products li.product:hover {
	border-color: var(--dcm-border-strong);
	box-shadow: var(--dcm-shadow);
	transform: translateY(-3px);
}
.woocommerce ul.products li.product .woocommerce-loop-product__link {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	color: inherit;
	min-width: 0;
	max-width: 100%;
	overflow: hidden;
	border-radius: var(--dcm-radius-sm);
}

.woocommerce ul.products li.product img,
.woocommerce ul.products li.product .attachment-woocommerce_thumbnail {
	flex: 0 0 auto;
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
	margin: 0 !important;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	object-position: center;
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-elevated);
	display: block;
	box-sizing: border-box;
	vertical-align: top;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-category__title,
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3 {
	font-family: var(--dcm-font) !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	margin: 0 !important;
	padding: 0 !important;
	color: var(--dcm-text) !important;
	line-height: 1.35 !important;
	overflow-wrap: anywhere;
	word-break: break-word;
}

.woocommerce ul.products li.product .price {
	font-size: 1.05rem !important;
	margin: 0 !important;
}

.woocommerce ul.products li.product .star-rating {
	margin: 0 !important;
	font-size: 0.85em;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
	margin-top: auto !important;
	width: 100%;
	background: rgba(34, 211, 238, 0.1) !important;
	color: var(--dcm-accent) !important;
}
.woocommerce ul.products li.product .button:hover {
	background: var(--dcm-grad-aurora) !important;
	color: var(--dcm-bg) !important;
	box-shadow: 0 8px 22px var(--dcm-accent-glow) !important;
}
.woocommerce ul.products li.product .added_to_cart {
	display: inline-flex;
	justify-content: center;
}

/* Defensive: prevent invisible/empty buttons no matter what other code does. */
.woocommerce ul.products li.product .button:empty::after {
	content: attr(aria-label);
	font-size: 0.85em;
}

/* "View product" — soft secondary style for not-purchasable items */
.woocommerce ul.products li.product .dcm-loop-link--view {
	background: transparent !important;
	color: var(--dcm-text-soft) !important;
	border: 1px solid var(--dcm-border-2) !important;
}
.woocommerce ul.products li.product .dcm-loop-link--view:hover {
	background: rgba(34, 211, 238, 0.08) !important;
	color: var(--dcm-accent) !important;
	border-color: var(--dcm-border-strong) !important;
	box-shadow: none !important;
}

/* "Out of stock" — danger-tinted, non-actionable */
.woocommerce ul.products li.product .dcm-loop-link--oos {
	background: rgba(248, 113, 113, 0.08) !important;
	color: var(--dcm-danger) !important;
	border: 1px solid rgba(248, 113, 113, 0.25) !important;
	cursor: not-allowed;
	opacity: 0.9;
}
.woocommerce ul.products li.product .dcm-loop-link--oos:hover {
	background: rgba(248, 113, 113, 0.12) !important;
	color: var(--dcm-danger) !important;
	border-color: rgba(248, 113, 113, 0.4) !important;
	box-shadow: none !important;
	transform: none !important;
}

/* Show an out-of-stock badge on cards whose action button is OOS */
.woocommerce ul.products li.product:has(.dcm-loop-link--oos) {
	opacity: 0.92;
}
.woocommerce ul.products li.product:has(.dcm-loop-link--oos) .attachment-woocommerce_thumbnail,
.woocommerce ul.products li.product:has(.dcm-loop-link--oos) img {
	filter: grayscale(0.4);
}

/* Sale & out-of-stock badges */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
	position: absolute;
	top: 0.85rem;
	inset-inline-start: 0.85rem;
	z-index: 2;
	min-width: auto;
	min-height: auto;
	padding: 0.25rem 0.6rem !important;
	margin: 0 !important;
	font-family: var(--dcm-mono) !important;
	font-weight: 700 !important;
	font-size: 0.7rem !important;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--dcm-bg) !important;
	background: var(--dcm-grad-aurora) !important;
	border-radius: var(--dcm-radius-pill) !important;
	box-shadow: 0 4px 18px var(--dcm-accent-glow);
	line-height: 1.4 !important;
	border: none !important;
	top: 0.85rem !important;
	right: auto !important;
	left: 0.85rem !important;
}
.woocommerce .stock.out-of-stock {
	color: var(--dcm-danger);
}

/* 14. WooCommerce — single product ----------------------------------- */
.single-product .product {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: clamp(1rem, 3vw, 2.5rem);
	align-items: start;
	min-width: 0;
	padding: clamp(1rem, 3vw, 2rem);
	border-radius: var(--dcm-radius);
	border: 1px solid var(--dcm-border);
	background: var(--dcm-bg-card);
	box-shadow: var(--dcm-shadow-sm);
	margin-bottom: 2rem;
}
.single-product .product::before,
.single-product .product::after {
	display: none !important;
	content: none !important;
}
@media (max-width: 720px) {
	.single-product .product {
		grid-template-columns: 1fr;
		padding: 1rem;
	}
}

.single-product .product .images,
.single-product .product .summary,
.single-product .product .woocommerce-product-gallery {
	width: 100% !important;
	max-width: 100% !important;
	float: none !important;
	margin: 0 !important;
	min-width: 0;
}

.single-product div.product div.images {
	position: relative;
	max-width: 100%;
	overflow: hidden;
}

.single-product .woocommerce-product-gallery.images,
.single-product .woocommerce-product-gallery {
	max-width: 100% !important;
}

.single-product .flex-viewport,
.single-product div.product div.images > .woocommerce-product-gallery .flex-viewport {
	max-width: 100% !important;
	overflow: hidden !important;
}

.single-product .flexslider,
.single-product .flexslider.flexslider-carousel {
	max-width: 100% !important;
	margin-bottom: 0 !important;
}

.single-product .flexslider .slides {
	max-width: 100%;
}

.single-product .flexslider .slides > li {
	max-width: 100% !important;
	overflow: hidden;
	box-sizing: border-box;
}

.single-product .flexslider .slides > li img {
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
	display: block;
	box-sizing: border-box;
	vertical-align: top;
}

.single-product .woocommerce-product-gallery__wrapper {
	border-radius: var(--dcm-radius);
	overflow: hidden;
	background: var(--dcm-bg-elevated);
	max-width: 100% !important;
}

.single-product .woocommerce-product-gallery__image,
.single-product .woocommerce-product-gallery__image a {
	display: block;
	max-width: 100% !important;
	box-sizing: border-box;
}

.single-product .woocommerce-product-gallery__image img {
	border-radius: var(--dcm-radius);
	width: auto;
	max-width: 100% !important;
	height: auto !important;
	display: block;
	object-fit: contain;
	object-position: center;
}

/* Block-based single-product / patterns */
.wp-block-product-image img,
.wp-block-woocommerce-single-product-block img {
	max-width: 100% !important;
	height: auto !important;
}

.wc-block-components-product-gallery,
.wc-block-components-product-image {
	max-width: 100%;
	min-width: 0;
	overflow: hidden;
}

.single-product .flex-control-thumbs {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.4rem;
	margin: 0.5rem 0 0 !important;
	padding: 0 !important;
	list-style: none;
}
.single-product .flex-control-thumbs li {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
}
.single-product .flex-control-thumbs img {
	border-radius: var(--dcm-radius-sm);
	border: 1px solid var(--dcm-border);
	opacity: 0.7;
	transition: opacity var(--dcm-transition), border-color var(--dcm-transition);
}
.single-product .flex-control-thumbs img:hover,
.single-product .flex-control-thumbs img.flex-active {
	opacity: 1;
	border-color: var(--dcm-border-strong);
}

@media (max-width: 600px) {
	/* Many thumbs: horizontal strip with snap (iOS-safe) */
	.single-product .flex-control-thumbs {
		display: flex !important;
		flex-wrap: nowrap;
		grid-template-columns: unset;
		gap: 0.4rem;
		max-width: 100%;
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-overflow-scrolling: touch;
		overscroll-behavior-x: contain;
		scroll-snap-type: x mandatory;
		padding-bottom: 4px;
	}
	.single-product .flex-control-thumbs li {
		flex: 0 0 clamp(52px, 16vw, 68px);
		scroll-snap-align: start;
	}
	.single-product .flex-control-thumbs img {
		width: 100%;
		height: auto;
		aspect-ratio: 1 / 1;
		object-fit: cover;
	}
}

.single-product .product_title {
	margin: 0 0 0.75rem !important;
	font-size: clamp(1.5rem, 1.1rem + 1.5vw, 2rem) !important;
	font-weight: 800 !important;
	color: var(--dcm-text) !important;
	letter-spacing: -0.02em;
	overflow-wrap: anywhere;
	word-break: break-word;
}

.single-product .summary {
	max-width: 100%;
	overflow-wrap: anywhere;
	word-break: break-word;
	hyphens: auto;
	-webkit-hyphens: auto;
}

.single-product .summary .price {
	font-size: 1.4rem !important;
	margin: 0 0 0.75rem !important;
}
.single-product .woocommerce-product-rating {
	margin-bottom: 0.75rem !important;
}
.single-product .woocommerce-product-details__short-description {
	color: var(--dcm-text-soft);
	margin-bottom: 1.25rem;
}

.single-product form.cart {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	align-items: center;
	margin: 1.25rem 0 !important;
	padding: 1rem;
	border: 1px solid var(--dcm-border);
	border-radius: var(--dcm-radius-sm);
	background: rgba(255, 255, 255, 0.015);
}
.single-product form.cart .quantity {
	margin: 0 !important;
}
.single-product form.cart .quantity .qty {
	width: 80px;
	min-height: 44px;
	padding: 0.5rem 0.6rem;
	text-align: center;
	font-family: var(--dcm-mono);
	background: var(--dcm-bg-elevated);
	border: 1px solid var(--dcm-border-2);
	color: var(--dcm-text);
	border-radius: var(--dcm-radius-sm);
}
.single-product form.cart .single_add_to_cart_button {
	flex: 1 1 200px;
	min-height: 48px;
	font-size: 1rem !important;
}

/* Variations */
.single-product form.cart table.variations {
	table-layout: fixed;
	width: 100%;
}
.single-product table.variations td,
.single-product table.variations th {
	word-break: break-word;
}
.single-product table.variations th,
.single-product table.variations td {
	border: none;
	padding: 0.4rem 0;
	background: transparent;
	vertical-align: middle;
}
.single-product table.variations th {
	width: 30%;
	color: var(--dcm-text-muted);
	font-weight: 500;
	font-size: 0.875rem;
}
.single-product table.variations select {
	min-width: 0;
	max-width: 100%;
	box-sizing: border-box;
}
.single-product .reset_variations {
	color: var(--dcm-text-muted);
	font-size: 0.8125rem;
}

.product_meta {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--dcm-border);
	font-size: 0.875rem;
	color: var(--dcm-text-muted);
}
.product_meta > span {
	display: block;
	margin-block: 0.25rem;
}
.product_meta a {
	color: var(--dcm-text-soft);
}

/* Tabs */
.woocommerce-tabs {
	margin-top: 2rem;
	grid-column: 1 / -1;
}
.woocommerce-tabs ul.tabs {
	list-style: none;
	margin: 0 0 0 !important;
	padding: 0 !important;
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	border: none !important;
	background: transparent !important;
}
.woocommerce-tabs ul.tabs::before,
.woocommerce-tabs ul.tabs::after {
	display: none !important;
}
.woocommerce-tabs ul.tabs li {
	margin: 0 !important;
	padding: 0 !important;
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
}
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after {
	display: none !important;
}
.woocommerce-tabs ul.tabs li a {
	display: inline-flex !important;
	align-items: center;
	padding: 0.7rem 1rem !important;
	border: 1px solid var(--dcm-border-2) !important;
	border-radius: var(--dcm-radius-sm) !important;
	background: var(--dcm-bg-elevated) !important;
	color: var(--dcm-text-muted) !important;
	font-weight: 600 !important;
	font-size: 0.9rem;
}
.woocommerce-tabs ul.tabs li.active a {
	background: rgba(34, 211, 238, 0.12) !important;
	color: var(--dcm-accent) !important;
	border-color: var(--dcm-border-strong) !important;
}
.woocommerce-tabs .panel,
.woocommerce-Tabs-panel {
	margin-top: 1rem;
	padding: 1.25rem;
	border: 1px solid var(--dcm-border);
	border-radius: var(--dcm-radius);
	background: var(--dcm-bg-card);
	color: var(--dcm-text-soft);
}

/* Reviews */
.woocommerce #reviews #comments ol.commentlist {
	padding: 0 !important;
}
.woocommerce #reviews #comments ol.commentlist li {
	margin: 0 0 1rem !important;
	padding: 1rem !important;
	border: 1px solid var(--dcm-border) !important;
	border-radius: var(--dcm-radius-sm) !important;
	background: var(--dcm-bg-card);
}
.woocommerce #reviews #comments ol.commentlist li img.avatar {
	border: none !important;
	background: transparent !important;
	padding: 0 !important;
	border-radius: 50% !important;
	width: 44px !important;
	height: 44px !important;
}
.woocommerce #review_form #respond .comment-form-rating {
	margin-bottom: 0.5rem;
}

/* Related / Upsells */
.related.products,
.upsells.products,
.cross-sells {
	margin-top: 2.5rem;
}
.related.products > h2,
.upsells.products > h2,
.cross-sells > h2 {
	font-size: 1.25rem;
	margin: 0 0 1rem;
}

/* 15. WooCommerce — cart, checkout, account, blocks ------------------ */
/* Empty cart — classic notice */
.woocommerce-cart .cart-empty,
.woocommerce-checkout-empty,
.wc-empty-cart-message {
	max-width: 560px;
	margin: 1.5rem auto !important;
	padding: 1.5rem !important;
	text-align: center;
	border: 1px dashed var(--dcm-border-2) !important;
	border-radius: var(--dcm-radius);
	background: var(--dcm-bg-card) !important;
	color: var(--dcm-text-soft) !important;
	font-size: 1rem;
}
.woocommerce-cart .return-to-shop,
.wc-empty-cart-message + p {
	text-align: center;
	margin-top: 1rem;
}

/* Empty cart — Gutenberg block (the one currently dominating the page) */
.wp-block-woocommerce-empty-cart-block {
	max-width: 720px;
	margin-inline: auto !important;
	padding: 1.5rem 1rem !important;
	text-align: center;
}
.wp-block-woocommerce-empty-cart-block > * {
	max-width: 560px;
	margin-inline: auto;
}
.wp-block-woocommerce-empty-cart-block .wc-block-cart__empty-cart__title,
.wp-block-woocommerce-empty-cart-block > h2 {
	margin: 0.5rem auto 0.25rem !important;
	font-size: clamp(1.25rem, 1rem + 1.2vw, 1.6rem) !important;
	font-weight: 800 !important;
	letter-spacing: -0.01em;
	color: var(--dcm-text) !important;
}
.wp-block-woocommerce-empty-cart-block > p {
	color: var(--dcm-text-muted);
	margin: 0 auto 0.75rem !important;
}
.wp-block-woocommerce-empty-cart-block hr,
.wp-block-woocommerce-empty-cart-block .wp-block-separator {
	margin: 1.25rem auto !important;
	max-width: 320px;
	border: 0;
	height: 1px;
	background: var(--dcm-border-2);
}

/* Friendly cart icon above the title */
.wp-block-woocommerce-empty-cart-block::before {
	content: '';
	display: block;
	width: 56px;
	height: 56px;
	margin: 0 auto 0.85rem;
	border-radius: 50%;
	background-color: rgba(34, 211, 238, 0.08);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 24 24' fill='none' stroke='%2322d3ee' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 7h14l-1 9H7L6 7zm0 0L5 3H2'/><circle cx='9' cy='20' r='1.5' fill='%2322d3ee'/><circle cx='17' cy='20' r='1.5' fill='%2322d3ee'/></svg>");
	background-repeat: no-repeat;
	background-position: center;
	border: 1px solid var(--dcm-border-2);
}

/* "New in store" heading inside the empty-cart block */
.wp-block-woocommerce-empty-cart-block h2 + .wp-block-woocommerce-product-new,
.wp-block-woocommerce-empty-cart-block h2 + .wc-block-product-new,
.wp-block-woocommerce-empty-cart-block h2 + ul {
	margin-top: 0.75rem !important;
}
.wp-block-woocommerce-empty-cart-block h2 {
	font-size: 0.8125rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--dcm-text-muted) !important;
}

/* Override the > * 560px child cap so the upsell grid can use full block width */
.wp-block-woocommerce-empty-cart-block > .wp-block-woocommerce-product-new,
.wp-block-woocommerce-empty-cart-block > .wc-block-product-new,
.wp-block-woocommerce-empty-cart-block > .wc-block-grid,
.wp-block-woocommerce-empty-cart-block > ul.products,
.wp-block-woocommerce-empty-cart-block > ul.wc-block-grid__products {
	max-width: none !important;
}
.wp-block-woocommerce-empty-cart-block .wc-block-grid {
	max-width: 720px;
	margin-inline: auto !important;
}

/* Compact product grid inside the empty-cart upsell — beat WC's flex layout */
.wp-block-woocommerce-empty-cart-block ul,
.wp-block-woocommerce-empty-cart-block ul.products,
.wp-block-woocommerce-empty-cart-block ul.wc-block-grid__products,
.wp-block-woocommerce-empty-cart-block .wc-block-grid ul,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__products,
.wp-block-woocommerce-empty-cart-block .wp-block-woocommerce-product-new ul {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
	gap: 0.85rem !important;
	max-width: 720px !important;
	width: 100% !important;
	margin: 0.5rem auto 0 !important;
	padding: 0 !important;
	list-style: none !important;
	text-align: start;
	flex-wrap: wrap;
}
.wp-block-woocommerce-empty-cart-block ul::before,
.wp-block-woocommerce-empty-cart-block ul::after {
	display: none !important;
	content: none !important;
}

/* Each product card — neutralise WC's fixed width / float / flex-basis */
.wp-block-woocommerce-empty-cart-block li,
.wp-block-woocommerce-empty-cart-block ul li,
.wp-block-woocommerce-empty-cart-block ul.products li.product,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product,
.wp-block-woocommerce-empty-cart-block ul.wc-block-grid__products > li {
	display: flex !important;
	flex: 1 1 auto !important;
	flex-direction: column !important;
	gap: 0.4rem !important;
	min-width: 0 !important;
	max-width: none !important;
	width: auto !important;
	margin: 0 !important;
	padding: 0.75rem !important;
	float: none !important;
	clear: none !important;
	border: 1px solid var(--dcm-border) !important;
	border-radius: var(--dcm-radius-sm) !important;
	background: var(--dcm-bg-card) !important;
	font-size: 0.85rem;
	text-align: start !important;
	overflow: hidden;
	box-sizing: border-box;
	word-break: break-word;
}
.wp-block-woocommerce-empty-cart-block li::before,
.wp-block-woocommerce-empty-cart-block li::after {
	display: none !important;
	content: none !important;
}

/* Inner anchor sometimes wraps the entire card on Woo blocks */
.wp-block-woocommerce-empty-cart-block li > a,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-link {
	display: flex !important;
	flex-direction: column;
	gap: 0.4rem;
	color: inherit;
	text-decoration: none;
}

/* Thumbnails — uniform square, never natural-width */
.wp-block-woocommerce-empty-cart-block li img,
.wp-block-woocommerce-empty-cart-block ul.products li.product img,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-image img,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-image {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
	aspect-ratio: 1 / 1 !important;
	object-fit: cover !important;
	border-radius: var(--dcm-radius-xs) !important;
	margin: 0 0 0.25rem !important;
	background: var(--dcm-bg-elevated);
}

/* Title — wrap by word, clamp to 2 lines */
.wp-block-woocommerce-empty-cart-block li h3,
.wp-block-woocommerce-empty-cart-block li .woocommerce-loop-product__title,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-title {
	font-size: 0.85rem !important;
	font-weight: 600 !important;
	line-height: 1.3 !important;
	margin: 0 0 0.2rem !important;
	color: var(--dcm-text) !important;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	word-break: normal;
	overflow-wrap: anywhere;
	white-space: normal !important;
	writing-mode: horizontal-tb !important;
}

/* Price */
.wp-block-woocommerce-empty-cart-block li .price,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product-price {
	font-size: 0.85rem !important;
	margin: 0 0 0.35rem !important;
	white-space: nowrap !important;
	writing-mode: horizontal-tb !important;
}

/* Action button — never let single chars wrap vertically */
.wp-block-woocommerce-empty-cart-block li .button,
.wp-block-woocommerce-empty-cart-block li .added_to_cart,
.wp-block-woocommerce-empty-cart-block .wc-block-grid__product .wp-block-button__link {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 100% !important;
	padding: 0.5rem 0.75rem !important;
	margin-top: auto !important;
	font-size: 0.8rem !important;
	font-weight: 700 !important;
	line-height: 1.2 !important;
	min-height: 36px !important;
	white-space: nowrap !important;
	overflow: hidden;
	text-overflow: ellipsis;
	writing-mode: horizontal-tb !important;
	word-break: keep-all !important;
	overflow-wrap: normal !important;
}

/* Mobile: 2 columns with comfy thumbnails */
@media (max-width: 600px) {
	.wp-block-woocommerce-empty-cart-block ul,
	.wp-block-woocommerce-empty-cart-block ul.products,
	.wp-block-woocommerce-empty-cart-block ul.wc-block-grid__products,
	.wp-block-woocommerce-empty-cart-block .wc-block-grid ul,
	.wp-block-woocommerce-empty-cart-block .wc-block-grid__products {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 0.65rem !important;
	}
}
@media (max-width: 360px) {
	.wp-block-woocommerce-empty-cart-block ul,
	.wp-block-woocommerce-empty-cart-block .wc-block-grid__products {
		grid-template-columns: 1fr !important;
	}
}

/* CTA back to shop on empty cart */
.wp-block-woocommerce-empty-cart-block .wp-block-button,
.wp-block-woocommerce-empty-cart-block + p .button,
.woocommerce-cart .return-to-shop .button {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

.woocommerce table.shop_table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid var(--dcm-border) !important;
	border-radius: var(--dcm-radius);
	overflow: hidden;
	background: var(--dcm-bg-card);
	margin-bottom: 1.5rem !important;
}
.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
	padding: 0.85rem 1rem !important;
	border-top: 1px solid var(--dcm-border) !important;
	background: transparent !important;
	color: var(--dcm-text-soft) !important;
	vertical-align: middle;
}
.woocommerce table.shop_table thead th {
	border-top: none !important;
	background: rgba(255, 255, 255, 0.02) !important;
	color: var(--dcm-text) !important;
	font-weight: 600;
	letter-spacing: 0.02em;
}
.woocommerce table.shop_table tbody tr:first-child td {
	border-top: none !important;
}
.woocommerce table.shop_table img {
	width: 56px !important;
	max-width: 56px !important;
	border-radius: var(--dcm-radius-sm);
}
.woocommerce-cart-form .product-remove a.remove,
.woocommerce a.remove {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: rgba(248, 113, 113, 0.12) !important;
	color: var(--dcm-danger) !important;
	font-weight: 700;
	transition: background var(--dcm-transition), color var(--dcm-transition);
	text-decoration: none !important;
}
.woocommerce a.remove:hover {
	background: var(--dcm-danger) !important;
	color: var(--dcm-bg) !important;
}

/* Cart-collaterals */
.woocommerce .cart-collaterals,
.woocommerce-page .cart-collaterals {
	width: 100% !important;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 1.5rem;
	margin-top: 1rem;
}
.woocommerce .cart-collaterals .cart_totals {
	width: 100% !important;
	float: none !important;
}
.woocommerce .cart-collaterals .cart_totals h2 {
	margin: 0 0 0.75rem;
	font-size: 1.1rem;
}
.woocommerce-cart .actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
	padding-top: 0.5rem !important;
}
.woocommerce-cart .actions .coupon {
	display: flex !important;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
	flex: 1 1 280px;
}
.woocommerce-cart .actions .coupon input.input-text {
	min-width: 140px;
	flex: 1 1 160px;
	width: auto !important;
}

/* Coupon / login toggles on checkout */
.woocommerce-form-login-toggle,
.woocommerce-form-coupon-toggle {
	margin-bottom: 1rem !important;
}
.woocommerce-form-login,
.woocommerce-form-coupon {
	margin-bottom: 1.25rem !important;
	padding: 1rem;
	border: 1px solid var(--dcm-border);
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-card);
}

/* Checkout */
.woocommerce-checkout #customer_details {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 1.25rem;
	margin-bottom: 1rem;
}
@media (min-width: 768px) {
	.woocommerce-checkout #customer_details {
		grid-template-columns: 1fr 1fr;
	}
}
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
	width: 100% !important;
	float: none !important;
	max-width: none !important;
}
.woocommerce form .form-row {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	margin: 0 0 0.85rem !important;
	padding: 0 !important;
}
.woocommerce form .form-row label {
	font-size: 0.875rem;
	color: var(--dcm-text-muted);
}
.woocommerce form .form-row .required { color: var(--dcm-accent); }
.woocommerce form .form-row .input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea,
.woocommerce form .select2-container .select2-selection--single {
	width: 100% !important;
}
.woocommerce form .form-row.woocommerce-invalid input.input-text,
.woocommerce form .form-row.woocommerce-invalid select {
	border-color: var(--dcm-danger) !important;
	box-shadow: 0 0 0 3px rgba(248, 113, 113, 0.18);
}
.woocommerce form .form-row.woocommerce-validated input.input-text {
	border-color: var(--dcm-success) !important;
}

#order_review_heading {
	margin-top: 1.5rem;
}

#payment {
	background: var(--dcm-bg-card) !important;
	border: 1px solid var(--dcm-border) !important;
	border-radius: var(--dcm-radius) !important;
}
#payment ul.payment_methods {
	border-bottom: 1px solid var(--dcm-border) !important;
	padding: 1rem !important;
}
#payment ul.payment_methods li {
	background: transparent !important;
}
#payment div.payment_box {
	background: rgba(34, 211, 238, 0.05) !important;
	color: var(--dcm-text-soft) !important;
	border-radius: var(--dcm-radius-sm) !important;
	border: 1px solid var(--dcm-border) !important;
	margin-top: 0.5rem !important;
}
#payment div.payment_box::before {
	border-bottom-color: var(--dcm-border) !important;
}
#payment .place-order {
	padding: 1rem !important;
}

/* Account */
.woocommerce-account .woocommerce-MyAccount-navigation {
	margin-bottom: 1.5rem;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 0.4rem;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	margin: 0 !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation a {
	display: block;
	padding: 0.7rem 0.9rem;
	border: 1px solid var(--dcm-border-2);
	border-radius: var(--dcm-radius-sm);
	background: var(--dcm-bg-elevated);
	color: var(--dcm-text-muted);
	font-weight: 500;
	font-size: 0.9rem;
	text-align: center;
	transition: background var(--dcm-transition), color var(--dcm-transition), border-color var(--dcm-transition);
}
.woocommerce-account .woocommerce-MyAccount-navigation a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a {
	background: rgba(34, 211, 238, 0.1);
	border-color: var(--dcm-border-strong);
	color: var(--dcm-accent);
}

.woocommerce-MyAccount-content > * + * {
	margin-top: 1rem;
}

/* Select2 (used by WooCommerce) */
.select2-container--default .select2-selection--single {
	height: 44px !important;
	padding: 0 0.5rem !important;
	background: var(--dcm-bg-elevated) !important;
	border: 1px solid var(--dcm-border-2) !important;
	border-radius: var(--dcm-radius-sm) !important;
	color: var(--dcm-text) !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
	color: var(--dcm-text) !important;
	line-height: 44px !important;
	padding: 0 0.4rem !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 44px !important;
}
.select2-dropdown {
	background: var(--dcm-bg-card-solid) !important;
	border: 1px solid var(--dcm-border-2) !important;
	color: var(--dcm-text);
}
.select2-container--default .select2-results__option--highlighted[aria-selected] {
	background: rgba(34, 211, 238, 0.18) !important;
	color: var(--dcm-accent) !important;
}
.select2-search--dropdown .select2-search__field {
	background: var(--dcm-bg-elevated) !important;
	border: 1px solid var(--dcm-border-2) !important;
	color: var(--dcm-text);
	border-radius: var(--dcm-radius-sm);
}

/* Cart / Checkout blocks (Gutenberg) */
.wc-block-components-button,
.wp-block-button__link {
	background: var(--dcm-grad-aurora) !important;
	color: var(--dcm-bg) !important;
	border: none !important;
	border-radius: var(--dcm-radius-sm) !important;
	font-weight: 700 !important;
}
.wc-block-components-text-input input,
.wc-block-components-select select,
.wc-block-components-textarea {
	background: var(--dcm-bg-elevated) !important;
	border-color: var(--dcm-border-2) !important;
	color: var(--dcm-text) !important;
	border-radius: var(--dcm-radius-sm) !important;
}
.wc-block-components-product-name,
.wc-block-components-product-price {
	color: var(--dcm-text) !important;
}

/* 16. 404 / empty states --------------------------------------------- */
.dcm-404 {
	max-width: 600px;
	margin-inline: auto;
	text-align: center;
	padding: 2rem 1rem;
}
.dcm-404__code {
	font-family: var(--dcm-mono);
	font-size: clamp(4rem, 14vw, 8rem);
	font-weight: 700;
	margin: 0 0 0.5rem;
	letter-spacing: 0.04em;
	background: var(--dcm-grad-aurora);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	line-height: 1;
	filter: drop-shadow(0 0 30px rgba(34, 211, 238, 0.25));
}
.dcm-404__search {
	margin-block: 1.5rem;
}

/* 17. Reduced motion + print + responsive --------------------------- */

/* ===== Mobile / Tablet ============================================= */
@media (max-width: 900px) {
	.dcm-menu .sub-menu {
		position: static;
		transform: none;
		box-shadow: none;
		opacity: 1;
		visibility: visible;
		min-width: 0;
		padding: 0;
		border: none;
		background: transparent;
	}
}

@media (max-width: 782px) {
	:root {
		--dcm-header-h: var(--dcm-header-h-mobile);
	}
	.dcm-header__action--menu {
		display: inline-flex;
	}
	.dcm-header__nav {
		display: none;
	}
	.dcm-header__inner {
		grid-template-columns: auto 1fr auto;
	}
	.dcm-header__brand {
		justify-self: start;
	}

	/* Full-screen search on mobile */
	.dcm-search-panel {
		position: fixed;
		inset: 0;
		z-index: 2100;
		border: 0;
		display: flex;
		align-items: flex-start;
		padding-top: env(safe-area-inset-top);
	}
	.dcm-search-panel__inner {
		flex: 1;
		flex-wrap: nowrap;
		padding: 0.85rem 1rem;
	}
	.dcm-search-form {
		flex: 1;
	}

	body.dcm-search-open {
		overflow: hidden;
	}

	.dcm-page__title {
		font-size: clamp(1.5rem, 5vw, 2rem);
	}

	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 0.85rem;
	}
	.woocommerce ul.products li.product {
		padding: 0.75rem !important;
	}
	.woocommerce ul.products li.product .woocommerce-loop-product__title {
		font-size: 0.95rem !important;
	}

	.dcm-shop-toolbar {
		padding: 0.75rem 0.85rem;
	}
	.dcm-shop-toolbar .woocommerce-ordering {
		width: 100%;
	}
	.woocommerce .woocommerce-ordering .orderby,
	.woocommerce-ordering select {
		width: 100% !important;
	}
	.woocommerce-result-count,
	.woocommerce-ordering {
		float: none !important;
	}

	/* Cart table: convert to cards on mobile */
	.woocommerce-cart-form table.shop_table {
		border: none !important;
		background: transparent;
		display: block;
	}
	.woocommerce-cart-form table.shop_table thead {
		display: none;
	}
	.woocommerce-cart-form table.shop_table tbody,
	.woocommerce-cart-form table.shop_table tfoot {
		display: block;
		width: 100%;
	}
	.woocommerce-cart-form table.shop_table tr {
		display: block;
		width: 100%;
		padding: 0.85rem 1rem;
		margin-bottom: 0.75rem;
		border: 1px solid var(--dcm-border) !important;
		border-radius: var(--dcm-radius);
		background: var(--dcm-bg-card);
	}
	.woocommerce-cart-form table.shop_table tr.cart_item td {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 0.75rem;
		padding: 0.4rem 0 !important;
		border: none !important;
		text-align: end;
	}
	.woocommerce-cart-form table.shop_table tr.cart_item td.product-thumbnail {
		justify-content: center;
		padding-bottom: 0.5rem !important;
	}
	.woocommerce-cart-form table.shop_table tr.cart_item td.product-thumbnail img {
		width: 96px !important;
		max-width: 96px !important;
	}
	.woocommerce-cart-form table.shop_table tr.cart_item td.product-name {
		justify-content: center;
		text-align: center;
		font-weight: 600;
		font-size: 1.05rem;
		padding-bottom: 0.6rem !important;
		border-bottom: 1px solid var(--dcm-border) !important;
		margin-bottom: 0.4rem;
	}
	.woocommerce-cart-form table.shop_table tr.cart_item td::before {
		content: attr(data-title);
		font-size: 0.75rem;
		color: var(--dcm-text-muted);
		text-transform: uppercase;
		letter-spacing: 0.06em;
		font-weight: 600;
		text-align: start;
	}
	.woocommerce-cart-form table.shop_table tr.cart_item td.product-thumbnail::before,
	.woocommerce-cart-form table.shop_table tr.cart_item td.product-name::before {
		display: none;
	}
	.woocommerce-cart-form table.shop_table tr.cart_item td.product-quantity .qty {
		max-width: 80px;
	}
	.woocommerce-cart-form table.shop_table tr.actions td {
		display: block;
		padding: 0 !important;
	}
	.woocommerce-cart-form table.shop_table tr.actions .coupon {
		flex-wrap: wrap;
	}

	/* Account nav: scrollable horizontal */
	.woocommerce-account .woocommerce-MyAccount-navigation ul {
		grid-auto-flow: column;
		grid-auto-columns: minmax(120px, 1fr);
		grid-template-columns: none;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		padding-bottom: 4px;
	}
	.woocommerce-account .woocommerce-MyAccount-navigation a {
		scroll-snap-align: start;
	}

	/* Single-product summary breathing room */
	.single-product .summary {
		padding-top: 0.5rem;
	}
	.single-product form.cart {
		flex-direction: column;
		align-items: stretch;
	}
	.single-product form.cart .quantity .qty {
		width: 100%;
	}
}

@media (max-width: 480px) {
	:root {
		--dcm-gutter: 1rem;
	}
	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: 1fr !important;
	}
	.dcm-grid {
		grid-template-columns: 1fr;
	}
	.dcm-search-panel__close {
		width: 40px;
		height: 40px;
	}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
		scroll-behavior: auto !important;
	}
	.dcm-card:hover { transform: none; }
}

/* Print */
@media print {
	.dcm-header,
	.dcm-footer,
	.dcm-header__actions,
	.dcm-search-panel,
	.dcm-drawer,
	.dcm-sidebar,
	.dcm-page__foot,
	.dcm-comments,
	.woocommerce-tabs ul.tabs,
	.dcm-link-arrow,
	.dcm-btn {
		display: none !important;
	}
	body {
		background: #fff !important;
		color: #111 !important;
	}
	a { color: #111 !important; text-decoration: underline; }
}
