/*
Theme Name: Titlli for Hello Elementor
Theme URI: https://titlli.com/
Description: Pixel-perfect Hello Elementor child theme for the Titlli storefront. Implements the Figma design exactly with a responsive layout for desktop, tablet, and mobile.
Author: Titlli
Template: hello-elementor
Version: 2.0.0
Text Domain: titlli-hello-elementor
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/

/* ---------- Design tokens ---------- */
:root {
	--ttl-ink: #13132e;
	--ttl-ink-soft: rgba(19, 19, 46, 0.71);
	--ttl-cream: #faf5e6;
	--ttl-bg: #fdf8ef;
	--ttl-bg-warm: #f5e8d6;
	--ttl-bg-rose: #efd9cc;
	--ttl-line: rgba(19, 19, 46, 0.12);
	--ttl-line-soft: rgba(19, 19, 46, 0.06);
	--ttl-white: #ffffff;
	--ttl-shadow-sm: 0 8px 20px rgba(19, 19, 46, 0.06);
	--ttl-shadow-md: 0 18px 40px rgba(19, 19, 46, 0.08);
	--ttl-shadow-lg: 0 30px 70px rgba(19, 19, 46, 0.12);
	--ttl-font-display: "DM Sans", "Inter", system-ui, sans-serif;
	--ttl-font-eyebrow: "DM Sans", "Inter", system-ui, sans-serif;
	--ttl-font-body: "DM Sans", "Inter", system-ui, sans-serif;
	--ttl-radius-sm: 12px;
	--ttl-radius-md: 18px;
	--ttl-radius-lg: 28px;
	--ttl-radius-xl: 36px;
	--ttl-shell: 1280px;
	--ttl-pad: 104px;
}

/* ---------- Base reset ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--ttl-white);
	color: var(--ttl-ink);
	font-family: var(--ttl-font-body);
	font-size: 16px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; margin: 0; padding: 0; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
input, select, textarea { font: inherit; color: inherit; }

.site-shell { min-height: 100vh; display: flex; flex-direction: column; overflow-x: clip; }
.site-main { flex: 1; }

.ttl-visually-hidden {
	position: absolute;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

/* ---------- Header ---------- */
.site-header {
	position: absolute;
	inset: 0 0 auto 0;
	z-index: 30;
	background: transparent;
}

.site-header__bar {
	max-width: var(--ttl-shell);
	margin: 0 auto;
	padding: 24px 32px;
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	column-gap: 24px;
}

.site-header__logo img {
	width: 173px;
	height: 87px;
	object-fit: contain;
}

.site-header__nav .menu,
.site-header__nav .ttl-menu {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 32px;
	flex-wrap: wrap;
}

.site-header__nav .menu-item > a,
.ttl-menu .ttl-menu__item > a,
.ttl-menu li > a {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-family: var(--ttl-font-eyebrow);
	font-weight: 400;
	font-size: 18px;
	letter-spacing: 1.44px;
	text-transform: uppercase;
	color: var(--ttl-ink);
	white-space: nowrap;
	transition: opacity 0.2s ease;
}

.site-header__nav a:hover { opacity: 0.65; }

.ttl-menu__caret svg,
.menu-item-has-children > a::after {
	width: 18px;
	height: 18px;
	display: inline-block;
}

.menu-item-has-children > a::after {
	content: "";
	background-image: url("assets/figma/icon-down.png");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	margin-left: 4px;
}

.site-header__actions {
	display: flex;
	align-items: center;
	gap: 12px;
}

.site-header__search {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 233px;
	height: 42px;
	padding: 10px;
	background: rgba(255, 255, 255, 0.86);
	border-radius: 13px;
}

.site-header__search-icon {
	width: 24px;
	height: 24px;
	color: var(--ttl-ink);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.site-header__search-icon svg { width: 22px; height: 22px; }

.site-header__search input {
	flex: 1;
	min-width: 0;
	border: 0;
	background: transparent;
	font-family: var(--ttl-font-body);
	font-size: 16px;
	letter-spacing: 0.96px;
	color: var(--ttl-ink);
	outline: none;
}

.site-header__search input::placeholder { color: rgba(0, 0, 0, 0.5); }

.site-header__icon {
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--ttl-ink);
	position: relative;
	transition: opacity 0.2s ease;
}

.site-header__icon:hover { opacity: 0.7; }
.site-header__icon svg { width: 22px; height: 22px; }

.site-header__cart-count {
	position: absolute;
	top: 2px;
	right: 2px;
	min-width: 16px;
	height: 16px;
	padding: 0 4px;
	border-radius: 999px;
	background: var(--ttl-ink);
	color: var(--ttl-cream);
	font-size: 10px;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.site-header__toggle { display: none; }
.site-header__drawer { display: none; }

/* ---------- Buttons ---------- */
.ttl-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-width: 240px;
	height: 56px;
	padding: 0 28px;
	border-radius: 8px;
	font-family: var(--ttl-font-eyebrow);
	font-weight: 600;
	font-size: 16px;
	letter-spacing: 2.4px;
	text-transform: uppercase;
	transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.ttl-button--primary {
	background: var(--ttl-ink);
	color: var(--ttl-cream);
}

.ttl-button--primary:hover {
	background: #13132e;
	transform: translateY(-1px);
}

.ttl-button--light {
	background: var(--ttl-cream);
	color: var(--ttl-ink);
}

.ttl-button--light:hover {
	background: #ffffff;
	transform: translateY(-1px);
}

/* ---------- Eyebrow / Section title ---------- */
.ttl-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--ttl-font-eyebrow);
	font-weight: 500;
	font-size: 18px;
	letter-spacing: 4.14px;
	text-transform: uppercase;
	color: var(--ttl-ink);
}

.ttl-eyebrow--centered { justify-content: center; }
.ttl-eyebrow--light { color: var(--ttl-cream); }
.ttl-eyebrow__icon { width: 22px; height: 18px; object-fit: contain; }

.ttl-section {
	padding: 96px var(--ttl-pad);
	background: var(--ttl-white);
}

.ttl-section__header {
	max-width: var(--ttl-shell);
	margin: 0 auto 56px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
}

.ttl-section__title {
	margin: 0;
	font-family: var(--ttl-font-display);
	font-weight: 400;
	font-size: 56px;
	line-height: 1.05;
	letter-spacing: 1.4px;
	color: var(--ttl-ink);
}

.ttl-section__title em {
	font-style: italic;
	font-weight: 400;
}

/* ---------- Hero ---------- */
.ttl-hero {
	position: relative;
	min-height: 832px;
	padding: 200px var(--ttl-pad) 80px;
	background: var(--ttl-bg-warm);
	overflow: hidden;
}

.ttl-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center right;
	background-repeat: no-repeat;
	z-index: 0;
}

.ttl-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(245, 232, 214, 0.92) 0%, rgba(245, 232, 214, 0.55) 45%, rgba(245, 232, 214, 0) 75%);
	z-index: 1;
}

.ttl-hero__inner {
	position: relative;
	z-index: 2;
	max-width: var(--ttl-shell);
	margin: 0 auto;
}

.ttl-hero__content {
	max-width: 618px;
}

.ttl-hero__content .ttl-eyebrow { margin-bottom: 32px; }

.ttl-hero__title {
	margin: 0 0 32px;
	font-family: var(--ttl-font-display);
	font-weight: 400;
	font-size: 65px;
	line-height: 1.05;
	letter-spacing: 1.95px;
	color: var(--ttl-ink);
}

.ttl-hero__title em {
	font-style: italic;
	font-weight: 400;
}

