/* =============================================================
   TAYZE CRAZE TEES — theme.css
   Replicates the Lovable/React design exactly.
   All color references use CSS custom properties.
   ============================================================= */

/* ---- Google Fonts are enqueued via wp_enqueue_style in functions.php ---- */

/* =============================================================
   CSS CUSTOM PROPERTIES
   ============================================================= */
:root {
	/* Colors — overridden by PHP wp_add_inline_style */
	--color-primary:      #7c3aed;
	--color-primary-text: #ffffff;
	--color-accent:       #ec4899;
	--color-accent-text:  #ffffff;
	--color-background:   #ffffff;
	--color-foreground:   #1a1617;
	--color-secondary:    #f0eff2;
	--color-muted:        #e5e4e8;
	--color-muted-fg:     #6b6878;
	--color-border:       #e0dfe3;
	--color-card:         #f5f4f7;
	--color-neon-purple:  #7c3aed;
	--color-neon-pink:    #ec4899;
	--color-neon-cyan:    #06b6d4;
	--color-error:        #ef4444;

	/* Typography */
	--font-display: 'Bebas Neue', sans-serif;
	--font-body:    'Inter', sans-serif;

	/* Radius */
	--radius:        1.25rem;
	--radius-sm:     calc(var(--radius) - 4px);
	--radius-lg:     var(--radius);

	/* Shadows */
	--shadow-soft:     0 4px 24px -6px rgba(26,22,23,0.06);
	--shadow-elevated: 0 12px 48px -12px rgba(26,22,23,0.1);

	/* Transitions */
	--transition-smooth: cubic-bezier(0.4, 0, 0.2, 1);

	/* Logo */
	--logo-height: 60px;

	/* Button tokens */
	--btn-height:          2.75rem;
	--btn-padding:         0 2rem;
	--btn-font-size:       0.875rem;
	--btn-font-weight:     500;
	--btn-letter-spacing:  0.02em;
	--btn-text-transform:  none;
	--btn-radius:          var(--radius);
}

/* =============================================================
   RESET & BASE
   ============================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
	font-family: var(--font-body);
	font-size: 16px;
	color: var(--color-foreground);
	background-color: var(--color-background);
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
	line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	font-weight: 400;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1.1;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { background: none; border: none; cursor: pointer; font-family: var(--font-body); }

/* =============================================================
   LAYOUT HELPERS
   ============================================================= */
.container-wide {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}
@media (min-width: 1024px) {
	.container-wide { padding-left: 2rem; padding-right: 2rem; }
}

/* =============================================================
   UTILITY CLASSES
   ============================================================= */
.gradient-text {
	background: linear-gradient(90deg, var(--color-neon-purple), var(--color-neon-pink), var(--color-neon-cyan));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.gradient-hero {
	background: linear-gradient(135deg,
		hsl(270 80% 15%),
		hsl(260 20% 8%) 40%,
		hsl(330 50% 15%) 80%,
		hsl(260 20% 8%)
	);
}

.gradient-cta {
	background: linear-gradient(90deg,
		hsl(0 85% 45%), hsl(30 90% 50%), hsl(50 95% 50%),
		hsl(120 70% 40%), hsl(170 80% 40%), hsl(220 80% 50%),
		hsl(270 80% 50%), hsl(320 85% 50%), hsl(0 85% 45%)
	);
	background-size: 800% 100%;
	animation: gradient-shift 20s linear infinite;
}

@keyframes gradient-shift {
	0%   { background-position: 0% 50%; }
	100% { background-position: 100% 50%; }
}

.text-muted { color: var(--color-muted-fg); }

.link-underline { position: relative; display: inline-block; }
.link-underline::after {
	content: '';
	position: absolute;
	bottom: 0; left: 0;
	width: 100%; height: 1px;
	background: var(--color-neon-pink);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.3s var(--transition-smooth);
}
.link-underline:hover::after { transform: scaleX(1); }

.hidden { display: none !important; }

/* =============================================================
   ANIMATIONS
   ============================================================= */
@keyframes fadeIn   { from { opacity: 0; }            to { opacity: 1; } }
@keyframes slideUp  { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes slideIn  { from { transform: translateX(100%); } to { transform: translateX(0); } }

.animate-fade-in { animation: fadeIn  0.6s var(--transition-smooth) forwards; }
.animate-slide-up{ animation: slideUp 0.6s var(--transition-smooth) forwards; }

/* =============================================================
   BUTTONS
   ============================================================= */
.tct-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	height: var(--btn-height);
	padding: var(--btn-padding);
	font-family: var(--font-body);
	font-size: var(--btn-font-size);
	font-weight: var(--btn-font-weight);
	letter-spacing: var(--btn-letter-spacing);
	text-transform: var(--btn-text-transform);
	border-radius: var(--btn-radius);
	border: 2px solid transparent;
	cursor: pointer;
	transition: opacity 0.2s ease, background-color 0.2s ease, color 0.2s ease;
	white-space: nowrap;
}
.tct-btn:hover   { opacity: 0.88; }
.tct-btn:disabled{ opacity: 0.5; cursor: not-allowed; pointer-events: none; }

.tct-btn-primary {
	background-color: var(--color-primary);
	color: var(--color-primary-text);
	border-color: var(--color-primary);
}
.tct-btn-accent {
	background-color: var(--color-accent);
	color: var(--color-accent-text);
	border-color: var(--color-accent);
}
.tct-btn-outline {
	background-color: transparent;
	color: var(--color-foreground);
	border-color: var(--color-border);
}
.tct-btn-outline:hover {
	background-color: var(--color-secondary);
	opacity: 1;
}
.tct-btn-outline-light {
	background-color: transparent;
	color: var(--color-foreground);
	border-color: rgba(26,22,23,0.3);
}
.tct-btn-outline-light:hover {
	background-color: rgba(26,22,23,0.1);
	opacity: 1;
}
.tct-btn-white {
	background-color: #ffffff;
	color: var(--color-foreground);
	border-color: #ffffff;
}
.tct-btn-ghost-light {
	background-color: transparent;
	color: #ffffff;
	border-color: rgba(255,255,255,0.3);
}
.tct-btn-ghost-light:hover {
	background-color: rgba(255,255,255,0.1);
	opacity: 1;
}
.tct-btn-destructive {
	background-color: transparent;
	color: var(--color-error);
	border-color: var(--color-error);
}
.tct-btn-destructive:hover { background-color: color-mix(in srgb, var(--color-error) 12%, transparent); opacity:1; }

/* =============================================================
   SITE LOGO
   ============================================================= */
.site-logo-img  { height: var(--logo-height) !important; width: auto !important; display: block; }
.site-logo-text { font-family: var(--font-display); letter-spacing: 0.05em; text-transform: uppercase; line-height: 1; display: block; }

/* =============================================================
   HEADER
   ============================================================= */
.tct-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 500;
	transition: all 0.5s var(--transition-smooth);
}
.tct-header-inner {
	transition: all 0.5s var(--transition-smooth);
}

/* Transparent state (home, not scrolled) */
.tct-header:not(.is-scrolled) .tct-header-inner {
	background: transparent;
	border-radius: 0;
	margin: 0;
	border: none;
	box-shadow: none;
}
.tct-header:not(.is-scrolled) .tct-header-inner .container-wide,
.tct-header:not(.is-scrolled) .tct-header-inner .tct-header-nav-inner { padding-left: 1.5rem; padding-right: 1.5rem; }
.tct-header:not(.is-scrolled) .tct-header-nav { height: 6rem; }
.tct-header:not(.is-scrolled) .site-logo-text { font-size: 2rem; }
@media (min-width: 1024px) {
	.tct-header:not(.is-scrolled) .site-logo-text { font-size: 2.5rem; }
}

