/**
 * WooCommerce custom styles.
 * Loaded only when WooCommerce is active.
 *
 * @package Dropshipper
 */

/* =========================================================
   SHOP / ARCHIVE PAGE
   ========================================================= */

.woocommerce-page .site-content,
.woocommerce .site-content { padding-block: 0; }

.ds-page-header {
	background: var(--ds-color-bg-alt);
	border-bottom: 1px solid var(--ds-color-border);
	padding-block: 2rem;
	margin-bottom: 2rem;
}
.ds-page-header__title { margin: 0; }
.ds-page-header__desc  { color: var(--ds-color-text-light); margin-top: .5rem; max-width: 60ch; }

/* WooCommerce toolbar (sorting, results count) */
.woocommerce-products-header { display: none; }

.woocommerce-ordering select {
	padding: .5rem 2rem .5rem 1rem;
	border-radius: var(--ds-btn-radius);
	background: var(--ds-color-bg);
	border: 1px solid var(--ds-color-border);
	font-size: .9375rem;
	cursor: pointer;
}

/* =========================================================
   PRODUCT GRID
   ========================================================= */

ul.products,
.ds-products-grid {
	display: grid;
	gap: 1.5rem;
	list-style: none;
	padding: 0;
	margin: 0;
	grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 640px)  { ul.products, .ds-products-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { ul.products, .ds-products-grid { grid-template-columns: repeat(4, 1fr); } }
.ds-products-grid--2col { grid-template-columns: repeat(2, 1fr) !important; }
.ds-products-grid--3col { grid-template-columns: repeat(3, 1fr) !important; }
.ds-products-grid--4col { grid-template-columns: repeat(4, 1fr) !important; }
.ds-products-grid--5col { grid-template-columns: repeat(5, 1fr) !important; }

/* =========================================================
   PRODUCT CARD
   ========================================================= */

.ds-product-card {
	border-radius: 12px;
	border: 1px solid var(--ds-color-border);
	background: var(--ds-color-bg);
	overflow: hidden;
	position: relative;
	transition: box-shadow var(--ds-transition), transform var(--ds-transition);
}
.ds-product-card:hover {
	box-shadow: var(--ds-shadow-lg);
	transform: translateY(-3px);
}

/* Thumbnail */
.ds-product-card__thumb {
	position: relative;
	overflow: hidden;
	aspect-ratio: 3/4;
	background: var(--ds-color-bg-alt);
}
.ds-product-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.ds-product-card__img--hover {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity .4s ease;
}

/* Hover effects */
.ds-product-card--hover-zoom .ds-product-card__img--main {
	transition: transform .45s ease;
}
.ds-product-card--hover-zoom:hover .ds-product-card__img--main {
	transform: scale(1.07);
}
.ds-product-card--hover-fade:hover .ds-product-card__img--hover   { opacity: 1; }
.ds-product-card--hover-fade:hover .ds-product-card__img--main    { opacity: 0; }

/* Badges */
.ds-product-card__badges {
	position: absolute;
	top: .75rem;
	left: .75rem;
	display: flex;
	flex-direction: column;
	gap: .375rem;
	z-index: 2;
}

.ds-sale-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--ds-color-secondary);
	color: #fff;
	font-size: .75rem;
	font-weight: 700;
	padding: .2rem .5rem;
	border-radius: 99px;
	line-height: 1;
}