.ttl-hero__lead {
	margin: 0 0 40px;
	max-width: 579px;
	font-family: var(--ttl-font-body);
	font-size: 22px;
	line-height: 1.45;
	color: var(--ttl-ink);
	font-weight: 400;
}

.ttl-hero__actions { display: flex; gap: 16px; flex-wrap: wrap; }

/* ---------- Product cards (shared across homepage + WooCommerce) ---------- */
:root {
	--ttl-card-bg: #f7ecda;
	--ttl-card-radius: 18px;
	--ttl-card-accent: #9F2A2E;
}

.ttl-product-grid {
	max-width: var(--ttl-shell);
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 24px;
}

.ttl-product-card,
.woocommerce ul.products li.product.ttl-product-card,
.woocommerce ul.products li.product {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--ttl-card-bg);
	border: 0;
	border-radius: var(--ttl-card-radius);
	overflow: hidden;
	box-shadow: 0 2px 0 rgba(19, 19, 46, 0.04);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	list-style: none;
	margin: 0;
	padding: 0;
	width: auto;
	float: none;
	border-bottom: .5px solid #9F2A2E;
}

.ttl-product-card:hover,
.woocommerce ul.products li.product.ttl-product-card:hover,
.woocommerce ul.products li.product:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 36px rgba(19, 19, 46, 0.10);
}

.ttl-product-card__media {
	position: relative;
	aspect-ratio: 1 / 1;
	background: var(--ttl-card-bg);
	overflow: hidden;
}

.ttl-product-card__image-link,
.ttl-product-card__media a {
	display: block;
	width: 100%;
	height: 100%;
}

.ttl-product-card__media img,
.ttl-product-card__image,
.woocommerce ul.products li.product .ttl-product-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 0;
	aspect-ratio: auto;
}

.ttl-product-card .ttl-product-card__badge,
.ttl-product-card__badge,
.woocommerce ul.products li.product.ttl-product-card .ttl-product-card__badge {
	position:absolute;
	top:14px;
	left:-34px;
	z-index:3;
	width:130px;
	background:#13132e ;
	color:#fff ;
	text-align:center;
	font-family:"DM Sans",system-ui,sans-serif ;
	font-size:14px ;
	font-weight:600 ;
	letter-spacing:1.5px ;
	text-transform:uppercase;
	transform:rotate(-45deg);
	border-radius:0 ;
	box-shadow:none ;
}

button.ttl-product-card__favorite,
.ttl-product-card .ttl-product-card__favorite {
	position: absolute;
	top: 14px;
	right: 14px;
	z-index: 2;
	width: 34px;
	height: 34px;
	min-width: 34px;
	padding: 0;
	border-radius: 999px !important;
	background: #ffffff !important;
	background-color: #ffffff !important;
	color: var(--ttl-ink);
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 10px rgba(19, 19, 46, 0.10);
	transition: transform 0.2s ease, background 0.2s ease;
	cursor: pointer;
	border: 0 !important;
	outline: 0;
	font-size: 0;
	line-height: 0;
	text-decoration: none;
	appearance: none;
	-webkit-appearance: none;
}

.ttl-product-card__favorite:hover { transform: scale(1.05); background: #ffffff !important; }
.ttl-product-card__favorite svg { width: 17px; height: 17px; color: var(--ttl-ink); }

.ttl-product-card__body {
	padding: 18px 22px 22px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex: 1;
	background: #ffffff;
}

.ttl-product-card__eyebrow {
	margin: 0;
	font-family: DM Sans;
	font-weight: 500;
	font-style: Medium;
	font-size: 11px;
	line-height: 12.75px;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--ttl-card-accent);

}



.ttl-product-card__title,
.woocommerce ul.products li.product.ttl-product-card .woocommerce-loop-product__title,
.woocommerce ul.products li.product .ttl-product-card__title {
	margin: 4px 0 2px;
	padding: 0;	
	color: var(--ttl-ink);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	font-family: DM Sans;
	font-weight: 400;
	font-style: Regular;
	font-size: 18px;
	/* line-height: 19.5px; */
	letter-spacing: 0px;

}

.ttl-product-card__title a { color: inherit; text-decoration: none; }

.ttl-product-card__desc {
	margin: 0 0 -5px;
	color: var(--ttl-ink-soft);
	display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
	font-family: DM Sans;
	font-weight: 400;
	font-style: Regular;
	font-size: 11px;
	leading-trim: NONE;
	line-height: 13.5px;
	letter-spacing: 0px;

}

.ttl-product-card__footer,
.ttl-product-card__price-row {
	margin-top: auto;
	padding-top: 14px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	min-width: 0;
}

.ttl-product-card__price {
	display: flex;
	flex-direction: column;
	gap: 2px;
	line-height: 1;
	min-width: 0;
	flex: 1 1 auto;
}

/* When the stepper is active, stack price above the stepper so neither
   gets clipped on narrow cards. */
/* .ttl-product-card__footer:has(.ttl-product-card__cart[data-state="qty"]) {
	flex-direction: column;
	align-items: stretch;
	gap: 12px;
}

.ttl-product-card__footer:has(.ttl-product-card__cart[data-state="qty"]) .ttl-product-card__cart {
	align-self: flex-end;
} */

.ttl-product-card__price strong,
.ttl-product-card__price .amount,.ttl-product-card__price .woocommerce-Price-currencySymbol,
.woocommerce ul.products li.product.ttl-product-card .price,
.woocommerce ul.products li.product .ttl-product-card__price strong {
	
	color: #13132e;	
	display: block;
	min-width: 0;
	max-width: 100%;
	overflow: hidden;
	font-family: DM Sans;
	font-weight: 600;
	font-size: 18px;
	line-height: 15px;
	letter-spacing: 0px;

}

span.woocommerce-Price-currencySymbol {
    float: left;
    margin: 0px!important;
}
.ttl-product-card__price .amount { font-size: inherit; }

/* Compact WooCommerce sale-price stacking inside the card. */
/* .ttl-product-card__price strong del,
.ttl-product-card__price strong ins {
	display: block;
	text-decoration: none;
} */
.ttl-product-card__price strong{
	display:flex;
	align-items:center;
	flex-wrap:wrap;
	gap:8px;
}

.ttl-product-card__price strong del,
.ttl-product-card__price strong ins{
	display:inline-flex;
	align-items:center;
	margin:0;
	text-decoration:none;
}

.ttl-product-card__price strong del{
	font-size:14px;
	font-weight:400;
	color:var(--ttl-ink-soft);
	text-decoration:line-through;
	opacity:.7;
}

.ttl-product-card__price strong ins{
	background:transparent;
	font-weight:700;
	padding:0;
}
.ttl-product-card__price strong del {
	font-size: 14px;
	font-weight: 400;
	color: var(--ttl-ink-soft);
	text-decoration: line-through;
	margin-bottom: 2px;
}

.ttl-product-card__price strong ins {
	background: transparent;
	font-weight: 700;
}

.ttl-product-card__price span,
.ttl-product-card__price-note {
	margin-top: 6px;
	font-family: var(--ttl-font-body);
	font-size: 11px;
	font-weight: 400;
	letter-spacing: 0.2px;
	color: var(--ttl-ink-soft);
	line-height: 1;
}

.ttl-product-card__cart {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	margin: 0;
	min-width: 30px;
	min-height: 30px;
}

/* Default state: show the single "+" button. */
.ttl-product-card__cart[data-state="idle"] .ttl-product-card__stepper { display: none !important; }
.ttl-product-card__cart[data-state="idle"] .ttl-product-card__add { display: inline-grid !important; }
.ttl-product-card__cart[data-state="idle"] .ttl-product-card__add svg,
.ttl-product-card__cart[data-state="idle"] .ttl-product-card__add svg path {
    color: #b9bac2 ;
    fill: #b9bac2 ;
}