/* Scrolled / inner-page state */
.tct-header.is-scrolled .tct-header-inner,
[data-scrolled="true"] .tct-header .tct-header-inner,
.theme-no-hero .tct-header .tct-header-inner {
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	margin: 0.75rem 1rem 0;
	border-radius: 9999px;
	border: 1px solid rgba(224,223,227,0.5);
	box-shadow: var(--shadow-elevated);
}
.tct-header.is-scrolled .tct-header-nav,
[data-scrolled="true"] .tct-header .tct-header-nav,
.theme-no-hero .tct-header .tct-header-nav { height: 3.5rem; }
.tct-header.is-scrolled .site-logo-text,
[data-scrolled="true"] .tct-header .site-logo-text,
.theme-no-hero .tct-header .site-logo-text { font-size: 1.125rem; }
@media (min-width: 1024px) {
	.tct-header.is-scrolled .site-logo-text,
	[data-scrolled="true"] .tct-header .site-logo-text,
	.theme-no-hero .tct-header .site-logo-text { font-size: 1.25rem; }
}

.tct-header-inner { overflow: hidden; }
.tct-header-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 1.5rem;
	transition: height 0.5s var(--transition-smooth);
}
@media (min-width: 1024px) {
	.tct-header-nav { padding: 0 2rem; }
}

.tct-logo { flex-shrink: 0; }

.tct-nav-links {
	display: none;
	align-items: center;
	gap: 2rem;
}
@media (min-width: 1024px) {
	.tct-nav-links { display: flex; }
}
.tct-nav-link {
	font-family: var(--font-body);
	font-size: 0.875rem;
	letter-spacing: 0.05em;
	transition: color 0.3s;
}
.tct-nav-link:hover { color: var(--color-muted-fg); }

.tct-cart-btn {
	position: relative;
	padding: 0.5rem;
	transition: opacity 0.3s;
}
.tct-cart-btn:hover { opacity: 0.6; }
.tct-cart-btn .theme-cart-count:empty { display: none; }
.theme-cart-count {
	position: absolute;
	top: -2px; right: -2px;
	min-width: 20px; height: 20px;
	display: flex; align-items: center; justify-content: center;
	font-size: 10px; font-weight: 500;
	background-color: var(--color-accent);
	color: var(--color-accent-text);
	border-radius: 9999px;
	padding: 0 4px;
}
.theme-cart-count:empty { display: none; }

.tct-mobile-controls {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
@media (min-width: 1024px) { .tct-mobile-controls { display: none; } }

.tct-mobile-toggle { padding: 0.5rem; transition: opacity 0.3s; }
.tct-mobile-toggle:hover { opacity: 0.6; }

.tct-mobile-menu {
	display: none;
	margin: 0.5rem 1rem 0;
	background: rgba(255,255,255,0.97);
	backdrop-filter: blur(20px);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	box-shadow: var(--shadow-elevated);
	overflow: hidden;
}
.tct-mobile-menu.is-open { display: block; animation: fadeIn 0.2s ease; }
.tct-mobile-menu-inner {
	display: flex;
	flex-direction: column;
	gap: 0;
	padding: 1rem 1.5rem;
}
.tct-mobile-link {
	padding: 0.625rem 0;
	font-family: var(--font-body);
	font-size: 0.875rem;
	letter-spacing: 0.05em;
	transition: color 0.2s;
	border-bottom: 1px solid var(--color-border);
}
.tct-mobile-link:last-child { border-bottom: none; }
.tct-mobile-link:hover { color: var(--color-muted-fg); }

/* =============================================================
   FOOTER
   ============================================================= */
.tct-footer {
	background-color: var(--color-secondary);
	border-top: 1px solid var(--color-border);
	border-radius: 1.5rem 1.5rem 0 0;
}
.tct-footer > .container-wide { padding-top: 4rem; padding-bottom: 5rem; }
.tct-footer-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem 3rem;
}
@media (min-width: 768px) {
	.tct-footer-grid { grid-template-columns: 2fr 1fr 1fr; }
}

.tct-footer-logo { display: inline-block; margin-bottom: 1rem; }
.tct-footer-logo .site-logo-text { font-size: 1.5rem; }
.tct-footer-tagline {
	font-size: 0.875rem;
	color: var(--color-muted-fg);
	max-width: 320px;
	line-height: 1.6;
	margin-bottom: 1.5rem;
}
.tct-social-links { display: flex; gap: 0.5rem; }
.tct-social-icon {
	padding: 0.5rem;
	transition: opacity 0.2s;
}
.tct-social-icon:hover { opacity: 0.6; }

.tct-footer-col-title {
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.875rem;
	text-transform: none;
	letter-spacing: normal;
	margin-bottom: 1rem;
}
.tct-footer-links {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.tct-footer-links a {
	font-size: 0.875rem;
	color: var(--color-muted-fg);
	transition: color 0.2s;
}
.tct-footer-links a:hover { color: var(--color-foreground); }
.tct-footer-contact-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--color-muted-fg);
}
.tct-footer-contact-item a { transition: color 0.2s; word-break: break-all; }
.tct-footer-contact-item a:hover { color: var(--color-foreground); }

.tct-footer-bottom {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	text-align: center;
}
@media (min-width: 640px) {
	.tct-footer-bottom { flex-direction: row; justify-content: space-between; text-align: left; }
}
.tct-footer-bottom p {
	font-size: 0.75rem;
	color: var(--color-muted-fg);
}
.tct-footer-bottom a { transition: color 0.2s; }
.tct-footer-bottom a:hover { color: var(--color-foreground); }

/* =============================================================
   SECTION SHARED ELEMENTS
   ============================================================= */
.tct-section-header {
	text-align: center;
	margin-bottom: 3rem;
}
.tct-section-header h2 {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	margin-top: 0.5rem;
}
.tct-section-header p {
	color: var(--color-muted-fg);
	max-width: 40rem;
	margin: 0.75rem auto 0;
}
.tct-section-eyebrow {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-accent);
}
.tct-section-eyebrow.text-muted { color: var(--color-muted-fg); }

.tct-back-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--color-muted-fg);
	transition: color 0.2s;
	margin-bottom: 2rem;
}
.tct-back-link:hover { color: var(--color-foreground); }

/* =============================================================
   HERO
   ============================================================= */
.tct-hero {
	min-height: 85vh;
	position: relative;
	overflow: hidden;
	border-radius: 0 0 3rem 3rem;
	display: flex;
	flex-direction: column;
}
.tct-hero-video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.tct-hero-video::after { /* dark overlay */
	content: '';
}
.tct-hero-content {
	position: relative;
	z-index: 2;
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-top: 8rem;
	padding-bottom: 4rem;
}
.tct-hero-inner {
	max-width: 48rem;
	text-align: center;
}
.tct-hero-eyebrow {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: 1.5rem;
	animation: fadeIn 0.6s var(--transition-smooth) forwards;
}
.tct-hero-headline {
	font-size: clamp(4rem, 12vw, 10rem);
	line-height: 0.95;
	margin-bottom: 2rem;
	animation: slideUp 0.6s var(--transition-smooth) forwards;
}
.tct-hero-actions {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	justify-content: center;
	align-items: center;
	animation: slideUp 0.6s var(--transition-smooth) forwards;
	animation-delay: 0.2s;
	opacity: 0;
}
@media (min-width: 640px) {
	.tct-hero-actions { flex-direction: row; }
}

