/* ═══════════════════════════════════════════════════════════════════
   Cuan from iPhone — WooCommerce Frontend Theme
   v1.5.1 — Dark luxury aesthetic untuk semua WC pages.
   Target: single product, shop archive, cart, checkout, my-account.
   ═══════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════
   CSS VARS — sinkron dengan main theme
═══════════════════════════════════════════ */
.woocommerce, .woocommerce-page {
	--cf-bg: #000;
	--cf-bg2: #0a0a0a;
	--cf-bg3: #1d1d1f;
	--cf-line: rgba(255,255,255,.08);
	--cf-line2: rgba(255,255,255,.14);
	--cf-text: #f5f5f7;
	--cf-til: #d2d2d7;
	--cf-textm: #86868b;
	--cf-ti: #6e6e73;
	--cf-blue: #0071e3;
	--cf-green: #2d8b56;
	--cf-red: #d23d3d;
	--cf-orange: #d68b1a;
}

/* ═══════════════════════════════════════════
   GLOBAL WC CONTAINER
═══════════════════════════════════════════ */
.woocommerce, .woocommerce-page {
	color: var(--cf-text);
	font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Inter', 'Segoe UI', system-ui, sans-serif;
	background: transparent;
	max-width: 1200px;
	margin: 0 auto;
	padding: 48px 24px;
	min-height: 70vh;
}

.woocommerce a, .woocommerce-page a {
	color: var(--cf-blue);
	text-decoration: none;
	transition: opacity .2s ease;
}
.woocommerce a:hover, .woocommerce-page a:hover {
	opacity: .75;
}

/* ═══════════════════════════════════════════
   BREADCRUMB
═══════════════════════════════════════════ */
.woocommerce-breadcrumb {
	font-size: 12px;
	color: var(--cf-ti);
	letter-spacing: .04em;
	margin: 0 0 24px;
	text-transform: uppercase;
}
.woocommerce-breadcrumb a {
	color: var(--cf-textm);
}
.woocommerce-breadcrumb a:hover {
	color: var(--cf-blue);
}

/* ═══════════════════════════════════════════
   SHOP ARCHIVE (/shop/)
═══════════════════════════════════════════ */
.woocommerce .woocommerce-products-header {
	margin-bottom: 28px;
}
.woocommerce .woocommerce-products-header__title {
	font-size: clamp(36px, 5vw, 56px);
	font-weight: 700;
	letter-spacing: -.03em;
	line-height: 1.05;
	margin: 0 0 8px;
	color: var(--cf-text);
}
.woocommerce .term-description {
	color: var(--cf-textm);
	font-size: 15px;
	line-height: 1.55;
	max-width: 640px;
	margin-bottom: 20px;
}

.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
	color: var(--cf-textm);
	font-size: 13px;
	margin-bottom: 22px;
}
.woocommerce .woocommerce-ordering select {
	background: var(--cf-bg2);
	color: var(--cf-text);
	border: 1px solid var(--cf-line);
	border-radius: 10px;
	padding: 8px 32px 8px 14px;
	font-size: 13px;
	font-family: inherit;
}

/* Product grid */
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 18px;
	padding: 0;
	margin: 0 0 40px;
	list-style: none;
}
.woocommerce ul.products li.product {
	background: var(--cf-bg2);
	border: 1px solid var(--cf-line);
	border-radius: 16px;
	padding: 22px;
	margin: 0 !important;
	width: auto !important;
	float: none !important;
	clear: none !important;
	transition: transform .25s ease, border-color .25s ease;
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-3px);
	border-color: var(--cf-line2);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3 {
	color: var(--cf-text);
	font-size: 15px !important;
	font-weight: 700 !important;
	letter-spacing: -.01em;
	line-height: 1.3;
	padding: 12px 0 6px !important;
	margin: 0 !important;
}

.woocommerce ul.products li.product .price {
	color: var(--cf-til);
	font-size: 13.5px !important;
	font-weight: 600;
	margin-bottom: 10px;
	display: block;
}
.woocommerce ul.products li.product .price del {
	color: var(--cf-ti);
	font-weight: 400;
	margin-right: 6px;
	opacity: .6;
}
.woocommerce ul.products li.product .price ins {
	color: var(--cf-text);
	text-decoration: none;
	font-weight: 700;
	background: transparent;
}