.ds-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: .6875rem;
	font-weight: 700;
	padding: .2rem .5rem;
	border-radius: 99px;
	line-height: 1;
}
.ds-badge--featured { background: var(--ds-color-primary); color: #fff; }
.ds-badge--out      { background: #6b7280; color: #fff; }

/* Card action buttons */
.ds-product-card__actions {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	display: flex;
	justify-content: center;
	gap: .5rem;
	padding: .75rem;
	background: linear-gradient(to top, rgba(0,0,0,.5), transparent);
	opacity: 0;
	transform: translateY(6px);
	transition: opacity var(--ds-transition), transform var(--ds-transition);
}
.ds-product-card:hover .ds-product-card__actions {
	opacity: 1;
	transform: translateY(0);
}
.ds-product-card__action-btn,
.ds-quick-view-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .375rem;
	background: rgba(255,255,255,.92);
	color: var(--ds-color-text);
	border-radius: var(--ds-btn-radius);
	padding: .5rem 1rem;
	font-size: .8125rem;
	font-weight: 600;
	transition: background var(--ds-transition), color var(--ds-transition);
	backdrop-filter: blur(4px);
	cursor: pointer;
	border: none;
	white-space: nowrap;
}
.ds-product-card__action-btn:hover,
.ds-quick-view-btn:hover {
	background: var(--ds-color-primary);
	color: #fff;
}

/* Card info */
.ds-product-card__info {
	padding: 1rem;
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.ds-product-card__cat {
	font-size: .75rem;
	font-weight: 500;
	color: var(--ds-color-text-light);
	text-transform: uppercase;
	letter-spacing: .04em;
}
.ds-product-card__cat a { color: inherit; }
.ds-product-card__cat a:hover { color: var(--ds-color-primary); }

.ds-product-card__title {
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.35;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.ds-product-card__title a { color: var(--ds-color-text); }
.ds-product-card__title a:hover { color: var(--ds-color-primary); }

.ds-product-card__rating { margin: 0; }
.ds-product-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
	margin-top: auto;
}
.ds-product-card__price .price {
	font-size: 1rem;
	font-weight: 700;
	color: var(--ds-color-text);
}
.ds-product-card__price del { color: var(--ds-color-text-light); font-weight: 400; font-size: .875rem; }
.ds-product-card__price ins { text-decoration: none; color: var(--ds-color-secondary); }

/* ATC button on card */
.ds-product-card__atc .button,
.ds-product-card__atc a.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: var(--ds-btn-radius);
	background: var(--ds-color-primary);
	color: #fff;
	font-size: 1.2rem;
	font-weight: 700;
	transition: background var(--ds-transition);
	cursor: pointer;
	text-decoration: none;
	border: none;
}
.ds-product-card__atc .button:hover,
.ds-product-card__atc a.button:hover { background: var(--ds-color-btn-hover); }
.ds-product-card__atc .button.loading { pointer-events: none; }

/* =========================================================
   STARS
   ========================================================= */

.ds-stars { display: inline-flex; align-items: center; gap: 2px; font-size: .875rem; line-height: 1; }
.ds-star--full, .ds-star--half { color: #fbbf24; }
.ds-star--empty { color: #d1d5db; }
.ds-stars__count { font-size: .8125rem; color: var(--ds-color-text-light); margin-left: .25rem; }

/* WooCommerce native star rating */
.star-rating {
	display: inline-flex;
	align-items: center;
	color: #fbbf24;
	font-size: .875rem;
	overflow: hidden;
	position: relative;
	height: 1em;
}

/* =========================================================
   SINGLE PRODUCT PAGE
   ========================================================= */

.woocommerce div.product {
	padding-block: 3rem;
}

.woocommerce div.product .woocommerce-product-gallery {
	width: 50%;
	margin-bottom: 0;
}

.woocommerce div.product .summary {
	width: 46%;
}

@media (max-width: 767px) {
	.woocommerce div.product .woocommerce-product-gallery,
	.woocommerce div.product .summary { width: 100%; }
}

/* Product title */
.woocommerce div.product .product_title {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	line-height: 1.2;
	margin-bottom: .75rem;
}

/* Price */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-size: 1.75rem;
	font-weight: 800;
	color: var(--ds-color-text);
	margin-bottom: 1rem;
	display: block;
}
.woocommerce div.product span.price del { font-size: 1.25rem; color: var(--ds-color-text-light); font-weight: 400; }
.woocommerce div.product span.price ins { text-decoration: none; color: var(--ds-color-secondary); }

/* ATC button */
.woocommerce .single_add_to_cart_button,
.woocommerce button.single_add_to_cart_button {
	background: var(--ds-color-btn-bg) !important;
	color: var(--ds-color-btn-text) !important;
	border-radius: var(--ds-btn-radius) !important;
	padding: .875rem 2rem !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	border: none !important;
	cursor: pointer;
	transition: background var(--ds-transition), transform var(--ds-transition) !important;
	display: inline-flex;
	align-items: center;
	gap: .5rem;
}
.woocommerce .single_add_to_cart_button:hover {
	background: var(--ds-color-btn-hover) !important;
	transform: translateY(-1px);
}
.woocommerce .single_add_to_cart_button.loading:after {
	display: inline-block;
	width: 18px;
	height: 18px;
	border: 2.5px solid rgba(255,255,255,.35);
	border-top-color: #fff;
	border-radius: 50%;
	animation: ds-spin .6s linear infinite;
	content: '';
}

/* Quantity */
.woocommerce .quantity { display: flex; align-items: center; gap: 0; }
.woocommerce .quantity input.qty {
	width: 64px !important;
	height: 48px;
	text-align: center;
	border-radius: 0 !important;
	border-left: none !important;
	border-right: none !important;
	-moz-appearance: textfield;
}
.woocommerce .quantity input.qty::-webkit-outer-spin-button,
.woocommerce .quantity input.qty::-webkit-inner-spin-button { -webkit-appearance: none; }

.ds-qty-btn {
	width: 42px;
	height: 48px;
	border: 1px solid var(--ds-color-border);
	background: var(--ds-color-bg-alt);
	font-size: 1.25rem;
	font-weight: 700;
	cursor: pointer;
	transition: background var(--ds-transition);
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}
.ds-qty-minus { border-radius: var(--ds-btn-radius) 0 0 var(--ds-btn-radius); }
.ds-qty-plus  { border-radius: 0 var(--ds-btn-radius) var(--ds-btn-radius) 0; }
.ds-qty-btn:hover { background: var(--ds-color-border); }

/* =========================================================
   TRUST BADGES
   ========================================================= */

.ds-trust-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	padding: 1rem;
	border: 1px solid var(--ds-color-border);
	border-radius: 10px;
	background: var(--ds-color-bg-alt);
	margin-top: 1rem;
}

.ds-trust-badge {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: .8125rem;
	font-weight: 600;
	color: var(--ds-color-text-light);
	flex: 1;
	min-width: 100px;
}
.ds-trust-badge svg { color: var(--ds-color-primary); flex-shrink: 0; }

/* =========================================================
   COUNTDOWN TIMER
   ========================================================= */

.ds-countdown,
.ds-product-countdown {
	display: flex;
	align-items: center;
	gap: .5rem;
	flex-wrap: wrap;
	padding: .875rem 1rem;
	background: var(--ds-color-secondary);
	color: #fff;
	border-radius: 10px;
	margin-block: 1rem;
}
.ds-product-countdown .ds-countdown__label { font-weight: 600; font-size: .9375rem; }

.ds-countdown__units { display: flex; align-items: center; gap: .375rem; }
.ds-countdown__unit  { display: flex; flex-direction: column; align-items: center; }
.ds-countdown__num   { font-size: 1.5rem; font-weight: 800; line-height: 1; min-width: 2ch; text-align: center; }
.ds-countdown__name  { font-size: .625rem; font-weight: 500; text-transform: uppercase; letter-spacing: .05em; opacity: .85; }
.ds-countdown__sep   { font-size: 1.25rem; font-weight: 800; padding-bottom: .75rem; opacity: .7; }

/* =========================================================
   SOCIAL SHARE
   ========================================================= */

.ds-product-share {
	display: flex;
	align-items: center;
	gap: .75rem;
	flex-wrap: wrap;
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--ds-color-border);
}
.ds-product-share__label { font-size: .875rem; font-weight: 600; color: var(--ds-color-text-light); }
.ds-product-share__links { display: flex; gap: .5rem; }
.ds-product-share__links a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	background: var(--ds-color-bg-alt);
	border: 1px solid var(--ds-color-border);
	color: var(--ds-color-text-light);
	transition: all var(--ds-transition);
}
.ds-product-share__links a:hover { background: var(--ds-color-primary); border-color: var(--ds-color-primary); color: #fff; }

/* =========================================================
   STICKY ADD-TO-CART BAR
   ========================================================= */

.ds-sticky-atc {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 400;
	background: var(--ds-color-bg);
	border-top: 1px solid var(--ds-color-border);
	box-shadow: 0 -4px 16px rgba(0,0,0,.1);
	transform: translateY(100%);
	transition: transform .3s cubic-bezier(.4,0,.2,1);
}
.ds-sticky-atc.is-visible { transform: translateY(0); }

@media (max-width: 1023px) {
	.ds-sticky-atc { bottom: 57px; /* above mobile bar */ }
}

.ds-sticky-atc__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-block: .75rem;
}
.ds-sticky-atc__product { display: flex; align-items: center; gap: 1rem; }
.ds-sticky-atc__image   { width: 48px; height: 48px; object-fit: cover; border-radius: 8px; }
.ds-sticky-atc__name    { font-weight: 700; font-size: 1rem; line-height: 1.25; }
.ds-sticky-atc__price   { font-size: .9375rem; color: var(--ds-color-text-light); }
.ds-sticky-atc__actions .single_add_to_cart_button { margin: 0 !important; }