/* =============================================================
   BRAND TAGLINE
   ============================================================= */
.tct-brand-tagline {
	padding: 4rem 1.5rem;
	text-align: center;
}
.tct-brand-tagline p {
	color: rgba(26,22,23,0.7);
	font-size: 1.125rem;
	max-width: 36rem;
	margin: 1.5rem auto;
	line-height: 1.8;
}
.tct-divider-line {
	width: 4rem;
	height: 2px;
	margin: 0 auto;
	border-radius: 9999px;
	background: linear-gradient(90deg, var(--color-neon-purple), var(--color-neon-pink), var(--color-neon-cyan));
}

/* =============================================================
   NEW DROPS / SHOP SECTIONS
   ============================================================= */
.tct-new-drops,
.tct-shop { padding: 5rem 1.5rem; }

@media (min-width: 1024px) {
	.tct-new-drops, .tct-shop { padding-left: 2rem; padding-right: 2rem; }
}

/* =============================================================
   PRODUCT GRID
   ============================================================= */
.theme-product-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.75rem;
	align-items: stretch;
}
@media (min-width: 768px) {
	.theme-product-grid { grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
}
@media (min-width: 1024px) {
	.theme-product-grid { gap: 2rem; }
}

/* Latest Collection: three cards in one row (avoid 2+1 from default 2-col grid) */
.tct-new-drops .theme-product-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 639px) {
	.tct-new-drops .theme-product-grid {
		grid-template-columns: 1fr;
	}
}

.tct-product-item { display: flex; flex-direction: column; height: 100%; }

/* Wrapper for grid/flex (direct child of .theme-product-grid) */
.theme-product-card-outer {
	display: flex;
	flex-direction: column;
	height: 100%;
	min-width: 0;
}

/* Screen reader only — product card hit link label */
.theme-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* =============================================================
   PRODUCT CARD
   ============================================================= */
.theme-product-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	border-radius: var(--radius);
	padding: 0.75rem;
	background-color: var(--color-secondary);
	transition: background-color 0.5s var(--transition-smooth), box-shadow 0.5s var(--transition-smooth);
	overflow: hidden;
	min-height: 320px;
	position: relative;
}
@media (min-width: 640px) {
	.theme-product-card { padding: 1.25rem; min-height: 420px; }
}
.theme-product-card:hover { box-shadow: var(--shadow-elevated); }

/* Clickable overlay — sits under .theme-product-card-surface; add-to-cart re-enables pointer-events */
.theme-product-card-hit {
	position: absolute;
	inset: 0;
	z-index: 1;
	border-radius: inherit;
}
.theme-product-card-surface {
	position: relative;
	z-index: 2;
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
	min-width: 0;
	pointer-events: none;
}
.theme-product-card-surface .tct-quick-add {
	pointer-events: auto;
}

.theme-product-card__badges {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
}
.tct-badge {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 9999px;
}
.tct-badge-category {
	background-color: var(--color-muted);
	color: var(--color-muted-fg);
	transition: background-color 0.5s, color 0.5s;
}
.tct-badge-new {
	background-color: var(--color-accent);
	color: var(--color-accent-text);
	display: none;
}
@media (min-width: 640px) { .tct-badge-new { display: inline-block; } }
.tct-badge-new--mobile {
	display: inline-block;
	position: absolute;
	bottom: 0.75rem; left: 0.75rem;
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(4px);
	color: var(--color-foreground);
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 9999px;
}
@media (min-width: 640px) { .tct-badge-new--mobile { display: none; } }
.tct-badge-soldout {
	background-color: var(--color-error);
	color: var(--color-primary-text);
}

.theme-product-card__title-row {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.5rem;
	margin-bottom: 1rem;
	min-width: 0;
}
.theme-product-card__title {
	font-family: var(--font-display);
	font-size: clamp(1.1rem, 3vw, 1.75rem);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	line-height: 1.1;
	transition: color 0.5s;
	min-width: 0;
}
.theme-product-card__price {
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	white-space: nowrap;
	transition: color 0.5s;
}

.theme-product-card__image-wrapper {
	position: relative;
	flex: 1;
	margin: 0 -0.75rem -0.75rem;
	border-radius: 0 0 calc(var(--radius) - 2px) calc(var(--radius) - 2px);
	overflow: hidden;
	aspect-ratio: 4/5;
}
@media (min-width: 640px) {
	.theme-product-card__image-wrapper { margin: 0 -1.25rem -1.25rem; }
}
.theme-product-card__image-wrapper img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.5s ease-out;
}
.theme-product-card:hover .theme-product-card__image-wrapper img { transform: scale(1.05); }
.theme-product-card__image-wrapper.is-sold-out img { opacity: 0.6; }

.tct-quick-add {
	position: absolute;
	z-index: 3;
	bottom: 0.75rem; right: 0.75rem;
	width: 36px; height: 36px;
	border-radius: 9999px;
	background: rgba(255,255,255,0.92);
	backdrop-filter: blur(4px);
	display: flex; align-items: center; justify-content: center;
	color: var(--color-foreground);
	box-shadow: var(--shadow-soft);
	transition: background-color 0.2s, color 0.2s, transform 0.2s;
	border: none;
	cursor: pointer;
}
.tct-quick-add:hover,
.tct-quick-add.is-added {
	background-color: var(--color-accent);
	color: var(--color-accent-text);
	transform: scale(1.1);
}

/* Hovered card colors — fg / badge tints from Customizer (--product-card-hover-fg) */
.theme-product-card.is-hovered .tct-badge-category {
	background-color: color-mix(in srgb, var(--product-card-hover-fg, var(--color-primary-text)) 20%, transparent);
	color: var(--product-card-hover-fg, var(--color-primary-text));
}
.theme-product-card.is-hovered .tct-badge-new {
	background-color: color-mix(in srgb, var(--product-card-hover-fg, var(--color-primary-text)) 30%, transparent);
	color: var(--product-card-hover-fg, var(--color-primary-text));
}
.theme-product-card.is-hovered .theme-product-card__title { color: var(--product-card-hover-fg, var(--color-primary-text)); }
.theme-product-card.is-hovered .theme-product-card__price { color: var(--product-card-hover-fg, var(--color-primary-text)); }

/* =============================================================
   SHOP SEARCH & FILTERS
   ============================================================= */
.tct-shop-search-wrap { margin-bottom: 1.5rem; display: flex; justify-content: center; }
.tct-shop-search {
	position: relative;
	max-width: 28rem;
	width: 100%;
}
.tct-search-icon {
	position: absolute;
	left: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	color: var(--color-muted-fg);
	pointer-events: none;
}
.tct-search-input {
	width: 100%;
	height: 2.5rem;
	border-radius: 9999px;
	border: 1px solid var(--color-border);
	background: var(--color-card);
	padding: 0 2.5rem 0 2.25rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--color-foreground);
	outline: none;
	transition: box-shadow 0.2s;
}
.tct-search-input::placeholder { color: var(--color-muted-fg); }
.tct-search-input:focus {
	box-shadow: 0 0 0 2px var(--color-primary);
	border-color: var(--color-primary);
}
.tct-search-clear {
	position: absolute;
	right: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	color: var(--color-muted-fg);
	transition: color 0.2s;
}
.tct-search-clear:hover { color: var(--color-foreground); }

