/*
Theme Name: Alluvi Healthcare
Theme URI: https://retatrutide40mgpen.uk
Author: Alluvi Healthcare UK
Description: Clinical dark theme for Alluvi Healthcare UK
Version: 7.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: alluvi
*/

/* =============================================
   DESIGN TOKENS
   White text · Orange accents · Black backgrounds
   ============================================= */
:root {
	--or:        #FF6B1A;
	--or-hover:  #ff7f35;
	--or-dim:    rgba(255, 107, 26, 0.12);
	--or-mid:    rgba(255, 107, 26, 0.30);
	--or-glow:   rgba(255, 107, 26, 0.35);
	--or-border: rgba(255, 107, 26, 0.22);

	--bg:        #000000;
	--bg2:       #0a0600;
	--card:      #111111;
	--card2:     #1a1a1a;

	--white:     #ffffff;
	--w85:       rgba(255, 255, 255, 0.85);
	--w65:       rgba(255, 255, 255, 0.65);
	--w40:       rgba(255, 255, 255, 0.40);
	--w20:       rgba(255, 255, 255, 0.20);

	--fhead: 'Syne', sans-serif;
	--fbody: 'DM Sans', sans-serif;
	--r:    12px;
	--rsm:   8px;
}

/* =============================================
   RESET
   ============================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
img  { max-width: 100%; height: auto; display: block; }
ul   { list-style: none; }

/* =============================================
   BASE
   ============================================= */
html, body {
	background-color: var(--bg);
	color: var(--w85);
	font-family: var(--fbody);
	font-size: 16px;
	line-height: 1.7;
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--fhead);
	color: var(--white);
	font-weight: 800;
	line-height: 1.2;
}

p  { color: var(--w65); }
li { color: var(--w65); }
strong { color: var(--white); font-weight: 700; }

a { color: var(--or); text-decoration: none; transition: opacity 0.2s; }
a:hover { opacity: 0.80; }

input, select, textarea, button { font-family: var(--fbody); }

/* =============================================
   LAYOUT
   ============================================= */
#page {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	background-color: var(--bg);
}
#content   { flex: 1; background-color: var(--bg); }
.site-main { padding-top: 64px; background-color: var(--bg); }

#primary, #secondary, .entry-content, .page-content,
main, article, section,
.woocommerce, .woocommerce-page,
.woocommerce-checkout, .woocommerce-cart,
.woocommerce-account, .woocommerce-order-received {
	background-color: var(--bg) !important;
}

/* =============================================
   NAVIGATION
   ============================================= */
.site-header {
	position: fixed;
	inset: 0 0 auto;
	z-index: 400;
	height: 64px;
	display: flex;
	align-items: center;
	background-color: rgba(0, 0, 0, 0.95);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border-bottom: 1px solid var(--w20);
}

.nav-inner {
	width: 100%; max-width: 1200px; margin: 0 auto;
	padding: 0 40px;
	display: flex; align-items: center;
	justify-content: space-between; gap: 20px;
}

.site-logo {
	font-family: var(--fhead);
	font-size: 1.1rem; font-weight: 800;
	color: var(--white);
	letter-spacing: -0.01em; flex-shrink: 0;
}
.site-logo:hover { opacity: 1; color: var(--or); }

.main-nav { display: flex; align-items: center; gap: 2px; }

.main-nav a {
	font-size: 0.84rem; color: var(--w65);
	font-weight: 500; padding: 7px 14px;
	border-radius: 6px;
	transition: color 0.2s, background-color 0.2s;
}
.main-nav a:hover {
	color: var(--white);
	background-color: rgba(255, 255, 255, 0.06);
	opacity: 1;
}

/* BUY NOW — orange bg, white text */
.main-nav .nav-cta {
	background-color: var(--or) !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	font-weight: 700;
	padding: 9px 20px;
	border-radius: 6px;
	margin-left: 8px;
	box-shadow: 0 0 20px var(--or-glow);
	opacity: 1;
}
.main-nav .nav-cta:hover {
	background-color: var(--or-hover) !important;
	color: var(--white) !important;
}

.nav-ham {
	display: none; flex-direction: column;
	gap: 5px; background: none; border: none;
	padding: 6px; cursor: pointer;
}
.nav-ham span {
	display: block; width: 22px; height: 2px;
	background-color: var(--white); border-radius: 2px;
}

.mob-nav {
	display: none;
	position: fixed; inset: 64px 0 0;
	background-color: rgba(0, 0, 0, 0.98);
	z-index: 399; padding: 32px 28px;
	flex-direction: column; gap: 4px;
}
.mob-nav.open { display: flex; }
.mob-nav a {
	font-size: 1.05rem; font-weight: 600;
	color: var(--w65); padding: 14px 0;
	border-bottom: 1px solid var(--w20);
	transition: color 0.2s;
}
.mob-nav a:hover, .mob-nav .mob-cta { color: var(--or); opacity: 1; }

/* =============================================
   PAGE CONTENT
   ============================================= */
.page-wrap {
	max-width: 860px; margin: 0 auto; padding: 72px 40px;
}
.page-wrap h1 { font-size: clamp(1.9rem, 4vw, 2.8rem); margin-bottom: 28px; color: var(--white); }
.page-wrap h2 { font-size: clamp(1.25rem, 3vw, 1.75rem); margin: 38px 0 14px; color: var(--white); }
.page-wrap h3 { font-size: 1.1rem; margin: 26px 0 10px; color: var(--white); }
.page-wrap p  { font-size: 0.97rem; line-height: 1.85; margin-bottom: 16px; color: var(--w65); }
.page-wrap ul,
.page-wrap ol { font-size: 0.97rem; line-height: 1.8; padding-left: 24px; margin-bottom: 16px; color: var(--w65); }

/* =============================================
   WOOCOMMERCE BASE
   ============================================= */
.woo-wrap {
	max-width: 1200px; margin: 0 auto;
	padding: 60px 40px; background-color: var(--bg);
}

.woocommerce-Price-amount,
.woocommerce .price,
.woocommerce .amount {
	color: var(--or) !important;
	font-family: var(--fhead) !important;
	font-weight: 800 !important;
}