/* =========================================================
   PRODUCT TABS
   ========================================================= */

.woocommerce-tabs ul.tabs { list-style: none; display: flex; gap: .25rem; border-bottom: 2px solid var(--ds-color-border); margin-bottom: 0; padding: 0; }
.woocommerce-tabs ul.tabs li {
	position: relative;
}
.woocommerce-tabs ul.tabs li a {
	display: block;
	padding: .75rem 1.25rem;
	font-weight: 600;
	color: var(--ds-color-text-light);
	border-radius: 8px 8px 0 0;
	transition: color var(--ds-transition);
}
.woocommerce-tabs ul.tabs li.active a { color: var(--ds-color-primary); }
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce-tabs ul.tabs li.active::after {
	display: block;
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	right: 0;
	height: 2px;
	background: var(--ds-color-primary);
}

.woocommerce-tabs .panel { padding: 2rem 0; }

/* =========================================================
   RELATED / UPSELLS
   ========================================================= */

.related.products > h2,
.upsells.products > h2 {
	font-size: 1.5rem;
	margin-bottom: 1.5rem;
	padding-top: 2rem;
	border-top: 1px solid var(--ds-color-border);
}

/* =========================================================
   CART PAGE
   ========================================================= */

.woocommerce table.shop_table {
	border: 1px solid var(--ds-color-border);
	border-radius: 10px;
	overflow: hidden;
}
.woocommerce table.shop_table th {
	background: var(--ds-color-bg-alt);
	padding: 1rem;
	font-weight: 700;
	font-size: .875rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	border-bottom: 1px solid var(--ds-color-border);
}
.woocommerce table.shop_table td { padding: 1rem; border-bottom: 1px solid var(--ds-color-border); vertical-align: middle; }
.woocommerce table.shop_table tr:last-child td { border-bottom: none; }

/* Coupon toggle */
.woocommerce .coupon { margin-bottom: 1rem; }
.woocommerce .coupon label { font-weight: 600; display: block; margin-bottom: .5rem; }
.woocommerce .coupon .input-text { width: auto !important; min-width: 200px; }

/* Cart totals */
.woocommerce-cart .cart_totals {
	background: var(--ds-color-bg-alt);
	border: 1px solid var(--ds-color-border);
	border-radius: 12px;
	padding: 1.5rem;
}
.woocommerce-cart .cart_totals h2 { font-size: 1.25rem; margin-bottom: 1rem; }

/* Checkout button */
.woocommerce .checkout-button,
.woocommerce a.checkout-button {
	background: var(--ds-color-btn-bg) !important;
	color: var(--ds-color-btn-text) !important;
	border-radius: var(--ds-btn-radius) !important;
	padding: 1rem 2rem !important;
	font-size: 1.0625rem !important;
	font-weight: 700 !important;
	width: 100%;
	display: block;
	text-align: center;
	margin-top: 1rem;
}
.woocommerce .checkout-button:hover { background: var(--ds-color-btn-hover) !important; }

/* =========================================================
   CHECKOUT PAGE
   ========================================================= */

.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review { margin-bottom: 2rem; }

.woocommerce form .form-row label { font-weight: 600; font-size: .9375rem; display: block; margin-bottom: .375rem; }
.woocommerce form .form-row .input-text { width: 100%; }
.woocommerce-checkout .wc_payment_method label { font-weight: 500; }