.tct-category-filters {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem;
	margin-bottom: 2rem;
}
.tct-category-btn {
	padding: 0.625rem 1.25rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	border-radius: 9999px;
	background-color: var(--color-secondary);
	color: var(--color-foreground);
	transition: background-color 0.3s, color 0.3s;
}
.tct-category-btn:hover { background-color: var(--color-muted); }
.tct-category-btn.is-active {
	background-color: var(--color-primary);
	color: var(--color-primary-text);
}

.tct-shop-more { text-align: center; margin-top: 2rem; }

.tct-shop-empty-state { text-align: center; padding: 5rem 0; }
.tct-shop-empty-state p { color: var(--color-muted-fg); margin-bottom: 1rem; }

/* =============================================================
   PROCESS SECTION
   ============================================================= */
.tct-process { padding: 4rem 1.5rem; }
@media (min-width: 1024px) { .tct-process { padding-left: 2rem; padding-right: 2rem; } }

.tct-process-steps {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem 2rem;
}
@media (min-width: 1024px) {
	.tct-process-steps { grid-template-columns: repeat(4, 1fr); }
}

.tct-process-step {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.tct-process-connector {
	display: none;
}
@media (min-width: 1024px) {
	.tct-process-connector {
		display: block;
		position: absolute;
		top: 2rem;
		left: calc(50% + 24px);
		right: calc(-50% + 24px);
		width: calc(100% - 48px);
		height: 1px;
		background-color: var(--color-border);
	}
}

.tct-step-icon-wrap {
	width: 4rem; height: 4rem;
	border-radius: var(--radius-sm);
	background-color: var(--color-secondary);
	display: flex; align-items: center; justify-content: center;
	margin-bottom: 1rem;
	color: var(--color-primary);
	transition: background-color 0.3s;
}
.tct-process-step:hover .tct-step-icon-wrap { background-color: rgba(124,58,237,0.1); }
.tct-step-num {
	font-family: var(--font-body);
	font-size: 0.75rem;
	letter-spacing: 0.3em;
	color: var(--color-muted-fg);
	text-transform: uppercase;
	margin-bottom: 0.25rem;
}
.tct-step-title {
	font-family: var(--font-display);
	font-size: 1.25rem;
	text-transform: uppercase;
	margin-bottom: 0.5rem;
}
.tct-step-desc {
	font-size: 0.875rem;
	color: var(--color-muted-fg);
	line-height: 1.6;
	max-width: 12rem;
}

/* =============================================================
   CTA SECTION
   ============================================================= */
.tct-cta-section {
	margin: 0 1rem 1rem;
	border-radius: 1.5rem;
	overflow: hidden;
	position: relative;
	background: linear-gradient(90deg,
		hsl(0 85% 45%), hsl(30 90% 50%), hsl(50 95% 50%),
		hsl(120 70% 40%), hsl(170 80% 40%), hsl(220 80% 50%),
		hsl(270 80% 50%), hsl(320 85% 50%), hsl(0 85% 45%)
	);
	background-size: 800% 100%;
	animation: gradient-shift 20s linear infinite;
}
.tct-cta-inner {
	padding: 5rem 1.5rem;
	text-align: center;
	position: relative;
	z-index: 1;
}
.tct-cta-inner h2 {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	color: var(--color-primary-text);
	margin-bottom: 1rem;
}
.tct-cta-inner p {
	color: rgba(255,255,255,0.8);
	max-width: 36rem;
	margin: 0 auto 2rem;
}
.tct-cta-actions {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	justify-content: center;
	align-items: center;
}
@media (min-width: 640px) { .tct-cta-actions { flex-direction: row; } }

/* =============================================================
   INNER PAGE BASE
   ============================================================= */
.tct-inner-page {
	padding-top: 6rem;
	min-height: 100vh;
}
@media (min-width: 1024px) { .tct-inner-page { padding-top: 8rem; } }
.tct-inner-page > .container-wide { padding-top: 2.5rem; padding-bottom: 5rem; }

/* =============================================================
   ABOUT PAGE
   ============================================================= */
.tct-about-hero {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: center;
	margin-bottom: 5rem;
}
@media (min-width: 1024px) {
	.tct-about-hero { grid-template-columns: 1fr 1fr; }
}
.tct-about-hero-text h1 {
	font-size: clamp(2rem, 5vw, 3rem);
	margin-top: 0.5rem;
	margin-bottom: 1.5rem;
}
.tct-about-paragraphs { display: flex; flex-direction: column; gap: 1rem; }
.tct-about-paragraphs p { color: var(--color-muted-fg); line-height: 1.8; }
.tct-about-hero-img-wrap { border-radius: var(--radius); overflow: hidden; }
.tct-about-hero-img { width: 100%; height: 100%; object-fit: cover; }

.tct-about-mission {
	background-color: var(--color-secondary);
	border-radius: var(--radius);
	padding: 2.5rem;
	text-align: center;
	margin-bottom: 5rem;
}
@media (min-width: 1024px) { .tct-about-mission { padding: 4rem; } }
.tct-about-mission h2 { font-size: clamp(1.5rem, 4vw, 2rem); margin-bottom: 1.5rem; }
.tct-mission-quote {
	font-family: var(--font-display);
	font-size: clamp(1.25rem, 3vw, 1.5rem);
	color: var(--color-muted-fg);
	max-width: 40rem;
	margin: 0 auto;
	line-height: 1.4;
	font-weight: 400;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}
.tct-about-mission > p { color: var(--color-muted-fg); margin-top: 1.5rem; max-width: 36rem; margin-left: auto; margin-right: auto; font-size: 0.875rem; }

.tct-about-process { margin-bottom: 5rem; }
.tct-about-process-grid {
	background-color: var(--color-secondary);
	border-radius: var(--radius);
	padding: 2rem;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	margin-bottom: 3rem;
}
@media (min-width: 768px) {
	.tct-about-process-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 1024px) { .tct-about-process-grid { padding: 3rem; } }
.tct-about-step { text-align: center; }
.tct-about-step-icon {
	width: 3.5rem; height: 3.5rem;
	border-radius: 9999px;
	background-color: var(--color-background);
	display: flex; align-items: center; justify-content: center;
	margin: 0 auto 0.75rem;
	color: var(--color-primary);
}
.tct-step-num-accent {
	display: block;
	font-family: var(--font-body);
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--color-accent);
	margin-bottom: 0.25rem;
}
.tct-about-step h3 { font-size: 1.25rem; margin-bottom: 0.5rem; }
.tct-about-step p { font-size: 0.875rem; color: var(--color-muted-fg); }

.tct-about-details { max-width: 48rem; margin: 0 auto; display: flex; flex-direction: column; gap: 3rem; }
.tct-about-detail-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: center;
}
@media (min-width: 768px) {
	.tct-about-detail-row { grid-template-columns: 1fr 1fr; }
	.tct-about-detail-row--reversed .tct-about-detail-img { order: -1; }
}
.tct-about-detail-img { border-radius: var(--radius); overflow: hidden; }
.tct-about-detail-img img { width: 100%; object-fit: cover; border-radius: var(--radius); }
.tct-about-detail-text h3 { font-size: 1.5rem; margin-bottom: 1rem; }
.tct-about-detail-text p { color: var(--color-muted-fg); margin-bottom: 1rem; line-height: 1.8; }

.tct-detail-list { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; }
.tct-detail-list li { display: flex; align-items: flex-start; gap: 0.75rem; font-size: 0.875rem; color: var(--color-muted-fg); }
.tct-list-dot {
	width: 6px; height: 6px; flex-shrink: 0;
	border-radius: 9999px;
	margin-top: 0.45rem;
}
.tct-list-dot--accent   { background-color: var(--color-accent); }
.tct-list-dot--primary  { background-color: var(--color-primary); }

