/* ==========================================================================
   DOT Made — woocommerce.css
   Product card (shared by shop loop + Elementor rails), shop grid, and the
   merchandising blocks rendered by the DOT Made Elements plugin.
   ========================================================================== */

/* ---- Shop / archive grid ------------------------------------------------- */
.dm-shop { padding: 24px; display: block; }
.woocommerce ul.products,
ul.products {
	list-style: none; margin: 0; padding: 0;
	display: grid; gap: var(--dm-gap);
	grid-template-columns: repeat(4, 1fr);
}
ul.products::before, ul.products::after { content: none !important; }
.dm-cell { list-style: none; margin: 0 !important; width: auto !important; float: none !important; }

.woocommerce-products-header__title,
.dm-shop h1 { font-family: var(--dm-display); font-weight: 700; }

/* ---- Product card -------------------------------------------------------- */
.dm-card {
	background: var(--dm-card);
	border: 1px solid var(--dm-line);
	border-radius: var(--dm-radius);
	padding: 12px;
	display: flex; flex-direction: column; gap: 7px;
	height: 100%;
	transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.dm-card:hover { box-shadow: var(--dm-shadow-hover); transform: translateY(-3px); }

.dm-card__media { position: relative; display: block; border-radius: 8px; overflow: hidden; background: var(--dm-bg); aspect-ratio: 1; }
.dm-card__media img { width: 100%; height: 100%; object-fit: cover; }

.dm-card__off {
	position: absolute; top: 8px; left: 8px;
	background: var(--dm-orange); color: #fff;
	font: 700 11px var(--dm-font); padding: 3px 7px; border-radius: 5px;
}
.dm-card__off--single { top: 12px; left: 12px; font-size: 13px; }

/* NEW badge — loop card (top-right, clears the wishlist heart on hover) */
.dm-card__new {
	position: absolute; top: 8px; right: 8px;
	background: #f4c13d; color: #fff;
	font: 700 11px var(--dm-font); padding: 3px 7px; border-radius: 5px;
	pointer-events: none;
}
.dm-card:hover .dm-card__new { opacity: 0; } /* reveal the heart on hover */

.dm-card__wish {
	position: absolute; top: 8px; right: 8px;
	width: 30px; height: 30px; border-radius: 50%;
	background: rgba(255, 255, 255, 0.92); border: 0; cursor: pointer;
	display: grid; place-items: center; color: var(--dm-muted);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}
.dm-card__wish:hover, .dm-card__wish.is-active { color: var(--dm-orange); }

.dm-card__title {
	font-size: 12.5px; line-height: 1.32; color: var(--dm-ink);
	min-height: 33px;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.dm-card__title:hover { color: var(--dm-green-dark); }

.dm-card__rating { font-size: 12px; color: var(--dm-muted); display: flex; align-items: center; gap: 4px; }
.dm-card__star { color: var(--dm-star); }
.dm-card__score { color: var(--dm-star); font-weight: 600; }

.dm-card__price { font-family: var(--dm-display); font-weight: 700; font-size: 16px; color: var(--dm-ink); }
.dm-card__price .woocommerce-Price-amount,
.dm-card__price ins { text-decoration: none; }
.dm-card__price del { color: var(--dm-muted); font-weight: 400; font-size: 12px; margin-left: 6px; }
.dm-card__price ins { color: var(--dm-ink); }

/* Add-to-cart button (WooCommerce loop button, restyled) */
.dm-card .button,
.dm-btn--cart {
	margin-top: auto;
	display: inline-flex; align-items: center; justify-content: center;
	background: #fff; color: var(--dm-orange);
	border: 1.5px solid var(--dm-orange); border-radius: 7px;
	font: 700 12.5px var(--dm-font); padding: 8px 10px; cursor: pointer;
	transition: background 0.15s, color 0.15s;
}
.dm-card .button:hover,
.dm-btn--cart:hover { background: var(--dm-orange); color: #fff; }
.dm-card .added_to_cart { font-size: 11px; color: var(--dm-green-dark); text-align: center; margin-top: 4px; }

/* ==========================================================================
   Elementor merchandising blocks (also valid as standalone markup)
   ========================================================================== */

/* ---- Rail ---------------------------------------------------------------- */
.dm-rail { margin: 0 0 8px; }
.dm-rail__head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.dm-rail__title { font-family: var(--dm-display); font-weight: 700; font-size: 21px; color: var(--dm-ink); margin: 0; }
.dm-rail__note { background: var(--dm-orange-tint); color: var(--dm-orange); font: 700 12.5px var(--dm-font); padding: 4px 10px; border-radius: 20px; }
.dm-rail__all { margin-left: auto; color: var(--dm-green-dark); font: 700 13.5px var(--dm-font); }
.dm-rail__all:hover { text-decoration: underline; }

.dm-rail__track { display: grid; gap: var(--dm-gap); }
.dm-rail__track.is-grid { grid-template-columns: repeat(var(--dm-cols, 6), 1fr); }
.dm-rail__track.is-scroll {
	display: flex; overflow-x: auto; scroll-snap-type: x mandatory;
	padding-bottom: 6px; scrollbar-width: none;
}
.dm-rail__track.is-scroll::-webkit-scrollbar { display: none; }
.dm-rail__track.is-scroll > .dm-card { flex: 0 0 var(--dm-card-w, 200px); scroll-snap-align: start; }

/* Optional arrows */
.dm-rail__arrows { display: flex; gap: 8px; margin-left: 8px; }
.dm-rail__arrow {
	width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--dm-line-strong);
	background: #fff; cursor: pointer; color: var(--dm-body); display: grid; place-items: center;
}
.dm-rail__arrow:hover { border-color: var(--dm-green); color: var(--dm-green-dark); }

/* ---- Category tiles ------------------------------------------------------ */
.dm-tiles { display: grid; gap: var(--dm-gap); grid-template-columns: repeat(var(--dm-cols, 6), 1fr); }
.dm-tile { border: 1px solid var(--dm-line); border-radius: var(--dm-radius); overflow: hidden; background: #fff; transition: box-shadow 0.15s; }
.dm-tile:hover { box-shadow: var(--dm-shadow); }
.dm-tile__media { aspect-ratio: 1.1; background: var(--dm-bg); }
.dm-tile__media img { width: 100%; height: 100%; object-fit: cover; }
.dm-tile__body { padding: 10px 12px; }
.dm-tile__name { font: 600 13px var(--dm-font); color: var(--dm-ink); line-height: 1.3; }
.dm-tile__from { font: 700 12px var(--dm-font); color: var(--dm-green-dark); margin-top: 3px; }

/* ---- Hero ---------------------------------------------------------------- */
.dm-hero {
	border-radius: var(--dm-radius-lg); overflow: hidden; position: relative;
	background: linear-gradient(110deg, var(--dm-green-dark) 0%, var(--dm-green) 55%, #8acb82 100%);
	color: #fff; padding: 38px;
	display: flex; align-items: center; min-height: 300px;
}
.dm-hero__body { max-width: 56%; position: relative; z-index: 2; }
.dm-hero__eyebrow {
	display: inline-block; background: rgba(255, 255, 255, 0.22); color: #fff;
	font: 700 12px var(--dm-font); letter-spacing: 0.1em; text-transform: uppercase;
	padding: 5px 11px; border-radius: 20px;
}
.dm-hero__title { font-family: var(--dm-display); font-weight: 800; font-size: 42px; line-height: 1.02; margin: 14px 0 6px; }
.dm-hero__sub { font-size: 15px; color: rgba(255, 255, 255, 0.92); margin-bottom: 18px; }
.dm-hero__cta { background: #fff; color: var(--dm-orange); font: 700 15px var(--dm-font); padding: 13px 24px; border-radius: 8px; display: inline-block; }
.dm-hero__cta:hover { filter: brightness(0.97); }
.dm-hero__media { position: absolute; right: 0; top: 0; bottom: 0; width: 42%; z-index: 1; }
.dm-hero__media img { width: 100%; height: 100%; object-fit: cover; }

/* ---- Flash deal ---------------------------------------------------------- */
.dm-flash { border: 1px solid var(--dm-line); border-radius: var(--dm-radius-lg); padding: 14px; background: #fff; display: flex; gap: 14px; align-items: center; }
.dm-flash__media { width: 96px; height: 96px; flex: 0 0 auto; border-radius: 8px; overflow: hidden; background: var(--dm-bg); position: relative; }
.dm-flash__media img { width: 100%; height: 100%; object-fit: cover; }
.dm-flash__body { flex: 1; min-width: 0; }
.dm-flash__head { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.dm-flash__label { font: 700 14px var(--dm-display); color: var(--dm-ink); }
.dm-flash__timer { background: var(--dm-orange-tint); color: var(--dm-orange); font: 700 12px var(--dm-font); padding: 3px 8px; border-radius: 5px; font-variant-numeric: tabular-nums; }
.dm-flash__title { font-size: 13px; color: var(--dm-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dm-flash__price { margin-top: 5px; }
.dm-flash__price .ins, .dm-flash__price ins { color: var(--dm-orange); font: 700 20px var(--dm-display); text-decoration: none; }
.dm-flash__price del { color: var(--dm-muted); font-size: 13px; margin-left: 6px; }
.dm-flash__cta { flex: 0 0 auto; background: var(--dm-orange); color: #fff; border: 0; font: 700 13px var(--dm-font); padding: 11px 16px; border-radius: 8px; cursor: pointer; }
.dm-flash__cta:hover { filter: brightness(0.96); }

/* ==========================================================================
   Single product page
   ========================================================================== */
.single-product div.product { display: grid; grid-template-columns: 46% 1fr; gap: 36px; align-items: start; }
.single-product .woocommerce-product-gallery { position: relative; }
.single-product .woocommerce-product-gallery__image img { border-radius: 12px; }

/* PDP badge stack on the gallery */
.dm-pdp-badges { position: absolute; top: 14px; right: 14px; z-index: 3; display: flex; flex-direction: column; gap: 6px; align-items: flex-end; }
.dm-badge { color: #fff; font: 700 12px var(--dm-font); padding: 4px 9px; border-radius: 6px; }
.dm-badge--new { background: #f4c13d; }
.dm-badge--feat { background: var(--dm-green); }

/* Title / price / rating */
.single-product .product_title { font-family: var(--dm-display); font-weight: 700; font-size: 28px; line-height: 1.18; color: var(--dm-ink); margin: 6px 0 10px; }
.single-product .woocommerce-product-rating { margin-bottom: 14px; }
.single-product p.price, .single-product .price { color: var(--dm-orange); font-family: var(--dm-display); font-weight: 800; font-size: 32px; }
.single-product p.price del { color: var(--dm-muted); font-weight: 400; font-size: 17px; }
.single-product p.price ins { text-decoration: none; }

/* Inspiration line */
.dm-inspiration { font-size: 14px; color: var(--dm-body); margin: 4px 0 14px; }
.dm-inspiration span { color: var(--dm-muted); }
.dm-inspiration strong { color: var(--dm-green-dark); font-weight: 600; }

/* BNPL / Payflex strip */
.dm-bnpl { display: flex; align-items: center; gap: 14px; background: #f4f1fc; border: 1px solid #e4dcf7; border-radius: 10px; padding: 11px 14px; margin: 0 0 18px; }
.dm-bnpl__brand { background: #b79cf6; color: #fff; font: 700 13px var(--dm-display); padding: 8px 13px; border-radius: 7px; flex: 0 0 auto; }
.dm-bnpl__text { font-size: 12.5px; color: var(--dm-body); line-height: 1.45; }
.dm-bnpl__text strong { color: #6b4fb0; }
.dm-bnpl__text a { color: var(--dm-green-dark); font-weight: 600; }

/* Add-to-cart form */
.single-product form.cart { display: flex; gap: 12px; align-items: stretch; margin: 4px 0 18px; }
.single-product form.cart .quantity input.qty { width: 64px; height: 50px; border: 1.5px solid var(--dm-line-strong); border-radius: 9px; text-align: center; font-weight: 700; }
.single-product form.cart .single_add_to_cart_button {
	flex: 1; background: var(--dm-orange); color: #fff; border: 0;
	font: 700 16px var(--dm-display); border-radius: 9px; cursor: pointer; padding: 0 24px;
	transition: filter 0.15s;
}
.single-product form.cart .single_add_to_cart_button:hover { filter: brightness(0.96); }

/* Meta, sold-by, share */
.single-product .product_meta { font-size: 12.5px; color: var(--dm-muted); border-top: 1px solid var(--dm-line); padding-top: 14px; margin-top: 16px; }
.single-product .product_meta a { color: var(--dm-green-dark); }
.dm-soldby { font-size: 13px; color: var(--dm-muted); margin: 12px 0 0; }
.dm-soldby a { color: var(--dm-green-dark); font-weight: 600; text-decoration: underline; }
.dm-share { display: flex; align-items: center; gap: 8px; margin-top: 14px; }
.dm-share__label { font-size: 12px; color: var(--dm-muted); }
.dm-share__btn { width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--dm-line-strong); display: inline-flex; align-items: center; justify-content: center; font: 700 12px var(--dm-font); color: var(--dm-body); }
.dm-share__btn:hover { border-color: var(--dm-green); color: var(--dm-green-dark); }

/* Trust row */
.single-product .dm-pdp-trust { display: flex; gap: 20px; border-top: 1px solid var(--dm-line); padding-top: 16px; margin-top: 16px; font-size: 12.5px; color: var(--dm-body); }

/* Tabs */
.woocommerce-tabs ul.tabs { list-style: none; margin: 0; padding: 0; display: flex; gap: 28px; border-bottom: 1px solid var(--dm-line); }
.woocommerce-tabs ul.tabs li { padding: 12px 0; }
.woocommerce-tabs ul.tabs li a { color: var(--dm-muted); font-weight: 600; }
.woocommerce-tabs ul.tabs li.active { border-bottom: 2px solid var(--dm-orange); }
.woocommerce-tabs ul.tabs li.active a { color: var(--dm-ink); }
.woocommerce-tabs .panel { padding: 22px 0; font-size: 14px; line-height: 1.7; color: var(--dm-body); }

/* Related / upsells */
.single-product .related > h2,
.single-product .upsells > h2 { font-family: var(--dm-display); font-weight: 700; font-size: 21px; margin: 20px 0 14px; }

/* ---- Sticky mobile add-to-basket bar ------------------------------------- */
.dm-stickybuy {
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 95;
	background: #fff; border-top: 1px solid var(--dm-line-strong);
	display: none; align-items: center; gap: 12px;
	padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
	box-shadow: 0 -6px 20px rgba(40, 50, 60, 0.10);
}
.dm-stickybuy.is-visible { display: flex; }
.dm-stickybuy__price { line-height: 1.1; font-family: var(--dm-display); font-weight: 800; font-size: 19px; color: var(--dm-orange); white-space: nowrap; }
.dm-stickybuy__price del { color: var(--dm-muted); font-weight: 400; font-size: 12px; display: block; }
.dm-stickybuy__price ins { text-decoration: none; }
.dm-stickybuy__btn { flex: 1; background: var(--dm-orange); color: #fff; text-align: center; font: 700 15px var(--dm-display); padding: 13px; border-radius: 9px; }

/* ==========================================================================
   Archive: filter/sort bar, chips, bottom sheets, load more
   ========================================================================== */
.dm-shopbar { display: none; } /* desktop uses the sidebar; bar is mobile-only */
.dm-shopbar__btn {
	flex: 1; display: flex; align-items: center; justify-content: center; gap: 7px;
	background: #fff; border: 0; cursor: pointer;
	font: 600 13.5px var(--dm-font); color: var(--dm-ink); padding: 12px;
}
.dm-shopbar__btn + .dm-shopbar__btn { border-left: 1px solid var(--dm-line); }
.dm-shopbar__count { background: var(--dm-orange); color: #fff; font: 700 10px var(--dm-font); border-radius: 9px; padding: 1px 6px; }

.dm-chips { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 14px; }
.dm-chip { background: var(--dm-green-tint); color: #3c5e3a; border: 1px solid #cfe8cd; font: 600 12px var(--dm-font); padding: 6px 11px; border-radius: 18px; }
.dm-chip:hover { filter: brightness(0.97); }
.dm-chip--clear { background: #fff; color: var(--dm-muted); border-color: var(--dm-line-strong); }

/* Filter widgets in the sidebar (desktop) */
.dm-filter-widget { margin-bottom: 22px; }
.dm-filter-widget__title { font: 700 14px var(--dm-display); margin: 0 0 12px; color: var(--dm-ink); }

/* Bottom sheets */
.dm-sheet { position: fixed; inset: 0; z-index: 200; display: block; }
.dm-sheet[hidden] { display: none; }
.dm-sheet__overlay { position: absolute; inset: 0; background: rgba(20, 24, 28, 0.5); border: 0; cursor: pointer; }
.dm-sheet__panel {
	position: absolute; left: 0; right: 0; bottom: 0; max-height: 82vh;
	background: #fff; border-radius: 18px 18px 0 0; display: flex; flex-direction: column;
	transform: translateY(100%); transition: transform 0.28s ease;
}
.dm-sheet.is-open .dm-sheet__panel { transform: translateY(0); }
.dm-sheet__head { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px; border-bottom: 1px solid var(--dm-line); font: 700 16px var(--dm-display); }
.dm-sheet__close { background: none; border: 0; font-size: 26px; line-height: 1; cursor: pointer; color: var(--dm-body); }
.dm-sheet__body { overflow-y: auto; padding: 16px 18px; }
.dm-sheet__foot { padding: 14px 18px calc(14px + env(safe-area-inset-bottom)); border-top: 1px solid var(--dm-line); }
.dm-sheet__apply { width: 100%; background: var(--dm-orange); color: #fff; border: 0; font: 700 15px var(--dm-display); padding: 13px; border-radius: 9px; cursor: pointer; }
.dm-sortlist { list-style: none; margin: 0; padding: 0; }
.dm-sortlist a { display: flex; justify-content: space-between; padding: 13px 2px; color: var(--dm-body); font-size: 14.5px; border-bottom: 1px solid var(--dm-line); }
.dm-sortlist a.is-active { color: var(--dm-green-dark); font-weight: 700; }

/* Load more */
.dm-loadmore { text-align: center; margin: 26px 0 6px; }
.dm-loadmore__btn { background: #fff; border: 1.5px solid var(--dm-green); color: var(--dm-green-dark); font: 700 13.5px var(--dm-font); padding: 12px 28px; border-radius: 9px; cursor: pointer; }
.dm-loadmore__btn:hover { background: var(--dm-green-tint); }
.dm-loadmore__btn[disabled] { opacity: 0.55; cursor: default; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1024px) {
	ul.products { grid-template-columns: repeat(3, 1fr); }
	.dm-rail__track.is-grid,
	.dm-tiles { grid-template-columns: repeat(3, 1fr); }
	.dm-hero__title { font-size: 34px; }
	.dm-hero__body { max-width: 64%; }
}

@media (max-width: 768px) {
	.dm-shop { padding: 16px; }
	ul.products { grid-template-columns: repeat(2, 1fr); gap: 11px; }
	.dm-rail__title { font-size: 17px; }
	.dm-rail__track.is-grid { grid-template-columns: repeat(2, 1fr); gap: 11px; }
	.dm-rail__track.is-scroll > .dm-card { flex-basis: 150px; }
	.dm-tiles { grid-template-columns: repeat(3, 1fr); gap: 10px; }
	.dm-hero { padding: 22px; min-height: 0; }
	.dm-hero__body { max-width: 100%; }
	.dm-hero__title { font-size: 27px; }
	.dm-hero__media { display: none; }
	.dm-card__title { font-size: 12px; }

	/* PDP stacks; native add-to-cart hidden in favour of the sticky bar */
	.single-product div.product { grid-template-columns: 1fr; gap: 18px; }
	.single-product .product_title { font-size: 20px; }
	.single-product p.price { font-size: 28px; }
	.dm-pdp-trust { flex-wrap: wrap; gap: 12px; }
	body.single-product { padding-bottom: 76px; }

	/* Archive: reveal the sticky filter/sort bar, hide the desktop sidebar */
	.dm-shopbar {
		display: flex; position: sticky; top: 0; z-index: 30;
		border-top: 1px solid var(--dm-line); border-bottom: 1px solid var(--dm-line);
		margin: 0 0 12px;
	}
	.woocommerce-ordering, .dm-shop .widget-area, .dm-shop aside { display: none; }
}