/* =========================================================
   NOTICES
   ========================================================= */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-radius: 10px;
	padding: 1rem 1.25rem;
	margin-bottom: 1.25rem;
	border: 1px solid transparent;
	display: flex;
	align-items: flex-start;
	gap: .75rem;
}
.woocommerce-message { background: #d1fae5; border-color: #6ee7b7; color: #065f46; }
.woocommerce-info    { background: #dbeafe; border-color: #93c5fd; color: #1e3a8a; }
.woocommerce-error   { background: #fee2e2; border-color: #fca5a5; color: #7f1d1d; }
.woocommerce-error::before,
.woocommerce-info::before,
.woocommerce-message::before { font-size: 1rem; flex-shrink: 0; margin-top: .1rem; }

.woocommerce-message::before { content: '✓'; color: #059669; }
.woocommerce-info::before    { content: 'ℹ'; color: #2563eb; }
.woocommerce-error::before   { content: '✕'; color: #dc2626; }

/* =========================================================
   MY ACCOUNT
   ========================================================= */

.woocommerce-account .woocommerce-MyAccount-navigation {
	width: 220px;
	float: left;
	margin-right: 2rem;
}
.woocommerce-account .woocommerce-MyAccount-content { float: left; width: calc(100% - 240px); }
@media (max-width: 767px) {
	.woocommerce-account .woocommerce-MyAccount-navigation,
	.woocommerce-account .woocommerce-MyAccount-content { width: 100%; float: none; margin-right: 0; }
}
.woocommerce-MyAccount-navigation ul { list-style: none; }
.woocommerce-MyAccount-navigation ul li { border-bottom: 1px solid var(--ds-color-border); }
.woocommerce-MyAccount-navigation ul li a { display: block; padding: .75rem 1rem; color: var(--ds-color-text); font-weight: 500; }
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover { color: var(--ds-color-primary); }

/* =========================================================
   MINI CART (in drawer)
   ========================================================= */

.ds-mini-cart__empty { text-align: center; color: var(--ds-color-text-light); padding: 2rem 0; }
.ds-mini-cart__items { list-style: none; }

.ds-mini-cart__item {
	display: grid;
	grid-template-columns: 64px 1fr auto;
	gap: .875rem;
	align-items: start;
	padding-block: 1rem;
	border-bottom: 1px solid var(--ds-color-border);
}
.ds-mini-cart__item:last-child { border-bottom: none; }

.ds-mini-cart__item-thumb { border-radius: 8px; overflow: hidden; aspect-ratio: 1; }
.ds-mini-cart__item-thumb img { width: 100%; height: 100%; object-fit: cover; }

.ds-mini-cart__item-name { font-weight: 600; font-size: .9375rem; line-height: 1.4; display: block; margin-bottom: .25rem; }
.ds-mini-cart__item-name a { color: var(--ds-color-text); }
.ds-mini-cart__item-name a:hover { color: var(--ds-color-primary); }
.ds-mini-cart__item-qty-price { font-size: .875rem; color: var(--ds-color-text-light); }

.ds-mini-cart__remove {
	color: var(--ds-color-text-light);
	font-size: 1.25rem;
	line-height: 1;
	transition: color var(--ds-transition);
	text-decoration: none;
}
.ds-mini-cart__remove:hover { color: #dc2626; }

.ds-mini-cart__footer { margin-top: 1rem; }
.ds-mini-cart__total {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 1rem;
	font-weight: 700;
	margin-bottom: 1rem;
}
.ds-mini-cart__actions { display: flex; flex-direction: column; gap: .625rem; }
.ds-mini-cart__actions .btn { width: 100%; }

/* =========================================================
   HOMEPAGE — SECTIONS
   ========================================================= */

.ds-section {
	padding-block: 5rem;
}

/* Hero */
.ds-hero {
	position: relative;
	min-height: 560px;
	display: flex;
	align-items: center;
	overflow: hidden;
	background: var(--ds-color-primary);
	background-image: var(--ds-hero-bg, none);
	background-size: cover;
	background-position: center;
}
.ds-hero__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,calc(var(--ds-hero-overlay, 50%) / 100));
}
.ds-hero .ds-container { position: relative; z-index: 1; }
.ds-hero__content { max-width: 680px; color: #fff; padding-block: 5rem; }
.ds-hero__eyebrow {
	display: inline-block;
	background: rgba(255,255,255,.15);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,.25);
	color: #fff;
	font-size: .875rem;
	font-weight: 600;
	padding: .375rem .875rem;
	border-radius: 99px;
	margin-bottom: 1.25rem;
	letter-spacing: .04em;
}
.ds-hero__heading { font-size: clamp(2rem, 5vw, 3.5rem); color: #fff; line-height: 1.1; margin-bottom: 1.25rem; }
.ds-hero__sub     { font-size: 1.125rem; opacity: .9; margin-bottom: 2rem; max-width: 540px; }
.ds-hero__ctas    { display: flex; gap: 1rem; flex-wrap: wrap; }

/* Trust strip */
.ds-trust-strip {
	background: var(--ds-color-bg-alt);
	border-block: 1px solid var(--ds-color-border);
	padding-block: 1.25rem;
}
.ds-trust-strip__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2rem;
	flex-wrap: wrap;
}
.ds-trust-strip__item { display: flex; align-items: center; gap: .625rem; font-weight: 600; font-size: .9375rem; white-space: nowrap; }
.ds-trust-strip__item svg { color: var(--ds-color-primary); flex-shrink: 0; }

/* Promo banners */
.ds-promo-banners__grid {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .ds-promo-banners__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ds-promo-banners__grid { grid-template-columns: repeat(3, 1fr); } }

.ds-promo-banner {
	position: relative;
	overflow: hidden;
	border-radius: 14px;
	aspect-ratio: 4/3;
	display: block;
	background: var(--ds-color-bg-alt);
}
.ds-promo-banner img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.ds-promo-banner:hover img { transform: scale(1.05); }
.ds-promo-banner__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,.7) 0%, transparent 60%);
	display: flex;
	align-items: flex-end;
	padding: 1.5rem;
	color: #fff;
}
.ds-promo-banner__title { font-size: 1.25rem; font-weight: 700; }
.ds-promo-banner__link  { font-size: .875rem; opacity: .8; text-decoration: underline; }

/* Tabs */
.ds-tabs {
	display: flex;
	gap: .25rem;
	border-bottom: 2px solid var(--ds-color-border);
	margin-bottom: 2rem;
	flex-wrap: wrap;
}
.ds-tab {
	padding: .625rem 1.25rem;
	font-weight: 600;
	font-size: .9375rem;
	color: var(--ds-color-text-light);
	border-radius: 8px 8px 0 0;
	position: relative;
	transition: color var(--ds-transition);
	cursor: pointer;
	background: none;
	border: none;
}
.ds-tab:hover { color: var(--ds-color-primary); }
.ds-tab.is-active { color: var(--ds-color-primary); }
.ds-tab.is-active::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	right: 0;
	height: 2px;
	background: var(--ds-color-primary);
}

/* Flash sale */
.ds-flash-sale { background: var(--ds-color-primary); }
.ds-flash-sale__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 1.5rem;
	text-align: center;
}
.ds-flash-sale__heading { color: #fff; font-size: clamp(1.5rem, 3vw, 2.25rem); margin: 0; }
.ds-flash-sale .ds-countdown { background: rgba(255,255,255,.15); backdrop-filter: blur(8px); }

/* Categories */
.ds-categories__grid {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 640px)  { .ds-categories__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .ds-categories__grid { grid-template-columns: repeat(6, 1fr); } }

.ds-category-tile {
	position: relative;
	overflow: hidden;
	border-radius: 12px;
	aspect-ratio: 3/4;
	display: block;
	background: var(--ds-color-bg-alt);
}
.ds-category-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.ds-category-tile:hover img { transform: scale(1.08); }
.ds-category-tile__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 60%);
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 1.25rem;
	text-align: center;
}
.ds-category-tile__name { color: #fff; font-weight: 700; font-size: 1rem; }
.ds-category-tile__count { color: rgba(255,255,255,.75); font-size: .8125rem; }

/* Testimonials */
.ds-testimonials { background: var(--ds-color-bg-alt); }
.ds-testimonials-swiper { overflow: hidden; }
.ds-testimonial {
	background: var(--ds-color-bg);
	border-radius: 14px;
	padding: 1.5rem;
	border: 1px solid var(--ds-color-border);
}
.ds-testimonial__body { font-size: 1rem; line-height: 1.7; color: var(--ds-color-text-light); margin-bottom: 1.25rem; font-style: italic; }
.ds-testimonial__author { display: flex; align-items: center; gap: .875rem; }
.ds-testimonial__avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; }
.ds-testimonial__name { font-weight: 700; font-size: .9375rem; }
.ds-testimonial__verified { font-size: .8125rem; color: var(--ds-color-accent); }