.tct-heatpress-text { }
.tct-heatpress-text h3 { font-size: 1.5rem; margin-bottom: 1rem; }
.tct-heatpress-text p  { color: var(--color-muted-fg); line-height: 1.8; }

.tct-about-diff {
	background-color: var(--color-secondary);
	border-radius: var(--radius);
	padding: 2.5rem;
	text-align: center;
	max-width: 48rem;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
}
@media (min-width: 1024px) { .tct-about-diff { padding: 4rem; } }
.tct-about-diff h2 { font-size: clamp(1.5rem, 4vw, 2rem); }
.tct-about-diff p  { color: var(--color-muted-fg); line-height: 1.8; }
.tct-about-diff .tct-btn { margin-top: 1rem; }

/* =============================================================
   CONTACT PAGE
   ============================================================= */
.tct-contact-header { text-align: center; margin-bottom: 3rem; }
.tct-contact-header h1 { font-size: clamp(2rem, 5vw, 3rem); margin-bottom: 1rem; }
.tct-contact-header p  { color: var(--color-muted-fg); max-width: 36rem; margin: 0 auto; }

.tct-contact-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}
@media (min-width: 1024px) {
	.tct-contact-layout { grid-template-columns: 1fr 2fr; }
}

.tct-contact-sidebar { display: flex; flex-direction: column; gap: 1.5rem; }
.tct-contact-info-card {
	background-color: var(--color-secondary);
	border-radius: var(--radius);
	padding: 1.5rem;
}
.tct-contact-info-card h3 { font-size: 1.125rem; margin-bottom: 1rem; }
.tct-contact-info-list { list-style: none; display: flex; flex-direction: column; gap: 1rem; }
.tct-contact-info-list li {
	display: flex; align-items: center; gap: 0.75rem;
	font-size: 0.875rem;
}
.tct-contact-info-list svg { color: var(--color-accent); flex-shrink: 0; }
.tct-contact-info-list a { transition: color 0.2s; word-break: break-all; }
.tct-contact-info-list a:hover { color: var(--color-accent); }

.tct-contact-info-card > p { font-size: 0.875rem; color: var(--color-muted-fg); margin-bottom: 0.75rem; }
.tct-contact-social-links { display: flex; flex-direction: column; gap: 0.5rem; }
.tct-contact-social-links a {
	display: flex; align-items: center; gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--color-accent);
	transition: opacity 0.2s;
}
.tct-contact-social-links a:hover { opacity: 0.75; text-decoration: underline; }

/* Contact Form */
.tct-contact-form { display: flex; flex-direction: column; gap: 1.5rem; }
.tct-form-row { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) { .tct-form-row--2 { grid-template-columns: 1fr 1fr; gap: 1.5rem; } }
.tct-form-field { display: flex; flex-direction: column; gap: 0.5rem; }
.tct-form-field label {
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	text-transform: none;
	letter-spacing: normal;
}
.tct-form-field label span { color: var(--color-accent); }
.tct-form-field input,
.tct-form-field select,
.tct-form-field textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	background-color: var(--color-card);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--color-foreground);
	outline: none;
	transition: box-shadow 0.2s, border-color 0.2s;
}
.tct-form-field input::placeholder,
.tct-form-field textarea::placeholder { color: var(--color-muted-fg); }
.tct-form-field input:focus,
.tct-form-field select:focus,
.tct-form-field textarea:focus {
	box-shadow: 0 0 0 1px var(--color-primary);
	border-color: var(--color-primary);
}
.tct-form-field textarea { resize: none; }

.tct-form-error {
	padding: 0.75rem 1rem;
	background-color: color-mix(in srgb, var(--color-error) 12%, transparent);
	border: 1px solid var(--color-error);
	border-radius: var(--radius-sm);
	color: var(--color-error);
	font-size: 0.875rem;
}

.tct-contact-success {
	text-align: center;
	padding: 5rem 0;
}
.tct-success-icon {
	width: 4rem; height: 4rem;
	border-radius: 9999px;
	background-color: var(--color-accent);
	display: flex; align-items: center; justify-content: center;
	color: var(--color-accent-text);
	margin: 0 auto 1.5rem;
}
.tct-contact-success h2 { font-size: clamp(1.5rem, 4vw, 2rem); margin-bottom: 1rem; }
.tct-contact-success p { color: var(--color-muted-fg); margin-bottom: 2rem; }

/* =============================================================
   FAQ PAGE
   ============================================================= */
.tct-faq-header { text-align: center; margin-bottom: 3rem; }
.tct-faq-header h1 { font-size: clamp(2rem, 5vw, 3rem); margin-bottom: 1rem; }
.tct-faq-header p  { color: var(--color-muted-fg); }

.tct-faq-content { max-width: 48rem; margin: 0 auto; }
.tct-faq-section { margin-bottom: 2.5rem; }
.tct-faq-section h2 {
	font-size: 1.25rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--color-border);
	margin-bottom: 0.75rem;
}
.tct-faq-items { display: flex; flex-direction: column; gap: 0.75rem; }
.tct-faq-item {
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	overflow: hidden;
}
.tct-faq-question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.25rem;
	text-align: left;
	transition: background-color 0.2s;
}
.tct-faq-question:hover { background-color: rgba(240,239,242,0.5); }
.tct-faq-question span:first-child {
	font-family: var(--font-body);
	font-weight: 500;
	font-size: 0.875rem;
	text-transform: none;
	letter-spacing: normal;
	padding-right: 1rem;
}
.tct-faq-chevron {
	flex-shrink: 0;
	color: var(--color-muted-fg);
	transition: transform 0.2s;
}
.tct-faq-question[aria-expanded="true"] .tct-faq-chevron { transform: rotate(180deg); }
.tct-faq-answer { padding: 0 1.25rem 1.25rem; }
.tct-faq-answer p { font-size: 0.875rem; color: var(--color-muted-fg); line-height: 1.8; }

.tct-faq-cta {
	max-width: 48rem;
	margin: 4rem auto 0;
	padding-top: 2.5rem;
	border-top: 1px solid var(--color-border);
	text-align: center;
}
.tct-faq-cta h2 { font-size: 1.25rem; margin-bottom: 1rem; }
.tct-faq-cta p  { color: var(--color-muted-fg); margin-bottom: 1.5rem; }

/* =============================================================
   404 PAGE
   ============================================================= */
.tct-notfound-page { background-color: var(--color-secondary); }
.tct-notfound-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 60vh;
	text-align: center;
	gap: 1.5rem;
}
.tct-notfound-code { font-size: 8rem; font-family: var(--font-body); font-weight: 700; line-height: 1; }
.tct-notfound-title { font-size: clamp(1.25rem, 3vw, 1.75rem); font-weight: 600; margin: 0.5rem 0 1rem; }
.tct-notfound-msg  { font-size: 1.25rem; color: var(--color-muted-fg); }

/* =============================================================
   PAGE.PHP (CHECKOUT ETC.)
   ============================================================= */
.tct-page-content { padding-top: 2.5rem; padding-bottom: 5rem; }
.page-title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 5vw, 3rem);
	margin-bottom: 2rem;
	text-transform: uppercase;
}
.entry-content { max-width: 100%; }

/* =============================================================
   WOOCOMMERCE SINGLE PRODUCT
   ============================================================= */