/* ALL WC BUTTONS — orange bg, white text */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	background-color: var(--or) !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	font-family: var(--fbody) !important;
	font-weight: 700 !important;
	font-size: 0.92rem !important;
	border: none !important;
	border-radius: var(--rsm) !important;
	padding: 13px 26px !important;
	cursor: pointer !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	box-shadow: 0 0 18px var(--or-glow) !important;
	display: inline-block !important;
	transition: background-color 0.2s !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	background-color: var(--or-hover) !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
}

/* Notices */
.woocommerce-message {
	background-color: var(--card) !important;
	border-left: 3px solid var(--or) !important;
	border-top: none !important;
	border-radius: var(--rsm) !important;
	color: var(--w65) !important;
	padding: 14px 18px !important;
}
.woocommerce-error {
	background-color: rgba(255, 60, 60, 0.08) !important;
	border-left: 3px solid #ff4444 !important;
	border-top: none !important;
	border-radius: var(--rsm) !important;
	color: rgba(255, 180, 180, 0.92) !important;
	list-style: none !important;
	padding: 14px 18px !important;
}
.woocommerce-info {
	background-color: var(--card) !important;
	border-left: 3px solid var(--or) !important;
	border-top: none !important;
	border-radius: var(--rsm) !important;
	color: var(--w65) !important;
	padding: 14px 18px !important;
}
.woocommerce-info a { color: var(--or) !important; font-weight: 600 !important; }

/* =============================================
   SHOP GRID
   ============================================= */
.woocommerce ul.products {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
	gap: 18px !important;
	list-style: none !important;
	padding: 0 !important; margin: 0 !important;
}
.woocommerce ul.products li.product {
	background-color: var(--card) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--r) !important;
	overflow: hidden !important;
	transition: border-color 0.25s, transform 0.25s !important;
	margin: 0 !important; float: none !important; width: auto !important;
}
.woocommerce ul.products li.product:hover {
	border-color: var(--or) !important;
	transform: translateY(-4px) !important;
}
.woocommerce ul.products li.product img {
	width: 100% !important; height: 200px !important; object-fit: cover !important;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--fhead) !important; color: var(--white) !important;
	padding: 14px 16px 6px !important; font-size: 0.94rem !important; font-weight: 700 !important;
}
.woocommerce ul.products li.product .price { padding: 0 16px 12px !important; }
.woocommerce ul.products li.product a.button {
	margin: 0 16px 16px !important; display: block !important; text-align: center !important;
}

/* =============================================
   SINGLE PRODUCT
   ============================================= */
.woocommerce div.product {
	background-color: var(--card) !important;
	border: 1px solid var(--w20) !important;
	border-radius: 16px !important; padding: 40px !important;
}
.woocommerce div.product .product_title {
	color: var(--white) !important;
	font-family: var(--fhead) !important;
	font-size: clamp(1.5rem, 3vw, 2.1rem) !important;
	font-weight: 800 !important;
}
.woocommerce div.product .woocommerce-product-details__short-description p {
	color: var(--w65) !important;
}
.woocommerce div.product form.cart .qty {
	background-color: var(--card2) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--rsm) !important;
	color: var(--white) !important;
	padding: 10px 14px !important; width: 72px !important;
}

/* =============================================
   CART TABLE
   ============================================= */
.woocommerce table.shop_table {
	background-color: var(--card) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--r) !important;
	border-collapse: separate !important;
	border-spacing: 0 !important;
	overflow: hidden !important; width: 100% !important;
}
.woocommerce table.shop_table th {
	background-color: rgba(255, 255, 255, 0.04) !important;
	color: var(--or) !important;
	font-family: var(--fhead) !important;
	font-size: 0.7rem !important; letter-spacing: 0.13em !important;
	text-transform: uppercase !important;
	border: none !important;
	border-bottom: 1px solid var(--w20) !important;
	padding: 13px 18px !important;
}
.woocommerce table.shop_table td {
	color: var(--w65) !important;
	background-color: transparent !important;
	border: none !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
	padding: 13px 18px !important;
	vertical-align: middle !important;
}
.woocommerce table.shop_table .product-name a {
	color: var(--white) !important; font-weight: 600 !important;
}
.woocommerce table.shop_table .order-total th,
.woocommerce table.shop_table .order-total td {
	color: var(--or) !important;
	font-size: 1.05rem !important; font-weight: 800 !important;
	border-bottom: none !important;
}

.cart-collaterals, .cart_totals {
	background-color: var(--card) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--r) !important; padding: 24px !important;
}
.cart_totals h2 {
	font-family: var(--fhead) !important;
	font-size: 0.72rem !important; font-weight: 700 !important;
	letter-spacing: 0.15em !important; text-transform: uppercase !important;
	color: var(--w40) !important;
	border-bottom: 1px solid var(--w20) !important;
	padding-bottom: 12px !important; margin-bottom: 18px !important;
}

/* Proceed to Checkout */
.wc-proceed-to-checkout .checkout-button,
.wc-proceed-to-checkout a.button {
	display: block !important;
	background-color: var(--or) !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	font-family: var(--fhead) !important;
	font-size: 1rem !important; font-weight: 800 !important;
	text-align: center !important;
	padding: 16px 28px !important;
	border-radius: var(--rsm) !important;
	box-shadow: 0 0 28px var(--or-glow) !important;
	transition: background-color 0.2s !important;
}
.wc-proceed-to-checkout .checkout-button:hover,
.wc-proceed-to-checkout a.button:hover {
	background-color: var(--or-hover) !important;
	color: var(--white) !important;
}

/* =============================================
   CHECKOUT — LAYOUT
   ============================================= */
body.woocommerce-checkout { background-color: var(--bg) !important; }
.woocommerce-checkout .col2-set { width: 100% !important; float: none !important; }

.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 {
	width: 100% !important; float: none !important;
	background-color: var(--card) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--r) !important;
	padding: 30px 28px !important; margin-bottom: 22px !important;
}

/* Section headings — orange pill badge */
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
	display: inline-block !important;
	font-family: var(--fhead) !important;
	font-size: 0.68rem !important; font-weight: 800 !important;
	letter-spacing: 0.18em !important; text-transform: uppercase !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	background-color: var(--or) !important;
	border: none !important; border-radius: 4px !important;
	padding: 5px 14px !important; margin-bottom: 22px !important;
}

/* Labels */
.woocommerce-checkout label {
	display: block !important;
	color: var(--w65) !important;
	font-size: 0.76rem !important; font-weight: 600 !important;
	letter-spacing: 0.05em !important; text-transform: uppercase !important;
	margin-bottom: 7px !important;
}
.woocommerce-checkout .required { color: var(--or) !important; }