/* Newsletter */
.ds-newsletter {
	background: linear-gradient(135deg, var(--ds-color-primary), var(--ds-color-primary-dark, #1d4ed8));
	color: #fff;
	text-align: center;
}
.ds-newsletter__heading { color: #fff; font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: .5rem; }
.ds-newsletter__sub     { opacity: .85; margin-bottom: 2rem; }
.ds-newsletter__form {
	display: flex;
	max-width: 480px;
	margin-inline: auto;
	gap: 0;
}
.ds-newsletter__input {
	flex: 1;
	padding: .875rem 1.25rem;
	border-radius: var(--ds-btn-radius) 0 0 var(--ds-btn-radius);
	border: none;
	font-size: 1rem;
}
.ds-newsletter__btn {
	background: var(--ds-color-secondary);
	color: #fff;
	padding: .875rem 1.5rem;
	border-radius: 0 var(--ds-btn-radius) var(--ds-btn-radius) 0;
	font-weight: 700;
	border: none;
	cursor: pointer;
	transition: background var(--ds-transition);
	white-space: nowrap;
}
.ds-newsletter__btn:hover { background: var(--ds-color-secondary-dark, #ea6c00); }
@media (max-width: 480px) {
	.ds-newsletter__form { flex-direction: column; }
	.ds-newsletter__input { border-radius: var(--ds-btn-radius); }
	.ds-newsletter__btn   { border-radius: var(--ds-btn-radius); }
}

/* Brands */
.ds-brands { background: var(--ds-color-bg-alt); padding-block: 3rem; }
.ds-brands-swiper { overflow: hidden; }
.ds-brand-logo {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: .75rem 1.5rem;
	filter: grayscale(100%);
	opacity: .6;
	transition: filter var(--ds-transition), opacity var(--ds-transition);
}
.ds-brand-logo:hover { filter: none; opacity: 1; }
.ds-brand-logo img { max-height: 48px; width: auto; object-fit: contain; }

/* Search bar */
.ds-search-bar {
	background: var(--ds-color-bg-alt);
	border-top: 1px solid var(--ds-color-border);
	padding-block: 1rem;
}
.ds-search-form {
	display: flex;
	gap: .5rem;
	max-width: 640px;
	margin-inline: auto;
}
.ds-search-form__input {
	flex: 1;
	padding: .75rem 1.25rem;
	border: 1px solid var(--ds-color-border);
	border-radius: var(--ds-btn-radius);
	font-size: 1rem;
}
.ds-search-form__input:focus { outline: none; border-color: var(--ds-color-primary); box-shadow: 0 0 0 3px rgba(37,99,235,.15); }

/* =========================================================
   HIGH-VELOCITY EDITORIAL OVERRIDES
   ========================================================= */

/* No-line sectioning via tonal rhythm */
.ds-section:nth-of-type(even),
.woocommerce div.product,
.woocommerce-tabs {
	background: var(--ds-surface-low);
}

.ds-section:nth-of-type(odd),
.woocommerce .site-content {
	background: var(--ds-color-bg);
}

.ds-flash-sale,
.ds-testimonials,
.site-footer {
	background: var(--ds-color-inverse-surface);
}

.ds-flash-sale__heading,
.ds-testimonials .ds-section__title,
.site-footer,
.site-footer h2,
.site-footer h3 {
	color: var(--ds-color-bg);
}

/* Product cards: tonal depth over borders */
.ds-product-card {
	border: none;
	border-radius: 2px;
	background: var(--ds-surface-lowest);
	box-shadow: 0 20px 40px rgba(28, 27, 27, 0.06);
}

.ds-product-card__thumb {
	background: var(--ds-surface-low);
}

.ds-sale-badge,
.ds-badge {
	border-radius: 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.ds-sale-badge,
.ds-badge--featured {
	background: var(--ds-color-accent);
	color: var(--ds-color-text);
}

.ds-product-card__title,
.woocommerce div.product .product_title,
.ds-hero__heading,
.ds-section__title {
	font-weight: 900;
	letter-spacing: -0.02em;
}

/* Buttons */
.woocommerce .single_add_to_cart_button,
.woocommerce button.single_add_to_cart_button,
.woocommerce .checkout-button,
.woocommerce a.checkout-button,
.ds-newsletter__btn {
	border-radius: 2px !important;
	background: linear-gradient(120deg, var(--ds-color-primary), var(--ds-color-secondary)) !important;
	color: var(--ds-color-btn-text) !important;
	box-shadow: none !important;
}

.woocommerce .single_add_to_cart_button:hover,
.woocommerce .checkout-button:hover,
.ds-newsletter__btn:hover {
	transform: scale(1.02);
	filter: brightness(1.05);
}

/* Product page rhythm */
.woocommerce div.product {
	padding-block: 0;
}

.ds-single-product__inner {
	padding-block: 3rem;
	display: grid;
	grid-template-columns: minmax(0, 58%) minmax(0, 42%);
	gap: 2.5rem;
}

@media (max-width: 1023px) {
	.ds-single-product__inner {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}
}

.ds-product-countdown,
.ds-countdown {
	background: rgba(255, 87, 34, 0.12);
	color: var(--ds-color-text);
	border-radius: 2px;
}

.ds-countdown__num {
	color: var(--ds-color-primary);
}

.ds-trust-badges {
	background: var(--ds-surface-high);
	border: none;
	border-radius: 2px;
}

.ds-trust-badge {
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: .72rem;
	font-weight: 700;
}

.ds-sticky-atc {
	background: rgba(252, 249, 248, 0.8);
	backdrop-filter: blur(20px);
	border-top: none;
	box-shadow: 0 20px 40px rgba(28, 27, 27, 0.08);
}

.ds-mobile-bar {
	background: rgba(252, 249, 248, 0.84);
	backdrop-filter: blur(20px);
	border-top: none;
	box-shadow: 0 20px 40px rgba(28, 27, 27, 0.1);
}

/* Inputs follow editorial rule */
.woocommerce form .form-row .input-text,
.ds-search-form__input,
.ds-newsletter__input {
	background: var(--ds-surface-high);
	border: none;
	border-bottom: 2px solid transparent;
	border-radius: 2px;
}

.woocommerce form .form-row .input-text:focus,
.ds-search-form__input:focus,
.ds-newsletter__input:focus {
	outline: none;
	border-bottom-color: var(--ds-color-primary);
	box-shadow: none;
}

/* Editorial testimonial cards */
.ds-testimonial {
	border: none;
	border-radius: 2px;
	background: var(--ds-surface-lowest);
	box-shadow: 0 20px 40px rgba(28, 27, 27, 0.06);
}

/* Newsletter hero block */
.ds-newsletter {
	background: linear-gradient(120deg, var(--ds-color-primary), var(--ds-color-secondary));
}

/* =========================================================
   SHOP PAGE LAYOUT (VITESSE STYLE)
   ========================================================= */

.ds-shop-layout {
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr);
	gap: 1.5rem;
	padding-bottom: 4rem;
}

@media (max-width: 1023px) {
	.ds-shop-layout {
		grid-template-columns: 1fr;
	}
}

.ds-shop-sidebar .ds-sidebar {
	background: var(--ds-surface-low);
	padding: 1.25rem;
	border-radius: 2px;
}

.ds-shop-sidebar .widget-title {
	font-size: 1.25rem;
	margin-bottom: .75rem;
	border: none;
	padding: 0;
	text-transform: uppercase;
}

.ds-shop-sidebar .ds-widget ul li {
	border: none;
	padding: .375rem 0;
}

.ds-shop-toolbar {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: .5rem;
	margin-bottom: 1rem;
}

.ds-shop-toolbar__label {
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .05em;
	text-transform: uppercase;
	color: var(--ds-color-text-light);
}

.ds-shop-main ul.products,
.ds-shop-main .ds-products-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 1rem;
}

@media (max-width: 1280px) {
	.ds-shop-main ul.products,
	.ds-shop-main .ds-products-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.ds-shop-main ul.products,
	.ds-shop-main .ds-products-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.ds-product-card__cta-row {
	margin-top: .5rem;
}

.ds-product-card__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 42px;
	padding: .75rem 1rem;
	font-size: .8rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .05em;
	border-radius: 2px;
	background: linear-gradient(120deg, var(--ds-color-primary), var(--ds-color-secondary));
	color: var(--ds-color-btn-text);
	text-decoration: none;
	transition: transform var(--ds-transition), filter var(--ds-transition);
}

.ds-product-card__cta:hover {
	transform: scale(1.02);
	filter: brightness(1.06);
	color: var(--ds-color-btn-text);
}

.ds-product-card__cta--details {
	background: var(--ds-color-inverse-surface);
	color: var(--ds-color-bg);
}

.ds-shop-newsletter {
	margin-top: 3rem;
	padding: 4.5rem 1.5rem;
	background: #2b2a2a;
	text-align: center;
	border-radius: 2px;
}

.ds-shop-newsletter__title {
	color: #fff;
	font-size: clamp(2rem, 6vw, 3rem);
	margin-bottom: 1rem;
	text-transform: uppercase;
}

.ds-shop-newsletter__text {
	color: #cbc8c6;
	max-width: 620px;
	margin: 0 auto 1.5rem;
}

.ds-shop-newsletter__form {
	display: flex;
	justify-content: center;
	gap: .75rem;
	flex-wrap: wrap;
}

.ds-shop-newsletter__form input {
	max-width: 320px;
	min-width: 240px;
	background: #fff;
	border-radius: 2px;
	border: none;
	border-bottom: 2px solid transparent;
}

.ds-shop-newsletter__form button {
	padding: .75rem 1.25rem;
	font-size: .75rem;
	font-weight: 800;
	letter-spacing: .06em;
	text-transform: uppercase;
	border-radius: 2px;
	background: linear-gradient(120deg, var(--ds-color-primary), var(--ds-color-secondary));
	color: var(--ds-color-btn-text);
}

/* =========================================================
   CART PAGE LAYOUT (VITESSE STYLE)
   ========================================================= */

.ds-page-header--cart {
	background: transparent;
	margin-bottom: 1rem;
	padding: 0;
}

.ds-cart-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 1.5rem;
	align-items: start;
}

@media (max-width: 1023px) {
	.ds-cart-layout {
		grid-template-columns: 1fr;
	}
}

.ds-cart-item {
	display: grid;
	grid-template-columns: 96px minmax(0, 1fr) 24px;
	gap: 1rem;
	background: var(--ds-surface-lowest);
	padding: .875rem;
	margin-bottom: 1rem;
	border-radius: 2px;
	box-shadow: 0 20px 40px rgba(28, 27, 27, 0.05);
}

.ds-cart-item__media img {
	width: 96px;
	height: 96px;
	object-fit: cover;
	border-radius: 2px;
}

.ds-cart-item__title {
	font-size: 1.75rem;
	margin: 0 0 .35rem;
	line-height: 1.1;
}

.ds-cart-item__title a {
	color: var(--ds-color-text);
}

.ds-cart-item__meta {
	font-size: .8rem;
	color: var(--ds-color-text-light);
	margin-bottom: .35rem;
}

.ds-cart-item__price {
	font-size: 1.3rem;
	font-weight: 800;
	color: var(--ds-color-primary);
	margin-bottom: .5rem;
}

.ds-cart-item__qty {
	display: flex;
	align-items: center;
	gap: .75rem;
	flex-wrap: wrap;
}

.ds-cart-item__save {
	font-size: .75rem;
	text-decoration: underline;
	text-underline-offset: 2px;
	color: var(--ds-color-text-light);
}

.ds-cart-item__remove .remove {
	font-size: 1.5rem;
	line-height: 1;
	color: var(--ds-color-text-light);
}

.ds-cart-item__remove .remove:hover {
	color: var(--ds-color-primary);
}

.ds-cart-actions {
	display: flex;
	gap: .75rem;
	flex-wrap: wrap;
	margin-bottom: 2rem;
}

.ds-cart-empty {
	background: var(--ds-surface-lowest);
	padding: 1.25rem;
	border-radius: 2px;
	box-shadow: 0 20px 40px rgba(28, 27, 27, 0.05);
	margin-bottom: 1rem;
}

.ds-cart-actions .button {
	border-radius: 2px;
	padding: .65rem 1rem;
	font-size: .75rem;
	text-transform: uppercase;
	letter-spacing: .05em;
}

.ds-cart-summary {
	background: var(--ds-surface-low);
	padding: 1.25rem;
	border-radius: 2px;
	position: sticky;
	top: 90px;
}

.ds-cart-summary h2 {
	font-size: 2rem;
	text-transform: uppercase;
	margin-bottom: .75rem;
}

.ds-cart-summary__free-shipping {
	font-size: .78rem;
	font-weight: 700;
	margin-bottom: .35rem;
}

.ds-cart-summary__progress {
	height: 6px;
	background: #ddd7d4;
	border-radius: 999px;
	overflow: hidden;
	margin-bottom: 1rem;
}

.ds-cart-summary__progress span {
	display: block;
	height: 100%;
	background: linear-gradient(120deg, var(--ds-color-primary), var(--ds-color-secondary));
}

.ds-cart-summary__rows {
	display: grid;
	gap: .625rem;
	font-size: .9rem;
	margin-bottom: 1rem;
}

.ds-cart-summary__rows > div {
	display: flex;
	justify-content: space-between;
	gap: .5rem;
}

.ds-cart-summary__total {
	padding-top: .75rem;
	border-top: 1px solid rgba(28, 27, 27, 0.12);
	font-size: 1.125rem;
	font-weight: 900;
}

.ds-cart-summary .checkout-button {
	width: 100%;
	margin: .5rem 0 .75rem;
	text-transform: uppercase;
	letter-spacing: .05em;
}

.ds-cart-summary__trust {
	font-size: .72rem;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--ds-color-text-light);
	text-align: center;
}

.ds-cart-cross-sells {
	margin-top: 3rem;
	padding-bottom: 1rem;
}

.ds-cart-cross-sells__head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 1rem;
}

.ds-cart-cross-sells__head h2 {
	font-size: 2rem;
	text-transform: uppercase;
}

.ds-cart-cross-sells__head a {
	font-size: .75rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--ds-color-primary);
}