/* Stepper state: show the dark navy pill "− qty +". */
.ttl-product-card__cart[data-state="qty"] .ttl-product-card__add { display: none !important; }
.ttl-product-card__cart[data-state="qty"] .ttl-product-card__stepper { display: inline-flex !important; }

.ttl-product-card__stepper {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 0;
	height: 30px;
	min-width: 93px;
	padding: 0 2px;
	border-radius: 999px;
	background: #13132e;
	background-color: #13132e;
	color: #ffffff;
	box-shadow: 0 8px 16px rgba(19, 19, 46, 0.18);
	user-select: none;
	animation: ttl-stepper-pop 180ms ease-out;
	flex-shrink: 0;
}

@keyframes ttl-stepper-pop {
	from { transform: scale(0.9); opacity: 0; }
	to   { transform: scale(1);   opacity: 1; }
}

button.ttl-product-card__step,
.ttl-product-card__step {
	width: 30px !important;
	height: 30px !important;
	min-width: 30px;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	border-radius: 999px !important;
	background: transparent !important;
	background-color: transparent !important;
	color: #ffffff !important;
	display: inline-grid !important;
	place-items: center;
	font-size: 0 !important;
	line-height: 0 !important;
	cursor: pointer;
	outline: 0;
	appearance: none;
	-webkit-appearance: none;
	transition: background 0.15s ease, transform 0.15s ease;
	flex-shrink: 0;
}

.ttl-product-card__step:hover {
	background: rgba(255, 255, 255, 0.10) !important;
	transform: scale(1.06);
}

.ttl-product-card__step svg {
	width: 16px !important;
	height: 16px !important;
	color: #9F2A2E;
	fill: #ffffff;
}