/* =============================================
   CHECKOUT — INPUTS
   ============================================= */
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="number"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout select,
.woocommerce-checkout textarea {
	background-color: var(--card2) !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--rsm) !important;
	font-family: var(--fbody) !important;
	font-size: 0.93rem !important;
	padding: 13px 16px !important;
	width: 100% !important;
	outline: none !important;
	box-shadow: none !important;
	-webkit-appearance: none !important;
	transition: border-color 0.2s, box-shadow 0.2s !important;
}
.woocommerce-checkout input:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus {
	border-color: var(--or) !important;
	box-shadow: 0 0 0 3px var(--or-dim) !important;
	outline: none !important;
}
.woocommerce-checkout input::placeholder,
.woocommerce-checkout textarea::placeholder {
	color: var(--w40) !important;
	-webkit-text-fill-color: var(--w40) !important;
}
.woocommerce-checkout input:-webkit-autofill,
.woocommerce-checkout input:-webkit-autofill:focus {
	-webkit-box-shadow: 0 0 0 1000px var(--card2) inset !important;
	-webkit-text-fill-color: var(--white) !important;
}
input[type="checkbox"],
input[type="radio"] { accent-color: var(--or) !important; width: auto !important; }

/* =============================================
   SELECT2
   ============================================= */
.select2-container .select2-selection--single {
	background-color: var(--card2) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--rsm) !important; height: 48px !important;
}
.select2-container .select2-selection--single .select2-selection__rendered {
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	line-height: 48px !important; padding: 0 16px !important;
}
.select2-container .select2-selection--single .select2-selection__arrow { height: 48px !important; }
.select2-container--open .select2-selection--single { border-color: var(--or) !important; }
.select2-dropdown {
	background-color: var(--card) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--rsm) !important;
}
.select2-results__option { color: var(--w65) !important; padding: 10px 15px !important; font-size: 0.88rem !important; }
.select2-results__option--highlighted {
	background-color: var(--or-dim) !important; color: var(--white) !important;
}
.select2-search--dropdown .select2-search__field {
	background-color: var(--card2) !important;
	border: 1px solid var(--w20) !important;
	border-radius: 6px !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	padding: 8px 12px !important;
}

/* =============================================
   CHECKOUT — ORDER REVIEW
   ============================================= */
.woocommerce-checkout #order_review {
	background-color: var(--card) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--r) !important;
	padding: 28px 26px !important;
}
.woocommerce-checkout table.shop_table {
	background-color: transparent !important;
	border: none !important; border-collapse: collapse !important; width: 100% !important;
}
.woocommerce-checkout table.shop_table thead th {
	color: var(--or) !important;
	font-size: 0.68rem !important; font-weight: 700 !important;
	letter-spacing: 0.13em !important; text-transform: uppercase !important;
	background-color: transparent !important; border: none !important;
	border-bottom: 1px solid var(--w20) !important; padding: 0 0 12px !important;
}
.woocommerce-checkout table.shop_table td,
.woocommerce-checkout table.shop_table tfoot th {
	color: var(--w65) !important;
	background-color: transparent !important; border: none !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
	padding: 12px 0 !important;
}
.woocommerce-checkout table.shop_table .product-name,
.woocommerce-checkout table.shop_table .product-name a {
	color: var(--white) !important; font-weight: 600 !important;
}
.woocommerce-checkout table.shop_table .order-total td,
.woocommerce-checkout table.shop_table .order-total th {
	color: var(--or) !important;
	font-size: 1.1rem !important; font-weight: 800 !important;
	border-top: 1px solid var(--w20) !important;
	border-bottom: none !important; padding-top: 14px !important;
}

/* =============================================
   CHECKOUT — PAYMENT + PLACE ORDER
   ============================================= */
.woocommerce-checkout #payment {
	background-color: var(--card) !important;
	border: 1px solid var(--w20) !important;
	border-radius: var(--r) !important;
	overflow: hidden !important; margin-top: 22px !important; padding: 0 !important;
}
.woocommerce-checkout #payment ul.payment_methods {
	background-color: transparent !important;
	border-bottom: 1px solid var(--w20) !important;
	padding: 20px 26px !important; list-style: none !important; margin: 0 !important;
}
.woocommerce-checkout #payment ul.payment_methods li { background-color: transparent !important; }
.woocommerce-checkout #payment ul.payment_methods li label {
	color: var(--w85) !important; font-weight: 600 !important; font-size: 0.9rem !important;
}
.woocommerce-checkout #payment div.payment_box {
	background-color: rgba(255, 255, 255, 0.04) !important;
	border: 1px solid var(--w20) !important;
	border-radius: 6px !important; color: var(--w65) !important;
	font-size: 0.83rem !important; padding: 12px 15px !important; margin-top: 10px !important;
}
.woocommerce-checkout #payment .place-order {
	padding: 22px 26px !important; background-color: transparent !important;
}

/* PLACE ORDER BUTTON */
.woocommerce-checkout #payment #place_order,
#place_order {
	background-color: var(--or) !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	font-family: var(--fhead) !important;
	font-size: 1.05rem !important; font-weight: 800 !important;
	padding: 17px 32px !important;
	border-radius: var(--rsm) !important; border: none !important;
	width: 100% !important; cursor: pointer !important;
	letter-spacing: 0.02em !important; text-transform: none !important;
	display: block !important;
	box-shadow: 0 0 36px var(--or-glow) !important;
	transition: background-color 0.2s, transform 0.15s !important;
}
.woocommerce-checkout #payment #place_order:hover,
#place_order:hover {
	background-color: var(--or-hover) !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	transform: translateY(-2px) !important;
}

/* =============================================
   CHECKOUT — TOP BANNER
   ============================================= */
