/* =========================================================
   Awakening Alchemy — Custom Affirmations Landing Page
   Two themes: default is dark+gold. Add class "aa-theme-light"
   to .aa-landing (or use [aa_affirmation_landing theme="light"])
   for the warm-ivory + copper preset.
   ========================================================= */

/* --------- THEME: DARK + GOLD (default) --------- */
.aa-landing {
	--aa-bg:            #0C0B09;
	--aa-bg-alt:        #141210;
	--aa-accent:        #C4A265;
	--aa-accent-2:      #d9bd82;
	--aa-text:          #EAE6DC;
	--aa-muted:         #A09A8C;
	--aa-border:        rgba(196, 162, 101, 0.22);

	--aa-accent-soft:   rgba(196, 162, 101, 0.06);
	--aa-accent-soft-2: rgba(196, 162, 101, 0.02);
	--aa-accent-glow:   rgba(196, 162, 101, 0.12);
	--aa-accent-hover:  rgba(196, 162, 101, 0.08);
	--aa-accent-hover2: rgba(196, 162, 101, 0.07);
	--aa-accent-topic:  rgba(196, 162, 101, 0.05);
	--aa-accent-topic-h:rgba(196, 162, 101, 0.12);
	--aa-accent-faq:    rgba(196, 162, 101, 0.03);

	--aa-btn-shadow:    rgba(196, 162, 101, 0.20);
	--aa-btn-shadow-h:  rgba(196, 162, 101, 0.30);
	--aa-on-accent:     #1a1710;

	--aa-input-bg:      #0C0B09;
	--aa-input-bg-foc:  #141210;
	--aa-input-focus:   rgba(196, 162, 101, 0.15);
	--aa-option-bg:     #141210;

	--aa-shadow:        0 20px 60px rgba(0, 0, 0, 0.45);

	background: var(--aa-bg);
	color: var(--aa-text);
	font-family: 'Noto Sans Arabic', Tahoma, Arial, sans-serif;
	direction: rtl;
	text-align: right;
	line-height: 1.8;
	font-size: 17px;
	margin: 0;
	padding: 0;
}

/* --------- THEME: WARM IVORY + COPPER (light) --------- */
.aa-landing.aa-theme-light {
	--aa-bg:            #FAF6EE;
	--aa-bg-alt:        #F0E9DA;
	--aa-accent:        #B8754A;
	--aa-accent-2:      #D4956A;
	--aa-text:          #2A241C;
	--aa-muted:         #7A6E5E;
	--aa-border:        rgba(184, 117, 74, 0.28);

	--aa-accent-soft:   rgba(184, 117, 74, 0.07);
	--aa-accent-soft-2: rgba(184, 117, 74, 0.03);
	--aa-accent-glow:   rgba(184, 117, 74, 0.14);
	--aa-accent-hover:  rgba(184, 117, 74, 0.10);
	--aa-accent-hover2: rgba(184, 117, 74, 0.09);
	--aa-accent-topic:  rgba(184, 117, 74, 0.06);
	--aa-accent-topic-h:rgba(184, 117, 74, 0.14);
	--aa-accent-faq:    rgba(184, 117, 74, 0.04);

	--aa-btn-shadow:    rgba(184, 117, 74, 0.18);
	--aa-btn-shadow-h:  rgba(184, 117, 74, 0.28);
	--aa-on-accent:     #FAF6EE;

	--aa-input-bg:      #FFFFFF;
	--aa-input-bg-foc:  #FFFFFF;
	--aa-input-focus:   rgba(184, 117, 74, 0.18);
	--aa-option-bg:     #FAF6EE;

	--aa-shadow:        0 20px 60px rgba(60, 40, 20, 0.12);
}

/* Theme-aware body background on the shop page */
body.aa-landing-page.aa-landing-dark {
	background: #0C0B09;
}
body.aa-landing-page.aa-landing-light {
	background: #FAF6EE;
}

/* Let the landing page take over full width, even inside theme wrappers */
body.aa-landing-page .site-content,
body.aa-landing-page .content-area,
body.aa-landing-page .entry-content,
body.aa-landing-page main,
body.aa-landing-page #main,
body.aa-landing-page #primary,
body.aa-landing-page #content,
body.aa-landing-page .site-main,
body.aa-landing-page .wp-site-blocks,
body.aa-landing-page .container,
body.aa-landing-page .site-inner,
body.aa-landing-page .content-wrap,
body.aa-landing-page .page-content,
body.aa-landing-page article.page,
body.aa-landing-page article.post {
	max-width: none !important;
	width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
	background: transparent !important;
}

/* Hide the theme's page title / page header — every variant we've seen */
body.aa-landing-page .entry-header,
body.aa-landing-page .page-header,
body.aa-landing-page .post-title,
body.aa-landing-page .entry-title,
body.aa-landing-page .page-title,
body.aa-landing-page h1.entry-title,
body.aa-landing-page h1.page-title,
body.aa-landing-page .wp-block-post-title,
body.aa-landing-page header.entry-header,
body.aa-landing-page header.page-header,
body.aa-landing-page article > header,
body.aa-landing-page article.page > header,
body.aa-landing-page .page > header,
body.aa-landing-page .site-main > header,
body.aa-landing-page .page-hero,
body.aa-landing-page .page-banner,
body.aa-landing-page .page-banner-area,
body.aa-landing-page .hero-wrap,
body.aa-landing-page .title-wrap,
body.aa-landing-page .title-bar,
body.aa-landing-page .breadcrumb,
body.aa-landing-page .breadcrumbs,
body.aa-landing-page .woocommerce-breadcrumb,
body.aa-landing-page .breadcrumb-area,
body.aa-landing-page .banner-title,
body.aa-landing-page .page-header-inner,
body.aa-landing-page .post-header,
body.aa-landing-page .header-image,
body.aa-landing-page .wp-block-template-part[data-type="page-header"] {
	display: none !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
}