.ttl-product-card__step svg path { fill: #ffffff !important; }

.ttl-product-card__qty {
	min-width: 24px;
	padding: 0 4px;
	font-family: var(--ttl-font-body);
	font-size: 15px;
	font-weight: 600;
	color: #ffffff;
	text-align: center;
	font-variant-numeric: tabular-nums;
	line-height: 1;
}

.ttl-product-card__favorite.is-active svg path {
	stroke: #9F2A2E !important;
	fill: #9F2A2E !important;
	color: #9F2A2E !important;
}
/* Busy state while a request is in flight. */
.ttl-product-card__cart.is-busy { opacity: 0.7; pointer-events: none; }
.ttl-product-card__cart.is-busy .ttl-product-card__add,
.ttl-product-card__cart.is-busy .ttl-product-card__stepper { cursor: progress; }

button.ttl-product-card__add,
a.ttl-product-card__add,
.ttl-product-card .ttl-product-card__add,
.woocommerce ul.products li.product.ttl-product-card .ttl-product-card__add,
.woocommerce ul.products li.product .ttl-product-card__add {
	display: inline-grid ;
	place-items: center;
	width: 30px ;
	height: 30px ;
	min-width: 30px;
	padding: 0 ;
	margin: 0 ;
	border: 0 ;
	border-radius: 999px ;
	background: #13132e ;
	background-color: #13132e ;
	color: #ffffff ;
	font-size: 0 ;
	line-height: 0 ;
	letter-spacing: 0;
	box-shadow: 0 8px 16px rgba(19, 19, 46, 0.18);
	transition: transform 0.2s ease, background 0.2s ease;
	cursor: pointer;
	text-decoration: none ;
	outline: 0;
	appearance: none;
	-webkit-appearance: none;
}

.ttl-product-card__add:hover { background: #13132e !important; transform: scale(1.05); }
.ttl-product-card__add svg { width: 18px !important; height: 18px !important; color: #ffffff; fill: #ffffff; }
.ttl-product-card__add svg path { fill: #ffffff !important; }

/* Hide WooCommerce default add-to-cart link inside our cards (we render our own +) */
.ttl-product-card .added_to_cart,
.ttl-product-card > .button,
.ttl-product-card .button.add_to_cart_button:not(.ttl-product-card__add) {
	display: none !important;
}

/* ---------- Trust bar ---------- */
.ttl-trust { background: var(--ttl-bg); }

.ttl-trust__grid {
	max-width: var(--ttl-shell);
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
}

.ttl-trust__item {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	padding: 24px;
}

.ttl-trust__icon {
	width: 56px;
	height: 56px;
	border-radius: 999px;
	background: var(--ttl-bg-warm);
	color: var(--ttl-ink);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.ttl-trust__icon svg { width: 28px; height: 28px; }

.ttl-trust__item h3 {
	margin: 0;
	font-family: var(--ttl-font-display);
	font-size: 20px;
	font-weight: 400;
	color: var(--ttl-ink);
}

.ttl-trust__item p {
	margin: 0;
	font-size: 14px;
	color: var(--ttl-ink-soft);
	line-height: 1.55;
}

/* ---------- Your gift, your way ---------- */
.ttl-gift { background: var(--ttl-white); }

.ttl-gift__layout {
	max-width: var(--ttl-shell);
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
	gap: 48px;
	align-items: stretch;
}

.ttl-gift__tabs { display: flex; flex-direction: column; gap: 16px; }

.ttl-gift__tab {
	display: grid;
	grid-template-columns: 56px 1fr;
	gap: 20px;
	align-items: flex-start;
	text-align: left;
	padding: 24px 28px;
	border-radius: var(--ttl-radius-md);
	background: var(--ttl-bg);
	border: 1px solid var(--ttl-line);
	transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.ttl-gift__tab.is-active {
	background: var(--ttl-bg-rose);
	border-color: rgba(184, 76, 60, 0.4);
	transform: translateX(4px);
}
.eve_det_shipping {
    min-height: 233px;
}
.ttl-gift__tab-step {
	font-family: var(--ttl-font-display);
	font-size: 24px;
	font-weight: 400;
	color: var(--ttl-ink);
}

.ttl-gift__tab-content { display: flex; flex-direction: column; gap: 6px; }
.ttl-gift__tab-content strong {
	font-family: var(--ttl-font-display);
	font-size: 22px;
	font-weight: 400;
	color: var(--ttl-ink);
}

.ttl-gift__tab-content em {
	font-style: normal;
	font-size: 14px;
	color: var(--ttl-ink-soft);
	line-height: 1.55;
}

.ttl-gift__media {
	border-radius: var(--ttl-radius-lg);
	overflow: hidden;
	min-height: 460px;
	background: var(--ttl-bg-warm);
}

.ttl-gift__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ---------- What brings you here ---------- */
.ttl-occasions { background: var(--ttl-bg); }

.ttl-occasions__grid {
	max-width: var(--ttl-shell);
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.ttl-occasion-card {
	background: var(--ttl-white);
	border-radius: var(--ttl-radius-md);
	overflow: hidden;
	box-shadow: var(--ttl-shadow-sm);
	display: flex;
	flex-direction: column;
}

.ttl-occasion-card__media {
	aspect-ratio: 16 / 11;
	background: var(--ttl-bg-warm);
}

.ttl-occasion-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ttl-occasion-card__body {
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.ttl-occasion-card__body h3 {
	margin: 0;
	font-family: var(--ttl-font-display);
	font-size: 22px;
	font-weight: 400;
	color: var(--ttl-ink);
}

.ttl-occasion-card__body p {
	margin: 0;
	font-size: 14px;
	color: var(--ttl-ink-soft);
}

/* ---------- Banner ---------- */
.ttl-banner {
	position: relative;
	min-height: 520px;
	display: flex;
	align-items: center;
	padding: 96px var(--ttl-pad);
	overflow: hidden;
	color: var(--ttl-cream);
}

.ttl-banner__media {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	z-index: 0;
}

.ttl-banner__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(19, 19, 46, 0.72) 0%, rgba(19, 19, 46, 0.45) 65%, rgba(19, 19, 46, 0.2) 100%);
	z-index: 1;
}

.ttl-banner__inner {
	position: relative;
	z-index: 2;
	max-width: 640px;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.ttl-banner__title {
	margin: 0;
	font-family: var(--ttl-font-display);
	font-size: 56px;
	line-height: 1.05;
	font-weight: 400;
	letter-spacing: 1.4px;
}

.ttl-banner__title em { font-style: italic; font-weight: 400; }

.ttl-banner__lead {
	margin: 0;
	max-width: 480px;
	font-size: 18px;
	line-height: 1.55;
}

.ttl-banner .ttl-button { align-self: flex-start; margin-top: 8px; }

/* ---------- Corporate gifting (dark) ---------- */
.ttl-corporate {
	background: var(--ttl-ink);
	color: var(--ttl-cream);
	padding: 80px var(--ttl-pad);
}

.ttl-corporate__inner {
	max-width: var(--ttl-shell);
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 64px;
	align-items: center;
}

.ttl-corporate__content { display: flex; flex-direction: column; gap: 24px; }

.ttl-corporate__title {
	margin: 0;
	font-family: var(--ttl-font-display);
	font-size: 64px;
	line-height: 1.02;
	letter-spacing: 1.6px;
	font-weight: 400;
}

.ttl-corporate__title em { font-style: italic; font-weight: 400; }

.ttl-corporate__lead {
	margin: 0;
	font-size: 17px;
	line-height: 1.55;
	color: rgba(250, 245, 230, 0.8);
	max-width: 480px;
}

.ttl-corporate__media {
	position: relative;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
}

.ttl-corporate__media-img {
	width: 100%;
	border-radius: var(--ttl-radius-lg);
	box-shadow: var(--ttl-shadow-lg);
	aspect-ratio: 3 / 4;
	object-fit: cover;
}

.ttl-corporate__media-img--a { transform: translateY(-24px); }
.ttl-corporate__media-img--b { transform: translateY(24px); }

/* ---------- Testimonials ---------- */
.ttl-testimonials { background: var(--ttl-white); }

.ttl-testimonials__grid {
	max-width: var(--ttl-shell);
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.ttl-testimonial {
	margin: 0;
	padding: 32px;
	border-radius: var(--ttl-radius-md);
	background: var(--ttl-bg);
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.ttl-testimonial__stars { display: flex; gap: 4px; }
.ttl-testimonial__stars img { width: 14px; height: 14px; }

.ttl-testimonial blockquote {
	margin: 0;
	font-family: var(--ttl-font-display);
	font-size: 18px;
	font-style: italic;
	line-height: 1.5;
	color: var(--ttl-ink);
}

.ttl-testimonial figcaption { display: flex; flex-direction: column; gap: 4px; }
.ttl-testimonial figcaption strong {
	font-family: var(--ttl-font-eyebrow);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 1.6px;
	text-transform: uppercase;
	color: var(--ttl-ink);
}
.ttl-testimonial figcaption span { font-size: 12px; color: var(--ttl-ink-soft); }

/* ---------- Footer ---------- */
.site-footer {
	position: relative;
	padding: 27px 24px;
	background: var(--ttl-white);
}

.site-footer__shell {
	position: relative;
	max-width: 1231px;
	margin: 0 auto;
	background: var(--ttl-ink);
	color: var(--ttl-cream);
	border-radius: var(--ttl-radius-lg);
	padding: 75px;
	overflow: hidden;
}

.site-footer__shell::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("assets/figma/footer-bg.png");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0.08;
	pointer-events: none;
	z-index: 0;
}

.site-footer__shell > * { position: relative; z-index: 1; }

.site-footer__main {
	display: grid;
	grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
	gap: 64px;
	align-items: flex-start;
}

.site-footer__brand {
	display: flex;
	flex-direction: column;
	gap: 28px;
}

.site-footer__logo img {
	width: 164px;
	height: auto;
	object-fit: contain;
}

.site-footer__rating {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	background: rgba(238, 217, 225, 0.07);
	border: 0.8px solid rgba(238, 217, 225, 0.12);
	border-radius: 10px;
	max-width: 220px;
}

.site-footer__rating-score {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.site-footer__rating-score strong {
	font-family: var(--ttl-font-display);
	font-size: 16px;
	color: var(--ttl-cream);
	line-height: 1;
}

.site-footer__rating-score span,
.site-footer__rating-stars span {
	font-family: var(--ttl-font-body);
	font-weight: 300;
	font-size: 9.5px;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.4;
}

.site-footer__rating-divider {
	width: 1px;
	height: 28px;
	background: rgba(255, 255, 255, 0.4);
}

.site-footer__rating-stars { display: flex; flex-direction: column; gap: 4px; }
.site-footer__stars { display: flex; gap: 1px; }
.site-footer__stars img { width: 9px; height: 9px; filter: brightness(0) invert(1); opacity: 0.95; }

.site-footer__columns {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 48px;
	position: relative;
}

.site-footer__columns::before,
.site-footer__columns::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 1px;
	background: rgba(250, 245, 230, 0.25);
}

.site-footer__columns::before { left: 33.33%; }
.site-footer__columns::after { left: 66.66%; }

.site-footer__column { padding-right: 16px; }

.site-footer__title {
	margin: 0 0 24px;
	font-family: var(--ttl-font-eyebrow);
	font-weight: 600;
	font-size: 24px;
	letter-spacing: 2.5px;
	text-transform: uppercase;
	color: var(--ttl-cream);
	line-height: 1;
}

.ttl-footer-menu li { margin-bottom: 14px; }
.ttl-footer-menu li:last-child { margin-bottom: 0; }

.ttl-footer-menu a {
	display: inline-block;
	font-family: var(--ttl-font-body);
	font-weight: 400;
	font-size: 18px;
	line-height: 19.5px;
	color: var(--ttl-cream);
	transition: color 0.2s ease;
}

.ttl-footer-menu a:hover { color: var(--ttl-white); }

.site-footer__contact-bar {
	margin-top: 48px;
	padding-top: 24px;
	border-top: 0.8px solid rgba(255, 255, 255, 0.6);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
}

.site-footer__contact {
	display: flex;
	align-items: center;
	gap: 28px;
	flex-wrap: wrap;
	font-family: var(--ttl-font-body);
	font-weight: 300;
	font-size: 14px;
	line-height: 18px;
	color: var(--ttl-cream);
}

.site-footer__contact a { color: inherit; transition: color 0.2s ease; }
.site-footer__contact a:hover { color: var(--ttl-white); }

.site-footer__social { display: flex; gap: 8px; }

.site-footer__social a {
	width: 32px;
	height: 32px;
	border-radius: 999px;
	background: var(--ttl-white);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--ttl-shadow-sm);
	transition: transform 0.2s ease;
}

.site-footer__social a:hover { transform: translateY(-2px); }
.site-footer__social img { width: 16px; height: 16px; }

.site-footer__bottom {
	margin-top: 32px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
}

.site-footer__copyright {
	margin: 0;
	font-size: 14px;
	font-weight: 400;
	color: var(--ttl-cream);
	line-height: 16.5px;
}

.ttl-footer-legal-menu { display: flex; gap: 24px; flex-wrap: wrap; }

.ttl-footer-legal-menu a,
.ttl-footer-legal-menu li {
	font-family: var(--ttl-font-body);
	font-weight: 300;
	font-size: 11px;
	color: var(--ttl-cream);
	line-height: 16.5px;
	transition: opacity 0.2s ease;
}

.ttl-footer-legal-menu a:hover { opacity: 0.75; }

/* ---------- WooCommerce baseline (shop page) ---------- */
.ttl-woocommerce {
	/* padding: 140px var(--ttl-pad) 80px; */
	background: var(--ttl-white);
	color: var(--ttl-ink);
}

.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr)) ;
	gap: 24px !important;
	list-style: none;
	padding: 0 !important;
	margin: 32px 0 !important;
	width: 100%;
}
@media (max-width: 1024px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* Mobile */
@media (max-width: 767px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products {
		grid-template-columns: repeat(1, minmax(0, 1fr));
	}
}

.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after { content: none !important; display: none !important; }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	float: none !important;
	clear: none !important;
	width: auto !important;
	margin: 0 !important;
}

/* Hide WooCommerce default loop chrome we replace with our own card */
.woocommerce ul.products li.product .woocommerce-LoopProduct-link,
.woocommerce ul.products li.product .onsale {
	display: none !important;
}

.woocommerce-notices-wrapper {
	position: relative;
	z-index: 20;
}

.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-info {
	position: relative;
	padding-right: 52px !important;
	transition: opacity 0.22s ease, transform 0.22s ease;
}

.woocommerce-notices-wrapper .ttl-notice-closing {
	opacity: 0;
	transform: translateY(-6px);
}

.ttl-notice-close {
	position: absolute;
	top: 50%;
	right: 14px;
	transform: translateY(-50%);
	width: 30px;
	height: 30px;
	border-radius: 999px;
	background: rgba(19, 19, 46, 0.08);
	color: #13132e;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	line-height: 1;
	font-weight: 400;
}

.ttl-notice-close:hover {
	background: rgba(19, 19, 46, 0.14);
}

/* ---------- Responsive: Tablet ---------- */
@media (max-width: 1100px) {
	:root { --ttl-pad: 48px; }

	.site-header__bar { padding: 16px 24px; }
	.site-header__logo img { width: 140px; height: auto; }
	.site-header__nav .menu,
	.site-header__nav .ttl-menu { gap: 18px; }
	.site-header__nav a { font-size: 14px; letter-spacing: 1.2px; }
	.site-header__search { width: 180px; }

	.ttl-section { padding: 72px var(--ttl-pad); }
	.ttl-hero { padding: 160px var(--ttl-pad) 64px; min-height: auto; }
	.ttl-hero__title { font-size: 52px; }
	.ttl-section__title,
	.ttl-banner__title,
	.ttl-corporate__title { font-size: 44px; }

	.ttl-product-grid { grid-template-columns: repeat(3, 1fr); }
	.ttl-trust__grid { grid-template-columns: repeat(2, 1fr); }
	.ttl-occasions__grid { grid-template-columns: repeat(2, 1fr); }
	.ttl-testimonials__grid { grid-template-columns: repeat(2, 1fr); }
	.ttl-gift__layout { grid-template-columns: 1fr; }
	.ttl-gift__media { min-height: 320px; }

	.ttl-corporate__inner { grid-template-columns: 1fr; gap: 40px; }
	.ttl-corporate__media-img--a,
	.ttl-corporate__media-img--b { transform: none; }

	.site-footer__shell { padding: 48px 32px; }
	.site-footer__main { grid-template-columns: 1fr; gap: 40px; }
	.site-footer__columns { gap: 24px; }
	.site-footer__columns::before { left: 33.33%; }
	.site-footer__columns::after { left: 66.66%; }
}
.ttl-product-card__cart[data-state="qty"] .ttl-product-card__add {
    display: none!important;
}
.ttl-tags-wrap{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    width:100%;
}
.ttl-tags{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
}
.ttl-tag{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:3px 10px;
    border:1px solid #c8d3e2;
    border-radius:999px;
    background:#fff;
    color:#3b3b3b;
  
    text-decoration:none;
    transition:all .2s ease;
	font-family: DM Sans;
	font-weight: 300;
	font-style: Light;
	font-size: 10px;
	leading-trim: NONE;
	line-height: 15px;
	letter-spacing: 0px;

}

.ttl-tag:hover{
    background:#f5f7fb;
}

.ttl-arrow-btn{
    width:30px;
    height:30px;   
    transition:all .2s ease;
}
.ttl-tags-wrap.wrap-2 .ttl-arrow-btn:hover, .ttl-tags-wrap .ttl-arrow-btn:hover{
    transform:translateX(2px);   
}
.ttl-tags-wrap.wrap-2 .ttl-tag{
    color:#9F2A2E;
    border:1px solid #9F2A2E;

}
img.rev_star {
    width: auto;
    height: 10px;
    margin-bottom: 20px;
}
.rev-link{
	 align-items:center;
    justify-content:center;
    padding:3px 10px;
    border:1px solid #c8d3e2;
    border-radius:999px;
    background:#fff;
	color:#9F2A2E;
	width: fit-content;
    margin: 20px 0 0 0;

}

/* ---------- Single product ---------- */
.ttl-shop-wrapper:has(.ttl-single-product) {
	background: #ffffff;
}

.ttl-single-product {
	font-family: var(--ttl-font-body);
	color: #13132e;
	background: #ffffff;
}

.ttl-single-product__shell,
.ttl-related-products__shell,
.ttl-product-reviews__shell {
	max-width: 1280px;
	margin: 0 auto;	
}

.ttl-product-breadcrumb {
	padding: 10px 0 12px;
	border-top: 1px solid #EDD8DE;
	border-bottom: 1px solid #EDD8DE;	
	color: #9F2A2E;
	font-family: DM Sans;
	font-weight: 500;
	font-size: 14px;
	line-height: 17.25px;
	letter-spacing: 0px;
}

.ttl-product-breadcrumb a {
	color: inherit;	
	color: #13132eB2;
	font-weight: 400;
}

.ttl-product-breadcrumb__separator {
	display: inline-block;
	margin: 0 7px;
	color: #13132e66;
}

.ttl-product-hero {
	display: grid;
	grid-template-columns: minmax(0, 560px) minmax(360px, 1fr);
	gap: 86px;
	padding: 28px 0 72px;
	align-items: start;
}

.ttl-product-gallery__stage {
	position: relative;
	aspect-ratio: 1 / 0.94;
	overflow: hidden;
	border-radius: 8px;
	background: #f7ecda;
}

.ttl-product-gallery__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.ttl-product-gallery__zoom-trigger {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	opacity: 0;
	pointer-events: none;
	cursor: zoom-in;
}

.ttl-product-gallery__zoom-trigger.is-active {
	opacity: 1;
	pointer-events: auto;
}

/* .ttl-product-gallery__zoom-trigger::after {
	content: "+";
	position: absolute;
	right: 16px;
	bottom: 16px;
	width: 42px;
	height: 42px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.92);
	color: #1f2035;
	display: grid;
	place-items: center;
	font-size: 28px;
	line-height: 1;
	box-shadow: 0 8px 18px rgba(19, 19, 46, 0.14);
} */

.ttl-product-gallery__image.is-active {
	opacity: 1;
}

.ttl-product-gallery__thumbs {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 18px;
	margin-top: 24px;
}

.ttl-product-gallery__thumb {
	aspect-ratio: 1 / 1;
	padding: 0;
	border: 2px solid transparent;
	border-radius: 8px;
	overflow: hidden;
	background: #f7ecda;
}

.ttl-product-gallery__thumb.is-active {
	border-color: #9f2a2e;
}

.ttl-product-gallery__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ttl-product-summary {
	padding-top: 2px;
}

.ttl-product-summary__eyebrow {
	margin: 0 0 12px;
	font-family: var(--ttl-font-eyebrow);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #9f2a2e;
}

.ttl-product-summary__title {
	font-family: DM Sans;
	font-weight: 400;
	font-size: 35px;
	line-height: 39px;
	letter-spacing: 2px;
	margin: 0 0 12px;
	color: #13132e;
}

.ttl-product-summary__rating {
	display: flex;
	align-items: center;
	gap: 7px;
	margin: 0 0 18px;
	font-family: var(--ttl-font-body);
	font-size: 16px;
	line-height: 1.2;
	color: #13132e;
}

.ttl-product-summary__stars {
	color: #C98A13;
	font-size: 17px;
	letter-spacing: 1px;
	line-height: 1;
}

.ttl-product-summary__rating-score {
	font-weight: 700;
	color: #13132e;
}

.ttl-product-summary__review-count {
	color: rgba(26, 31, 46, 0.42);
	font-weight: 400;
}

.ttl-product-summary__review-count--empty {
	color: rgba(26, 31, 46, 0.58);
}
.ttl-product-summary__price{
	display:ruby;
	align-items:baseline;
	gap:22px;
	margin-bottom:24px;
	color:#13132e;
	font-family:"DM Sans",serif;
	font-weight:500;
	
	line-height:28px;
	letter-spacing:0;
	flex-wrap:wrap;
}

/* SALE PRICE */

.ttl-product-summary__price ins{
	text-decoration:none;
	background:transparent;
	order:2;
	max-width: 13px;
}

.ttl-product-summary__price ins .woocommerce-Price-amount,
.ttl-product-summary__price ins .woocommerce-Price-currencySymbol{
	color:#13132e;
	font-family:"DM Sans",serif;
	font-weight:500;
	font-size:35px;
	line-height:28px;
}

/* OLD PRICE */

.ttl-product-summary__price del{
	color:rgba(26,31,46,.48);
	text-decoration:line-through;
	font-weight:400;
	font-size:25px;
	order:1;
}

.ttl-product-summary__price del .woocommerce-Price-amount,
.ttl-product-summary__price del .woocommerce-Price-currencySymbol{
	color:rgba(26,31,46,.48);
	font-size:25px;
	font-weight:400;
}

/* PRICE NOTE */

.ttl-product-summary__price .ttl-price-note{
	font-family:var(--ttl-font-body);
	font-size:18px;
	line-height:1.2;
	font-weight:400;
	color:rgba(26,31,46,.65);
}

.ttl-product-summary__delivery,
.ttl-product-summary__promise {
	margin: 15px 0 15px;
	font-size: 18px;
	line-height: 1.25;
	font-weight: 400;
	color: #3A7A4E;
}

.ttl-product-summary__delivery::before {
	content: "🚚";
	display: inline-block;
	width: auto;
	height: auto;
	margin-right: 12px;
	border: 0;
	background: none;
	vertical-align: -2px;
}

.ttl-product-summary__promise {
	font-size: 12px;
	font-weight: 600;
	color: rgba(26, 31, 46, 0.86);
}

.ttl-product-choice {
	margin-bottom: 18px;
}

.ttl-product-choice__label {
	margin: 0 0 10px;
	font-size: 14px;
	font-weight: 700;
}

.ttl-product-choice__radios {
	display: grid;
	border: 1px solid rgba(26, 31, 46, 0.12);
	border-radius: 8px;
	overflow: hidden;
}

.ttl-product-choice__radio {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 45px;
	padding: 0 16px;
	border-bottom: 1px solid rgba(26, 31, 46, 0.08);
	font-size: 13px;
	cursor: pointer;
}

.ttl-product-choice__radio:last-child {
	border-bottom: 0;
}

.ttl-product-choice__radio input {
	width: 15px;
	height: 15px;
	accent-color: #9f2a2e;
}

.ttl-product-choice__select,
.ttl-product-choice__select select {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
}

.ttl-product-note {
	margin: 0 0 22px;
}

.ttl-product-note__label,
.ttl-product-order-label {
	margin: 0 0 14px;
	
	color: #13132eF2;
	font-family: DM Sans;
	font-weight: 600;
	font-size: 14px;
	line-height: 18px;
	letter-spacing: 0px;

}

.ttl-product-note__card {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	min-height: 98px;
	padding: 22px 28px;
	border: 1px solid #EDE5D8;
	border-radius: 10px;
	background: #ffffff;
	max-width: 500px;
}

.ttl-product-note__card strong {
	display: block;
	margin-bottom: 8px;
	font-size: 14px;
	line-height: 1.2;
	color: #1f2035;
}

.ttl-product-note__card span {
	display: block;
	font-size: 14px;
	line-height: 1.25;
	color: #76778a;
}

.ttl-product-note__add {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 2px solid #9F2A2E;
	border-radius: 10px;
	background: #ffffff;
	color: #9F2A2E;
	font-size: 14px;
	font-weight: 500;
	white-space: nowrap;
	height: 30px;
	width: 90px;
}

.ttl-product-note__add svg {
	width: 20px;
	height: 20px;
	transform: rotate(-90deg);
}

.ttl-product-note__field {
	display: none;
	width: 100%;
	max-width: 500px;
	min-height: 86px;
	margin-top: 12px;
	padding: 14px 16px;
	border: 2px solid #efe5d9;
	border-radius: 16px;
	resize: vertical;
	font-size: 15px;
	outline: none;
}

.ttl-product-note.is-open .ttl-product-note__field {
	display: block;
}

.ttl-product-actions,
.ttl-product-actions .woocommerce-variation-add-to-cart {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
	margin-bottom: 28px;
	font-size: 14px;
}

.ttl-product-qty {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;	
	height: 44px;
	width: 110px;
	padding: 0 20px;
	border: 2px solid #efe5d9;
	border-radius: 10px;
}
.ttl-product-qty button, .ttl-product-qty button:hover  {
	background:transparent;
	border: none;
}
.ttl-product-qty .quantity {
	
	height: auto;
	border: 0;
}

.ttl-product-qty .quantity input.qty {
	
	padding: 0;
	padding-left: 10px;
	border: 0;
	background: transparent;
	text-align: center;
	font-weight: 500;
	color: #1f2035;
	appearance: textfield;
}

.ttl-product-qty__step {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 42px;
	padding: 0;
	color: #1f2035;
	line-height: 1;
	font-weight: 300;
}

.ttl-product-qty__step:first-child {
	color: #b9bac2;
}

.ttl-product-qty.is-busy {
	opacity: 0.65;
	pointer-events: none;
}

.ttl-product-actions .single_add_to_cart_button,
.ttl-product-actions__cart,
.ttl-product-actions__buy {
	display: inline-flex;
	align-items: center;
	justify-content: center;	
	height: 44px;
	padding: 0 32px;
	border-radius: 10px;
	border: 1px solid #1f2035;
	font-weight: 500;
	text-transform: none;
	letter-spacing: 0;
}

.ttl-product-actions .single_add_to_cart_button,
.ttl-product-actions__cart {
	background: #13132e;
	color: #ffffff;
}

.ttl-product-actions__buy {
	background: #ffffff;
	color: #1f2035;
	width: 110px;
}

.ttl-product-actions .woocommerce-variation.single_variation {
	flex-basis: 100%;
	margin-bottom: 8px;
}

.ttl-product-actions .woocommerce-variation-price {
	display: none;
}

.ttl-product-actions .reset_variations {
	display: none !important;
}
button.single_add_to_cart_button.button.alt.ttl-product-actions__cart{
	
border-radius: 10px;
background: #13132e;
width: 110px;

}
.ttl-product-summary__promise {
	margin-bottom: 18px;
	font-size: 12px;
	color: rgba(26, 31, 46, 0.86);
}

.ttl-product-accordions {
	border-top: 1px solid rgba(26, 31, 46, 0.12);
}

.ttl-product-accordion {
	border-bottom: 1px solid rgba(26, 31, 46, 0.12);
}

.ttl-product-accordion summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 48px;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	list-style: none;
}

.ttl-product-accordion summary::-webkit-details-marker {
	display: none;
}

.ttl-product-accordion summary::after {
	content: "+";
	font-size: 18px;
	font-weight: 400;
	color: #13132e;
}

.ttl-product-accordion[open] summary::after {
	content: "x";
	font-size: 13px;
	color: #9f2a2e;
}

.ttl-product-accordion__content {
	padding: 0 0 18px;
	font-size: 13px;
	color: rgba(26, 31, 46, 0.82);
}

.ttl-product-accordion__content p,
.ttl-product-accordion__content ul {
	margin: 0 0 10px;
}

.ttl-product-accordion__content ul {
	padding-left: 18px;
	list-style: disc;
}

.ttl-product-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 14px;
}

.ttl-product-tags span,
.ttl-product-tags a {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	padding: 0 11px;
	border: 1px solid #c8d3e2;
	border-radius: 999px;
	background: #ffffff;
	font-size: 10px;
	color: #46615d;
}

.ttl-product-tags a:hover {
	border-color: #9f2a2e;
	color: #9f2a2e;
}

.ttl-product-zoom {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 32px;
	background: rgba(19, 19, 46, 0.82);
	cursor: zoom-out;
}

.ttl-product-zoom.is-open {
	display: flex;
}

.ttl-product-zoom__image {
	max-width: min(1100px, 94vw);
	max-height: 90vh;
	width: auto;
	height: auto;
	object-fit: contain;
	border-radius: 8px;
	box-shadow: 0 28px 80px rgba(0, 0, 0, 0.32);
	cursor: default;
}

.ttl-product-zoom__close {
	position: absolute;
	top: 22px;
	right: 22px;
	width: 44px;
	height: 44px;
	border-radius: 999px;
	background: #ffffff;
	color: #1f2035;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.ttl-product-zoom__close svg {
	width: 22px;
	height: 22px;
}

.ttl-product-zoom__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
	width: 54px;
	height: 54px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.94);
	color: #1f2035;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.22);
}