.al-banner {
	display: flex; align-items: center;
	justify-content: space-between; flex-wrap: wrap; gap: 12px;
	background-color: var(--card);
	border: 1px solid var(--w20);
	border-left: 3px solid var(--or);
	border-radius: var(--r);
	padding: 14px 20px; margin-bottom: 24px;
}
.al-banner-left { display: flex; align-items: center; gap: 9px; }
.al-pulse {
	width: 7px; height: 7px; border-radius: 50%;
	background-color: var(--or); flex-shrink: 0;
	animation: alPulse 2s infinite;
}
@keyframes alPulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%       { opacity: 0.3; transform: scale(1.7); }
}
.al-banner-left span {
	font-family: var(--fhead); font-size: 0.72rem; font-weight: 700;
	letter-spacing: 0.14em; text-transform: uppercase; color: var(--white);
}
.al-banner-right { display: flex; flex-wrap: wrap; gap: 14px; }
.al-badge {
	font-size: 0.74rem; color: var(--w40);
	display: flex; align-items: center; gap: 5px;
}
.al-badge::before { content: '✓'; color: var(--or); font-weight: 700; }

/* =============================================
   CHECKOUT — INFO CARDS
   ============================================= */
.al-info-grid {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 12px; margin-bottom: 12px;
}
.al-info-card {
	background-color: var(--card2);
	border: 1px solid var(--w20);
	border-radius: 10px; padding: 14px 15px;
}
.al-info-card-icon { font-size: 1.2rem; margin-bottom: 6px; }
.al-info-card-title {
	display: block; font-family: var(--fhead);
	font-size: 0.65rem; font-weight: 700;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--or); margin-bottom: 6px;
}
.al-info-card p { font-size: 0.79rem; color: var(--w40); line-height: 1.6; margin: 0; }
.al-info-card p strong { color: var(--w85); }

.al-confirm-note {
	background-color: var(--card2);
	border: 1px solid var(--w20);
	border-left: 3px solid var(--or);
	border-radius: var(--rsm);
	padding: 12px 15px; margin-bottom: 14px;
	font-size: 0.81rem; color: var(--w65); line-height: 1.6;
}
.al-confirm-note strong { color: var(--white); }

/* =============================================
   ORDER RECEIVED PAGE
   ============================================= */
body.woocommerce-order-received { background-color: var(--bg) !important; }

.al-ty-hero {
	background: linear-gradient(135deg, rgba(255, 107, 26, 0.08), rgba(255, 107, 26, 0.02));
	border: 1px solid var(--or-mid);
	border-radius: var(--r);
	padding: 36px 28px; margin-bottom: 20px; text-align: center;
}
.al-ty-hero h2 { font-size: 1.7rem; margin-bottom: 10px; color: var(--white); }
.al-ty-hero p  { font-size: 0.92rem; line-height: 1.8; max-width: 500px; margin: 0 auto; color: var(--w65); }
.al-ty-hero p strong { color: var(--white); }

.al-order-ref {
	display: inline-block;
	background-color: var(--or-dim);
	border: 1px solid var(--or-mid);
	border-radius: var(--rsm);
	padding: 9px 24px; margin-top: 14px;
	font-family: var(--fhead); font-size: 1.1rem; font-weight: 800;
	color: var(--or); letter-spacing: 0.05em;
}

/* WhatsApp */
.al-wa-wrap { text-align: center; margin: 18px 0 20px; }
.al-wa-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: 10px;
	background-color: #25D366 !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	font-family: var(--fbody); font-size: 0.97rem; font-weight: 700;
	padding: 14px 36px; border-radius: 10px; text-decoration: none;
	box-shadow: 0 0 26px rgba(37, 211, 102, 0.28);
	transition: background-color 0.2s, transform 0.15s;
}
.al-wa-btn:hover {
	background-color: #1ebe59 !important;
	color: var(--white) !important;
	-webkit-text-fill-color: var(--white) !important;
	transform: translateY(-2px); opacity: 1;
}
.al-wa-btn svg { width: 22px; height: 22px; fill: var(--white) !important; flex-shrink: 0; }
.al-wa-btn * { color: var(--white) !important; -webkit-text-fill-color: var(--white) !important; }
.al-wa-note { font-size: 0.74rem; color: var(--w40); margin-top: 7px; }

/* Alert */
.al-alert {
	background-color: rgba(255, 60, 60, 0.07);
	border: 1px solid rgba(255, 80, 80, 0.22);
	border-left: 3px solid #ff5555;
	border-radius: var(--rsm);
	padding: 13px 16px; font-size: 0.79rem;
	color: rgba(255, 180, 180, 0.85); line-height: 1.62; margin-bottom: 18px;
}
.al-alert strong { color: rgba(255, 200, 200, 0.95); }

/* Bank card */
.al-bank-card {
	background-color: var(--card);
	border: 1px solid var(--w20);
	border-top: 3px solid var(--or);
	border-radius: var(--r);
	padding: 24px 22px; margin-bottom: 18px;
}
.al-bank-heading {
	display: block; font-family: var(--fhead);
	font-size: 0.68rem; font-weight: 700;
	letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--or); margin-bottom: 12px;
	padding-bottom: 12px; border-bottom: 1px solid var(--w20);
}
.al-bank-intro { font-size: 0.87rem; color: var(--w65); line-height: 1.7; margin-bottom: 16px; }
.al-bank-intro strong { color: var(--white); }
.al-bank-rows { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.al-bank-row {
	display: flex; justify-content: space-between; align-items: center;
	padding: 11px 15px;
	background-color: var(--card2);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--rsm); flex-wrap: wrap; gap: 6px;
}
.al-bank-row.highlight {
	background-color: var(--or-dim);
	border-color: var(--or-mid);
}
.al-bank-label { font-size: 0.67rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--w40); }
.al-bank-value { font-family: var(--fhead); font-size: 0.92rem; font-weight: 700; color: var(--white); }
.al-bank-value.orange { color: var(--or); }
.al-bank-warning {
	background-color: rgba(255, 180, 0, 0.05);
	border: 1px solid rgba(255, 180, 0, 0.18);
	border-left: 3px solid #FFB400;
	border-radius: var(--rsm);
	padding: 11px 14px; font-size: 0.78rem;
	color: rgba(255, 210, 100, 0.75); line-height: 1.6;
}
.al-bank-warning strong { color: rgba(255, 220, 120, 0.95); }

/* Next steps */
.al-next-steps {
	background-color: var(--card);
	border: 1px solid var(--w20);
	border-radius: var(--r); padding: 22px 20px;
}
.al-next-heading {
	display: block; font-family: var(--fhead);
	font-size: 0.68rem; font-weight: 700;
	letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--w40); margin-bottom: 14px;
}
.al-next-list { display: flex; flex-direction: column; gap: 11px; }
.al-next-item {
	display: flex; align-items: flex-start;
	gap: 12px; font-size: 0.82rem; color: var(--w65); line-height: 1.6;
}
.al-next-item strong { color: var(--white); }
.al-next-num {
	font-family: var(--fhead); font-size: 0.95rem;
	font-weight: 800; color: var(--or);
	flex-shrink: 0; margin-top: 1px;
}