/* =========================================================
   TRACK ORDER TEMPLATE
   ========================================================= */

.ds-track-order-page {
	padding-block: 2rem 4rem;
}

.ds-track-order__header {
	text-align: center;
	max-width: 760px;
	margin: 0 auto 1.5rem;
}

.ds-track-order__header h1 {
	font-size: clamp(2rem, 6vw, 3.5rem);
	text-transform: uppercase;
	margin-bottom: .5rem;
}

.ds-track-order__header p {
	color: var(--ds-color-text-light);
}

.ds-track-order__form {
	background: var(--ds-surface-low);
	padding: 1rem;
	border-radius: 2px;
	margin: 0 auto 1.5rem;
	max-width: 920px;
}

.ds-track-order__fields {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: .75rem;
	align-items: end;
}

@media (max-width: 860px) {
	.ds-track-order__fields {
		grid-template-columns: 1fr;
	}
}

.ds-track-order__field label {
	display: block;
	font-size: .7rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .05em;
	margin-bottom: .35rem;
}

.ds-track-order__fields .btn {
	min-height: 44px;
	padding-inline: 1.5rem;
	text-transform: uppercase;
	letter-spacing: .05em;
	font-size: .75rem;
	font-weight: 800;
}

.ds-track-order__error {
	max-width: 920px;
	margin: 0 auto 1.25rem;
	padding: .75rem 1rem;
	border-radius: 2px;
	background: rgba(176, 47, 0, 0.1);
	color: var(--ds-color-primary);
	font-weight: 700;
}