.ttl-product-zoom__arrow svg {
	width: 26px;
	height: 26px;
}

.ttl-product-zoom__arrow--prev {
	left: 28px;
}

.ttl-product-zoom__arrow--prev svg {
	transform: rotate(90deg);
}

.ttl-product-zoom__arrow--next {
	right: 28px;
}

.ttl-product-zoom__arrow--next svg {
	transform: rotate(-90deg);
}

html.ttl-zoom-open,
html.ttl-zoom-open body {
	overflow: hidden;
}

.ttl-related-products {
	padding: 54px 0 64px;
	border-top: 1px solid rgba(159, 42, 46, 0.14);
	border-bottom: 1px solid rgba(159, 42, 46, 0.14);
	background: #ffffff;
}

.ttl-related-products h2,
.ttl-product-reviews h2 {
	margin: 0 0 30px;
	font-family: var(--ttl-font-display);
	font-size: 34px;
	line-height: 1.2;
	font-weight: 400;
	color: #13132e;
}

.ttl-related-products h2 em {
	color: #9f2a2e;
}

.ttl-related-products ul.products {
	margin: 0 !important;
}

.ttl-product-reviews {
	padding: 96px 0 104px;
	background: #ffffff;
	border-top: 1px solid #EDD8DE;
}

.ttl-product-reviews__shell {
	max-width: 1160px;
}