/* =============================================
   FOOTER
   ============================================= */
.site-footer {
	background-color: #050505;
	border-top: 1px solid var(--w20);
	padding: 56px 40px 28px;
}
.footer-inner { max-width: 1100px; margin: 0 auto; }
.footer-grid {
	display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 44px; padding-bottom: 38px;
	border-bottom: 1px solid var(--w20);
}
.footer-logo {
	display: block; font-family: var(--fhead);
	font-size: 1.15rem; font-weight: 800;
	color: var(--white); margin-bottom: 12px;
}
.footer-brand p { font-size: 0.82rem; color: var(--w40); line-height: 1.7; max-width: 250px; }
.footer-col h4 {
	font-family: var(--fhead); font-size: 0.84rem;
	font-weight: 700; color: var(--white); margin-bottom: 14px;
}
.footer-col li { margin-bottom: 8px; }
.footer-col a { font-size: 0.81rem; color: var(--w40); transition: color 0.2s; }
.footer-col a:hover { color: var(--or); opacity: 1; }
.footer-bottom {
	display: flex; align-items: center;
	justify-content: space-between; flex-wrap: wrap;
	gap: 10px; padding-top: 22px;
}
.footer-bottom p { font-size: 0.75rem; color: var(--w20); }
.footer-social { display: flex; gap: 18px; }
.footer-social a { font-size: 0.78rem; color: var(--w20); transition: color 0.2s; }
.footer-social a:hover { color: var(--or); opacity: 1; }
.footer-disclaimer {
	font-size: 0.68rem; color: var(--w20);
	line-height: 1.65; padding-top: 18px;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	margin-top: 18px;
}

/* =============================================
   SCROLLBAR
   ============================================= */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--w20); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--or); }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 960px) {
	.main-nav { display: none; }
	.nav-ham { display: flex; }
	.footer-grid { grid-template-columns: 1fr 1fr; }
	.woo-wrap { padding: 40px 20px; }
	.al-info-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
	.nav-inner { padding: 0 20px; }
	.footer-grid { grid-template-columns: 1fr; }
	.footer-bottom { flex-direction: column; text-align: center; }
	.footer-social { justify-content: center; }
	.page-wrap { padding: 50px 20px; }
	.site-footer { padding: 40px 20px 24px; }
	.woocommerce div.product { padding: 22px !important; }
	.woocommerce-checkout .col2-set .col-1,
	.woocommerce-checkout .col2-set .col-2 { padding: 20px 18px !important; }
}

/* =============================================
   SELECT / COUNTRY / STATE DROPDOWN FIX
   ============================================= */
.woocommerce-checkout select,
.woocommerce-checkout select.country_select,
.woocommerce-checkout select.state_select,
#billing_country, #shipping_country,
#billing_state, #shipping_state,
select#billing_country, select#shipping_country,
select#billing_state, select#shipping_state {
	background-color: #1a1a1a !important;
	background: #1a1a1a !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
	border-radius: 8px !important;
	padding: 13px 16px !important;
	width: 100% !important;
	font-family: 'DM Sans', sans-serif !important;
	font-size: 0.93rem !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	outline: none !important;
	cursor: pointer !important;
}
.woocommerce-checkout select:focus,
#billing_country:focus, #shipping_country:focus,
#billing_state:focus, #shipping_state:focus {
	background-color: #1a1a1a !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	border-color: #FF6B1A !important;
	box-shadow: 0 0 0 3px rgba(255,107,26,0.15) !important;
	outline: none !important;
}
.select2-container--default .select2-selection--single {
	background-color: #1a1a1a !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
	border-radius: 8px !important;
	height: 48px !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	line-height: 48px !important;
	padding-left: 16px !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow { height: 46px !important; }
.select2-container--default.select2-container--open .select2-selection--single { border-color: #FF6B1A !important; }
.select2-dropdown,
.select2-dropdown.select2-dropdown--below,
.select2-dropdown.select2-dropdown--above {
	background-color: #1a1a1a !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
	border-radius: 8px !important;
	color: #ffffff !important;
}
.select2-results__option {
	background-color: #1a1a1a !important;
	color: #ffffff !important;
	padding: 10px 16px !important;
	font-size: 0.88rem !important;
}
.select2-results__option--highlighted,
.select2-results__option--highlighted.select2-results__option--selectable {
	background-color: rgba(255,107,26,0.15) !important;
	color: #ffffff !important;
}
.select2-results__option[aria-selected=true] {
	background-color: rgba(255,107,26,0.10) !important;
	color: #FF6B1A !important;
}
.select2-search--dropdown .select2-search__field {
	background-color: #111111 !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
	border-radius: 6px !important;
	padding: 8px 12px !important;
	outline: none !important;
}
.select2-container--default .select2-selection--single .select2-selection__placeholder { color: rgba(255,255,255,0.35) !important; }
.select2-container--default .select2-selection--single .select2-selection__arrow b { border-color: rgba(255,255,255,0.4) transparent transparent transparent !important; }
.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b { border-color: transparent transparent #FF6B1A transparent !important; }


/* ═══════════════════════════════════════════════════════════════════
   ALLUVI SHOP PAGE CSS — Barlow Condensed · #E8610A
   ═══════════════════════════════════════════════════════════════════ */
:root {
  --ao:   #E8610A;
  --aol:  #F47B2E;
  --aod:  #E8610A22;
  --aog:  #E8610A44;
  --d:    #0E0E0E;
  --d2:   #141414;
  --d3:   #1C1C1C;
  --d4:   #242424;
  --d5:   #2E2E2E;
  --d6:   #3A3A3A;
  --of:   #F0EDE8;
  --g:    #888888;
  --gl:   #BBBBBB;
  --cond: 'Barlow Condensed', sans-serif;
}

/* GLOBAL SHOP BG */
body.woocommerce,
body.woocommerce-page,
body.post-type-archive-product,
.woocommerce-page .site,
.woocommerce-page #page {
  background-color: var(--d) !important;
  color: var(--of) !important;
}

.woocommerce-page .site-content,
.woocommerce-page #primary,
.woocommerce-page main,
.woocommerce-page .content-area {
  background-color: var(--d);
  background-image:
    linear-gradient(var(--d3) 1px, transparent 1px),
    linear-gradient(90deg, var(--d3) 1px, transparent 1px);
  background-size: 54px 54px;
  background-attachment: fixed;
}

/* SHOP TITLE */
.woocommerce-products-header,
.woocommerce-page h1.page-title {
  font-family: var(--cond) !important;
  font-size: clamp(40px, 5.5vw, 72px) !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  line-height: 0.92 !important;
  color: #fff !important;
  margin-bottom: 32px !important;
}

.woocommerce-products-header::after {
  content: '';
  display: block;
  width: 56px;
  height: 4px;
  background: var(--ao);
  margin-top: 16px;
  border-radius: 2px;
}

/* TOOLBAR */
.woocommerce-ordering,
.woocommerce-result-count {
  background: var(--d3) !important;
  border: 1px solid var(--d5) !important;
  border-radius: 4px !important;
  padding: 8px 14px !important;
  font-family: var(--cond) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--gl) !important;
}

.woocommerce-ordering select,
select.orderby {
  background: var(--d3) !important;
  border: 1.5px solid var(--d5) !important;
  border-radius: 4px !important;
  color: var(--gl) !important;
  font-family: var(--cond) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  padding: 9px 36px 9px 14px !important;
  cursor: pointer !important;
}
.woocommerce-ordering select:focus { outline: none !important; border-color: var(--ao) !important; }

/* PRODUCT GRID */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
@media (max-width: 900px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 540px) { .woocommerce ul.products { grid-template-columns: 1fr !important; } }

/* PRODUCT CARD */
.woocommerce ul.products li.product {
  background: var(--d3) !important;
  border: 1px solid var(--d5) !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  position: relative !important;
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease !important;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-7px) !important;
  border-color: var(--ao) !important;
  box-shadow: 0 20px 48px rgba(232, 97, 10, 0.18) !important;
}
.woocommerce ul.products li.product::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--ao);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
  z-index: 3;
}
.woocommerce ul.products li.product:hover::before { transform: scaleX(1); }