.tct-single-product { padding-top: 6rem; min-height: 100vh; }
@media (min-width: 1024px) { .tct-single-product { padding-top: 8rem; } }
.tct-single-product > .container-wide { padding-top: 1.5rem; padding-bottom: 5rem; }

/* Single product — prevent horizontal overflow on narrow viewports */
.tct-single-product .tct-product-gallery,
.tct-single-product .tct-product-info {
	min-width: 0;
	max-width: 100%;
}
.tct-single-product .tct-gallery-main { max-width: 100%; }
.tct-single-product .tct-thumbnails {
	flex-wrap: wrap;
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 0.25rem;
	scrollbar-width: thin;
}
.tct-single-product .tct-thumb-btn { flex-shrink: 0; }
.tct-single-product .tct-product-title,
.tct-single-product .tct-product-long-desc,
.tct-single-product .tct-product-info {
	overflow-wrap: anywhere;
	word-break: break-word;
}
.tct-single-product .variations_form { max-width: 100%; }
.tct-single-product .tct-add-to-cart-area {
	flex-wrap: wrap;
	max-width: 100%;
}
.tct-single-product .tct-add-to-cart-area .single_add_to_cart_button {
	min-width: 0;
	flex: 1 1 12rem;
}
@media (max-width: 480px) {
	.tct-single-product .tct-add-to-cart-area {
		flex-direction: column;
		align-items: stretch;
	}
	.tct-single-product .tct-add-to-cart-area .theme-quantity-wrapper {
		width: 100%;
		justify-content: center;
	}
	.tct-single-product .tct-add-to-cart-area .single_add_to_cart_button {
		width: 100%;
		flex: none;
	}
}
.tct-single-product .variations td.label label.tct-variation-label-with-value {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.25rem 0.35rem;
}
.tct-single-product .variations td.label .tct-variation-selected-name {
	font-weight: 500;
	color: var(--color-foreground);
}

.tct-product-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem 4rem;
	padding-bottom: 5rem;
}
@media (min-width: 1024px) {
	.tct-product-layout { grid-template-columns: 1fr 1fr; }
}

/* Gallery */
.tct-product-gallery { }
.tct-gallery-main {
	aspect-ratio: 3/4;
	background-color: var(--color-secondary);
	border-radius: var(--radius);
	overflow: hidden;
	cursor: pointer;
	margin-bottom: 1rem;
}
.tct-gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.tct-thumbnails { display: flex; gap: 0.75rem; }
.tct-thumb-btn {
	width: 5rem; height: 5rem;
	border-radius: var(--radius-sm);
	overflow: hidden;
	border: 2px solid transparent;
	opacity: 0.6;
	transition: opacity 0.2s, border-color 0.2s;
}
.tct-thumb-btn:hover { opacity: 1; }
.tct-thumb-btn.is-active { border-color: var(--color-foreground); opacity: 1; }
.tct-thumb-btn img { width: 100%; height: 100%; object-fit: cover; }

/* Product info */
.tct-product-info { padding-top: 2.5rem; }
.tct-product-category {
	font-family: var(--font-body);
	font-size: 0.75rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-muted-fg);
}
.tct-product-title { font-size: clamp(1.5rem, 4vw, 2rem); margin: 0.5rem 0 1rem; }
.tct-product-price { font-family: var(--font-body); font-size: 1.25rem; margin-bottom: 1.5rem; }
.tct-product-price ins { text-decoration: none; }
.tct-product-price del { opacity: 0.5; font-size: 1rem; margin-right: 0.5rem; }
.tct-soldout-badge {
	display: inline-block;
	padding: 0.5rem 1rem;
	background-color: var(--color-muted);
	color: var(--color-muted-fg);
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	border-radius: var(--radius-sm);
	margin-bottom: 1rem;
}
.tct-product-description { color: var(--color-muted-fg); line-height: 1.8; margin-bottom: 2rem; }

/* Color/Size selectors */
.tct-attr-group { margin-bottom: 1.5rem; }
.tct-attr-label {
	display: block;
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	text-transform: none;
	letter-spacing: normal;
	margin-bottom: 0.75rem;
}
.tct-color-swatches { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.tct-color-swatch {
	width: 2.5rem; height: 2.5rem;
	border-radius: 9999px;
	border: 2px solid transparent;
	transition: transform 0.2s, border-color 0.2s;
	cursor: pointer;
}
.tct-color-swatch:hover { transform: scale(1.05); }
.tct-color-swatch.is-selected { border-color: var(--color-accent); transform: scale(1.1); }
/* Variable attributes: keep light swatches visible on white background */
.variations td.value .tct-color-swatches--variation .tct-color-swatch {
	box-shadow: inset 0 0 0 1px rgba(26, 22, 23, 0.12);
}

.tct-size-btns { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.tct-size-btn {
	min-width: 3rem;
	padding: 0.5rem 1rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	transition: border-color 0.2s, background-color 0.2s, color 0.2s;
	cursor: pointer;
}
.tct-size-btn:hover { border-color: var(--color-accent); }
.tct-size-btn.is-selected {
	border-color: var(--color-accent);
	background-color: var(--color-accent);
	color: var(--color-accent-text);
}

/* Variations table */
.variations { border: none; border-collapse: collapse; width: 100%; margin-bottom: 1rem; }
.variations td { padding: 0 0 0.75rem 0; }
.variations td.label label {
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	text-transform: none;
	letter-spacing: normal;
	display: block;
	margin-bottom: 0.5rem;
}
/* Variable product: one row per attribute — label full width, options below (not side-by-side table cells) */
.tct-single-product .variations_form table.variations tbody,
.tct-single-product .variations_form table.variations tr {
	display: block;
}
.tct-single-product .variations_form table.variations tr {
	margin-bottom: 1.5rem;
}
.tct-single-product .variations_form table.variations tr:last-child {
	margin-bottom: 0;
}
.tct-single-product .variations_form table.variations td {
	display: block;
	width: 100%;
	padding: 0;
}
.tct-single-product .variations_form table.variations td.label label {
	margin-bottom: 0.75rem;
}
.theme-attr-select-hidden { display: none !important; }

/* Quantity + ATC */
.theme-quantity-wrapper {
	display: flex;
	align-items: center;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
}
.theme-qty-minus,
.theme-qty-plus {
	padding: 0.75rem;
	transition: background-color 0.2s;
	border: none;
	background: none;
	cursor: pointer;
	color: var(--color-foreground);
}
.theme-qty-minus:hover,
.theme-qty-plus:hover { background-color: var(--color-secondary); }
.theme-qty-input {
	padding: 0.75rem;
	min-width: 2.5rem;
	text-align: center;
	border: none;
	background: none;
	font-family: var(--font-body);
	font-size: 1rem;
	color: var(--color-foreground);
	outline: none;
	-moz-appearance: textfield;
}
.theme-qty-input::-webkit-outer-spin-button,
.theme-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; }

.tct-add-to-cart-area {
	display: flex;
	gap: 0.75rem;
	margin-bottom: 2rem;
}
.tct-add-to-cart-area .theme-quantity-wrapper { flex-shrink: 0; }

.tct-handmade-note {
	text-align: center;
	font-size: 0.75rem;
	color: var(--color-muted-fg);
	margin-bottom: 1rem;
}

/* Single variation wrap — WooCommerce */
.single_variation_wrap { }
.single_variation_wrap .woocommerce-variation-price .price { font-family: var(--font-body); font-size: 1.25rem; }

/* Product long description */
.tct-product-long-desc { color: var(--color-muted-fg); line-height: 1.8; margin-bottom: 2rem; }

/* Product details section */
.tct-product-details { border-top: 1px solid var(--color-border); padding-top: 2rem; }
.tct-product-details h3 {
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	text-transform: none;
	letter-spacing: normal;
	margin-bottom: 1rem;
}
.tct-details-list { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; }
.tct-details-list li {
	display: flex; align-items: flex-start; gap: 0.75rem;
	font-size: 0.875rem;
	color: var(--color-muted-fg);
}

/* Related products */
.tct-related-products {
	padding: 5rem 0;
	border-top: 1px solid var(--color-border);
}
.tct-related-products h2 { font-size: clamp(1.25rem, 3vw, 1.5rem); margin-bottom: 2.5rem; }
.tct-related-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem 2rem;
}
@media (min-width: 1024px) {
	.tct-related-grid { grid-template-columns: repeat(4, 1fr); }
}