.aa-landing *,
.aa-landing *::before,
.aa-landing *::after {
	box-sizing: border-box;
}

.aa-landing h1,
.aa-landing h2,
.aa-landing h3 {
	font-family: 'Noto Naskh Arabic', 'Noto Sans Arabic', Tahoma, serif;
	color: var(--aa-text);
	font-weight: 700;
	line-height: 1.4;
	margin: 0 0 18px;
}

.aa-landing p {
	color: var(--aa-text);
	margin: 0 0 14px;
}

.aa-container {
	max-width: 1080px;
	margin: 0 auto;
	padding: 0 24px;
}
.aa-container-narrow {
	max-width: 760px;
}

.aa-glyph {
	color: var(--aa-accent);
	font-size: 30px;
	letter-spacing: 4px;
	margin-bottom: 14px;
	opacity: .85;
}

/* -------------------- HERO -------------------- */
.aa-hero {
	padding: 110px 0 90px;
	text-align: center;
	background:
		radial-gradient(ellipse at top, var(--aa-accent-glow), transparent 60%),
		linear-gradient(180deg, var(--aa-bg) 0%, var(--aa-bg-alt) 100%);
	border-bottom: 1px solid var(--aa-border);
}
.aa-hero-title {
	font-size: clamp(32px, 5vw, 54px);
	margin-bottom: 20px;
	color: var(--aa-text);
}
.aa-hero-sub {
	font-size: clamp(16px, 2vw, 20px);
	color: var(--aa-muted);
	max-width: 680px;
	margin: 0 auto 36px;
}

.aa-price-block {
	display: inline-flex;
	align-items: baseline;
	gap: 16px;
	margin: 14px 0 28px;
}
.aa-price-old {
	color: var(--aa-muted);
	text-decoration: line-through;
	font-size: 22px;
}
.aa-price-new {
	color: var(--aa-accent);
	font-size: 46px;
	font-weight: 700;
	font-family: 'Noto Naskh Arabic', Tahoma, serif;
}

/* -------------------- BUTTONS -------------------- */
.aa-btn {
	display: inline-block;
	padding: 16px 44px;
	border-radius: 999px;
	font-family: 'Noto Sans Arabic', Tahoma, sans-serif;
	font-size: 17px;
	font-weight: 700;
	text-decoration: none;
	transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
	border: none;
	cursor: pointer;
}
.aa-btn-primary {
	background: linear-gradient(135deg, var(--aa-accent) 0%, var(--aa-accent-2) 100%);
	color: var(--aa-on-accent);
	box-shadow: 0 10px 30px var(--aa-btn-shadow);
}
.aa-btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 40px var(--aa-btn-shadow-h);
	color: var(--aa-on-accent);
}

/* -------------------- SECTIONS -------------------- */
.aa-section {
	padding: 90px 0;
	background: var(--aa-bg);
}
.aa-section-alt {
	background: var(--aa-bg-alt);
	border-top: 1px solid var(--aa-border);
	border-bottom: 1px solid var(--aa-border);
}
.aa-section-title {
	font-size: clamp(26px, 3.2vw, 38px);
	text-align: center;
	margin-bottom: 16px;
}
.aa-section-title::after {
	content: "";
	display: block;
	width: 60px;
	height: 2px;
	background: var(--aa-accent);
	margin: 18px auto 0;
	opacity: .7;
}
.aa-section-sub {
	text-align: center;
	color: var(--aa-muted);
	margin: 0 auto 48px;
	max-width: 620px;
}

/* -------------------- CARDS -------------------- */
.aa-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 26px;
	margin-top: 40px;
}
.aa-card {
	background: linear-gradient(180deg, var(--aa-accent-soft), var(--aa-accent-soft-2));
	border: 1px solid var(--aa-border);
	border-radius: 14px;
	padding: 38px 28px;
	text-align: center;
	transition: transform .25s ease, border-color .25s ease;
}
.aa-card:hover {
	transform: translateY(-4px);
	border-color: var(--aa-accent);
}
.aa-card-icon {
	color: var(--aa-accent);
	font-size: 32px;
	margin-bottom: 14px;
}
.aa-card h3 {
	font-size: 22px;
	margin-bottom: 12px;
	color: var(--aa-text);
}
.aa-card p {
	color: var(--aa-muted);
	margin: 0;
}

/* -------------------- TOPICS -------------------- */
.aa-topics {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 14px;
	margin-top: 30px;
}
.aa-topic {
	background: var(--aa-accent-topic);
	border: 1px solid var(--aa-border);
	color: var(--aa-text);
	padding: 18px 20px;
	border-radius: 10px;
	text-align: center;
	font-size: 16px;
	transition: all .25s ease;
	cursor: default;
}
.aa-topic:hover {
	background: var(--aa-accent-topic-h);
	border-color: var(--aa-accent);
	color: var(--aa-accent);
}

/* -------------------- STEPS -------------------- */
.aa-steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	margin-top: 40px;
}
.aa-step {
	text-align: center;
	padding: 30px 20px;
}
.aa-step-num {
	width: 60px;
	height: 60px;
	margin: 0 auto 18px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--aa-accent) 0%, var(--aa-accent-2) 100%);
	color: var(--aa-on-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
	font-weight: 700;
	font-family: 'Noto Naskh Arabic', serif;
}
.aa-step h3 {
	font-size: 20px;
	margin-bottom: 10px;
}
.aa-step p {
	color: var(--aa-muted);
	margin: 0;
}