.woocommerce ul.products li.product a img {
  width: 100% !important;
  height: 240px !important;
  object-fit: cover !important;
  display: block !important;
  background: var(--d4) !important;
  transition: transform 0.4s ease !important;
}
.woocommerce ul.products li.product:hover a img { transform: scale(1.06) !important; }

.woocommerce ul.products li.product .woocommerce-loop-product__link {
  display: block !important;
  overflow: hidden !important;
  position: relative !important;
}
.woocommerce ul.products li.product .woocommerce-loop-product__link::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(14,14,14,0.82) 100%);
  pointer-events: none;
  z-index: 1;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--cond) !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  color: #fff !important;
  padding: 18px 18px 6px !important;
  margin: 0 !important;
  line-height: 1.2 !important;
  transition: color 0.2s !important;
}
.woocommerce ul.products li.product:hover .woocommerce-loop-product__title { color: var(--ao) !important; }

.woocommerce ul.products li.product .price {
  font-family: var(--cond) !important;
  font-size: 24px !important;
  font-weight: 900 !important;
  color: var(--ao) !important;
  padding: 4px 18px 0 !important;
  display: block !important;
}
.woocommerce ul.products li.product .price del { color: var(--g) !important; font-size: 15px !important; font-weight: 400 !important; margin-right: 6px !important; opacity: 0.7 !important; }
.woocommerce ul.products li.product .price ins { text-decoration: none !important; color: var(--ao) !important; }

/* SALE BADGE */
.woocommerce span.onsale {
  background: var(--ao) !important;
  color: #fff !important;
  font-family: var(--cond) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  padding: 5px 12px !important;
  border-radius: 3px !important;
  min-height: unset !important;
  min-width: unset !important;
  line-height: 1 !important;
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  left: unset !important;
  z-index: 2 !important;
  animation: alluviPulse 2.5s ease-in-out infinite !important;
}
@keyframes alluviPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(232,97,10,0.5); }
  50%       { box-shadow: 0 0 0 10px transparent; }
}

/* ADD TO CART BUTTON */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button {
  display: block !important;
  width: calc(100% - 36px) !important;
  margin: 14px 18px 18px !important;
  background: var(--aod) !important;
  border: 1.5px solid var(--ao) !important;
  color: var(--ao) !important;
  font-family: var(--cond) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  padding: 11px 18px !important;
  border-radius: 3px !important;
  cursor: pointer !important;
  text-align: center !important;
  box-shadow: none !important;
  transition: background 0.2s ease, color 0.2s ease !important;
  line-height: 1 !important;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.button:hover {
  background: var(--ao) !important;
  color: #fff !important;
  transform: none !important;
}

.woocommerce ul.products li.product .added_to_cart {
  display: block !important;
  text-align: center !important;
  font-family: var(--cond) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: var(--ao) !important;
  padding: 0 18px 14px !important;
}

/* PAGINATION */
.woocommerce nav.woocommerce-pagination { margin-top: 48px !important; text-align: center !important; }
.woocommerce nav.woocommerce-pagination ul {
  display: inline-flex !important;
  gap: 6px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}
.woocommerce nav.woocommerce-pagination ul li { border: none !important; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: grid !important;
  place-items: center !important;
  width: 40px !important;
  height: 40px !important;
  background: var(--d3) !important;
  border: 1px solid var(--d5) !important;
  border-radius: 4px !important;
  font-family: var(--cond) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--g) !important;
}
.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--aod) !important;
  border-color: var(--ao) !important;
  color: var(--ao) !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--ao) !important;
  border-color: var(--ao) !important;
  color: #fff !important;
}

/* STOCK STATUS */
.woocommerce-page .stock.in-stock {
  font-family: var(--cond) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: #22c55e !important;
  padding: 0 18px 14px !important;
  display: block !important;
}
.woocommerce-page .stock.out-of-stock {
  font-family: var(--cond) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: #ef4444 !important;
  padding: 0 18px 14px !important;
  display: block !important;
}

/* STAR RATINGS */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before { color: var(--ao) !important; }
.woocommerce .star-rating { margin: 4px 18px 0 !important; }