/* =============================================================
   WC SHOP / ARCHIVE
   ============================================================= */
.tct-archive-product { padding-top: 6rem; min-height: 100vh; }
@media (min-width: 1024px) { .tct-archive-product { padding-top: 8rem; } }
.tct-archive-product > .container-wide { padding-top: 2.5rem; padding-bottom: 5rem; }
.tct-archive-header { margin-bottom: 3rem; }
.tct-archive-title { font-size: clamp(2rem, 5vw, 3rem); margin-bottom: 0.5rem; }
.tct-archive-desc { color: var(--color-muted-fg); }

/* =============================================================
   WOOCOMMERCE ADD TO CART BUTTON OVERRIDES (Section 11.4.1)
   ============================================================= */
.single_add_to_cart_button.button,
.add_to_cart_button.button,
a.single_add_to_cart_button,
a.add_to_cart_button {
	background-color: var(--color-primary) !important;
	color: var(--color-primary-text) !important;
	border: none !important;
	border-radius: var(--btn-radius) !important;
	min-height: var(--btn-height) !important;
	padding: var(--btn-padding) !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-family: var(--font-body) !important;
	font-size: var(--btn-font-size) !important;
	font-weight: var(--btn-font-weight) !important;
	letter-spacing: var(--btn-letter-spacing) !important;
	text-transform: var(--btn-text-transform) !important;
	cursor: pointer !important;
	transition: opacity 0.2s ease !important;
}
a.tct-quick-add.add_to_cart_button {
	min-height: unset !important;
	padding: 0 !important;
}
.single_add_to_cart_button.button:hover,
.add_to_cart_button.button:hover {
	opacity: 0.85 !important;
	background-color: var(--color-primary) !important;
	color: var(--color-primary-text) !important;
}
/* Disabled state (Section 11.4.1) */
.single_add_to_cart_button.button:disabled,
.single_add_to_cart_button.button.disabled,
.add_to_cart_button.button:disabled,
.add_to_cart_button.button.disabled {
	cursor: not-allowed !important;
	opacity: 0.4 !important;
	pointer-events: none !important;
}
.single_add_to_cart_button.button:disabled:hover,
.single_add_to_cart_button.button.disabled:hover,
.add_to_cart_button.button:disabled:hover,
.add_to_cart_button.button.disabled:hover {
	opacity: 0.4 !important;
	background-color: var(--color-primary) !important;
}

/* Hide "View cart" injected after AJAX add (Section 11.4.2) */
.woocommerce-page a.added_to_cart.wc-forward,
.single-product a.added_to_cart.wc-forward,
body a.added_to_cart.wc-forward {
	display: none !important;
}

/* Button loading state (Section 31.8) */
.ajax_add_to_cart.theme-btn-loading {
	opacity: 0.6 !important;
	pointer-events: none !important;
	cursor: wait !important;
}

/* =============================================================
   WOOCOMMERCE NOTICES (Section 14.1)
   ============================================================= */
/* Scoped hiding on single product page where drawer provides feedback */
.single-product .woocommerce-message,
.single-product .woocommerce-info { display: none; }
#theme-cart-drawer .woocommerce-message { display: none; }

/* Style notices on shop/archive */
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-error {
	background-color: var(--color-secondary);
	border-left: 4px solid var(--color-primary);
	border-radius: var(--radius-sm);
	padding: 1rem 1.25rem;
	margin-bottom: 1.5rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
	list-style: none;
}
.woocommerce-notices-wrapper .woocommerce-error { border-left-color: var(--color-error); }
.woocommerce-notices-wrapper .woocommerce-message::before,
.woocommerce-notices-wrapper .woocommerce-info::before { display: none; }

/* =============================================================
   SIDE CART DRAWER
   ============================================================= */
#theme-cart-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background-color: rgba(26,22,23,0.2);
	z-index: 600;
}
body.cart-open #theme-cart-overlay { display: block; animation: fadeIn 0.2s ease; }

#theme-cart-drawer {
	position: fixed;
	top: 0; right: 0;
	height: 100%;
	width: 100%;
	max-width: 28rem;
	background-color: var(--color-background);
	z-index: 650;
	display: flex;
	flex-direction: column;
	box-shadow: var(--shadow-elevated);
	transform: translateX(100%);
	transition: transform 0.35s var(--transition-smooth);
}
body.cart-open #theme-cart-drawer { transform: translateX(0); }
#theme-cart-drawer.is-updating { opacity: 0.6; pointer-events: none; }

.tct-drawer-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.5rem;
	border-bottom: 1px solid var(--color-border);
	flex-shrink: 0;
}
.tct-drawer-header-left { display: flex; align-items: center; gap: 0.75rem; }
.tct-drawer-title { font-size: 1.125rem; }
.tct-drawer-empty-btn {
	font-size: 0.75rem;
	color: var(--color-muted-fg);
	transition: color 0.2s;
	cursor: pointer;
}
.tct-drawer-empty-btn:hover { color: var(--color-error); }
.tct-drawer-close {
	padding: 0.25rem;
	transition: opacity 0.2s;
	cursor: pointer;
}
.tct-drawer-close:hover { opacity: 0.6; }

/* Empty state */
.tct-drawer-empty {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 1.5rem;
	text-align: center;
	gap: 1.5rem;
}
.tct-drawer-empty svg { color: var(--color-muted-fg); }
.tct-drawer-empty p { color: var(--color-muted-fg); }

/* Items */
.tct-drawer-items {
	flex: 1;
	overflow-y: auto;
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.tct-cart-item { display: flex; gap: 1rem; }
.tct-cart-item-img {
	width: 5rem; height: 6rem;
	background-color: var(--color-secondary);
	border-radius: var(--radius-sm);
	overflow: hidden;
	flex-shrink: 0;
}
.tct-cart-item-img a { display: block; width: 100%; height: 100%; }
.tct-cart-item-img img { width: 100%; height: 100%; object-fit: cover; }
.tct-cart-item-info { flex: 1; min-width: 0; }
.tct-cart-item-name {
	display: block;
	font-family: var(--font-body);
	font-size: 0.875rem;
	font-weight: 500;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: opacity 0.2s;
	margin-bottom: 0.25rem;
}
.tct-cart-item-name:hover { opacity: 0.7; }
.tct-cart-item-price {
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--color-muted-fg);
	margin-bottom: 0.25rem;
}
.tct-cart-item-meta {
	font-size: 0.75rem;
	color: var(--color-muted-fg);
	margin-bottom: 0.75rem;
}
.tct-cart-item-controls {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}
.tct-cart-qty-btn {
	padding: 0.25rem;
	border-radius: var(--radius-sm);
	transition: background-color 0.2s;
	cursor: pointer;
}
.tct-cart-qty-btn:hover { background-color: var(--color-secondary); }
.tct-cart-qty-val { font-size: 0.875rem; min-width: 1.5rem; text-align: center; }
.tct-cart-remove {
	margin-left: auto;
	font-size: 0.75rem;
	color: var(--color-muted-fg);
	transition: color 0.2s;
	cursor: pointer;
}
.tct-cart-remove:hover { color: var(--color-foreground); }