/* -------------------- PRODUCT WRAPPER (embedded WC product) -------------------- */
.aa-product-wrapper {
	background: linear-gradient(180deg, var(--aa-accent-soft), var(--aa-accent-soft-2)),
	            var(--aa-bg-alt);
	border: 1px solid var(--aa-border);
	border-radius: 16px;
	padding: 40px 34px;
	margin-top: 30px;
	box-shadow: var(--aa-shadow);
	color: var(--aa-text);
}

/* Kill any white "card" the theme wraps around the WC product */
.aa-product-wrapper,
.aa-product-wrapper .woocommerce,
.aa-product-wrapper .product,
.aa-product-wrapper .type-product,
.aa-product-wrapper .single-product,
.aa-product-wrapper .summary,
.aa-product-wrapper .entry-summary,
.aa-product-wrapper .entry-content,
.aa-product-wrapper .product-inner,
.aa-product-wrapper .product-wrap,
.aa-product-wrapper form.cart,
.aa-product-wrapper > div,
.aa-product-wrapper > div > div {
	background-color: transparent !important;
	background-image: none !important;
	box-shadow: none !important;
	color: var(--aa-text) !important;
}
/* Restore the ONE gradient we want (the outer wrapper only) */
.aa-product-wrapper {
	background: linear-gradient(180deg, var(--aa-accent-soft), var(--aa-accent-soft-2)),
	            var(--aa-bg-alt) !important;
}

/* All text inside inherits our theme unless explicitly set below */
.aa-product-wrapper,
.aa-product-wrapper p,
.aa-product-wrapper span,
.aa-product-wrapper label,
.aa-product-wrapper h1,
.aa-product-wrapper h2,
.aa-product-wrapper h3 {
	color: var(--aa-text) !important;
}