.ttl-product-reviews__header {
	text-align: center;
	margin-bottom: 42px;
}

.ttl-product-reviews__header p {
	margin: 0 0 26px;
	font-family: var(--ttl-font-eyebrow);
	font-size: 17px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 5px;
	text-transform: uppercase;
	color: #13132e;
}

.ttl-review-add-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	margin-top: 24px;
	padding: 0 18px;
	border: 1px solid #A92B31;
	border-radius: 999px;
	color: #A92B31;
	font-size: 14px;
	font-weight: 600;
}

.ttl-review-add-link:hover {
	background: #A92B31;
	color: #ffffff;
}

.ttl-product-reviews h2 {
	margin: 0;
	font-family: var(--ttl-font-display);
	font-size: 56px;
	line-height: 1.08;
	font-weight: 400;
	letter-spacing: 0;
	color: #13132e;
}

.ttl-product-reviews h2 em {
	color: #A92B31;
	font-style: italic;
}

.ttl-review-summary {
	display: grid;
	grid-template-columns: 150px minmax(0, 330px);
	justify-content: center;
	align-items: center;
	gap: 56px;
	margin-bottom: 52px;
}

.ttl-review-summary__score {
	text-align: center;
}

.ttl-review-summary__score strong {
	display: block;
	margin-bottom: 10px;
	font-family: var(--ttl-font-display);
	font-size: 56px;
	line-height: 1;
	font-weight: 400;
	color: #13132e;
}