.woocommerce ul.products li.product img {
	border-radius: 12px;
	width: 100%;
	height: auto;
	background: var(--cf-bg3);
}

/* "Sale!" badge */
.woocommerce span.onsale {
	background: linear-gradient(135deg, #d68b1a, #b87214);
	color: #000;
	font-weight: 700;
	font-size: 11px;
	letter-spacing: .04em;
	text-transform: uppercase;
	border-radius: 999px;
	padding: 4px 12px;
	min-height: 0;
	min-width: 0;
	line-height: 1.4;
	top: 14px;
	right: 14px;
	left: auto;
	margin: 0;
}

/* "Add to cart" button on grid */
.woocommerce ul.products li.product .button {
	display: inline-block;
	background: linear-gradient(180deg, #f5f5f7, #d2d2d7);
	color: #000;
	border: none;
	border-radius: 10px;
	padding: 9px 18px;
	font-size: 12.5px;
	font-weight: 600;
	letter-spacing: -.005em;
	margin-top: 6px;
	transition: opacity .2s ease;
}
.woocommerce ul.products li.product .button:hover {
	opacity: .9;
	background: linear-gradient(180deg, #f5f5f7, #d2d2d7);
	color: #000;
}
.woocommerce ul.products li.product .added_to_cart {
	display: block;
	margin-top: 8px;
	font-size: 12px;
	color: var(--cf-green);
}

/* ═══════════════════════════════════════════
   SINGLE PRODUCT PAGE
═══════════════════════════════════════════ */
.woocommerce div.product {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: start;
}
@media (max-width: 768px) {
	.woocommerce div.product {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

.woocommerce div.product .images,
.woocommerce div.product div.images,
.woocommerce div.product .woocommerce-product-gallery {
	margin: 0;
	width: 100% !important;
	float: none !important;
}

.woocommerce div.product .woocommerce-product-gallery__image img,
.woocommerce div.product .wp-post-image {
	border-radius: 16px;
	border: 1px solid var(--cf-line);
	background: var(--cf-bg2);
	width: 100%;
	height: auto;
}

/* Placeholder kalau no image */
.woocommerce div.product .woocommerce-product-gallery__wrapper:has(img[src*="placeholder"]) {
	aspect-ratio: 1;
	background: linear-gradient(135deg, var(--cf-bg2), var(--cf-bg3));
	border-radius: 16px;
	border: 1px solid var(--cf-line);
	display: flex;
	align-items: center;
	justify-content: center;
}
.woocommerce div.product img[src*="woocommerce-placeholder"] {
	background: linear-gradient(135deg, var(--cf-bg2), var(--cf-bg3));
	padding: 80px;
	opacity: .35;
	filter: invert(.85);
}

.woocommerce div.product .summary,
.woocommerce div.product div.summary {
	margin: 0 !important;
	width: 100% !important;
	float: none !important;
}

.woocommerce div.product .product_title {
	font-size: clamp(28px, 4vw, 44px);
	font-weight: 700;
	letter-spacing: -.025em;
	line-height: 1.08;
	color: var(--cf-text);
	margin: 0 0 16px;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-size: 24px;
	font-weight: 700;
	color: var(--cf-text);
	margin: 0 0 18px;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
	color: var(--cf-ti);
	font-weight: 400;
	font-size: 18px;
	margin-right: 10px;
	opacity: .55;
}
.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
	color: var(--cf-text);
	background: transparent;
	text-decoration: none;
}

.woocommerce div.product .woocommerce-product-details__short-description,
.woocommerce div.product .woocommerce-product-details__short-description p {
	color: var(--cf-textm);
	font-size: 15px;
	line-height: 1.6;
	margin: 0 0 24px;
}

/* Add to cart form */
.woocommerce div.product form.cart {
	margin: 0 0 28px;
	padding: 0;
	display: flex;
	gap: 12px;
	align-items: stretch;
	flex-wrap: wrap;
}
.woocommerce div.product form.cart .quantity {
	display: flex;
	align-items: center;
}
.woocommerce .quantity .qty,
.woocommerce div.product form.cart .quantity input {
	background: var(--cf-bg2);
	border: 1px solid var(--cf-line);
	color: var(--cf-text);
	border-radius: 12px;
	padding: 12px 14px;
	font-size: 14px;
	font-weight: 600;
	width: 72px;
	height: auto;
	text-align: center;
	font-family: inherit;
}
.woocommerce div.product form.cart .button,
.woocommerce .single_add_to_cart_button {
	background: linear-gradient(180deg, #f5f5f7, #d2d2d7) !important;
	color: #000 !important;
	border: none !important;
	border-radius: 12px !important;
	padding: 14px 28px !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	letter-spacing: -.005em !important;
	cursor: pointer;
	flex: 1;
	min-width: 200px;
	text-transform: none !important;
	transition: opacity .2s ease;
}
.woocommerce div.product form.cart .button:hover,
.woocommerce .single_add_to_cart_button:hover {
	opacity: .88;
}

/* Variations (kalau ada) */
.woocommerce div.product .variations {
	margin-bottom: 18px;
}
.woocommerce div.product .variations select {
	background: var(--cf-bg2);
	color: var(--cf-text);
	border: 1px solid var(--cf-line);
	border-radius: 10px;
	padding: 10px 14px;
	font-family: inherit;
}

/* Product meta footer */
.woocommerce div.product .product_meta {
	border-top: 1px solid var(--cf-line);
	padding-top: 18px;
	margin-top: 18px;
	font-size: 12.5px;
	color: var(--cf-ti);
	letter-spacing: .02em;
}
.woocommerce div.product .product_meta > span {
	display: block;
	margin-bottom: 6px;
}
.woocommerce div.product .product_meta .sku,
.woocommerce div.product .product_meta a {
	color: var(--cf-til);
	font-family: ui-monospace, monospace;
	font-size: 12px;
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs {
	margin-top: 56px;
	grid-column: 1 / -1;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	gap: 4px;
	padding: 0;
	margin: 0 0 24px;
	border: none;
	list-style: none;
	border-bottom: 1px solid var(--cf-line);
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before {
	display: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent !important;
	border: none !important;
	padding: 0 !important;
	margin: 0;
	border-radius: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: inline-block;
	padding: 12px 20px;
	font-size: 13px;
	font-weight: 600;
	color: var(--cf-textm);
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--cf-text);
	border-bottom-color: var(--cf-blue);
}
.woocommerce div.product .woocommerce-tabs .panel {
	color: var(--cf-til);
	line-height: 1.6;
	padding-top: 8px;
}

/* Related products */
.woocommerce .related,
.woocommerce .upsells {
	margin-top: 56px;
	grid-column: 1 / -1;
}
.woocommerce .related > h2,
.woocommerce .upsells > h2 {
	font-size: 22px;
	font-weight: 700;
	letter-spacing: -.02em;
	margin: 0 0 22px;
	color: var(--cf-text);
}

/* ═══════════════════════════════════════════
   CART PAGE
═══════════════════════════════════════════ */
.woocommerce table.shop_table {
	background: var(--cf-bg2);
	border: 1px solid var(--cf-line);
	border-radius: 14px;
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
}
.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
	background: transparent;
	border-color: var(--cf-line) !important;
	color: var(--cf-til);
	padding: 14px 16px;
	font-size: 13.5px;
}
.woocommerce table.shop_table th {
	color: var(--cf-ti);
	font-size: 11.5px;
	font-weight: 600;
	letter-spacing: .06em;
	text-transform: uppercase;
}
.woocommerce table.shop_table .product-name a {
	color: var(--cf-text);
	font-weight: 600;
}
.woocommerce table.shop_table .product-price,
.woocommerce table.shop_table .product-subtotal,
.woocommerce table.shop_table .product-total {
	color: var(--cf-text);
	font-weight: 600;
}

.woocommerce a.remove,
.woocommerce table.shop_table .remove {
	color: var(--cf-ti) !important;
	font-size: 18px;
	background: transparent;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	line-height: 22px;
}
.woocommerce a.remove:hover {
	color: var(--cf-red) !important;
	background: rgba(210,61,61,.08);
}

.woocommerce .cart-collaterals .cart_totals h2 {
	font-size: 18px;
	font-weight: 700;
	letter-spacing: -.01em;
	color: var(--cf-text);
}
.woocommerce .cart-collaterals .cart_totals tr td,
.woocommerce .cart-collaterals .cart_totals tr th {
	background: transparent;
	border-color: var(--cf-line);
	color: var(--cf-til);
}
.woocommerce .cart-collaterals .cart_totals .order-total .amount {
	color: var(--cf-text);
	font-size: 22px;
	font-weight: 700;
}

.woocommerce .cart-collaterals .cart_totals .checkout-button,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
	background: linear-gradient(180deg, #f5f5f7, #d2d2d7) !important;
	color: #000 !important;
	border: none;
	border-radius: 12px !important;
	padding: 14px 28px !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	text-align: center;
}

.woocommerce .coupon input[name="coupon_code"] {
	background: var(--cf-bg2);
	color: var(--cf-text);
	border: 1px solid var(--cf-line);
	border-radius: 10px;
	padding: 10px 14px;
}

/* ═══════════════════════════════════════════
   CHECKOUT PAGE
═══════════════════════════════════════════ */
.woocommerce form .form-row {
	margin: 0 0 14px;
	padding: 0;
}
.woocommerce form .form-row label {
	color: var(--cf-til);
	font-size: 12.5px;
	font-weight: 600;
	margin-bottom: 6px;
	display: block;
}
.woocommerce form .form-row .input-text,
.woocommerce form .form-row input,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	background: var(--cf-bg2) !important;
	color: var(--cf-text) !important;
	border: 1px solid var(--cf-line) !important;
	border-radius: 10px !important;
	padding: 12px 14px !important;
	font-family: inherit;
	font-size: 14px;
	width: 100%;
	box-sizing: border-box;
}
.woocommerce form .form-row .input-text:focus {
	border-color: var(--cf-blue) !important;
	outline: none;
}
.woocommerce form .form-row.woocommerce-invalid .input-text {
	border-color: var(--cf-red) !important;
}

.woocommerce-checkout #order_review {
	background: var(--cf-bg2);
	border: 1px solid var(--cf-line);
	border-radius: 14px;
	padding: 24px;
}
.woocommerce-checkout h3 {
	font-size: 18px;
	font-weight: 700;
	color: var(--cf-text);
	letter-spacing: -.015em;
	margin: 0 0 18px;
}
.woocommerce-checkout-payment {
	background: transparent !important;
	border-radius: 0;
}
.woocommerce-checkout-payment ul.payment_methods {
	background: var(--cf-bg3) !important;
	border-radius: 10px;
	padding: 12px !important;
	border: 1px solid var(--cf-line);
}
.woocommerce-checkout-payment ul.payment_methods li {
	background: transparent;
	color: var(--cf-til);
}
.woocommerce-checkout-payment .payment_box {
	background: var(--cf-bg) !important;
	color: var(--cf-textm) !important;
	border-radius: 8px;
}
.woocommerce #payment #place_order {
	background: linear-gradient(180deg, #f5f5f7, #d2d2d7) !important;
	color: #000 !important;
	border: none;
	border-radius: 12px !important;
	padding: 14px 28px !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	width: 100%;
}

/* ═══════════════════════════════════════════
   MY ACCOUNT
═══════════════════════════════════════════ */
.woocommerce-account .woocommerce {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 32px;
}
@media (max-width: 768px) {
	.woocommerce-account .woocommerce {
		grid-template-columns: 1fr;
	}
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
	background: var(--cf-bg2);
	border: 1px solid var(--cf-line);
	border-radius: 14px;
	overflow: hidden;
}
.woocommerce-account .woocommerce-MyAccount-navigation li {
	border-bottom: 1px solid var(--cf-line);
}
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child {
	border-bottom: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
	display: block;
	padding: 12px 18px;
	color: var(--cf-til);
	font-size: 13.5px;
	font-weight: 600;
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a {
	color: var(--cf-text);
	background: var(--cf-bg3);
}

.woocommerce-account .woocommerce-MyAccount-content {
	color: var(--cf-til);
	line-height: 1.6;
}
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
	color: var(--cf-text);
	font-weight: 700;
	letter-spacing: -.015em;
}

/* Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	background: var(--cf-bg2) !important;
	color: var(--cf-til) !important;
	border-left: 3px solid var(--cf-blue) !important;
	border-radius: 10px;
	padding: 14px 18px !important;
	margin: 0 0 22px;
}
.woocommerce-message {
	border-left-color: var(--cf-green) !important;
}
.woocommerce-error {
	border-left-color: var(--cf-red) !important;
}
.woocommerce-message a.button,
.woocommerce-info a.button {
	background: transparent !important;
	color: var(--cf-blue) !important;
	border: 1px solid var(--cf-line);
	padding: 6px 14px !important;
	border-radius: 8px;
	font-size: 12px;
	font-weight: 600;
	margin-left: 12px;
}

/* Cart-fragments mini cart icon kalau ada */
.woocommerce .widget_shopping_cart,
.cart_list {
	background: var(--cf-bg2);
	color: var(--cf-til);
}

/* ═══════════════════════════════════════════
   THANK YOU PAGE (post-purchase)
═══════════════════════════════════════════ */
.woocommerce-order-received .woocommerce-order h2,
.woocommerce-order-received .woocommerce-order h3 {
	color: var(--cf-text);
	font-weight: 700;
}
.woocommerce-order-received .woocommerce-thankyou-order-received {
	font-size: 18px;
	color: var(--cf-text);
	font-weight: 600;
	margin-bottom: 24px;
}
.woocommerce-order-received ul.order_details {
	background: var(--cf-bg2);
	border: 1px solid var(--cf-line);
	border-radius: 14px;
	padding: 20px 24px;
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	list-style: none;
	margin-bottom: 28px;
}
.woocommerce-order-received ul.order_details li {
	border: none !important;
	padding: 0 18px 0 0 !important;
	color: var(--cf-textm);
	font-size: 12px;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.woocommerce-order-received ul.order_details li strong {
	display: block;
	font-size: 14px;
	color: var(--cf-text);
	margin-top: 4px;
	letter-spacing: 0;
	text-transform: none;
	font-weight: 700;
}

/* ═══════════════════════════════════════════
   CUAN POST-CHECKOUT CTA (member-access banner)
═══════════════════════════════════════════ */
.cuan-thankyou-cta {
	background: linear-gradient(135deg, rgba(0,113,227,.12), rgba(0,113,227,.04)) !important;
	border: 1px solid rgba(0,113,227,.3) !important;
	border-radius: 16px !important;
	padding: 28px !important;
	margin: 28px 0 !important;
	text-align: center;
}
.cuan-thankyou-cta h3 {
	font-size: 22px !important;
	color: var(--cf-text) !important;
	margin: 0 0 10px !important;
}
.cuan-thankyou-cta p {
	color: var(--cf-textm) !important;
	font-size: 14px !important;
	line-height: 1.55 !important;
	margin: 0 0 18px !important;
}
.cuan-thankyou-cta .button {
	display: inline-block;
	background: linear-gradient(180deg, #f5f5f7, #d2d2d7) !important;
	color: #000 !important;
	border: none;
	border-radius: 12px !important;
	padding: 12px 26px !important;
	font-size: 14px !important;
	font-weight: 700 !important;
}

/* ═══════════════════════════════════════════
   CATEGORY ARCHIVE & FILTERS
═══════════════════════════════════════════ */
.woocommerce .woocommerce-pagination {
	margin-top: 32px;
}
.woocommerce .woocommerce-pagination ul.page-numbers {
	display: flex;
	gap: 6px;
	border: none;
	justify-content: center;
}
.woocommerce .woocommerce-pagination ul.page-numbers li {
	border: none;
	margin: 0;
}
.woocommerce .woocommerce-pagination ul.page-numbers li .page-numbers {
	background: var(--cf-bg2);
	border: 1px solid var(--cf-line);
	color: var(--cf-til);
	border-radius: 10px;
	padding: 8px 14px;
	font-size: 13px;
	font-weight: 600;
}
.woocommerce .woocommerce-pagination ul.page-numbers li .page-numbers.current,
.woocommerce .woocommerce-pagination ul.page-numbers li a:hover {
	background: var(--cf-text);
	color: var(--cf-bg) !important;
}

/* Sale price helper */
.woocommerce .price {
	color: var(--cf-text);
}