/* Tame WC's default product page markup inside our wrapper */
.aa-product-wrapper .product .images,
.aa-product-wrapper .woocommerce-product-gallery,
.aa-product-wrapper .product_meta,
.aa-product-wrapper .woocommerce-tabs,
.aa-product-wrapper .related,
.aa-product-wrapper .upsells,
.aa-product-wrapper .woocommerce-breadcrumb,
.aa-product-wrapper .woocommerce-product-rating,
.aa-product-wrapper .onsale,
.aa-product-wrapper .afterpay-paragraph,
.aa-product-wrapper .klarna-placement,
.aa-product-wrapper [class*="afterpay"],
.aa-product-wrapper [class*="klarna"] {
	display: none !important;
}
.aa-product-wrapper .product {
	display: block !important;
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
.aa-product-wrapper .summary {
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
.aa-product-wrapper .product_title,
.aa-product-wrapper .wc-stripe-paylater-messaging,
.aa-product-wrapper .stripe-payment-message,
.aa-product-wrapper [id*="afterpay"],
.aa-product-wrapper [id*="klarna"],
.aa-product-wrapper .woocommerce-breadcrumb {
	display: none !important;
}
.aa-product-wrapper .price {
	text-align: center;
	margin-bottom: 20px;
	font-size: 28px;
	color: var(--aa-accent) !important;
}
.aa-product-wrapper .price del {
	color: var(--aa-muted) !important;
	font-size: 18px;
	margin-left: 10px;
}
.aa-product-wrapper .price ins,
.aa-product-wrapper .price bdi {
	color: var(--aa-accent) !important;
	text-decoration: none;
	background: transparent;
}
.aa-product-wrapper .woocommerce-product-details__short-description,
.aa-product-wrapper .woocommerce-product-details__short-description * {
	color: var(--aa-muted) !important;
	background: transparent !important;
}
.aa-product-wrapper .woocommerce-product-details__short-description {
	border-right: 3px solid var(--aa-accent);
	padding-right: 16px;
	margin-bottom: 26px;
	text-align: right;
	text-wrap: pretty;
	max-width: 52ch;
	margin-left: auto;
	margin-right: 0;
}
.aa-product-wrapper .stock {
	color: var(--aa-accent) !important;
}

/* ----- Custom form fields inside the product form ----- */
.aa-aff-fields {
	margin: 24px 0 18px;
	display: grid;
	gap: 18px;
}
.aa-aff-field {
	display: flex;
	flex-direction: column;
}
.aa-aff-field label {
	color: var(--aa-text) !important;
	font-weight: 500;
	margin-bottom: 8px;
	font-size: 15px;
	background: transparent !important;
}
.aa-aff-field .aa-aff-hint {
	color: var(--aa-muted);
	font-size: 13px;
	margin-right: 4px;
	font-weight: 400;
}
.aa-aff-field .aa-aff-req {
	color: var(--aa-accent);
	margin-right: 2px;
}
.aa-aff-field input[type="text"],
.aa-aff-field select {
	background: var(--aa-input-bg) !important;
	border: 1px solid var(--aa-border) !important;
	color: var(--aa-text) !important;
	padding: 0 16px !important;
	border-radius: 10px !important;
	font-family: 'Noto Sans Arabic', Tahoma, sans-serif !important;
	font-size: 16px !important;
	width: 100% !important;
	height: 54px !important;
	min-height: 54px !important;
	max-height: 54px !important;
	line-height: 52px !important;
	box-sizing: border-box !important;
	transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
	direction: rtl;
	text-align: right;
	appearance: none !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	box-shadow: none !important;
	margin: 0 !important;
}
.aa-aff-field input[type="text"]:focus,
.aa-aff-field select:focus {
	outline: none !important;
	border-color: var(--aa-accent) !important;
	background: var(--aa-input-bg-foc) !important;
	box-shadow: 0 0 0 3px var(--aa-input-focus) !important;
}
.aa-aff-field input::placeholder {
	color: var(--aa-muted);
	opacity: .7;
}
.aa-aff-field select {
	background-image:
		linear-gradient(45deg, transparent 50%, var(--aa-accent) 50%),
		linear-gradient(135deg, var(--aa-accent) 50%, transparent 50%) !important;
	background-position: calc(100% - 18px) 24px, calc(100% - 12px) 24px !important;
	background-size: 6px 6px, 6px 6px !important;
	background-repeat: no-repeat !important;
	padding-left: 34px !important;
	cursor: pointer;
}
.aa-aff-field select option {
	background: var(--aa-option-bg);
	color: var(--aa-text);
	padding: 8px;
}

/* ----- If Select2 (or similar) slips past our JS destroy, match our look ----- */
.aa-aff-field .select2-container,
.aa-aff-field .select2-container--default,
.aa-aff-field .select2-container .select2-selection,
.aa-aff-field .select2-container--default .select2-selection--single {
	width: 100% !important;
	height: 54px !important;
	min-height: 54px !important;
	max-height: 54px !important;
	border: 1px solid var(--aa-border) !important;
	border-radius: 10px !important;
	background: var(--aa-input-bg) !important;
	box-shadow: none !important;
	outline: none !important;
}
.aa-aff-field .select2-container--default .select2-selection--single .select2-selection__rendered {
	color: var(--aa-text) !important;
	line-height: 52px !important;
	padding: 0 16px !important;
	text-align: right !important;
	direction: rtl !important;
}
.aa-aff-field .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 52px !important;
	width: 34px !important;
	left: 0 !important;
	right: auto !important;
	top: 0 !important;
}
.aa-aff-field .select2-container--default .select2-selection--single .select2-selection__arrow b {
	border-color: var(--aa-accent) transparent transparent transparent !important;
}

/* ----- WC add-to-cart button restyled ----- */
.aa-product-wrapper form.cart {
	display: block !important;
	margin: 0 !important;
}
.aa-product-wrapper .quantity {
	display: none !important;
}
.aa-product-wrapper .single_add_to_cart_button {
	background: linear-gradient(135deg, var(--aa-accent) 0%, var(--aa-accent-2) 100%) !important;
	color: var(--aa-on-accent) !important;
	border: none !important;
	border-radius: 999px !important;
	padding: 0 32px !important;
	font-family: 'Noto Sans Arabic', Tahoma, sans-serif !important;
	font-size: 17px !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	width: 100% !important;
	height: 58px !important;
	min-height: 58px !important;
	margin: 22px 0 0 0 !important;
	cursor: pointer;
	transition: transform .2s ease, box-shadow .2s ease;
	box-shadow: 0 6px 18px var(--aa-btn-shadow) !important;
	text-shadow: none !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	text-align: center !important;
	letter-spacing: 0 !important;
	float: none !important;
}
.aa-product-wrapper .single_add_to_cart_button:hover {
	transform: translateY(-1px);
	box-shadow: 0 8px 24px var(--aa-btn-shadow-h) !important;
}

/* Hide rogue elements some themes/plugins inject around the add-to-cart area */
.aa-product-wrapper .added_to_cart,
.aa-product-wrapper .wc-forward,
.aa-product-wrapper .tinv-wishlist,
.aa-product-wrapper .yith-wcwl-add-to-wishlist,
.aa-product-wrapper .compare,
.aa-product-wrapper .button.compare,
.aa-product-wrapper .product-badge,
.aa-product-wrapper .stock.in-stock,
.aa-product-wrapper .social-share,
.aa-product-wrapper .ti-sticker,
.aa-product-wrapper .product-share,
.aa-product-wrapper .product-stock-status,
/* Express checkout / quick buy / one-click plugins */
.aa-product-wrapper .buy-now-button,
.aa-product-wrapper .buy_now_button,
.aa-product-wrapper .wc-direct-checkout,
.aa-product-wrapper .direct-checkout,
.aa-product-wrapper .quick-buy,
.aa-product-wrapper .quick-view,
.aa-product-wrapper .aft-button,
.aa-product-wrapper .one-click-checkout,
.aa-product-wrapper .express-checkout,
.aa-product-wrapper .wc-express-checkout,
.aa-product-wrapper .wcboost-quick-checkout,
.aa-product-wrapper .yith-wcqv-button,
.aa-product-wrapper .wapf-buy-now,
.aa-product-wrapper [class*="buy-now"],
.aa-product-wrapper [class*="buynow"],
.aa-product-wrapper [class*="quick-buy"],
.aa-product-wrapper [class*="express-checkout"],
.aa-product-wrapper [class*="direct-checkout"],
.aa-product-wrapper [id*="buy-now"],
.aa-product-wrapper [id*="express"],
/* Payment request / Apple-Pay / Google-Pay badges */
.aa-product-wrapper .wc-stripe-payment-request-wrapper,
.aa-product-wrapper .apple-pay-button,
.aa-product-wrapper .gpay-button,
.aa-product-wrapper [class*="apple-pay"],
.aa-product-wrapper [class*="google-pay"],
.aa-product-wrapper [class*="payment-request"],
/* WooPay Express Button (the green square) */
.aa-product-wrapper .wcpay-express-checkout-wrapper,
.aa-product-wrapper #wcpay-woopay-button,
.aa-product-wrapper .woopay-express-button,
.aa-product-wrapper #wcpay-express-checkout-element,
/* Stripe BNPL / Afterpay / Klarna messaging */
.aa-product-wrapper #payment-method-message,
.aa-product-wrapper .StripeElement,
.aa-product-wrapper .wc-stripe-payment-request-button,
/* PayPal reCAPTCHA container and PayPal buttons on product page */
.aa-product-wrapper #ppcp-recaptcha-v2-container,
.aa-product-wrapper #ppc-button,
.aa-product-wrapper .ppcp-messages,
.aa-product-wrapper [id*="ppcp"],
.aa-product-wrapper [class*="ppcp"],
/* Product meta (SKU / category / tags below the button) */
.aa-product-wrapper .product_meta {
	display: none !important;
}
/* Catch colored squares that float near the button (notices, badges) */
.aa-product-wrapper form.cart > *:not(.aa-aff-fields):not(.quantity):not(button):not(.single_add_to_cart_button):not(input):not(br) {
	display: none !important;
}

/* WooCommerce notices inside the wrapper */
.aa-product-wrapper .woocommerce-message,
.aa-product-wrapper .woocommerce-info,
.aa-product-wrapper .woocommerce-error {
	background: var(--aa-accent-hover) !important;
	color: var(--aa-text) !important;
	border-right: 4px solid var(--aa-accent) !important;
	border-left: none !important;
	border-radius: 8px;
	padding: 14px 18px;
	margin-bottom: 18px;
}
.aa-product-wrapper .woocommerce-message a,
.aa-product-wrapper .woocommerce-error a {
	color: var(--aa-accent) !important;
}

/* -------------------- FAQ -------------------- */
.aa-faq {
	margin-top: 20px;
}
.aa-faq-item {
	border: 1px solid var(--aa-border);
	border-radius: 10px;
	margin-bottom: 12px;
	background: var(--aa-accent-faq);
	transition: border-color .2s ease;
	overflow: hidden;
}
.aa-faq-item[open] {
	border-color: var(--aa-accent);
	background: var(--aa-accent-hover2);
}
.aa-faq-item summary {
	padding: 18px 22px;
	font-weight: 700;
	cursor: pointer;
	color: var(--aa-text);
	list-style: none;
	position: relative;
	padding-left: 48px;
}
.aa-faq-item summary::-webkit-details-marker { display: none; }
.aa-faq-item summary::after {
	content: "+";
	position: absolute;
	left: 20px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--aa-accent);
	font-size: 24px;
	font-weight: 400;
	transition: transform .2s ease;
}
.aa-faq-item[open] summary::after {
	content: "–";
}
.aa-faq-item p {
	padding: 0 22px 20px;
	color: var(--aa-muted);
	margin: 0;
}