/* Footer */
.tct-drawer-footer {
	padding: 1.5rem;
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-direction: column;
	gap: 1rem;
	flex-shrink: 0;
}
.tct-drawer-subtotal {
	display: flex;
	justify-content: space-between;
	font-family: var(--font-body);
	font-size: 0.875rem;
}
.tct-drawer-subtotal span:first-child { color: var(--color-muted-fg); }
.tct-drawer-subtotal span:last-child  { font-weight: 500; }
.tct-drawer-shipping-note {
	font-size: 0.75rem;
	color: var(--color-muted-fg);
}
.tct-drawer-checkout-btn { width: 100%; }

/* =============================================================
   CHECKOUT PAGE (Section 13)
   ============================================================= */
body.woocommerce-checkout .entry-content { max-width: 100%; }

body.woocommerce-checkout .wc-block-checkout {
	font-family: var(--font-body);
}

@media (min-width: 768px) {
	body.woocommerce-checkout .wc-block-components-sidebar-layout.wc-block-checkout.is-large {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 2rem;
		align-items: start;
	}
}

body.woocommerce-checkout .wc-block-checkout__main,
body.woocommerce-checkout .wc-block-checkout__sidebar {
	min-width: 0;
	width: 100%;
	max-width: none;
}

/* Match .tct-form-field inputs/selects; padding left to WooCommerce defaults */
body.woocommerce-checkout .wc-block-components-text-input input,
body.woocommerce-checkout .wc-block-components-text-input textarea,
body.woocommerce-checkout .wc-block-checkout__form textarea,
body.woocommerce-checkout .wc-block-components-select select,
body.woocommerce-checkout .wc-blocks-components-select__select {
	width: 100% !important;
	max-width: none !important;
	background-color: var(--color-card) !important;
	border: 1px solid var(--color-border) !important;
	border-radius: var(--radius-sm) !important;
	font-family: var(--font-body) !important;
	font-size: 0.875rem !important;
	color: var(--color-foreground) !important;
	outline: none !important;
	transition: box-shadow 0.2s, border-color 0.2s !important;
}

body.woocommerce-checkout .wc-block-components-text-input textarea,
body.woocommerce-checkout .wc-block-checkout__form textarea {
	resize: none !important;
}

body.woocommerce-checkout .wc-block-components-text-input input::placeholder,
body.woocommerce-checkout .wc-block-components-text-input textarea::placeholder,
body.woocommerce-checkout .wc-block-checkout__form textarea::placeholder {
	color: var(--color-muted-fg) !important;
	opacity: 1;
}

body.woocommerce-checkout .wc-block-components-text-input input:focus,
body.woocommerce-checkout .wc-block-components-text-input textarea:focus,
body.woocommerce-checkout .wc-block-checkout__form textarea:focus,
body.woocommerce-checkout .wc-block-components-select select:focus,
body.woocommerce-checkout .wc-blocks-components-select__select:focus {
	outline: none !important;
	box-shadow: 0 0 0 1px var(--color-primary) !important;
	border-color: var(--color-primary) !important;
}

/* Match .tct-form-field label typography */
body.woocommerce-checkout .wc-block-components-text-input label,
body.woocommerce-checkout .wc-blocks-components-select__label {
	font-family: var(--font-body) !important;
	font-size: 0.875rem !important;
	font-weight: 500 !important;
	text-transform: none !important;
	letter-spacing: normal !important;
}

body.woocommerce-checkout .wc-block-components-checkout-place-order-button {
	background-color: var(--color-primary);
	color: var(--color-primary-text);
	border: none;
	border-radius: var(--btn-radius);
	padding: var(--btn-padding);
	min-height: var(--btn-height);
	font-family: var(--font-body);
	font-size: var(--btn-font-size);
	font-weight: var(--btn-font-weight);
	width: 100%;
	cursor: pointer;
	transition: opacity 0.2s;
}
body.woocommerce-checkout .wc-block-components-checkout-place-order-button:hover { opacity: 0.88; }

body.woocommerce-checkout .wc-block-checkout__sidebar {
	background-color: var(--color-secondary);
	border-radius: var(--radius);
	padding: 2rem;
}

body.woocommerce-checkout .wc-block-components-notice-banner {
	background-color: var(--color-secondary);
	border-left: 4px solid var(--color-primary);
	border-radius: var(--radius-sm);
	padding: 1rem 1.25rem;
	font-family: var(--font-body);
	font-size: 0.875rem;
}

body.woocommerce-checkout .wc-block-cart-items {
	font-family: var(--font-body);
	font-size: 0.875rem;
}

body.woocommerce-checkout .woocommerce-checkout .wc-block-checkout__notice,
body.woocommerce-checkout .wc-block-components-sidebar-layout.wc-block-checkout.is-large > .wc-block-components-notice-banner {
	grid-column: 1 / -1;
}

/* =============================================================
   THANK YOU PAGE (Section 22.8)
   ============================================================= */
body.theme-thankyou-page { overflow-x: hidden; }

body.theme-thankyou-page .woocommerce-order {
	font-family: var(--font-body);
	font-size: 0.875rem;
	max-width: 56rem;
	margin: 0 auto;
}
body.theme-thankyou-page .woocommerce-order > p:first-child {
	font-size: 1rem;
	margin-bottom: 1.5rem;
	color: var(--color-foreground);
}
body.theme-thankyou-page .woocommerce-order-overview {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	background-color: var(--color-secondary);
	border-radius: var(--radius);
	padding: 1.5rem;
	margin-bottom: 2rem;
}
body.theme-thankyou-page .woocommerce-order-overview li {
	font-family: var(--font-body);
	font-size: 0.875rem;
	color: var(--color-muted-fg);
}
body.theme-thankyou-page .woocommerce-order-overview li strong { color: var(--color-foreground); display: block; }

body.theme-thankyou-page h2 {
	font-family: var(--font-display);
	font-size: 1.5rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}

body.theme-thankyou-page .tct-thankyou-title.page-title {
	margin-top: 0;
	margin-bottom: 2rem;
}

body.theme-thankyou-page .woocommerce-customer-details address { min-width: 0; }

body.theme-thankyou-page .woocommerce-order-details table {
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
}
body.theme-thankyou-page .woocommerce-order-details table th,
body.theme-thankyou-page .woocommerce-order-details table td {
	padding: 0.75rem;
	border-bottom: 1px solid var(--color-border);
	font-family: var(--font-body);
	font-size: 0.875rem;
	text-align: left;
}

/* =============================================================
   WOOCOMMERCE DEFAULT STYLE OVERRIDES (Section 14)
   ============================================================= */
.woocommerce-page .button,
.woocommerce .button {
	background-color: var(--color-primary);
	color: var(--color-primary-text);
	border-radius: var(--btn-radius);
	border: none;
	font-family: var(--font-body);
	font-size: var(--btn-font-size);
	padding: 0.625rem 1.5rem;
	cursor: pointer;
	transition: opacity 0.2s;
}
.woocommerce-page .button:hover,
.woocommerce .button:hover { opacity: 0.88; }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width: 640px) {
	.tct-footer-grid { grid-template-columns: 1fr; }
}