/* TRUST BAR */
.alluvi-trust-bar {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px 0 !important;
  margin-bottom: 32px !important;
  border-top: 1px solid var(--d5) !important;
  border-bottom: 1px solid var(--d5) !important;
  background: var(--d3) !important;
}
.alluvi-trust-bar span {
  font-family: var(--cond) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--g) !important;
  padding: 0 16px !important;
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
}
.alluvi-trust-bar span::before {
  content: '' !important;
  width: 7px !important;
  height: 7px !important;
  border-radius: 50% !important;
  background: var(--ao) !important;
  flex-shrink: 0 !important;
}

@media (max-width: 768px) {
  .woocommerce ul.products li.product a img { height: 200px !important; }
}


/* ═══════════════════════════════════════════════════════════════════
   FULL SITE DARK MODE FORCE — KILLS ALL WHITE-ON-WHITE
   Every page · Every plugin · Every container
   ═══════════════════════════════════════════════════════════════════ */

/* ── 1. GLOBAL BASE — everything dark ────────────────────────────── */
html, body,
#page, #content, #primary, #secondary, #main,
.site, .site-content, .site-main, .content-area,
.wrapper, .wrap, .container, .inner,
main, article, section, aside,
.entry-content, .page-content, .post-content {
	background-color: #000 !important;
	color: rgba(255,255,255,0.85) !important;
}

/* ── 2. KILL INLINE WHITE BACKGROUNDS ────────────────────────────── */
[style*="background-color: rgb(255, 255, 255)"],
[style*="background-color:#fff"],
[style*="background-color: #fff"],
[style*="background-color:#ffffff"],
[style*="background-color: #ffffff"],
[style*="background: #fff"],
[style*="background:#fff"],
[style*="background: white"],
[style*="background:white"],
[style*="background-color: white"],
[style*="background-color:white"] {
	background-color: #111 !important;
	background: #111 !important;
}

/* ── 3. ALL TEXT READABLE ────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 { color: #ffffff !important; }
p, li, td, th, dt, dd, blockquote, figcaption, address,
.entry-content p, .entry-content li {
	color: rgba(255,255,255,0.72) !important;
}
strong, b { color: #ffffff !important; }
a { color: #FF6B1A !important; }
a:hover { color: #ff7f35 !important; }

/* ── 4. ALL WOOCOMMERCE PAGES ────────────────────────────────────── */
body.woocommerce, body.woocommerce-page,
body.woocommerce-cart, body.woocommerce-checkout,
body.woocommerce-account, body.woocommerce-order-received,
body.single-product, body.archive.tax-product_cat,
.woocommerce, .woocommerce-page,
.woocommerce #content, .woocommerce-page #content {
	background-color: #000 !important;
	color: rgba(255,255,255,0.85) !important;
}

/* Cart page */
.woocommerce-cart-form,
.woocommerce-cart .cart-collaterals,
.woocommerce-cart .cart_totals,
.woocommerce-cart table.cart,
.shop_table.cart {
	background-color: #111 !important;
	color: rgba(255,255,255,0.75) !important;
}
.woocommerce-cart table.cart td,
.woocommerce-cart table.cart th {
	background-color: transparent !important;
	color: rgba(255,255,255,0.75) !important;
	border-color: rgba(255,255,255,0.08) !important;
}
.woocommerce-cart table.cart .product-name a { color: #fff !important; }

/* Coupon field */
.coupon input.input-text,
#coupon_code {
	background: #1a1a1a !important;
	color: #fff !important;
	-webkit-text-fill-color: #fff !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
}

/* My Account */
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
	background-color: #111 !important;
	border: 1px solid rgba(255,255,255,0.12) !important;
	border-radius: 10px !important;
	padding: 20px !important;
	color: rgba(255,255,255,0.75) !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation a {
	color: rgba(255,255,255,0.65) !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a {
	color: #FF6B1A !important;
}

/* Order tables everywhere */
.woocommerce table.shop_table,
.woocommerce-page table.shop_table,
table.woocommerce-table,
.woocommerce-table--order-details {
	background-color: #111 !important;
	border: 1px solid rgba(255,255,255,0.12) !important;
	color: rgba(255,255,255,0.75) !important;
}
.woocommerce table.shop_table th,
table.woocommerce-table th {
	background-color: rgba(255,255,255,0.04) !important;
	color: #FF6B1A !important;
	border-color: rgba(255,255,255,0.08) !important;
}
.woocommerce table.shop_table td,
table.woocommerce-table td {
	background-color: transparent !important;
	color: rgba(255,255,255,0.72) !important;
	border-color: rgba(255,255,255,0.06) !important;
}

/* ── 5. FUNNEL / STEP CHECKOUT PLUGINS (FunnelKit, CartFlows) ───── */
.wfacp_main_form, .wfacp-form, #wfacp-e-form,
.wfacp_main_wrapper, .wfacp-section, .wfacp_section_wrap,
.wfacp-form-control-wrapper,
.wcf-embed-checkout-form, .wcf-checkout-form,
.wcf-embed-checkout-form .woocommerce,
.cartflows-container, .wcf-thankyou-wrap,
.elementor-widget-woocommerce-checkout-page,
.elementor-section, .elementor-container, .elementor-widget-wrap {
	background-color: #000 !important;
	background: #000 !important;
}

.wfacp_main_form *, .wcf-embed-checkout-form *,
.wfacp_main_form p, .wfacp_main_form span, .wfacp_main_form label,
.wfacp_main_form h1, .wfacp_main_form h2, .wfacp_main_form h3,
.wcf-embed-checkout-form p, .wcf-embed-checkout-form span, .wcf-embed-checkout-form label {
	color: rgba(255,255,255,0.85) !important;
	-webkit-text-fill-color: rgba(255,255,255,0.85) !important;
}

/* Steps progress bar */
.wfacp-progress-bar, .wfacp_progress_bar,
.wcf-progress-bar, .step-nav, .checkout-steps {
	background-color: #111 !important;
}

/* Order summary box in funnels */
.wfacp_mini_cart_sec, .wfacp-order-summary,
.wcf-order-summary, .order-summary,
#wfacp_order_summary {
	background-color: #111 !important;
	border: 1px solid rgba(255,107,26,0.25) !important;
	border-radius: 10px !important;
}