.ttl-review-stars,
.ttl-review-card__stars {
	color: #F1A400;
	letter-spacing: 2px;
	line-height: 1;
}

.ttl-review-summary__score small {
	display: block;
	margin-top: 8px;
	font-size: 12px;
	color: rgba(26, 31, 46, 0.42);
}

.ttl-review-bars {
	display: grid;
	gap: 12px;
}

.ttl-review-bar {
	display: grid;
	grid-template-columns: 16px minmax(0, 250px) 34px;
	align-items: center;
	gap: 12px;
	font-size: 11px;
	color: rgba(26, 31, 46, 0.42);
}

.ttl-review-bar b {
	display: block;
	height: 6px;
	border-radius: 999px;
	background: #EDE4D9;
	overflow: hidden;
}

.ttl-review-bar i {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: #A92B31;
}

.ttl-review-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.ttl-review-card {
	min-height: 150px;
	padding: 20px;
	border: 1px solid #E9DED2;
	border-radius: 8px;
	background: #ffffff;
	box-shadow: 0 6px 16px rgba(26, 31, 46, 0.05);
}

.ttl-review-card__top {
	display: grid;
	grid-template-columns: 34px 1fr auto;
	align-items: center;
	gap: 12px;
	margin-bottom: 14px;
}

.ttl-review-card__avatar {
	width: 34px;
	height: 34px;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	font-size: 13px;
	font-weight: 500;
}

