:root {
	--tt-dark: #111;
	--tt-orange: #f97316;
	--tt-yellow: #fde047;
	--tt-green: #84cc16;
	--tt-red: #ef4444;
	--tt-purple: #6d28d9;
	--tt-cream: #fff7dc;
	--tt-blue: #068ce9;
	--tt-pink: #ff66a3;
	--tt-radius: 24px;
	--tt-shadow: 8px 8px 0 #000;
	--tt-shadow-sm: 4px 4px 0 #000;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.teepi-theme {
	margin: 0;
	background: #fff;
	color: var(--tt-dark);
	font-family: Montserrat, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	overflow-x: hidden;
}
body.tt-is-loading { overflow: hidden; }
body.tt-cart-open { overflow: hidden; }
img { max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
.tt-container { width: min(100% - 32px, 1200px); margin-inline: auto; }
.tt-narrow { width: min(100% - 32px, 780px); }
.screen-reader-text, .skip-link { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link:focus { width: auto; height: auto; clip: auto; z-index: 999; background: #fff; padding: 12px; }

.tt-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	border: 2px solid #000;
	border-radius: 999px;
	padding: 13px 24px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .06em;
	line-height: 1;
	transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
}
.tt-btn:hover { transform: translateY(-3px); box-shadow: 0 14px 24px rgba(0,0,0,.18); }
.tt-btn:active { transform: translateY(1px); box-shadow: none; }
.tt-btn-dark { background: var(--tt-dark); color: #fff; }
.tt-btn-dark:hover { background: var(--tt-orange); color: #000; }
.tt-btn-red { background: var(--tt-red); color: #fff; border-width: 3px; border-radius: 14px; box-shadow: var(--tt-shadow-sm); width: 100%; padding: 17px 20px; font-size: 18px; }

.tt-loading-screen {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: grid;
	place-items: center;
	align-content: center;
	gap: 18px;
	background: var(--tt-yellow);
	color: var(--tt-dark);
	overflow: hidden;
	transition: opacity .45s ease, visibility .45s ease;
}
.tt-loading-screen.is-hidden {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}
.tt-loader-logo {
	position: relative;
	z-index: 2;
	animation: ttLoaderLogo 3.6s cubic-bezier(.4,0,.2,1) forwards;
}
.tt-loader-logo .tt-logo-img,
.tt-loader-logo .custom-logo {
	height: min(42vw, 260px);
	filter: drop-shadow(0 20px 50px rgba(0,0,0,.5));
}
.tt-loader-logo::before {
	content: "";
	position: absolute;
	inset: 4%;
	z-index: -1;
	border-radius: 999px;
	background: rgba(255,255,255,.64);
	filter: blur(36px);
	animation: ttLoaderGlow 2s ease-in-out infinite;
}
.tt-loader-swirl {
	position: absolute;
	left: 50%;
	top: 50%;
	width: 300vmax;
	height: 300vmax;
	transform: translate(-50%, -50%);
	animation: ttLoaderSwirl 8s linear infinite;
}
.tt-loader-swirl svg {
	width: 100%;
	height: 100%;
	display: block;
}
.tt-loader-ray {
	fill: var(--tt-red);
	stroke: var(--tt-red);
	stroke-width: 2;
	animation: ttLoaderRayFade .4s ease-in-out forwards;
	animation-delay: calc(1.5s + (var(--ray-index, 0) * .06s));
}
.tt-loader-ray:nth-child(even) {
	fill: var(--tt-purple);
	stroke: var(--tt-purple);
}
.tt-loader-ray-0 { --ray-index: 0; }
.tt-loader-ray-1 { --ray-index: 1; }
.tt-loader-ray-2 { --ray-index: 2; }
.tt-loader-ray-3 { --ray-index: 3; }
.tt-loader-ray-4 { --ray-index: 4; }
.tt-loader-ray-5 { --ray-index: 5; }
.tt-loader-ray-6 { --ray-index: 6; }
.tt-loader-ray-7 { --ray-index: 7; }
.tt-loader-ray-8 { --ray-index: 8; }
.tt-loader-ray-9 { --ray-index: 9; }
.tt-loader-ray-10 { --ray-index: 10; }
.tt-loader-ray-11 { --ray-index: 11; }
.tt-loader-ray-12 { --ray-index: 12; }
.tt-loader-ray-13 { --ray-index: 13; }
.tt-loader-ray-14 { --ray-index: 14; }
.tt-loader-ray-15 { --ray-index: 15; }

.tt-nav {
	position: fixed;
	inset: 0 0 auto;
	z-index: 100;
	padding: 18px 0;
	color: #fff;
	transition: background .35s ease, color .35s ease, padding .35s ease, box-shadow .35s ease;
}
.tt-nav.is-scrolled, .tt-nav.is-open, body:not(.has-pop-hero) .tt-nav {
	padding: 8px 0;
	color: var(--tt-dark);
	background: rgba(255,255,255,.95);
	backdrop-filter: blur(12px);
	box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
.tt-nav-inner { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px; }
.tt-brand { display: flex; justify-content: center; }
.tt-logo-img, .custom-logo { width: auto; height: 104px; object-fit: contain; filter: drop-shadow(0 10px 20px rgba(0,0,0,.25)); transition: height .35s ease, transform .2s ease; }
.tt-nav.is-scrolled .tt-logo-img, .tt-nav.is-open .tt-logo-img, body:not(.has-pop-hero) .tt-logo-img,
.tt-nav.is-scrolled .custom-logo, .tt-nav.is-open .custom-logo, body:not(.has-pop-hero) .custom-logo { height: 64px; }
.tt-logo-link:hover img, .custom-logo-link:hover img { transform: scale(1.05); }
.tt-menu, .tt-desktop-menu ul { display: flex; align-items: center; justify-content: center; gap: clamp(20px, 3.2vw, 54px); margin: 0; padding: 0; list-style: none; }
.tt-menu a { font-size: clamp(15px, 1.4vw, 21px); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; white-space: nowrap; transition: color .2s ease, transform .2s ease; display: inline-block; }
.tt-menu a:hover { color: var(--tt-yellow); transform: scale(1.05); }
.tt-nav-actions { display: flex; align-items: center; justify-content: flex-end; gap: 12px; }
.tt-cart-link { position: relative; display: grid; place-items: center; width: 44px; height: 44px; border-radius: 999px; transition: background .2s ease, transform .2s ease; }
.tt-cart-link:hover { background: rgba(0,0,0,.08); transform: scale(1.05); }
.tt-cart-link svg { width: 27px; height: 27px; }
.tt-cart-count { position: absolute; top: 2px; right: 1px; min-width: 17px; height: 17px; border-radius: 999px; background: var(--tt-red); color: #fff; display: grid; place-items: center; font-size: 10px; font-weight: 900; }
.tt-scroll-progress { position: absolute; left: 0; bottom: 0; height: 4px; width: 0; background: linear-gradient(90deg, var(--tt-orange), var(--tt-yellow), var(--tt-green)); }
.tt-menu-toggle { display: none; background: transparent; border: 0; color: inherit; align-items: center; gap: 7px; font-weight: 900; text-transform: uppercase; letter-spacing: .1em; }
.tt-menu-toggle span { width: 24px; height: 3px; background: currentColor; display: block; transition: transform .2s ease; }
.tt-menu-toggle span + span { margin-left: -31px; transform: translateY(8px); }
.tt-nav.is-open .tt-menu-toggle span:first-child { transform: rotate(45deg); }
.tt-nav.is-open .tt-menu-toggle span + span { transform: rotate(-45deg); margin-left: -31px; }
.tt-mobile-panel { position: absolute; top: 100%; left: 0; width: 100%; max-height: 0; overflow: hidden; background: #fff; color: var(--tt-dark); border-bottom: 0 solid #000; box-shadow: none; transition: max-height .35s ease, border-width .15s ease, box-shadow .2s ease; }
.tt-nav.is-open .tt-mobile-panel { max-height: 80vh; border-bottom-width: 4px; box-shadow: 0 24px 34px rgba(0,0,0,.18); }
.tt-mobile-panel .tt-container { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; padding: 34px 0; }
.tt-mobile-links { list-style: none; margin: 0; padding: 0; }
.tt-mobile-links a { display: inline-block; font-size: clamp(30px, 8vw, 56px); font-weight: 900; text-transform: uppercase; letter-spacing: -.02em; margin: 4px 0; }
.tt-mobile-meta { border-left: 4px solid #000; padding-left: 32px; align-self: end; }
.tt-mobile-meta h3 { margin: 0 0 8px; font-size: 24px; text-transform: uppercase; }
.tt-mobile-meta p { font-weight: 800; line-height: 1.8; }

.tt-hero {
	min-height: 100vh;
	height: 100svh;
	position: relative;
	display: grid;
	place-items: center;
	overflow: hidden;
	padding-top: 96px;
	background: var(--tt-green);
	transition: background 800ms ease;
}
.tt-hero-bg, .tt-hero-icons { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.tt-hero-mark { position: absolute; inset: 0; display: grid; place-items: center; font-size: 34vw; font-weight: 900; color: rgba(255,255,255,.2); filter: blur(3px); opacity: .55; transition: transform .8s ease, opacity .8s ease; }
.tt-float { position: absolute; width: 22px; height: 22px; border-radius: 999px; background: rgba(255,255,255,.22); animation: ttFloat 7s ease-in-out infinite; }
.tt-float-0 { left: 12%; top: 18%; width: 46px; height: 46px; }
.tt-float-1 { left: 76%; top: 22%; animation-delay: 1s; }
.tt-float-2 { left: 22%; top: 78%; width: 36px; height: 36px; animation-delay: 2s; }
.tt-float-3 { left: 88%; top: 70%; width: 28px; height: 28px; animation-delay: .5s; }
.tt-float-4 { left: 48%; top: 12%; width: 16px; height: 16px; animation-delay: 3s; }
.tt-float-5 { left: 62%; top: 86%; width: 40px; height: 40px; animation-delay: 1.7s; }
.tt-hero-icons span { position: absolute; color: rgba(255,255,255,.32); animation: ttFloat 6s ease-in-out infinite; }
.tt-icon-sun { top: 17%; left: 18%; width: 78px; height: 78px; border: 3px solid currentColor; border-radius: 999px; }
.tt-icon-zap { bottom: 20%; left: 12%; width: 70px; height: 100px; clip-path: polygon(50% 0, 78% 0, 58% 38%, 86% 38%, 36% 100%, 48% 52%, 20% 52%); background: currentColor; animation-delay: 1s; }
.tt-icon-star { top: 25%; right: 18%; width: 76px; height: 76px; clip-path: polygon(50% 0, 61% 34%, 98% 35%, 68% 56%, 79% 91%, 50% 70%, 21% 91%, 32% 56%, 2% 35%, 39% 34%); background: currentColor; animation-delay: .5s; }
.tt-icon-spark { bottom: 24%; right: 13%; width: 90px; height: 90px; border: 3px dashed currentColor; border-radius: 999px; animation-delay: 2s; }
.tt-hero-title {
	position: relative;
	z-index: 2;
	margin: 0;
	font-family: "Cabin Sketch", Montserrat, sans-serif;
	font-size: clamp(64px, 15vw, 230px);
	font-weight: 700;
	line-height: .82;
	text-align: center;
	letter-spacing: 0;
	background: linear-gradient(135deg, #fff 20%, var(--tt-blue));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	filter: drop-shadow(0 10px 30px rgba(0,0,0,.35));
	transition: background .8s ease;
}
.tt-hero-can-wrap { position: absolute; inset: 0; z-index: 4; display: grid; place-items: center; padding-top: 96px; pointer-events: none; }
.tt-hero-can {
	position: absolute;
	width: min(40vh, 310px);
	max-height: 65svh;
	object-fit: contain;
	filter: drop-shadow(0 28px 42px rgba(0,0,0,.4));
	opacity: 0;
	transform: translateY(80%) rotate(-12deg);
	transition: opacity .65s ease, transform .65s cubic-bezier(.34,1.56,.64,1);
}
		.tt-hero-can.is-active { opacity: 1; transform: translateY(34px) rotate(12deg); }
.tt-hero-copy { position: absolute; z-index: 5; inset: 0; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: clamp(190px, 34vh, 410px); padding-top: 96px; pointer-events: none; }
.tt-hero-copy h2 { margin: 0; color: #fff; text-transform: uppercase; font-size: clamp(39px, 8vw, 118px); font-weight: 900; line-height: .84; letter-spacing: 0; text-shadow: 0 8px 20px rgba(0,0,0,.25); }
.tt-hero-copy span { transition: color .8s ease; }
.tt-hero-dots { position: absolute; right: 32px; top: 50%; transform: translateY(-50%); display: grid; gap: 16px; z-index: 8; }
.tt-hero-dots span { width: 12px; height: 12px; border-radius: 999px; background: rgba(255,255,255,.45); transition: transform .2s ease, background .2s ease; }
.tt-hero-dots .is-active { background: #fff; transform: scale(1.5); }

.tt-section-heading { padding: 96px 16px 48px; background: var(--tt-cream); text-align: center; border-top: 4px solid #000; }
.tt-section-heading span, .tt-centered-heading > span, .tt-pill { display: inline-flex; align-items: center; background: #fff; color: var(--tt-pink); border: 2px solid #000; border-radius: 999px; padding: 8px 16px; box-shadow: var(--tt-shadow-sm); font-weight: 900; text-transform: uppercase; letter-spacing: .12em; }
.tt-section-heading h2, .tt-centered-heading h2 { margin: 24px 0 0; font-size: clamp(44px, 8vw, 104px); line-height: .88; font-weight: 900; text-transform: uppercase; letter-spacing: 0; }
.tt-section-heading em, .tt-centered-heading h2 em { color: var(--tt-orange); font-style: normal; }
.tt-centered-heading { text-align: center; margin-bottom: 56px; }
.tt-centered-heading p { color: #6b7280; font-size: clamp(18px, 2.2vw, 24px); font-weight: 800; margin: 16px auto 0; max-width: 720px; }

.tt-showcase { padding: 80px 0; background: var(--tt-cream); overflow: hidden; }
.tt-showcase.is-reversed { background: #fff; }
.tt-showcase-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(42px, 8vw, 96px); align-items: center; }
.tt-showcase.is-reversed .tt-showcase-visual { order: 2; }
.tt-showcase-visual { position: relative; display: grid; place-items: center; min-height: 440px; }
.tt-glow { position: absolute; width: min(120%, 620px); aspect-ratio: 1; border-radius: 999px; filter: blur(90px); opacity: .25; animation: ttPulse 4s ease-in-out infinite; }
.tt-showcase-visual img { position: relative; width: min(80%, 330px); z-index: 2; filter: drop-shadow(0 28px 42px rgba(0,0,0,.35)); transition: transform .25s ease; }
.tt-showcase-visual:hover img { transform: rotate(2deg) scale(1.05); }
.tt-bubble { position: absolute; width: 14px; height: 14px; border-radius: 999px; background: rgba(255,255,255,.35); left: calc(30% + (var(--n, 1) * 4%)); animation: ttBubble 6s linear infinite; }
.tt-showcase-content h2 { margin: 18px 0; font-size: clamp(48px, 7vw, 90px); line-height: .9; font-weight: 900; text-transform: uppercase; letter-spacing: 0; }
.tt-stars { color: var(--tt-dark); font-size: 26px; font-weight: 900; margin: 0 0 24px; }
.tt-stars small { color: rgba(17,17,17,.55); font-size: 15px; margin-left: 10px; }
.tt-showcase-content p { font-size: clamp(20px, 2.4vw, 28px); line-height: 1.2; font-weight: 800; color: rgba(17,17,17,.78); }
.tt-benefits { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-top: 34px; }
.tt-benefits div { display: flex; align-items: center; gap: 12px; background: #fff; border: 2px solid #000; border-radius: 14px; padding: 15px; box-shadow: 3px 3px 0 #000; font-size: 17px; font-weight: 900; transition: transform .2s ease; }
.tt-benefits div:hover { transform: translateX(5px) scale(1.02); }
.tt-benefits span { display: grid; place-items: center; width: 38px; height: 38px; border: 2px solid #000; border-radius: 10px; flex: 0 0 auto; }

.tt-product-grid { position: relative; padding: 80px 0; background: var(--tt-cream); overflow: hidden; }
.tt-pop-pattern { position: absolute; inset: 0; opacity: .08; background: radial-gradient(#000 1.4px, transparent 1.4px); background-size: 22px 22px; }
.tt-card-grid { position: relative; display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 28px; }
.tt-product-card { position: relative; min-height: 610px; background: var(--card-color); border: 4px solid #000; border-radius: 40px; padding: 26px; box-shadow: var(--tt-shadow); overflow: hidden; transition: transform .25s ease, box-shadow .25s ease; }
.tt-product-card:hover { transform: translateY(-10px); box-shadow: 12px 12px 0 #000; }
.tt-product-card::before { content: ""; position: absolute; top: 0; right: 0; width: 132px; height: 132px; border-radius: 0 0 0 100%; background: rgba(255,255,255,.2); }
.tt-card-head { display: flex; align-items: flex-start; justify-content: space-between; position: relative; z-index: 2; }
.tt-card-head span { background: #fff; border: 2px solid #000; border-radius: 999px; padding: 7px 14px; font-size: 13px; font-weight: 900; text-transform: uppercase; transform: rotate(-2deg); }
.tt-card-head strong { font-size: 18px; letter-spacing: -2px; }
.tt-card-can { position: relative; display: grid; place-items: center; min-height: 300px; }
.tt-card-can img { height: 260px; object-fit: contain; filter: drop-shadow(0 16px 18px rgba(0,0,0,.32)); transition: transform .25s ease; }
.tt-product-card:hover .tt-card-can img { transform: rotate(6deg) scale(1.08); }
.tt-card-can::before { content: ""; position: absolute; width: 165px; height: 165px; border-radius: 999px; background: var(--accent); border: 2px solid #000; filter: blur(18px); opacity: .5; }
.tt-card-info { position: relative; z-index: 2; background: rgba(255,255,255,.12); border: 2px solid rgba(0,0,0,.1); border-radius: 22px; padding: 18px; backdrop-filter: blur(8px); color: #fff; }
.tt-card-info h3 { margin: 0 0 8px; font-size: 38px; line-height: .9; font-weight: 900; text-transform: uppercase; }
.tt-card-info p { margin: 0 0 14px; font-size: 17px; line-height: 1.2; font-weight: 800; }
.tt-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.tt-tags span { background: #fff; color: #000; border: 2px solid #000; border-radius: 999px; padding: 5px 10px; font-size: 11px; font-weight: 900; text-transform: uppercase; }
.tt-card-buy { display: flex; align-items: center; justify-content: space-between; margin-top: 18px; }
.tt-card-buy strong { font-size: 30px; font-weight: 900; }
.tt-plus, .tt-card-add { display: grid; place-items: center; width: 48px; height: 48px; background: #fff; color: #000; border: 2px solid #000; border-radius: 14px; box-shadow: var(--tt-shadow-sm); font-size: 28px; font-weight: 900; }
.tt-card-add { position: absolute; right: 44px; bottom: 42px; z-index: 4; }

.tt-bundles { padding: 96px 0; background: #fff; border-block: 4px solid #000; position: relative; overflow: hidden; }
.tt-dot-pattern { position: absolute; inset: 0; opacity: .1; background: radial-gradient(#000 2px, transparent 2px); background-size: 30px 30px; }
.tt-bundle-grid { position: relative; display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 28px; }
.tt-bundle-card { background: #fff; border: 4px solid #000; border-radius: 32px; overflow: hidden; box-shadow: var(--tt-shadow); transition: transform .25s ease, box-shadow .25s ease; }
.tt-bundle-card:hover { transform: translateY(-6px); box-shadow: 12px 12px 0 #000; }
.tt-bundle-top { position: relative; min-height: 315px; padding: 30px; border-bottom: 4px solid #000; text-align: center; overflow: hidden; }
.tt-bundle-top b { position: absolute; left: -16px; bottom: -34px; font-size: 125px; line-height: 1; opacity: .2; }
.tt-badge { position: absolute; top: 18px; right: 18px; background: #fff; border: 2px solid #000; border-radius: 999px; padding: 5px 10px; font-size: 11px; font-weight: 900; text-transform: uppercase; }
.tt-bundle-top h3 { margin: 10px 0 4px; font-size: 31px; font-weight: 900; text-transform: uppercase; }
.tt-bundle-top p { font-weight: 800; color: rgba(0,0,0,.68); }
.tt-bundle-cans { position: relative; height: 162px; margin-top: 20px; }
.tt-bundle-cans img { position: absolute; left: calc(50% - 60px + var(--i) * 60px); transform: translateX(-50%) rotate(calc((var(--i) - 1) * 10deg)); height: 145px; filter: drop-shadow(0 14px 18px rgba(0,0,0,.25)); transition: transform .25s ease; }
.tt-bundle-card:hover .tt-bundle-cans img { transform: translateX(-50%) translateY(-10px) rotate(calc((var(--i) - 1) * -5deg)) scale(1.08); }
.tt-bundle-body { padding: 28px; }
.tt-bundle-body del { display: block; color: #9ca3af; font-size: 18px; font-weight: 800; }
.tt-bundle-body strong { display: block; font-size: 48px; line-height: .95; font-weight: 900; margin-bottom: 10px; }
.tt-bundle-body small { display: inline-block; background: #dcfce7; color: #15803d; border: 2px solid #15803d; border-radius: 10px; padding: 5px 9px; font-size: 12px; font-weight: 900; text-transform: uppercase; margin-bottom: 20px; }
.tt-bundle-body .tt-btn { width: 100%; border-radius: 14px; }
.tt-shipping-note { display: table; margin: 44px auto 0; background: #f3f4f6; border: 2px solid rgba(0,0,0,.1); border-radius: 999px; padding: 13px 24px; color: #6b7280; font-weight: 900; }

.tt-comparison { padding: 80px 0; background: #fff; }
.tt-comparison-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; max-width: 980px; margin: auto; }
.tt-regular, .tt-upgrade { border-radius: 28px; padding: 32px; }
.tt-regular { background: #f3f4f6; border: 2px solid #e5e7eb; opacity: .7; }
.tt-upgrade { position: relative; background: var(--tt-cream); border: 4px solid #000; box-shadow: var(--tt-shadow); }
.tt-upgrade > span { position: absolute; top: -18px; right: -18px; background: var(--tt-yellow); border: 2px solid #000; padding: 8px 14px; font-weight: 900; text-transform: uppercase; animation: ttWiggle 2s ease-in-out infinite; }
.tt-comparison h3 { margin: 0 0 26px; text-align: center; font-size: 28px; font-weight: 900; text-transform: uppercase; }
.tt-comparison ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 16px; font-weight: 900; font-size: 18px; }

.tt-science { position: relative; padding: 128px 0; background: #000; color: #fff; overflow: hidden; }
.tt-grid-bg { position: absolute; inset: 0; opacity: .22; background-image: linear-gradient(#333 1px, transparent 1px), linear-gradient(90deg, #333 1px, transparent 1px); background-size: 40px 40px; }
.tt-science .tt-centered-heading h2 { background: linear-gradient(90deg, var(--tt-yellow), var(--tt-orange), var(--tt-red)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.tt-science-steps { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin-top: 86px; }
.tt-science-steps::before { content: ""; position: absolute; left: 8%; right: 8%; top: 50%; height: 8px; border-radius: 999px; background: linear-gradient(90deg, var(--tt-yellow), var(--tt-orange)); transform: translateY(-50%); opacity: .45; }
.tt-science-steps article { position: relative; z-index: 2; background: #111827; border: 1px solid #263041; border-radius: 28px; padding: 56px 28px 30px; text-align: center; transition: border-color .2s ease, transform .2s ease; }
.tt-science-steps article:hover { border-color: var(--tt-yellow); transform: translateY(-4px); }
.tt-science-steps i { position: absolute; top: -42px; left: 50%; transform: translateX(-50%); width: 82px; height: 82px; border-radius: 999px; background: #000; border: 4px solid #263041; display: block; }
.tt-science-steps i::after { content: ""; position: absolute; inset: 20px; border-radius: 999px; background: var(--tt-yellow); box-shadow: 0 0 28px var(--tt-yellow); }
.tt-science-steps h3 { font-size: 30px; margin: 0 0 14px; text-transform: uppercase; }
.tt-science-steps p { color: #cbd5e1; font-weight: 700; line-height: 1.55; }

.tt-social { padding: 80px 0; background: color-mix(in srgb, var(--tt-pink), transparent 90%); }
.tt-social-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.tt-social-grid a { position: relative; aspect-ratio: 1; overflow: hidden; border: 2px solid #000; border-radius: 14px; background: #fff; transition: transform .2s ease; }
.tt-social-grid a:hover { transform: rotate(1deg) scale(1.02); }
.tt-social-grid img { width: 100%; height: 100%; object-fit: cover; display: block; }
.tt-social-grid span { position: absolute; inset: 0; display: grid; place-items: center; background: rgba(0,0,0,.5); color: #fff; font-size: 40px; opacity: 0; transition: opacity .2s ease; }
.tt-social-grid a:hover span { opacity: 1; }

.tt-faq { padding: 80px 0; background: #fff; }
.tt-faq h2 { text-align: center; margin: 0 0 40px; font-size: 42px; font-weight: 900; text-transform: uppercase; }
.tt-faq-item { border: 2px solid #000; border-radius: 14px; overflow: hidden; margin-bottom: 16px; }
.tt-faq-item summary { display: flex; align-items: center; justify-content: space-between; cursor: pointer; padding: 22px 24px; font-size: 18px; font-weight: 900; list-style: none; }
.tt-faq-item summary::-webkit-details-marker { display: none; }
.tt-faq-item[open] summary { background: var(--tt-yellow); }
.tt-faq-item summary span::before { content: "+"; font-size: 24px; }
.tt-faq-item[open] summary span::before { content: "-"; }
.tt-faq-item div { padding: 22px 24px; border-top: 2px solid #000; }
.tt-faq-item p { margin: 0; color: #4b5563; font-weight: 700; line-height: 1.6; }

.tt-page, .tt-wc-main { padding: 132px 0 80px; min-height: 70vh; }
.tt-page-header { text-align: center; margin-bottom: 52px; }
.tt-page-header h1 { margin: 0; font-size: clamp(48px, 7vw, 88px); line-height: .92; font-weight: 900; text-transform: uppercase; letter-spacing: 0; }
.tt-entry { font-size: 18px; font-weight: 600; line-height: 1.75; }
.tt-entry a { color: var(--tt-orange); font-weight: 900; }
.tt-featured-image img { border: 4px solid #000; border-radius: 28px; box-shadow: var(--tt-shadow); margin-bottom: 36px; }
.tt-post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.tt-post-card { background: #fff; border: 4px solid #000; border-radius: 28px; overflow: hidden; box-shadow: var(--tt-shadow); transition: transform .2s ease; }
.tt-post-card:hover { transform: translateY(-8px); }
.tt-post-thumb { height: 210px; border-bottom: 4px solid #000; overflow: hidden; }
.tt-post-thumb img { width: 100%; height: 100%; object-fit: cover; }
.tt-post-body { padding: 24px; }
.tt-post-body span { background: var(--tt-yellow); border: 2px solid #000; border-radius: 999px; padding: 5px 10px; font-size: 12px; font-weight: 900; text-transform: uppercase; }
.tt-post-body h2 { font-size: 26px; line-height: 1.05; text-transform: uppercase; }
.tt-post-body p { color: #4b5563; font-weight: 700; }
.tt-post-body b { color: var(--tt-orange); text-transform: uppercase; }

.tt-story-page { background: #ffea00; padding: 132px 0 88px; overflow: hidden; }
.tt-story-page .tt-container { width: min(100% - 32px, 980px); }
.tt-story-title-highlight { color: var(--tt-orange); }
.tt-story-page .tt-page-header { margin-bottom: 70px; }
.tt-story-page .tt-page-header h1 { font-size: clamp(48px, 6vw, 70px); }
.tt-story-row { display: grid; grid-template-columns: 1.03fr .97fr; align-items: center; gap: 70px; margin-bottom: 88px; }
.tt-story-row.is-reversed > div:first-child { order: 2; }
.tt-story-row h2 { font-size: clamp(28px, 3vw, 38px); line-height: .98; margin: 0 0 24px; font-weight: 900; text-transform: uppercase; }
.tt-story-row p { font-size: 16px; line-height: 1.55; font-weight: 750; color: #1f2937; }
.tt-story-lead { font-size: clamp(18px, 2vw, 24px) !important; line-height: 1.22 !important; font-weight: 900 !important; color: #1f2937 !important; }
.tt-story-row > img, .tt-story-stack img, .tt-story-overlap img { border: 4px solid #000; border-radius: 28px; box-shadow: var(--tt-shadow); object-fit: cover; width: 100%; background: #fff; }
.tt-story-row > img { aspect-ratio: 4 / 3; object-fit: contain; background: #d9d9d9; padding: 32px; }
.tt-story-stack { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.tt-story-stack img { aspect-ratio: 1; object-fit: contain; background: #d9d9d9; padding: 28px; }
.tt-story-stack img:first-child { margin-top: 42px; }
.tt-story-row strong { display: block; background: #fff; border: 4px solid #000; border-radius: 16px; box-shadow: var(--tt-shadow-sm); color: var(--tt-orange); font-size: clamp(22px, 2.4vw, 30px); line-height: 1.05; font-weight: 900; text-transform: uppercase; padding: 22px 28px; transform: rotate(-2deg); margin-top: 28px; }
.tt-story-banner { background: #b000ff; color: #fff; border: 4px solid #000; border-radius: 24px; box-shadow: var(--tt-shadow); padding: clamp(42px, 5vw, 62px) clamp(28px, 6vw, 72px); text-align: center; margin-bottom: 88px; }
.tt-story-banner p { font-size: clamp(28px, 3.4vw, 42px); line-height: 1.08; font-weight: 900; text-transform: uppercase; margin: 0 0 24px; }
.tt-story-banner span { font-size: clamp(17px, 1.7vw, 22px); line-height: 1.42; font-weight: 700; display: block; max-width: 760px; margin: auto; }
.tt-story-row ul { list-style: none; margin: 26px 0; padding: 0; display: grid; gap: 12px; }
.tt-story-row li { display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 12px; background: rgba(255,255,255,.5); border: 2px solid #000; border-radius: 10px; padding: 12px 14px; font-size: 15px; font-weight: 900; }
.tt-story-row li span { font-size: 22px; line-height: 1; }
.tt-story-no { color: var(--tt-red); }
.tt-story-yes { color: #84cc16; }
.tt-story-row li:last-child { background: #fff; box-shadow: var(--tt-shadow-sm); }
.tt-story-overlap { position: relative; min-height: 460px; }
.tt-story-overlap img:first-child { width: 78%; aspect-ratio: 1; object-fit: cover; padding: 0; background: #bd8437; }
.tt-story-overlap img:last-child { position: absolute; right: 0; bottom: 0; width: 58%; aspect-ratio: 1.25; object-fit: cover; padding: 0; }
.tt-story-conclusion p:first-child { font-size: clamp(24px, 2.8vw, 32px); line-height: 1.15; font-weight: 900; margin: 0 0 20px; color: #111827; }
.tt-story-note { font-size: clamp(16px, 1.7vw, 20px) !important; font-weight: 800 !important; margin: 0 0 26px !important; }
.tt-story-signoff { margin: 0; font-size: clamp(54px, 7vw, 82px) !important; line-height: .88 !important; font-weight: 900 !important; text-transform: uppercase; color: #111827 !important; }
.tt-story-signoff span { color: var(--tt-red); display: inline-block; transform: rotate(-2deg); }
.tt-story-ending-grid img { aspect-ratio: 3 / 4; padding: 0; object-fit: cover; background: #fff; }
.tt-story-ending-grid img:last-child { margin-top: 42px; }

.tt-partner-page {
	min-height: 100vh;
	background: #ff5a00;
	color: #000;
	padding: 92px 0 126px;
}
.tt-partner-page .tt-container {
	width: min(100% - 32px, 1120px);
}
.tt-partner-header {
	margin: 0 auto 70px;
	text-align: center;
}
.tt-partner-page .tt-page-header h1 {
	margin: 0 0 34px;
	color: #fff;
	font-size: clamp(48px, 6vw, 86px);
	line-height: .9;
	font-weight: 900;
	text-transform: uppercase;
	text-shadow: none;
}
.tt-partner-page .tt-page-header h1 span {
	color: var(--tt-yellow);
}
.tt-partner-page .tt-page-header p {
	max-width: 760px;
	margin: 0 auto;
	font-size: clamp(22px, 2.3vw, 30px);
	font-weight: 900;
	line-height: 1.28;
}
.tt-partner-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 34px;
	width: min(100%, 980px);
	margin: 0 auto 82px;
}
.tt-partner-grid article,
.tt-partner-cta,
.tt-contact-card,
.tt-contact-info > div,
.tt-manufacture-card {
	border: 4px solid #000;
	border-radius: 22px;
	box-shadow: 8px 8px 0 #000;
	background: #fff;
}
.tt-partner-grid article {
	min-height: 300px;
	padding: 38px 34px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
}
.tt-partner-grid article:nth-child(2) {
	background: var(--tt-yellow);
}
.tt-partner-grid article:nth-child(3) {
	background: var(--tt-green);
	color: #fff;
}
.tt-partner-grid b {
	display: block;
	margin-bottom: 34px;
	font-size: 38px;
	line-height: 1;
}
.tt-partner-grid h2,
.tt-partner-cta h2,
.tt-contact-card h2,
.tt-contact-info h2 {
	margin: 0 0 18px;
	font-size: clamp(24px, 2vw, 30px);
	line-height: 1;
	font-weight: 900;
	text-transform: uppercase;
}
.tt-partner-grid p,
.tt-partner-cta p {
	margin: 0;
	font-size: clamp(16px, 1.5vw, 19px);
	font-weight: 750;
	line-height: 1.5;
}
.tt-partner-cta {
	width: min(100%, 980px);
	margin: auto;
	padding: 68px 44px 66px;
	text-align: center;
}
.tt-partner-cta h2 {
	font-size: clamp(36px, 4vw, 50px);
	margin-bottom: 28px;
}
.tt-partner-cta p {
	max-width: 760px;
	margin: 0 auto 42px;
	font-size: clamp(20px, 2vw, 25px);
}
.tt-partner-cta-button {
	min-width: 340px;
	border-radius: 12px;
	padding-block: 22px;
	font-size: 22px;
	box-shadow: none;
}
.tt-contact-card,
.tt-contact-info > div,
.tt-manufacture-card {
	border-radius: 28px;
	box-shadow: var(--tt-shadow);
	padding: 32px;
}

.tt-contact-page { background: var(--tt-green); padding: 132px 0 88px; }
.tt-contact-page .tt-page-header h1 { color: #fff; text-shadow: 0 8px 20px rgba(0,0,0,.22); }
.tt-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 42px; }
.tt-contact-info { display: grid; gap: 28px; }
.tt-contact-info > div:first-child { background: var(--tt-yellow); }
.tt-contact-info a { display: inline-block; background: #000; color: #fff; border-radius: 999px; padding: 9px 13px; margin: 4px; font-size: 13px; font-weight: 900; text-transform: uppercase; }
.tt-form { display: grid; gap: 20px; }
.tt-form label { display: grid; gap: 8px; font-size: 13px; font-weight: 900; text-transform: uppercase; color: #374151; }
.tt-form input, .tt-form textarea { border: 2px solid #000; border-radius: 14px; padding: 13px; resize: vertical; }
.tt-form button { background: var(--tt-orange); color: #fff; border: 2px solid #000; border-radius: 14px; padding: 16px; box-shadow: var(--tt-shadow-sm); font-weight: 900; text-transform: uppercase; cursor: pointer; }
.tt-manufacture-card h3 { color: #6b7280; font-size: 13px; text-transform: uppercase; letter-spacing: .1em; margin: 24px 0 6px; }
.tt-manufacture-card h3:first-child { margin-top: 0; }
.tt-manufacture-card p { font-size: 20px; line-height: 1.5; }

.tt-footer { background: var(--tt-purple); color: #fff; border-top: 4px solid #000; }
.tt-newsletter { background: var(--tt-yellow); color: var(--tt-dark); border-bottom: 4px solid #000; padding: 48px 0; }
.tt-newsletter .tt-container { display: flex; align-items: center; justify-content: space-between; gap: 32px; }
.tt-newsletter h2 { margin: 0 0 6px; font-size: clamp(36px, 5vw, 56px); line-height: .9; font-weight: 900; text-transform: uppercase; }
.tt-newsletter p { margin: 0; font-size: 18px; font-weight: 800; }
.tt-newsletter form { display: flex; gap: 8px; width: min(100%, 460px); }
.tt-newsletter input { flex: 1; border: 2px solid #000; border-radius: 14px; padding: 16px; font-weight: 800; }
.tt-newsletter button { border: 2px solid #000; background: var(--tt-red); color: #fff; border-radius: 14px; min-width: 60px; box-shadow: var(--tt-shadow-sm); font-size: 24px; font-weight: 900; cursor: pointer; }
.tt-footer-main { display: grid; grid-template-columns: 1.4fr .8fr .8fr 1.1fr; gap: 46px; padding: 76px 0 54px; }
.tt-footer-about .tt-logo-img, .tt-footer-about .custom-logo { height: 96px; }
.tt-footer-about p { border-left: 2px solid var(--tt-orange); padding-left: 16px; font-weight: 700; line-height: 1.65; }
.tt-footer h4 { color: var(--tt-yellow); font-size: 20px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.tt-footer-menu { list-style: none; margin: 0; padding: 0; display: grid; gap: 12px; font-weight: 800; }
.tt-footer-menu a { display: inline-block; transition: transform .2s ease; }
.tt-footer-menu a:hover { transform: translateX(4px); }
.tt-social-links { display: flex; flex-wrap: wrap; gap: 10px; }
.tt-social-links a { background: #fff; color: var(--tt-dark); border-radius: 12px; padding: 10px 12px; font-size: 12px; font-weight: 900; text-transform: uppercase; box-shadow: 3px 3px 0 rgba(255,255,255,.35); }
.tt-footer-bottom { border-top: 2px solid rgba(255,255,255,.12); padding: 28px 0; display: flex; justify-content: space-between; gap: 16px; font-size: 14px; font-weight: 800; }
.tt-mobile-sticky-shop { position: fixed; left: 16px; right: 16px; bottom: 18px; z-index: 60; display: none; pointer-events: none; }
.tt-mobile-sticky-shop a { pointer-events: auto; }

.tt-cart-drawer {
	position: fixed;
	inset: 0;
	z-index: 120;
	pointer-events: none;
	visibility: hidden;
}
.tt-cart-drawer.is-open {
	pointer-events: auto;
	visibility: visible;
}
.tt-cart-drawer-backdrop {
	position: absolute;
	inset: 0;
	border: 0;
	background: rgba(0,0,0,.45);
	opacity: 0;
	transition: opacity .25s ease;
}
.tt-cart-drawer.is-open .tt-cart-drawer-backdrop { opacity: 1; }
.tt-cart-drawer-panel {
	position: absolute;
	top: 0;
	right: 0;
	width: min(100%, 430px);
	height: 100%;
	background: var(--tt-cream);
	border-left: 4px solid #000;
	box-shadow: -18px 0 38px rgba(0,0,0,.22);
	transform: translateX(105%);
	transition: transform .34s cubic-bezier(.34,1.56,.64,1);
	display: flex;
	flex-direction: column;
}
.tt-cart-drawer.is-open .tt-cart-drawer-panel { transform: translateX(0); }
.tt-cart-drawer header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 22px;
	border-bottom: 4px solid #000;
	background: var(--tt-yellow);
}
.tt-cart-drawer h2 {
	margin: 0;
	font-size: 28px;
	line-height: 1;
	font-weight: 900;
	text-transform: uppercase;
}
.tt-cart-drawer header button {
	width: 42px;
	height: 42px;
	border: 2px solid #000;
	border-radius: 999px;
	background: #fff;
	box-shadow: var(--tt-shadow-sm);
	font-size: 28px;
	font-weight: 900;
	line-height: 1;
	cursor: pointer;
}
.tt-mini-cart-content {
	padding: 20px;
	overflow: auto;
	flex: 1;
	position: relative;
	transition: opacity .18s ease;
}
.tt-mini-cart-content.is-updating {
	opacity: .62;
	pointer-events: none;
}
.tt-mini-cart-content .woocommerce-mini-cart {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 14px;
}
.tt-mini-cart-content .woocommerce-mini-cart-item {
	position: relative;
	display: grid;
	grid-template-columns: 72px 1fr;
	gap: 14px;
	align-items: center;
	background: #fff;
	border: 2px solid #000;
	border-radius: 16px;
	padding: 12px;
	box-shadow: 3px 3px 0 #000;
	font-weight: 800;
}
.tt-mini-cart-content .woocommerce-mini-cart-item img {
	width: 72px;
	height: 72px;
	object-fit: contain;
	background: var(--tt-cream);
	border-radius: 12px;
}
.tt-mini-cart-content .remove {
	position: absolute;
	top: 8px;
	right: 10px;
	font-size: 24px;
	font-weight: 900;
	color: var(--tt-red) !important;
}
.tt-mini-cart-thumb a,
.tt-mini-cart-thumb {
	display: block;
	line-height: 0;
}
.tt-mini-cart-item-main {
	min-width: 0;
	display: grid;
	gap: 9px;
}
.tt-mini-cart-item-head {
	display: grid;
	grid-template-columns: 1fr 30px;
	gap: 8px;
	align-items: start;
}
.tt-mini-cart-item-head strong {
	display: block;
	font-size: 14px;
	line-height: 1.15;
	text-transform: uppercase;
}
.tt-mini-cart-remove {
	width: 30px;
	height: 30px;
	border: 2px solid #000;
	border-radius: 999px;
	background: #fff;
	color: var(--tt-red);
	box-shadow: 2px 2px 0 #000;
	font-size: 20px;
	font-weight: 900;
	line-height: 1;
	cursor: pointer;
}
.tt-mini-cart-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}
.tt-mini-cart-price {
	font-weight: 900;
}
.tt-mini-cart-qty {
	display: grid;
	grid-template-columns: 30px 42px 30px;
	align-items: center;
	border: 2px solid #000;
	border-radius: 999px;
	overflow: hidden;
	background: var(--tt-yellow);
}
.tt-mini-cart-qty button,
.tt-mini-cart-qty input {
	width: 100%;
	height: 32px;
	border: 0;
	background: transparent;
	text-align: center;
	font-size: 14px;
	font-weight: 900;
}
.tt-mini-cart-qty button {
	cursor: pointer;
}
.tt-mini-cart-qty input {
	background: #fff;
	border-inline: 2px solid #000;
	-moz-appearance: textfield;
}
.tt-mini-cart-qty input::-webkit-outer-spin-button,
.tt-mini-cart-qty input::-webkit-inner-spin-button {
	margin: 0;
	-webkit-appearance: none;
}
.tt-mini-cart-line-total {
	color: #4b5563;
	font-size: 12px;
	font-weight: 850;
	text-transform: uppercase;
}
.tt-mini-cart-footer {
	position: sticky;
	bottom: -20px;
	margin: 18px -20px -20px;
	padding: 16px 20px 20px;
	background: var(--tt-cream);
	border-top: 3px solid #000;
}
.tt-mini-cart-empty {
	display: grid;
	gap: 12px;
	place-items: center;
	min-height: 50vh;
	text-align: center;
}
.tt-mini-cart-empty h3 {
	margin: 0;
	font-size: 28px;
	line-height: 1;
	font-weight: 900;
	text-transform: uppercase;
}
.tt-mini-cart-empty p {
	margin: 0;
	color: #4b5563;
	font-weight: 800;
}
.tt-mini-cart-content .woocommerce-mini-cart__total {
	display: flex;
	justify-content: space-between;
	border-top: 3px solid #000;
	margin-top: 20px;
	padding-top: 16px;
	font-size: 18px;
	font-weight: 900;
}
.tt-mini-cart-content .woocommerce-mini-cart__buttons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
.tt-mini-cart-content .button {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	border: 2px solid #000 !important;
	border-radius: 14px !important;
	background: var(--tt-dark) !important;
	color: #fff !important;
	padding: 13px !important;
	font-weight: 900 !important;
	text-transform: uppercase;
}

.tt-reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.tt-reveal.is-visible { opacity: 1; transform: translateY(0); }
.site-main, .tt-page, .tt-wc-main, .tt-story-page, .tt-partner-page, .tt-contact-page {
	animation: ttPageIn .55s ease both;
}

.woocommerce .products { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 28px; padding: 0; margin: 36px 0; list-style: none; }
.woocommerce ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; background: #fff; border: 4px solid #000; border-radius: 28px; box-shadow: var(--tt-shadow); padding: 22px; text-align: center; transition: transform .2s ease; }
.woocommerce ul.products li.product:hover { transform: translateY(-6px); }
.woocommerce ul.products li.product img { height: 270px; object-fit: contain; filter: drop-shadow(0 18px 20px rgba(0,0,0,.24)); }
.woocommerce-loop-product__title { font-size: 28px !important; line-height: 1 !important; font-weight: 900; text-transform: uppercase; color: var(--tt-dark); }
.woocommerce .price { color: var(--tt-dark) !important; font-size: 24px !important; font-weight: 900 !important; }
.woocommerce span.onsale { background: var(--tt-yellow); color: #000; border: 2px solid #000; min-width: auto; min-height: auto; padding: 7px 11px; border-radius: 999px; line-height: 1; font-weight: 900; }
.woocommerce div.product { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 56px; align-items: start; }
.woocommerce div.product div.images, .woocommerce div.product div.summary { width: auto !important; float: none !important; }
.woocommerce div.product div.images img { border: 4px solid #000; border-radius: 32px; background: var(--tt-cream); box-shadow: var(--tt-shadow); }
.woocommerce div.product .product_title { font-size: clamp(46px, 6vw, 82px); line-height: .9; font-weight: 900; text-transform: uppercase; }
.woocommerce div.product form.cart { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; margin-top: 28px; }
.woocommerce .quantity .qty { width: 82px; border: 2px solid #000; border-radius: 12px; padding: 14px; font-weight: 900; }
.woocommerce button.button, .woocommerce a.button, .woocommerce input.button, .woocommerce #respond input#submit { background: var(--tt-dark) !important; color: #fff !important; border: 2px solid #000 !important; border-radius: 14px !important; padding: 15px 24px !important; font-weight: 900 !important; text-transform: uppercase; letter-spacing: .06em; }
.woocommerce button.button:hover, .woocommerce a.button:hover { background: var(--tt-orange) !important; color: #000 !important; }
.woocommerce-cart table.cart, .woocommerce-checkout .woocommerce-checkout-review-order-table, .woocommerce table.shop_table { border: 3px solid #000; border-radius: 18px; overflow: hidden; background: #fff; }
.woocommerce-cart .cart-collaterals .cart_totals { border: 4px solid #000; border-radius: 24px; padding: 24px; box-shadow: var(--tt-shadow); background: var(--tt-cream); }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select { border: 2px solid #000; border-radius: 12px; padding: 13px; font-weight: 700; }
.woocommerce div.product form.cart .variations {
	border: 3px solid #000;
	border-radius: 18px;
	background: #fff;
	padding: 14px;
	width: 100%;
}
.woocommerce div.product form.cart .variations th,
.woocommerce div.product form.cart .variations td {
	display: block;
	text-align: left;
	padding: 6px 0;
}
.woocommerce div.product form.cart .variations label {
	font-weight: 900;
	text-transform: uppercase;
}
.woocommerce div.product form.cart .variations select {
	width: 100%;
	border: 2px solid #000;
	border-radius: 12px;
	padding: 12px;
	font-weight: 800;
	background: #fff;
}
.woocommerce div.product .woocommerce-tabs {
	border: 4px solid #000;
	border-radius: 24px;
	box-shadow: var(--tt-shadow);
	background: #fff;
	overflow: hidden;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	margin: 0 !important;
	padding: 0 !important;
	border-bottom: 4px solid #000;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	border: 0 !important;
	border-right: 2px solid #000 !important;
	border-radius: 0 !important;
	background: var(--tt-yellow) !important;
	margin: 0 !important;
	padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	padding: 15px 20px !important;
	font-weight: 900 !important;
	text-transform: uppercase;
}
.woocommerce div.product .woocommerce-tabs .panel {
	padding: 26px !important;
}
.woocommerce .related.products,
.woocommerce .up-sells.upsells.products {
	margin-top: 76px;
}
.woocommerce .related.products > h2,
.woocommerce .up-sells.upsells.products > h2,
.woocommerce-order h2,
.woocommerce-MyAccount-content h2 {
	font-size: clamp(34px, 5vw, 62px);
	line-height: .95;
	font-weight: 900;
	text-transform: uppercase;
}
.tt-single-product-grid { display: grid; grid-template-columns: minmax(0,.9fr) minmax(0,1.1fr); gap: 56px; align-items: start; }
.tt-product-promises { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.tt-product-promises span { background: var(--tt-yellow); border: 2px solid #000; border-radius: 999px; padding: 8px 12px; font-size: 13px; font-weight: 900; text-transform: uppercase; }
.tt-single-extra { margin-top: 70px; }
.tt-cart-product { display: flex; align-items: center; gap: 16px; font-weight: 900; }
.tt-cart-product img { width: 72px; height: 72px; object-fit: contain; border-radius: 12px; background: var(--tt-cream); }
.tt-checkout-grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(320px,.72fr); gap: 44px; align-items: start; }
.tt-order-review { border: 4px solid #000; border-radius: 24px; box-shadow: var(--tt-shadow); padding: 24px; background: var(--tt-cream); position: sticky; top: 110px; }
.tt-order-review h3 { margin-top: 0; font-size: 28px; font-weight: 900; text-transform: uppercase; }
.woocommerce-checkout-review-order-table {
	table-layout: fixed;
	width: 100%;
	border-collapse: separate !important;
	border-spacing: 0;
}
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
	padding: 14px 16px !important;
	vertical-align: middle;
}
.woocommerce-checkout-review-order-table .product-name {
	width: 100%;
	overflow-wrap: normal;
	word-break: normal;
}
.woocommerce-checkout-review-order-table thead,
.woocommerce-checkout-review-order-table tbody .product-total {
	display: none;
}
.woocommerce-checkout-review-order-table .cart_item .product-name {
	font-size: 16px;
	font-weight: 900;
	line-height: 1.25;
	text-transform: uppercase;
}
.woocommerce-checkout-review-order-table tfoot th,
.woocommerce-checkout-review-order-table tfoot td {
	font-weight: 900;
}
.tt-thankyou-card,
.woocommerce-MyAccount-navigation,
.woocommerce-MyAccount-content {
	background: #fff;
	border: 4px solid #000;
	border-radius: 24px;
	box-shadow: var(--tt-shadow);
	padding: 24px;
}
.woocommerce-order-overview {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
	list-style: none;
	padding: 0;
	margin: 24px 0;
}
.woocommerce-order-overview li {
	background: var(--tt-cream);
	border: 2px solid #000;
	border-radius: 14px;
	padding: 14px;
	font-weight: 900;
	text-transform: uppercase;
}
.woocommerce-account .woocommerce {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 34px;
}
.woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 10px;
}
.woocommerce-MyAccount-navigation a {
	display: block;
	background: var(--tt-yellow);
	border: 2px solid #000;
	border-radius: 12px;
	padding: 12px;
	font-weight: 900;
	text-transform: uppercase;
}

.tt-single-product-main {
	background:
		radial-gradient(circle at 8% 18%, rgba(253,224,71,.28), transparent 28%),
		radial-gradient(circle at 94% 8%, rgba(249,115,22,.16), transparent 24%),
		#fff;
	padding-top: 150px;
}
.woocommerce div.product.tt-single-product {
	display: block;
}
.tt-single-product-grid {
	grid-template-columns: minmax(0, 1.05fr) minmax(360px, .82fr);
	gap: clamp(34px, 5vw, 72px);
	align-items: start;
}
.tt-single-gallery {
	position: sticky;
	top: 108px;
	align-self: start;
}
.tt-product-gallery {
	display: grid;
	gap: 18px;
}
.tt-product-gallery-main {
	position: relative;
	margin: 0;
	display: grid;
	place-items: center;
	min-height: clamp(430px, 54vw, 680px);
	background:
		radial-gradient(circle at 50% 48%, rgba(253,224,71,.36), transparent 32%),
		linear-gradient(135deg, #fffdf0, #f7faf8);
	border: 4px solid #000;
	border-radius: 34px;
	box-shadow: 12px 12px 0 #000;
	overflow: hidden;
}
.tt-product-gallery-main::before {
	content: "";
	position: absolute;
	inset: 24px;
	border: 2px dashed rgba(0,0,0,.12);
	border-radius: 26px;
	pointer-events: none;
}
.tt-product-gallery-main img {
	position: relative;
	z-index: 2;
	width: min(78%, 520px);
	max-height: 600px;
	object-fit: contain;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	filter: drop-shadow(0 26px 34px rgba(0,0,0,.28));
	transition: transform .25s ease, opacity .2s ease;
}
.tt-product-gallery-main:hover img {
	transform: scale(1.035) rotate(1deg);
}
.tt-gallery-zoom {
	position: absolute;
	right: 18px;
	bottom: 18px;
	z-index: 4;
	background: #fff;
	border: 2px solid #000;
	border-radius: 999px;
	box-shadow: var(--tt-shadow-sm);
	padding: 9px 13px;
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
}
.tt-gallery-sale {
	position: absolute;
	top: 18px;
	left: 18px;
	z-index: 4;
	background: var(--tt-yellow);
	border: 2px solid #000;
	border-radius: 999px;
	box-shadow: var(--tt-shadow-sm);
	padding: 8px 14px;
	font-size: 14px;
	font-weight: 900;
	text-transform: uppercase;
}
.tt-product-gallery-thumbs {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}
.tt-gallery-thumb {
	aspect-ratio: 1;
	border: 3px solid #000;
	border-radius: 18px;
	background: #fff;
	box-shadow: 4px 4px 0 rgba(0,0,0,.4);
	cursor: pointer;
	padding: 8px;
	transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}
.tt-gallery-thumb:hover,
.tt-gallery-thumb.is-active {
	background: var(--tt-yellow);
	transform: translateY(-3px);
	box-shadow: 6px 6px 0 #000;
}
.tt-gallery-thumb img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.tt-single-summary {
	background: #fff;
	border: 4px solid #000;
	border-radius: 30px;
	box-shadow: var(--tt-shadow);
	padding: clamp(24px, 4vw, 42px);
	position: sticky;
	top: 108px;
}
.woocommerce div.product .tt-single-summary .product_title {
	margin: 0 0 18px;
	font-size: clamp(42px, 5vw, 72px);
	letter-spacing: 0;
}
.woocommerce div.product .tt-single-summary .price {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 10px;
	margin: 0 0 24px;
	font-size: clamp(28px, 3vw, 40px) !important;
	line-height: 1;
}
.woocommerce div.product .tt-single-summary .price del {
	color: rgba(0,0,0,.42);
	font-size: .72em;
}
.woocommerce div.product .tt-single-summary .price ins {
	color: var(--tt-dark);
	text-decoration-thickness: 3px;
}
.woocommerce-product-details__short-description {
	margin: 0 0 24px;
	color: #4b5563;
	font-size: 18px;
	font-weight: 750;
	line-height: 1.55;
}
.woocommerce div.product .tt-single-summary form.cart {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 14px;
	margin: 30px 0 20px;
}
.woocommerce div.product .tt-single-summary form.cart.variations_form {
	grid-template-columns: 1fr;
}
.woocommerce div.product .tt-single-summary .quantity .qty {
	width: 104px;
	height: 62px;
	text-align: center;
	font-size: 20px;
}
.woocommerce div.product .tt-single-summary .single_add_to_cart_button {
	min-height: 62px;
	min-width: 220px;
	flex: 1 1 220px;
	box-shadow: var(--tt-shadow-sm);
	font-size: 18px !important;
}
.woocommerce div.product .tt-single-summary .single_add_to_cart_button.is-loading {
	opacity: .72;
	cursor: wait;
}
.woocommerce div.product .product_meta {
	margin-top: 22px;
	border-top: 2px solid #000;
	padding-top: 20px;
	color: #4b5563;
	font-size: 14px;
	font-weight: 800;
	line-height: 1.5;
}
.woocommerce div.product .product_meta > span {
	display: block;
	margin-top: 6px;
}
.tt-product-promises {
	border-top: 2px dashed rgba(0,0,0,.18);
	padding-top: 22px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	margin-top: 22px;
}
.tt-product-promises span {
	margin: 0;
}
.tt-single-extra {
	margin-top: 84px;
}
.tt-single-extra .woocommerce-tabs,
.tt-single-extra .related.products,
.tt-single-extra .up-sells.upsells.products {
	max-width: 1200px;
	margin-inline: auto;
}
.tt-cart-drawer-backdrop {
	z-index: 1;
}
.tt-cart-drawer-panel {
	z-index: 2;
}
.tt-cart-drawer.is-open .tt-cart-drawer-panel,
.tt-cart-drawer.is-open .tt-cart-drawer-backdrop {
	pointer-events: auto;
}
.tt-empty-shop {
	background: var(--tt-cream);
	border: 4px solid #000;
	border-radius: 28px;
	box-shadow: var(--tt-shadow);
	padding: clamp(28px, 6vw, 64px);
	text-align: center;
}
.tt-empty-shop h2 {
	margin: 0 0 12px;
	font-size: clamp(34px, 5vw, 62px);
	line-height: .95;
	font-weight: 900;
	text-transform: uppercase;
}
.tt-lightbox {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: grid;
	place-items: center;
	background: rgba(0,0,0,.82);
	padding: 24px;
	cursor: zoom-out;
}
.tt-lightbox img {
	max-width: min(94vw, 1100px);
	max-height: 88vh;
	object-fit: contain;
	filter: drop-shadow(0 24px 44px rgba(0,0,0,.5));
}
.tt-lightbox button {
	position: fixed;
	top: 18px;
	right: 18px;
	width: 48px;
	height: 48px;
	border: 2px solid #000;
	border-radius: 999px;
	background: var(--tt-yellow);
	box-shadow: var(--tt-shadow-sm);
	font-size: 30px;
	font-weight: 900;
	cursor: pointer;
}
.woocommerce-notices-wrapper {
	position: relative;
	z-index: 3;
}
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
	border: 3px solid #000 !important;
	border-radius: 18px;
	background: var(--tt-yellow) !important;
	color: #000 !important;
	box-shadow: var(--tt-shadow-sm);
	font-weight: 850;
	margin: 0 0 28px !important;
	padding: 16px 18px !important;
	line-height: 1.25;
	clear: both;
}
.woocommerce-message {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
	display: none !important;
}
.woocommerce-message .button,
.woocommerce-message a.button {
	order: 2;
	flex: 0 0 auto;
	margin: 0 !important;
	white-space: nowrap;
}
.woocommerce-error {
	background: #fee2e2 !important;
}
.woocommerce-info {
	background: #e0f2fe !important;
}
.woocommerce-checkout #place_order,
.wc-proceed-to-checkout .checkout-button {
	width: 100%;
	min-height: 58px;
	box-shadow: var(--tt-shadow-sm);
}
.woocommerce-cart-form .actions {
	padding: 18px !important;
}
.woocommerce-cart-form .coupon {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.woocommerce-cart-form .coupon .input-text {
	min-width: min(100%, 260px);
	border: 2px solid #000;
	border-radius: 12px;
	padding: 13px;
	font-weight: 800;
}

/* WooCommerce Blocks cart/checkout alignment. */
.wc-block-components-sidebar,
.wp-block-woocommerce-checkout-order-summary-block,
.wp-block-woocommerce-cart-order-summary-block {
	border: 4px solid #000 !important;
	border-radius: 24px !important;
	background: var(--tt-cream) !important;
	box-shadow: var(--tt-shadow) !important;
	overflow: hidden;
}
.wc-block-components-sidebar {
	padding: 0 !important;
}
.wc-block-components-sidebar .wc-block-components-panel,
.wc-block-components-sidebar .wc-block-components-totals-wrapper,
.wp-block-woocommerce-checkout-order-summary-block .wc-block-components-panel,
.wp-block-woocommerce-cart-order-summary-block .wc-block-components-panel {
	border-color: #000 !important;
}
.wc-block-components-order-summary,
.wc-block-components-totals-wrapper,
.wc-block-components-sidebar .wc-block-components-panel {
	background: transparent !important;
}
.wc-block-components-order-summary__content {
	padding: 18px !important;
}
.wc-block-components-order-summary-item {
	display: grid !important;
	grid-template-columns: 1fr !important;
	gap: 0 !important;
	align-items: start !important;
	padding: 16px 0 !important;
	border-bottom: 2px solid rgba(0,0,0,.12) !important;
	min-width: 0 !important;
}
.wc-block-components-order-summary-item:last-child {
	border-bottom: 0 !important;
}
.wc-block-components-order-summary-item__image,
.wc-block-components-order-summary-item__quantity,
.wc-block-components-order-summary-item__total-price,
.wc-block-components-order-summary-item__individual-prices,
.wc-block-components-order-summary-item__description p,
.wc-block-components-product-metadata {
	display: none !important;
}
.wc-block-components-order-summary-item__description {
	min-width: 0 !important;
	padding: 0 !important;
}
.wc-block-components-order-summary-item__description .wc-block-components-product-name {
	display: block !important;
	margin: 0 !important;
	color: var(--tt-dark) !important;
	font-size: 16px !important;
	font-weight: 900 !important;
	line-height: 1.15 !important;
	text-transform: uppercase !important;
	overflow-wrap: break-word !important;
	word-break: normal !important;
}
.wp-block-woocommerce-checkout-order-summary-block .wc-block-components-order-summary-item > *:not(.wc-block-components-order-summary-item__description),
.wp-block-woocommerce-cart-order-summary-block .wc-block-components-order-summary-item > *:not(.wc-block-components-order-summary-item__description),
.wc-block-components-sidebar .wc-block-components-order-summary-item > *:not(.wc-block-components-order-summary-item__description) {
	display: none !important;
}
.wp-block-woocommerce-checkout-order-summary-block .wc-block-components-order-summary-item__description > *:not(.wc-block-components-product-name),
.wp-block-woocommerce-cart-order-summary-block .wc-block-components-order-summary-item__description > *:not(.wc-block-components-product-name),
.wc-block-components-sidebar .wc-block-components-order-summary-item__description > *:not(.wc-block-components-product-name) {
	display: none !important;
}
.woocommerce-checkout-review-order-table .product-name .variation,
.woocommerce-checkout-review-order-table .product-name .wc-item-meta,
.woocommerce-checkout-review-order-table .product-name .product-quantity,
.woocommerce-checkout-review-order-table .product-name p,
.woocommerce-checkout-review-order-table .product-name small,
.woocommerce-checkout-review-order-table .product-name .amount,
.woocommerce-checkout-review-order-table .product-name del,
.woocommerce-checkout-review-order-table .product-name ins {
	display: none !important;
}
.wc-block-components-totals-coupon,
.wc-block-components-totals-item {
	padding: 16px 20px !important;
}
.wc-block-components-totals-coupon__button,
.wc-block-components-button,
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button,
.wc-block-components-button.wc-block-components-totals-coupon__button {
	min-height: 54px !important;
	border: 3px solid #000 !important;
	border-radius: 16px !important;
	background: var(--tt-orange) !important;
	color: #000 !important;
	box-shadow: var(--tt-shadow-sm) !important;
	font-weight: 900 !important;
	text-transform: uppercase !important;
	letter-spacing: .02em !important;
	text-decoration: none !important;
	transition: transform .16s ease, box-shadow .16s ease, background .16s ease !important;
}
.wc-block-components-button:hover,
.wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover {
	transform: translate(2px, 2px) !important;
	box-shadow: 2px 2px 0 #000 !important;
	background: var(--tt-yellow) !important;
	color: #000 !important;
}
.wc-block-cart__submit-container {
	margin-top: 28px !important;
}
.wc-block-cart__submit-button {
	width: 100% !important;
	font-size: 18px !important;
}
.wc-block-components-totals-footer-item {
	padding: 20px !important;
	background: #fff !important;
	border-top: 3px solid #000 !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
	font-size: 26px !important;
	font-weight: 900 !important;
}
.wc-block-cart .wc-block-cart-items {
	border-color: #000 !important;
}
.wc-block-cart-items__row {
	border-bottom: 2px solid rgba(0,0,0,.18) !important;
}
.wc-block-cart-item__image img {
	width: 84px !important;
	height: 84px !important;
	object-fit: contain !important;
	background: #f5f8f6 !important;
	border-radius: 12px !important;
	padding: 8px !important;
}
.wc-block-cart-item__product .wc-block-components-product-name {
	color: var(--tt-orange) !important;
	font-weight: 900 !important;
	line-height: 1.15 !important;
	text-transform: uppercase !important;
}
.wc-block-components-quantity-selector {
	border: 2px solid #000 !important;
	border-radius: 12px !important;
	overflow: hidden !important;
}
.wc-block-components-quantity-selector input,
.wc-block-components-quantity-selector button {
	min-height: 38px !important;
	font-weight: 900 !important;
}

/* Alignment corrections for product cards and WooCommerce loops. */
.tt-product-card {
	display: flex;
	flex-direction: column;
}
.tt-product-card-link {
	display: flex;
	flex: 1;
	flex-direction: column;
	min-height: 0;
}
.tt-card-can {
	flex: 0 0 270px;
	min-height: 270px;
	padding: 18px 0 10px;
}
.tt-card-can img {
	max-width: 74%;
	max-height: 255px;
	height: auto;
}
.tt-card-info {
	display: flex;
	flex: 1;
	flex-direction: column;
	min-height: 280px;
}
.tt-card-info h3 {
	min-height: 72px;
}
.tt-card-info p {
	min-height: 102px;
}
.tt-tags {
	min-height: 36px;
	align-items: flex-start;
}
.tt-card-buy {
	margin-top: auto;
	padding-top: 18px;
	min-height: 70px;
}
.tt-card-add {
	right: 15%;
	bottom: 15%;
}
.tt-product-card.tt-has-product .tt-card-buy {
	padding-right: 62px;
}

.woocommerce ul.products li.product {
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 560px;
	padding: 28px 24px 24px;
}
.woocommerce ul.products li.product .woocommerce-loop-product__link {
	display: flex;
	flex: 1;
	flex-direction: column;
	align-items: center;
}
.woocommerce ul.products li.product img {
	width: 100%;
	max-width: 340px;
	height: 330px;
	margin: 0 auto 26px !important;
	padding: 28px;
	object-fit: contain;
	background: #f5f8f6;
	border-radius: 0;
	box-shadow: none;
	filter: none;
}
.woocommerce-loop-product__title {
	width: 100%;
	min-height: 68px;
	margin: 0 0 18px !important;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}
.woocommerce ul.products li.product .price {
	margin: 0 0 10px !important;
	min-height: 38px;
	display: flex !important;
	align-items: center;
	justify-content: center;
	gap: 8px;
}
.woocommerce ul.products li.product .button {
	align-self: center;
	margin-top: auto !important;
	min-width: 190px;
	text-align: center;
}
.woocommerce span.onsale {
	top: 18px;
	left: 50%;
	right: auto;
	transform: translateX(-50%);
	z-index: 5;
	margin: 0;
}

@keyframes ttFloat { 0%, 100% { transform: translate3d(0,0,0) rotate(0); opacity: .22; } 50% { transform: translate3d(18px,-36px,0) rotate(160deg); opacity: .5; } }
@keyframes ttPulse { 0%, 100% { transform: scale(1); opacity: .22; } 50% { transform: scale(1.1); opacity: .33; } }
@keyframes ttBubble { from { transform: translateY(160px); opacity: 0; } 25% { opacity: .9; } to { transform: translateY(-160px); opacity: 0; } }
@keyframes ttWiggle { 0%, 100% { transform: rotate(3deg); } 50% { transform: rotate(-3deg); } }
@keyframes ttLoaderSwirl { from { transform: translate(-50%, -50%) rotate(0); } to { transform: translate(-50%, -50%) rotate(360deg); } }
@keyframes ttLoaderRayFade { to { opacity: 0; } }
@keyframes ttLoaderGlow { 0%, 100% { transform: scale(1); opacity: .6; } 50% { transform: scale(1.2); opacity: .85; } }
@keyframes ttLoaderLogo {
	0% { opacity: 0; transform: scale(0); }
	33% { opacity: 1; transform: scale(1); }
	77% { opacity: 1; transform: scale(1); }
	100% { opacity: 0; transform: translateY(-45vh) scale(.2); }
}
@keyframes ttPageIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 1024px) {
	.tt-desktop-menu { display: none; }
	.tt-menu-toggle { display: flex; }
	.tt-nav-inner { grid-template-columns: 1fr auto 1fr; }
	.tt-shop-btn { display: none; }
	.tt-card-grid, .tt-bundle-grid, .woocommerce .products, .tt-post-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
	.tt-showcase-grid, .tt-comparison-grid, .woocommerce div.product { grid-template-columns: 1fr; }
	.tt-showcase.is-reversed .tt-showcase-visual { order: 0; }
	.tt-single-product-grid, .tt-checkout-grid { grid-template-columns: 1fr; }
	.tt-single-gallery, .tt-single-summary { position: static; }
	.tt-order-review { position: static; }
	.woocommerce-account .woocommerce, .woocommerce-order-overview { grid-template-columns: 1fr; }
	.tt-science-steps { grid-template-columns: 1fr; gap: 62px; }
	.tt-science-steps::before { display: none; }
	.tt-footer-main { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 700px) {
	.tt-container, .tt-narrow { width: min(100% - 24px, 1200px); }
	.tt-logo-img, .custom-logo { height: 72px; }
	.tt-nav.is-scrolled .tt-logo-img, .tt-nav.is-open .tt-logo-img, body:not(.has-pop-hero) .tt-logo-img,
	.tt-nav.is-scrolled .custom-logo, .tt-nav.is-open .custom-logo, body:not(.has-pop-hero) .custom-logo { height: 58px; }
	.tt-menu-toggle b { display: none; }
	.tt-mobile-panel .tt-container { grid-template-columns: 1fr; }
	.tt-mobile-meta { display: none; }
	.tt-hero { min-height: 100svh; height: 100svh; padding-top: 76px; }
	.tt-hero-title {
		position: absolute;
		top: 50%;
		left: 50%;
		width: 100%;
		transform: translate(-50%, -50%);
		font-size: clamp(54px, 17vw, 78px);
		line-height: .86;
	}
	.tt-hero-can-wrap {
		padding-top: 58px;
	}
	.tt-hero-can {
		width: min(40vh, 235px);
		max-height: 54svh;
	}
	.tt-hero-can.is-active {
		transform: translateY(24px) rotate(12deg);
	}
	.tt-hero-copy {
		gap: clamp(190px, 34svh, 235px);
		padding: 88px 12px 78px;
		justify-content: center;
		text-align: center;
	}
	.tt-hero-copy h2 {
		width: 100%;
		font-size: clamp(36px, 12.4vw, 48px);
		line-height: .92;
		white-space: nowrap;
	}
	.tt-hero-dots { display: none; }
	.tt-icon-star, .tt-icon-spark { display: none; }
	.tt-section-heading { padding-top: 76px; }
	.tt-showcase { padding: 58px 0; }
	.tt-showcase-visual { min-height: 330px; }
	.tt-benefits, .tt-card-grid, .tt-bundle-grid, .tt-comparison-grid, .tt-social-grid, .woocommerce .products, .tt-post-grid { grid-template-columns: 1fr; }
	.tt-product-card { min-height: 560px; }
	.tt-card-can { flex-basis: 240px; min-height: 240px; }
	.tt-card-can img { max-height: 225px; }
	.tt-card-info { min-height: 0; }
	.tt-card-info h3, .tt-card-info p, .tt-tags { min-height: 0; }
	.tt-card-buy strong { font-size: clamp(24px, 9vw, 34px); }
	.tt-product-card.tt-has-product .tt-card-buy { padding-right: 58px; }
	.tt-card-add { right: 15%; bottom: 15%; }
	.woocommerce ul.products li.product { min-height: 0; }
	.woocommerce ul.products li.product img { height: 280px; max-width: 300px; }
	.woocommerce-loop-product__title { min-height: 0; }
	.tt-social-grid { grid-template-columns: repeat(2, 1fr); }
	.tt-newsletter .tt-container, .tt-footer-bottom { flex-direction: column; align-items: flex-start; }
	.tt-newsletter form { width: 100%; }
	.tt-footer-main { grid-template-columns: 1fr; }
	.tt-page, .tt-wc-main { padding-top: 112px; }
	.tt-story-page, .tt-partner-page, .tt-contact-page { padding-top: 112px; }
	.tt-story-row, .tt-contact-grid { grid-template-columns: 1fr; }
	.tt-story-row.is-reversed > div:first-child { order: 0; }
	.tt-story-overlap { min-height: 360px; }
	.tt-story-ending-grid img:last-child { margin-top: 18px; }
	.tt-story-signoff { font-size: clamp(44px, 15vw, 72px) !important; }
	.tt-partner-page { padding: 104px 0 80px; }
	.tt-partner-page .tt-container { width: min(100% - 28px, 760px); }
	.tt-partner-header { margin-bottom: 28px; }
	.tt-partner-page .tt-page-header h1 { font-size: clamp(34px, 12vw, 46px); }
	.tt-partner-page .tt-page-header p { font-size: 15px; }
	.tt-partner-grid { grid-template-columns: 1fr; width: min(100%, 320px); gap: 18px; margin-bottom: 34px; }
	.tt-partner-grid article { min-height: 170px; }
	.tt-partner-cta { padding: 32px 20px; }
	.tt-partner-cta-button { width: 100%; min-width: 0; }
	.tt-mobile-sticky-shop { display: block; }
	body.woocommerce-cart .tt-mobile-sticky-shop, body.woocommerce-checkout .tt-mobile-sticky-shop { display: none; }
	.tt-single-product-main { padding-top: 118px; }
	.tt-product-gallery-main { min-height: 360px; border-radius: 24px; box-shadow: var(--tt-shadow-sm); }
	.tt-product-gallery-thumbs { grid-template-columns: repeat(4, minmax(0, 1fr)); }
	.woocommerce div.product .tt-single-summary form.cart { display: grid; grid-template-columns: 1fr; }
	.woocommerce div.product .tt-single-summary .quantity .qty,
	.woocommerce div.product .tt-single-summary .single_add_to_cart_button { width: 100%; min-width: 0; }
	.woocommerce-message { display: grid; gap: 12px; }
	.woocommerce-message .button,
	.woocommerce-message a.button { width: 100%; }
	.tt-cart-drawer-panel { width: min(100%, 390px); border-left-width: 3px; }
	.tt-mini-cart-content .woocommerce-mini-cart__buttons { grid-template-columns: 1fr; }
	.tt-order-review { padding: 18px; border-radius: 20px; box-shadow: var(--tt-shadow-sm); }
	.tt-order-review h3 { font-size: 22px; }
	.woocommerce-checkout-review-order-table th,
	.woocommerce-checkout-review-order-table td {
		padding: 12px !important;
	}
	.wc-block-components-order-summary-item {
		grid-template-columns: 1fr !important;
	}
	.wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
	.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
		font-size: 22px !important;
	}
}

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

/* Final fixes requested after WooCommerce/block styles load. */
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table thead,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-total,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name > *:not(a):not(strong):not(.product-name),
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name .variation,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name .wc-item-meta,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name .product-quantity,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name p,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name small,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name del,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name ins,
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name .amount {
	display: none !important;
}
body.woocommerce-checkout .tt-order-review .woocommerce-checkout-review-order-table .product-name {
	display: table-cell !important;
	width: 100% !important;
	padding: 14px 16px !important;
	font-size: 17px !important;
	font-weight: 900 !important;
	line-height: 1.18 !important;
	text-transform: uppercase !important;
	white-space: normal !important;
}
body.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-order-summary-item,
body.woocommerce-checkout .wc-block-components-sidebar .wc-block-components-order-summary-item {
	display: block !important;
	padding: 14px 0 !important;
}
body.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-order-summary-item > *:not(.wc-block-components-order-summary-item__description),
body.woocommerce-checkout .wc-block-components-sidebar .wc-block-components-order-summary-item > *:not(.wc-block-components-order-summary-item__description),
body.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-order-summary-item__description > *:not(.wc-block-components-product-name),
body.woocommerce-checkout .wc-block-components-sidebar .wc-block-components-order-summary-item__description > *:not(.wc-block-components-product-name) {
	display: none !important;
}
body.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block .wc-block-components-product-name,
body.woocommerce-checkout .wc-block-components-sidebar .wc-block-components-product-name {
	display: block !important;
	margin: 0 !important;
	color: var(--tt-dark) !important;
	font-size: 17px !important;
	font-weight: 900 !important;
	line-height: 1.18 !important;
	text-transform: uppercase !important;
}
body.single-product .tt-single-summary {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 18px;
	padding: clamp(32px, 4vw, 56px) !important;
}
body.single-product .woocommerce div.product .tt-single-summary .product_title {
	margin: 0 !important;
	font-size: clamp(42px, 4.4vw, 64px) !important;
	line-height: .96 !important;
}
body.single-product .woocommerce div.product .tt-single-summary .price {
	margin: 0 !important;
	gap: 12px !important;
	align-items: center !important;
}
body.single-product .woocommerce div.product .tt-single-summary form.cart {
	display: grid !important;
	grid-template-columns: 104px minmax(220px, 1fr) !important;
	gap: 14px !important;
	align-items: stretch !important;
	margin: 4px 0 0 !important;
}
body.single-product .woocommerce div.product .tt-single-summary .quantity,
body.single-product .woocommerce div.product .tt-single-summary .quantity .qty {
	width: 104px !important;
	margin: 0 !important;
}
body.single-product .woocommerce div.product .tt-single-summary .single_add_to_cart_button {
	width: 100% !important;
	min-width: 0 !important;
	margin: 0 !important;
}
body.single-product .woocommerce div.product .product_meta {
	margin: 0 !important;
	padding-top: 18px !important;
	border-top: 2px dashed rgba(0,0,0,.2) !important;
}
body.single-product .tt-product-promises {
	margin: 0 !important;
	padding-top: 4px !important;
	border-top: 0 !important;
	display: flex !important;
	gap: 12px !important;
	align-items: center !important;
}

@media (max-width: 700px) {
	body.single-product .woocommerce div.product .tt-single-summary form.cart {
		grid-template-columns: 1fr !important;
	}
	body.single-product .woocommerce div.product .tt-single-summary .quantity,
	body.single-product .woocommerce div.product .tt-single-summary .quantity .qty {
		width: 100% !important;
	}
}

body .tt-partner-page,
body .tt-partner-page .tt-partner-header,
body .tt-partner-page .tt-partner-grid,
body .tt-partner-page .tt-partner-grid article,
body .tt-partner-page .tt-partner-cta {
	opacity: 1 !important;
	visibility: visible !important;
}
body .tt-partner-page {
	display: block !important;
}
body .tt-partner-page .tt-partner-grid {
	display: grid !important;
}