/* ── 6. ALL FORMS / INPUTS SITE-WIDE ─────────────────────────────── */
input[type="text"], input[type="email"], input[type="tel"],
input[type="number"], input[type="password"], input[type="search"],
input[type="url"], input[type="date"],
select, textarea,
.input-text, .wfacp-form-control,
.wcf-embed-checkout-form input,
.wcf-embed-checkout-form select,
.wcf-embed-checkout-form textarea {
	background-color: #1a1a1a !important;
	background: #1a1a1a !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
	border-radius: 8px !important;
}
input:focus, select:focus, textarea:focus {
	border-color: #FF6B1A !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(255,107,26,0.15) !important;
}
input::placeholder, textarea::placeholder {
	color: rgba(255,255,255,0.35) !important;
	-webkit-text-fill-color: rgba(255,255,255,0.35) !important;
}
label, .form-row label, .wfacp-form-control-label {
	color: rgba(255,255,255,0.65) !important;
	-webkit-text-fill-color: rgba(255,255,255,0.65) !important;
}

/* Autofill fix — Chrome yellow/white autofill */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
	-webkit-box-shadow: 0 0 0 1000px #1a1a1a inset !important;
	-webkit-text-fill-color: #ffffff !important;
	caret-color: #ffffff !important;
}

/* ── 7. ALL BUTTONS — orange + white text ────────────────────────── */
button, input[type="submit"], input[type="button"],
.button, .btn, a.button,
.wfacp_next_btn_wrap button, .wfacp-next-btn,
.wcf-embed-checkout-form button,
#place_order {
	background-color: #FF6B1A !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	border: none !important;
}
button:hover, .button:hover, #place_order:hover {
	background-color: #ff7f35 !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
}

/* ── 8. MODALS / POPUPS / OVERLAYS ───────────────────────────────── */
.modal, .popup, .lightbox, .mfp-content,
.pum-container, .elementor-popup-modal .dialog-widget-content,
.dialog-message, .dialog-lightbox-message {
	background-color: #111 !important;
	color: rgba(255,255,255,0.85) !important;
	border: 1px solid rgba(255,255,255,0.15) !important;
}

/* ── 9. WIDGETS / SIDEBARS ───────────────────────────────────────── */
.widget, .widget-area .widget, aside .widget {
	background-color: #111 !important;
	color: rgba(255,255,255,0.7) !important;
}
.widget-title, .widgettitle { color: #fff !important; }
.widget a { color: rgba(255,255,255,0.6) !important; }
.widget a:hover { color: #FF6B1A !important; }

/* ── 10. BLOG / POSTS ────────────────────────────────────────────── */
article.post, .post-item, .blog-post,
.hentry, .type-post {
	background-color: #111 !important;
	border: 1px solid rgba(255,255,255,0.1) !important;
	border-radius: 10px !important;
}
.entry-title, .entry-title a { color: #fff !important; }
.entry-meta, .post-date, .posted-on { color: rgba(255,255,255,0.4) !important; }

/* Comments */
.comments-area, .comment-list, .comment-body,
.comment-respond, #respond {
	background-color: #111 !important;
	color: rgba(255,255,255,0.7) !important;
}

/* ── 11. SEARCH ──────────────────────────────────────────────────── */
.search-form input[type="search"] {
	background: #1a1a1a !important;
	color: #fff !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
}

/* ── 12. WOOCOMMERCE EXTRA BITS ──────────────────────────────────── */
/* Quantity */
.quantity .qty {
	background: #1a1a1a !important;
	color: #fff !important;
	-webkit-text-fill-color: #fff !important;
	border: 1px solid rgba(255,255,255,0.18) !important;
}
/* Variations dropdown */
table.variations select {
	background: #1a1a1a !important;
	color: #fff !important;
}
/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: #111 !important;
	border-color: rgba(255,255,255,0.12) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color: rgba(255,255,255,0.6) !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { background: #1a1a1a !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: #FF6B1A !important; }
.woocommerce div.product .woocommerce-tabs .panel {
	background: #111 !important;
	color: rgba(255,255,255,0.72) !important;
}
/* Reviews */
.woocommerce #reviews #comments ol.commentlist li {
	background: #111 !important;
	border: 1px solid rgba(255,255,255,0.1) !important;
}
.woocommerce #reviews #comments ol.commentlist li .comment-text {
	border-color: rgba(255,255,255,0.1) !important;
	color: rgba(255,255,255,0.7) !important;
}

/* Payment box on checkout */
.woocommerce-checkout #payment,
.woocommerce-checkout #payment div.payment_box,
.wc_payment_method label {
	background-color: #111 !important;
	color: rgba(255,255,255,0.8) !important;
}
.woocommerce-checkout #payment div.payment_box::before {
	border-bottom-color: #1a1a1a !important;
}

/* ── 13. TABLES GENERIC ──────────────────────────────────────────── */
table, thead, tbody, tfoot, tr {
	background-color: transparent !important;
}
table th { color: #FF6B1A !important; }
table td { color: rgba(255,255,255,0.72) !important; }

/* ── 14. HR / DIVIDERS ───────────────────────────────────────────── */
hr { border-color: rgba(255,255,255,0.1) !important; background: rgba(255,255,255,0.1) !important; }

/* ── 15. FOOTER STAYS DARK ───────────────────────────────────────── */
.site-footer, footer, #footer, #colophon {
	background-color: #050505 !important;
	color: rgba(255,255,255,0.5) !important;
}

/* ── 16. SELECT2 (country dropdowns) ─────────────────────────────── */
.select2-container--default .select2-selection--single,
.select2-dropdown {
	background-color: #1a1a1a !important;
	border-color: rgba(255,255,255,0.18) !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
	color: #fff !important;
	-webkit-text-fill-color: #fff !important;
}
.select2-results__option {
	background-color: #1a1a1a !important;
	color: rgba(255,255,255,0.75) !important;
}
.select2-results__option--highlighted {
	background-color: rgba(255,107,26,0.18) !important;
	color: #fff !important;
}

/* ── 17. STRIPE / PAYMENT IFRAME WRAPPERS ───────────────────────── */
.wc-stripe-elements-field, .wc_payment_methods li {
	background: #111 !important;
	border-color: rgba(255,255,255,0.12) !important;
}

/* ── 18. LAST RESORT — common white classes ──────────────────────── */
.white-bg, .bg-white, .has-white-background-color,
.light-bg, .bg-light, .section-white {
	background-color: #111 !important;
}
.has-black-color, .text-black, .text-dark {
	color: rgba(255,255,255,0.85) !important;
}