.ds-track-order__result {
	max-width: 1120px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 1.5rem;
}

@media (max-width: 1023px) {
	.ds-track-order__result {
		grid-template-columns: 1fr;
	}
}

.ds-track-order__summary,
.ds-track-order__timeline {
	background: var(--ds-surface-lowest);
	padding: 1.25rem;
	border-radius: 2px;
	box-shadow: 0 20px 40px rgba(28, 27, 27, 0.05);
}

.ds-track-order__badge {
	display: inline-flex;
	padding: .2rem .45rem;
	font-size: .7rem;
	font-weight: 800;
	letter-spacing: .05em;
	text-transform: uppercase;
	border-radius: 0;
	background: var(--ds-color-accent);
	color: var(--ds-color-text);
	margin-bottom: .5rem;
}

.ds-track-order__eta {
	font-size: 1.25rem;
	font-weight: 800;
	color: var(--ds-color-primary);
	margin-bottom: .35rem;
}

.ds-track-order__carrier {
	font-size: .9rem;
	margin-bottom: 1rem;
}

.ds-track-order__items h3,
.ds-track-order__timeline h3 {
	font-size: 1.2rem;
	margin-bottom: .75rem;
}

.ds-track-order__item {
	display: grid;
	grid-template-columns: 56px minmax(0, 1fr);
	gap: .75rem;
	align-items: center;
	padding: .6rem 0;
	border-top: 1px solid rgba(28, 27, 27, 0.08);
}