/* -------------------- FOOTER CTA -------------------- */
.aa-footer-cta {
	padding: 90px 0;
	text-align: center;
	background:
		radial-gradient(ellipse at bottom, var(--aa-accent-glow), transparent 60%),
		linear-gradient(180deg, var(--aa-bg-alt) 0%, var(--aa-bg) 100%);
	border-top: 1px solid var(--aa-border);
}
.aa-footer-cta .aa-price-block {
	margin-bottom: 28px;
}
.aa-tagline {
	color: var(--aa-muted);
	margin-top: 28px;
	font-size: 15px;
	letter-spacing: 1px;
}

/* -------------------- RESPONSIVE -------------------- */
@media (max-width: 860px) {
	.aa-cards,
	.aa-steps {
		grid-template-columns: 1fr;
		gap: 18px;
	}
	.aa-hero { padding: 70px 0 60px; }
	.aa-section { padding: 60px 0; }
	.aa-footer-cta { padding: 60px 0; }
	.aa-product-wrapper { padding: 28px 20px; }
	.aa-topics { grid-template-columns: repeat(2, 1fr); }
	.aa-price-new { font-size: 38px; }
}
@media (max-width: 480px) {
	.aa-landing { font-size: 16px; }
	.aa-topics { grid-template-columns: 1fr; }
	.aa-btn { padding: 14px 32px; width: 100%; max-width: 320px; }
}

/* -------------------- THEME CHROME SUPPRESSION (fallback) --------------------
   The blank-canvas page template should prevent these from rendering, but if
   the shop page is ever served via a theme that injects a product-archive hero
   (e.g. Kadence) above the_content, kill it defensively on our landing class. */
body.aa-landing-page .entry-hero,
body.aa-landing-page .product-archive-hero-section,
body.aa-landing-page .entry-hero-container-inner,
body.aa-landing-page .entry-hero-layout-standard,
body.aa-landing-page .hero-section-overlay,
body.aa-landing-page .hero-container,
body.aa-landing-page .entry-header.product-archive-title,
body.aa-landing-page .page-title.archive-title,
body.aa-landing-page .woocommerce-products-header,
body.aa-landing-page .woocommerce-breadcrumb,
body.aa-landing-page .page-title-wrap,
body.aa-landing-page .entry-header {
	display: none !important;
}

/* Blank-canvas body: drop default margin/padding and theme site frames. */
body.aa-aff-blank-canvas {
	margin: 0 !important;
	padding: 0 !important;
	background: var(--aa-bg) !important;
}
body.aa-aff-blank-canvas #wrapper,
body.aa-aff-blank-canvas .site,
body.aa-aff-blank-canvas .site-container,
body.aa-aff-blank-canvas .content-area,
body.aa-aff-blank-canvas .site-content {
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
}