.ttl-review-card__avatar--1 { background: #A92B31; }
.ttl-review-card__avatar--2 { background: #092A55; }
.ttl-review-card__avatar--3 { background: #3C8753; }
.ttl-review-card__avatar--4 { background: #B6A13A; }

.ttl-review-card__top strong {
	display: block;
	font-size: 14px;
	line-height: 1.2;
	font-weight: 600;
	color: #13132e;
}

.ttl-review-card__top small {
	display: block;
	margin-top: 2px;
	font-size: 11px;
	color: rgba(26, 31, 46, 0.42);
}

.ttl-review-card__stars {
	font-size: 11px;
	letter-spacing: 1px;
}

.ttl-review-card p {
	margin: 0 0 18px;
	font-size: 14px;
	line-height: 1.35;
	color: rgba(26, 31, 46, 0.72);
}

.ttl-review-card__tag {
	display: inline-flex;
	align-items: center;
	min-height: 20px;
	padding: 0 9px;
	border-radius: 999px;
	background: #F6F0E5;
	color: rgba(26, 31, 46, 0.72);
	font-size: 10px;
}

.ttl-review-form {
	max-width: 760px;
	margin: 48px auto 0;
	padding: 28px;
	border: 1px solid #E9DED2;
	border-radius: 8px;
	background: #ffffff;
	box-shadow: 0 6px 16px rgba(26, 31, 46, 0.05);
}

.ttl-review-form[hidden] {
	display: none;
}

.ttl-review-form #reviews {
	margin: 0;
}

.ttl-review-form #comments,
.ttl-review-form .woocommerce-Reviews-title,
.ttl-review-form .commentlist {
	display: none;
}

.ttl-review-form #review_form_wrapper,
.ttl-review-form #review_form {
	margin: 0;
}

.ttl-review-form .comment-reply-title {
	display: block;
	margin: 0 0 18px;
	font-family: var(--ttl-font-display);
	font-size: 26px;
	line-height: 1.2;
	font-weight: 400;
	color: #13132e;
}

.ttl-review-form .comment-form-rating,
.ttl-review-form .comment-form-comment,
.ttl-review-form .comment-form-author,
.ttl-review-form .comment-form-email {
	margin-bottom: 14px;
}

.ttl-review-form textarea,
.ttl-review-form input[type="text"],
.ttl-review-form input[type="email"] {
	width: 100%;
	border: 1px solid rgba(26, 31, 46, 0.14);
	border-radius: 8px;
	padding: 12px;
	background: #ffffff;
}

.ttl-review-form .form-submit input {
	min-height: 42px;
	padding: 0 20px;
	border: 0;
	border-radius: 8px;
	background: #13132e;
	color: #ffffff;
	font-weight: 700;
}

@media (max-width: 980px) {
	.ttl-product-hero {
		grid-template-columns: 1fr;
		gap: 36px;
	}

	.ttl-product-summary__title {
		font-size: 30px;
	}

	.ttl-product-reviews h2 {
		font-size: 44px;
	}

	.ttl-review-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.ttl-single-product__shell,
	.ttl-related-products__shell,
	.ttl-product-reviews__shell {
		padding: 0 16px;
	}

	.ttl-product-hero {
		padding-top: 18px;
	}

	.ttl-product-gallery__thumbs {
		gap: 10px;
		margin-top: 12px;
	}

	.ttl-product-summary__title {
		font-size: 26px;
	}

	.ttl-product-summary__price {
		flex-wrap: wrap;
		font-size: 26px;
	}

	.ttl-product-actions,
	.ttl-product-actions .woocommerce-variation-add-to-cart {
		display: grid;
		grid-template-columns: 1fr;
	}

	.ttl-product-qty,
	.ttl-product-actions .single_add_to_cart_button,
	.ttl-product-actions__cart,
	.ttl-product-actions__buy {
		width: 100%;
	}

	.ttl-product-note__card {
		align-items: flex-start;
		flex-direction: column;
		padding: 20px;
	}

	.ttl-product-note__card strong,
	.ttl-product-note__card span,
	.ttl-product-note__add,
	.ttl-product-note__label,
	.ttl-product-order-label {
		font-size: 18px;
	}

	.ttl-related-products h2,
	.ttl-product-reviews h2 {
		font-size: 28px;
	}

	.ttl-product-reviews {
		padding: 64px 0 72px;
	}

	.ttl-product-reviews__header p {
		font-size: 13px;
		letter-spacing: 3px;
		margin-bottom: 18px;
	}

	.ttl-review-summary {
		grid-template-columns: 1fr;
		gap: 24px;
		margin-bottom: 36px;
	}

	.ttl-review-bar {
		grid-template-columns: 16px minmax(0, 1fr) 34px;
	}

	.ttl-review-card__top {
		grid-template-columns: 34px 1fr;
	}

	.ttl-review-card__stars {
		grid-column: 1 / -1;
	}

	.ttl-product-zoom__arrow {
		width: 44px;
		height: 44px;
	}

	.ttl-product-zoom__arrow--prev {
		left: 12px;
	}

	.ttl-product-zoom__arrow--next {
		right: 12px;
	}
}
/* ---------- Responsive: Mobile ---------- */
@media (max-width: 768px) {
	:root { --ttl-pad: 20px; }

	.site-header { background: rgba(253, 248, 239, 0.92); backdrop-filter: blur(10px); position: sticky; }
	.site-header__bar {
		grid-template-columns: auto 1fr auto;
		padding: 12px 16px;
		column-gap: 12px;
	}
	.site-header__logo img { width: 110px; height: auto; }
	.site-header__nav,
	.site-header__search { display: none; }
	.site-header__toggle {
		display: inline-flex;
		width: 40px;
		height: 40px;
		align-items: center;
		justify-content: center;
		color: var(--ttl-ink);
	}
	.site-header__toggle svg { width: 24px; height: 24px; }
	.site-header__toggle-close { display: none; }
	.site-header.is-open .site-header__toggle-open { display: none; }
	.site-header.is-open .site-header__toggle-close { display: inline-flex; }

	.site-header__drawer {
		display: none;
		grid-column: 1 / -1;
		padding: 16px;
		border-top: 1px solid var(--ttl-line);
	}
	.site-header.is-open .site-header__drawer { display: block; }
	.site-header__drawer .ttl-menu,
	.site-header__drawer .menu {
		display: flex !important;
		flex-direction: column;
		gap: 14px;
	}

	.ttl-section { padding: 56px var(--ttl-pad); }
	.ttl-section__header { margin-bottom: 32px; }
	.ttl-section__title,
	.ttl-banner__title,
	.ttl-corporate__title { font-size: 32px; letter-spacing: 0.8px; }
	.ttl-hero { padding: 96px var(--ttl-pad) 48px; }
	.ttl-hero__title { font-size: 40px; letter-spacing: 1px; }
	.ttl-hero__lead { font-size: 16px; }
	.ttl-button { min-width: auto; width: 100%; height: 52px; font-size: 14px; }

	.ttl-product-grid,
	.ttl-trust__grid,
	.ttl-occasions__grid,
	.ttl-testimonials__grid { grid-template-columns: 1fr; }
	.ttl-product-grid { gap: 16px; }

	.ttl-gift__tab { padding: 16px 18px; grid-template-columns: 40px 1fr; gap: 12px; }
	.ttl-gift__tab-content strong { font-size: 18px; }

	.ttl-corporate { padding: 56px var(--ttl-pad); }
	.ttl-corporate__media { grid-template-columns: repeat(2, 1fr); gap: 12px; }

	.site-footer { padding: 16px 12px; }
	.site-footer__shell { padding: 32px 20px; border-radius: 24px; }
	.site-footer__columns {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.site-footer__columns::before,
	.site-footer__columns::after { display: none; }
	.site-footer__column { border-bottom: 1px solid rgba(250, 245, 230, 0.18); padding-bottom: 24px; }
	.site-footer__column:last-child { border-bottom: 0; padding-bottom: 0; }
	.site-footer__title { font-size: 18px; margin-bottom: 16px; }
	.ttl-footer-menu a { font-size: 15px; }
	.site-footer__contact-bar { flex-direction: column; align-items: flex-start; }
	.site-footer__contact { gap: 12px; font-size: 12px; }
	.site-footer__bottom { flex-direction: column; align-items: flex-start; }
}