.ds-track-order__item-thumb img {
	width: 56px;
	height: 56px;
	object-fit: cover;
	border-radius: 2px;
}

.ds-track-order__item-title {
	font-weight: 700;
	margin: 0;
}

.ds-track-order__item-meta {
	font-size: .82rem;
	color: var(--ds-color-text-light);
}

.ds-track-order__timeline ol {
	margin: 0;
	padding: 0;
	list-style: none;
	position: relative;
}

.ds-track-order__timeline li {
	position: relative;
	padding-left: 1.2rem;
	padding-bottom: 1rem;
	color: var(--ds-color-text-light);
}

.ds-track-order__timeline li::before {
	content: '';
	position: absolute;
	left: 0;
	top: .3rem;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: #cbc6c3;
}

.ds-track-order__timeline li.is-active {
	color: var(--ds-color-text);
}

.ds-track-order__timeline li.is-active::before {
	background: var(--ds-color-primary);
	box-shadow: 0 0 0 3px rgba(176, 47, 0, 0.16);
}

.ds-track-order__timeline li strong {
	display: block;
	font-size: .95rem;
	font-weight: 800;
	margin-bottom: .15rem;
}

.ds-track-order__timeline li span {
	font-size: .82rem;
	line-height: 1.4;
	color: var(--ds-color-text-light);
}

.ds-track-order__support {
	margin-top: .75rem;
	font-size: .82rem;
	color: var(--ds-color-text-light);
}