/* -------------------- NUCLEAR: kill any white card inside the product wrapper --------------------
   Covers any wrapper the theme/WC/other plugins inject that we didn't explicitly name. */
.aa-product-wrapper *:not(input):not(textarea):not(select):not(button):not(.aa-aff-select):not(.select2-selection):not(.select2-selection__rendered):not(.single_add_to_cart_button):not(.aa-btn):not(.aa-btn-primary) {
	background-color: transparent !important;
	background-image: none !important;
	box-shadow: none !important;
}

/* Green WooPay / WC Payments express-checkout square — every known marker */
.woopay-express-button,
.wcpay-express-checkout-wrapper,
.wcpay-express-checkout-button-separator,
#wcpay-express-checkout-element,
#wcpay-woopay-button,
[data-testid="woopay-express-button"],
[aria-label*="WooPay"],
[class*="woopay"],
[id*="woopay"],
[class*="wcpay-express"],
[id*="wcpay-express"],
.wc-block-components-express-payment,
.wc-block-components-express-payment__event-buttons,
.wc-block-components-express-payment-continue-rule {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	width: 0 !important;
	overflow: hidden !important;
	position: absolute !important;
	left: -9999px !important;
}

/* -------------------- INPUT TYPED-TEXT COLOR (hardened) --------------------
   Themes/browsers sometimes force input text to #000, making it invisible on
   our dark fields. Force the theme text color on typed input & -webkit-autofill. */
.aa-landing input[type="text"],
.aa-landing input[type="email"],
.aa-landing input[type="tel"],
.aa-landing input[type="number"],
.aa-landing textarea,
.aa-landing select,
.aa-product-wrapper input[type="text"],
.aa-product-wrapper input[type="email"],
.aa-product-wrapper input[type="tel"],
.aa-product-wrapper textarea,
.aa-product-wrapper select {
	color: var(--aa-text) !important;
	-webkit-text-fill-color: var(--aa-text) !important;
	caret-color: var(--aa-accent) !important;
}
.aa-landing input:-webkit-autofill,
.aa-landing input:-webkit-autofill:hover,
.aa-landing input:-webkit-autofill:focus,
.aa-landing textarea:-webkit-autofill {
	-webkit-text-fill-color: var(--aa-text) !important;
	-webkit-box-shadow: 0 0 0 1000px var(--aa-input-bg) inset !important;
	caret-color: var(--aa-accent) !important;
}

/* -------------------- HIDE BREADCRUMBS on WooCommerce pages --------------------
   Scoped to WC body classes so other site pages keep their breadcrumbs intact. */
body.woocommerce .woocommerce-breadcrumb,
body.woocommerce-page .woocommerce-breadcrumb,
body.woocommerce .kadence-breadcrumbs,
body.woocommerce-page .kadence-breadcrumbs,
body.woocommerce .breadcrumbs,
body.woocommerce-page .breadcrumbs,
body.woocommerce .breadcrumb,
body.woocommerce-page .breadcrumb,
body.woocommerce nav[aria-label="Breadcrumb"],
body.woocommerce-page nav[aria-label="Breadcrumb"],
body.woocommerce .breadcrumb-trail,
body.woocommerce-page .breadcrumb-trail,
body.woocommerce .yoast-breadcrumbs,
body.woocommerce-page .yoast-breadcrumbs,
body.woocommerce .rank-math-breadcrumb,
body.woocommerce-page .rank-math-breadcrumb {
	display: none !important;
}

/* -------------------- CHECKOUT PAGE PADDING (RTL safety) --------------------
   Fix order-summary and form clipping on RTL block checkout. */
body.woocommerce-checkout .wc-block-checkout,
body.woocommerce-checkout .wc-block-components-sidebar-layout,
body.woocommerce-checkout .wp-block-woocommerce-checkout {
	padding-inline: 24px !important;
	box-sizing: border-box;
}
body.woocommerce-checkout .wc-block-components-sidebar,
body.woocommerce-checkout .wc-block-components-order-summary {
	padding-inline: 16px !important;
}
body.woocommerce-checkout .wc-block-components-order-summary-item {
	padding-block: 12px !important;
}
/* Classic checkout (fallback, if you ever switch back) */
body.woocommerce-checkout .woocommerce,
body.woocommerce-checkout form.checkout,
body.woocommerce-checkout .woocommerce-checkout-review-order {
	padding-inline: 24px !important;
	box-sizing: border-box;
}
@media (max-width: 640px) {
	body.woocommerce-checkout .wc-block-checkout,
	body.woocommerce-checkout .wp-block-woocommerce-checkout,
	body.woocommerce-checkout form.checkout {
		padding-inline: 14px !important;
	}
}

/* -------------------- CART PAGE PADDING (RTL safety) --------------------
   Fix clipping on both sides of the cart on block + classic carts. */
body.woocommerce-cart .wc-block-cart,
body.woocommerce-cart .wp-block-woocommerce-cart,
body.woocommerce-cart .wc-block-components-sidebar-layout,
body.woocommerce-cart .woocommerce {
	padding-inline: 24px !important;
	box-sizing: border-box;
}
body.woocommerce-cart .wc-block-cart__sidebar,
body.woocommerce-cart .wc-block-components-sidebar,
body.woocommerce-cart .wc-block-cart-items {
	padding-inline: 16px !important;
	box-sizing: border-box;
}
body.woocommerce-cart .cart_totals,
body.woocommerce-cart .woocommerce-cart-form,
body.woocommerce-cart form.woocommerce-cart-form {
	padding-inline: 16px !important;
	box-sizing: border-box;
}
@media (max-width: 640px) {
	body.woocommerce-cart .wc-block-cart,
	body.woocommerce-cart .wp-block-woocommerce-cart,
	body.woocommerce-cart .woocommerce,
	body.woocommerce-cart form.woocommerce-cart-form {
		padding-inline: 14px !important;
	}
}

/* =========================================================
   AA CART + CHECKOUT MINIMAL SKIN
   Light neutral bg + copper accent, regardless of landing theme.
   Scoped strictly to WC cart/checkout bodies.
   ========================================================= */
body.woocommerce-cart,
body.woocommerce-checkout {
	--aa-c-bg:        #FAF6EE;
	--aa-c-panel:     #FFFFFF;
	--aa-c-text:      #2A241C;
	--aa-c-muted:     #7A6E5E;
	--aa-c-border:    rgba(184, 117, 74, 0.22);
	--aa-c-accent:    #B8754A;
	--aa-c-accent-h:  #A0623C;
	--aa-c-on-accent: #FAF6EE;
	--aa-c-focus:     rgba(184, 117, 74, 0.20);
	--aa-c-radius:    10px;

	background: var(--aa-c-bg) !important;
	color: var(--aa-c-text);
	font-family: 'Noto Sans Arabic', Tahoma, Arial, sans-serif;
}

/* Panel containers — white cards with soft border + radius */
body.woocommerce-cart .wc-block-cart,
body.woocommerce-cart .wc-block-cart-items,
body.woocommerce-cart .cart_totals,
body.woocommerce-cart table.shop_table,
body.woocommerce-checkout .wc-block-checkout,
body.woocommerce-checkout .wc-block-components-sidebar,
body.woocommerce-checkout .wc-block-components-order-summary,
body.woocommerce-checkout form.checkout,
body.woocommerce-checkout .woocommerce-checkout-review-order,
body.woocommerce-checkout table.shop_table {
	background: var(--aa-c-panel) !important;
	border: 1px solid var(--aa-c-border) !important;
	border-radius: var(--aa-c-radius) !important;
	box-shadow: 0 4px 18px rgba(60, 40, 20, 0.05) !important;
}

/* Headings inside the flow */
body.woocommerce-cart h1, body.woocommerce-cart h2, body.woocommerce-cart h3,
body.woocommerce-checkout h1, body.woocommerce-checkout h2, body.woocommerce-checkout h3,
body.woocommerce-cart .wc-block-components-title,
body.woocommerce-checkout .wc-block-components-title {
	color: var(--aa-c-text) !important;
	font-family: 'Noto Sans Arabic', Tahoma, Arial, sans-serif !important;
	font-weight: 700;
}

/* Muted labels/descriptions */
body.woocommerce-cart .wc-block-components-product-metadata,
body.woocommerce-cart .wc-block-components-product-price,
body.woocommerce-checkout .wc-block-components-form__label,
body.woocommerce-checkout .wc-block-components-checkout-step__description {
	color: var(--aa-c-muted) !important;
}

/* Inputs */
body.woocommerce-cart input[type="text"],
body.woocommerce-cart input[type="email"],
body.woocommerce-cart input[type="tel"],
body.woocommerce-cart input[type="number"],
body.woocommerce-cart textarea,
body.woocommerce-cart select,
body.woocommerce-checkout input[type="text"],
body.woocommerce-checkout input[type="email"],
body.woocommerce-checkout input[type="tel"],
body.woocommerce-checkout input[type="number"],
body.woocommerce-checkout textarea,
body.woocommerce-checkout select,
body.woocommerce-cart .wc-block-components-text-input input,
body.woocommerce-checkout .wc-block-components-text-input input {
	background: #FFFFFF !important;
	color: var(--aa-c-text) !important;
	-webkit-text-fill-color: var(--aa-c-text) !important;
	border: 1px solid var(--aa-c-border) !important;
	border-radius: 8px !important;
	padding: 10px 14px !important;
	font-family: inherit !important;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
body.woocommerce-cart input:focus,
body.woocommerce-cart textarea:focus,
body.woocommerce-cart select:focus,
body.woocommerce-checkout input:focus,
body.woocommerce-checkout textarea:focus,
body.woocommerce-checkout select:focus,
body.woocommerce-cart .wc-block-components-text-input input:focus,
body.woocommerce-checkout .wc-block-components-text-input input:focus {
	border-color: var(--aa-c-accent) !important;
	box-shadow: 0 0 0 3px var(--aa-c-focus) !important;
	outline: none !important;
}

/* Primary buttons — copper accent */
body.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
body.woocommerce-cart .wc-block-cart__submit-button,
body.woocommerce-cart button.wp-block-woocommerce-proceed-to-checkout-block,
body.woocommerce-checkout #place_order,
body.woocommerce-checkout button.wc-block-components-checkout-place-order-button,
body.woocommerce-checkout .wc-block-components-checkout-place-order-button {
	background: var(--aa-c-accent) !important;
	color: var(--aa-c-on-accent) !important;
	border: none !important;
	border-radius: 999px !important;
	padding: 14px 28px !important;
	font-family: inherit !important;
	font-weight: 700 !important;
	font-size: 16px !important;
	box-shadow: 0 6px 18px rgba(184, 117, 74, 0.22) !important;
	transition: background 0.15s ease, box-shadow 0.15s ease, transform 0.1s ease;
}
body.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover,
body.woocommerce-cart .wc-block-cart__submit-button:hover,
body.woocommerce-checkout #place_order:hover,
body.woocommerce-checkout button.wc-block-components-checkout-place-order-button:hover {
	background: var(--aa-c-accent-h) !important;
	box-shadow: 0 8px 22px rgba(184, 117, 74, 0.30) !important;
	transform: translateY(-1px);
}

/* Secondary buttons (Update cart, Apply coupon) — ghost style */
body.woocommerce-cart button[name="update_cart"],
body.woocommerce-cart button[name="apply_coupon"],
body.woocommerce-cart .wc-block-components-button--outlined,
body.woocommerce-checkout .wc-block-components-button--outlined {
	background: transparent !important;
	color: var(--aa-c-accent) !important;
	border: 1.5px solid var(--aa-c-accent) !important;
	border-radius: 999px !important;
	padding: 10px 20px !important;
	font-family: inherit !important;
	font-weight: 600 !important;
	transition: background 0.15s ease;
}
body.woocommerce-cart button[name="update_cart"]:hover,
body.woocommerce-cart button[name="apply_coupon"]:hover,
body.woocommerce-cart .wc-block-components-button--outlined:hover,
body.woocommerce-checkout .wc-block-components-button--outlined:hover {
	background: rgba(184, 117, 74, 0.08) !important;
}

/* Link color in the flow */
body.woocommerce-cart a,
body.woocommerce-checkout a {
	color: var(--aa-c-accent);
}
body.woocommerce-cart a:hover,
body.woocommerce-checkout a:hover {
	color: var(--aa-c-accent-h);
}

/* Totals / price emphasis */
body.woocommerce-cart .order-total .amount,
body.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
body.woocommerce-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
	color: var(--aa-c-accent) !important;
	font-weight: 700 !important;
}

/* Step number circles (block checkout) */
body.woocommerce-checkout .wc-block-components-checkout-step__heading-content,
body.woocommerce-checkout .wc-block-components-checkout-step--with-step-number .wc-block-components-checkout-step__title::before {
	color: var(--aa-c-accent) !important;
}

/* Remove harsh dark text overrides that some themes inject on WC pages */
body.woocommerce-cart .wc-block-components-product-name,
body.woocommerce-checkout .wc-block-components-product-name {
	color: var(--aa-c-text) !important;
}

/* -------------------- STATIC LABELS ABOVE INPUTS --------------------
   Kill the floating-label pattern and put each label on its own line above
   the input. More reliable in RTL, zero overlap risk, easier to scan.
   Covers: simple text inputs, comboboxes (country/state), select controls. */
body.woocommerce-checkout .wc-block-components-text-input,
body.woocommerce-cart .wc-block-components-text-input,
body.woocommerce-checkout .wc-block-components-combobox,
body.woocommerce-cart .wc-block-components-combobox,
body.woocommerce-checkout .wc-block-components-combobox-control,
body.woocommerce-cart .wc-block-components-combobox-control,
body.woocommerce-checkout .wc-block-components-country-input,
body.woocommerce-cart .wc-block-components-country-input,
body.woocommerce-checkout .wc-block-components-state-input,
body.woocommerce-cart .wc-block-components-state-input,
body.woocommerce-checkout .wc-block-components-select,
body.woocommerce-cart .wc-block-components-select {
	display: flex !important;
	flex-direction: column !important;
	gap: 6px !important;
	position: static !important;
}
/* Label: force it above, static, full width, readable weight */
body.woocommerce-checkout .wc-block-components-text-input > label,
body.woocommerce-cart .wc-block-components-text-input > label,
body.woocommerce-checkout .wc-block-components-combobox label,
body.woocommerce-cart .wc-block-components-combobox label,
body.woocommerce-checkout .wc-block-components-combobox-control label,
body.woocommerce-cart .wc-block-components-combobox-control label,
body.woocommerce-checkout .wc-block-components-country-input > label,
body.woocommerce-cart .wc-block-components-country-input > label,
body.woocommerce-checkout .wc-block-components-state-input > label,
body.woocommerce-cart .wc-block-components-state-input > label,
body.woocommerce-checkout .wc-block-components-select > label,
body.woocommerce-cart .wc-block-components-select > label {
	position: static !important;
	transform: none !important;
	top: auto !important;
	bottom: auto !important;
	left: auto !important;
	right: auto !important;
	inset-inline-start: auto !important;
	inset-inline-end: auto !important;
	order: -1 !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	color: var(--aa-c-text) !important;
	pointer-events: auto !important;
	margin: 0 !important;
	padding: 0 2px !important;
	max-width: 100% !important;
	width: 100% !important;
	white-space: normal !important;
	overflow: visible !important;
	text-overflow: clip !important;
	background: transparent !important;
	line-height: 1.4 !important;
	display: block !important;
}
/* Inputs / combobox fields: reset padding, no reserved top space */
body.woocommerce-checkout .wc-block-components-text-input input,
body.woocommerce-cart .wc-block-components-text-input input,
body.woocommerce-checkout .wc-block-components-combobox input,
body.woocommerce-cart .wc-block-components-combobox input,
body.woocommerce-checkout .wc-block-components-combobox-control input,
body.woocommerce-cart .wc-block-components-combobox-control input,
body.woocommerce-checkout .wc-block-components-country-input input,
body.woocommerce-cart .wc-block-components-country-input input,
body.woocommerce-checkout .wc-block-components-state-input input,
body.woocommerce-cart .wc-block-components-state-input input,
body.woocommerce-checkout .wc-block-components-select select,
body.woocommerce-cart .wc-block-components-select select {
	padding: 10px 14px !important;
	height: auto !important;
	line-height: 1.4 !important;
}
