/*
Theme Name: Halo Peptides
Description: Custom theme for Halo Peptides with Immortal aesthetics.
Author: Antigravity
Version: 1.0.0
Text Domain: halo-peptides
*/

/* --- Immortal Aesthetics: Global Styles --- */

:root {
    --color-dark: #0a0a0a;
    --color-dark-lighter: #111111;
    --color-gold: #C5A059;
    --color-gold-hover: #E2C27D;
    --color-white: #ffffff;
    --color-gray: #888888;
    --font-heading: 'Playfair Display', serif;
    --font-body: 'Inter', sans-serif;
}

body {
    background-color: var(--color-dark);
    color: var(--color-white);
    font-family: var(--font-body);
    margin: 0;
    padding: 0;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--color-white);
}

a {
    color: var(--color-gold);
    text-decoration: none;
    transition: color 0.3s ease;
}

a:hover {
    color: var(--color-gold-hover);
}

/* --- Utility Classes (Tailwind equivalents used in React) --- */
.bg-dark { background-color: var(--color-dark); }
.bg-light { background-color: var(--color-dark-lighter); /* Adjusted for dark mode */ }
.text-gold { color: var(--color-gold); }
.text-dark { color: var(--color-white); /* Adjusted for dark mode */ }
.text-white { color: var(--color-white); }
.font-serif { font-family: var(--font-heading); }
.bg-gold { background-color: var(--color-gold); }
.bg-gold-hover:hover { background-color: var(--color-gold-hover); }

/* Buttons */
.btn-premium {
    background: linear-gradient(90deg, #C5A059 0%, #E2C27D 100%);
    color: #000;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 15px 35px;
    border-radius: 50px;
    transition: transform 0.3s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
}

.btn-premium:hover {
    transform: translateY(-2px);
    color: #000;
}

/* WooCommerce Overrides */
.woocommerce ul.products li.product {
    background: #111111;
    border: 1px solid rgba(197, 160, 89, 0.2);
    border-radius: 12px;
    padding: 20px;
    transition: all 0.3s ease-in-out;
}

.woocommerce ul.products li.product:hover {
    border-color: var(--color-gold);
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--font-heading);
    color: var(--color-white);
    font-size: 1.4rem;
    margin-top: 15px;
}

.woocommerce ul.products li.product .price {
    color: var(--color-gold);
    font-weight: 700;
}

/* Hide images on shop page */
.woocommerce ul.products li.product a img {
    display: none;
}

/* =============================================
   WooCommerce Shop Page Overrides
   ============================================= */

/* Shop Page Title */
.woocommerce-products-header__title,
.woocommerce h1.page-title {
    font-family: var(--font-heading);
    color: var(--color-white);
    font-size: 2.5rem;
    margin-bottom: 1.5rem;
    font-weight: 400;
}

/* Result count ("Showing all 5 results") */
.woocommerce-result-count {
    color: var(--color-gray);
    font-size: 0.85rem;
    letter-spacing: 0.05em;
}

/* Ordering dropdown */
.woocommerce-ordering select {
    background-color: #111111 !important;
    color: var(--color-white) !important;
    border: 1px solid rgba(197, 160, 89, 0.3) !important;
    border-radius: 50px !important;
    padding: 8px 16px !important;
    font-size: 0.8rem !important;
    appearance: none;
    cursor: pointer;
}

/* Breadcrumb nav */
.woocommerce-breadcrumb {
    color: var(--color-gray);
    font-size: 0.8rem;
    margin-bottom: 2rem;
}

.woocommerce-breadcrumb a {
    color: var(--color-gray);
}

.woocommerce-breadcrumb a:hover {
    color: var(--color-gold);
}

/* Notices (success, error, info) */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    background: #111111 !important;
    border-top-color: var(--color-gold) !important;
    color: var(--color-white) !important;
}

/* Pagination */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    background: #111111 !important;
    color: var(--color-white) !important;
    border-color: rgba(197, 160, 89, 0.2) !important;
}

.woocommerce nav.woocommerce-pagination ul li a:focus,
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
    background: var(--color-gold) !important;
    color: #000 !important;
}

/* Single Product Page */
.woocommerce div.product .product_title {
    font-family: var(--font-heading) !important;
    color: var(--color-white) !important;
    font-size: 2.2rem !important;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    color: var(--color-gold) !important;
    font-size: 1.8rem !important;
}

.woocommerce div.product .woocommerce-product-details__short-description {
    color: var(--color-gray) !important;
}

/* Single Product Buy Button */
.woocommerce .single_add_to_cart_button {
    background: var(--color-gold) !important;
    color: #000 !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    border: none !important;
    padding: 14px 32px !important;
}

.woocommerce .single_add_to_cart_button:hover {
    background: var(--color-gold-hover) !important;
}

/* Cart & Checkout Tables */
.woocommerce table.shop_table {
    background: #111111 !important;
    border-color: rgba(255,255,255,0.1) !important;
    color: var(--color-white) !important;
}

.woocommerce table.shop_table th {
    border-color: rgba(255,255,255,0.1) !important;
    color: var(--color-gold) !important;
    font-family: var(--font-heading) !important;
    font-weight: 400 !important;
    font-size: 0.9rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
}

.woocommerce table.shop_table td {
    border-color: rgba(255,255,255,0.08) !important;
    color: var(--color-white) !important;
}

/* =============================================
   Cart Page Specific Fixes
   ============================================= */

/* Hide broken product thumbnail on cart */
.woocommerce-cart table.cart td.product-thumbnail,
.woocommerce-cart table.cart td.product-thumbnail img {
    display: none !important;
}

/* Cart product name */
.woocommerce-cart table.cart td.product-name a {
    color: var(--color-white) !important;
    font-family: var(--font-heading) !important;
    font-size: 1rem !important;
    text-decoration: none !important;
}

/* Cart quantity input */
.woocommerce-cart .quantity input.qty {
    background: #1a1a1a !important;
    color: var(--color-white) !important;
    border: 1px solid rgba(197,160,89,0.3) !important;
    border-radius: 8px !important;
    text-align: center !important;
    width: 60px !important;
}

/* Remove item button */
.woocommerce-cart table.cart td.product-remove a {
    color: var(--color-gray) !important;
}

.woocommerce-cart table.cart td.product-remove a:hover {
    color: #ff4444 !important;
}

/* Cart totals box */
.woocommerce-cart .cart_totals {
    background: #111111 !important;
    border: 1px solid rgba(197,160,89,0.2) !important;
    border-radius: 16px !important;
    padding: 24px !important;
}

.woocommerce-cart .cart_totals h2 {
    color: var(--color-white) !important;
    font-family: var(--font-heading) !important;
    font-size: 1.4rem !important;
    margin-bottom: 16px !important;
    font-weight: 400 !important;
}

/* "Proceed to Checkout" button */
.woocommerce-cart .wc-proceed-to-checkout .checkout-button {
    background: var(--color-gold) !important;
    color: #000 !important;
    border: none !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    font-size: 0.85rem !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    padding: 14px 32px !important;
    width: 100% !important;
    display: block !important;
    text-align: center !important;
    transition: background 0.2s ease !important;
}

.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover {
    background: var(--color-gold-hover) !important;
}

/* Coupon field */
.woocommerce-cart .coupon input#coupon_code {
    background: #1a1a1a !important;
    color: var(--color-white) !important;
    border: 1px solid rgba(197,160,89,0.3) !important;
    border-radius: 8px !important;
    padding: 10px 14px !important;
}

.woocommerce-cart .coupon button[name="apply_coupon"] {
    background: transparent !important;
    border: 1px solid rgba(197,160,89,0.5) !important;
    color: var(--color-gold) !important;
    border-radius: 8px !important;
    padding: 10px 20px !important;
    font-size: 0.8rem !important;
    transition: all 0.2s ease !important;
}

.woocommerce-cart .coupon button[name="apply_coupon"]:hover {
    background: rgba(197,160,89,0.1) !important;
}

/* Update Cart button */
button[name="update_cart"] {
    background: transparent !important;
    border: 1px solid rgba(255,255,255,0.1) !important;
    color: var(--color-gray) !important;
    border-radius: 8px !important;
    padding: 10px 20px !important;
    font-size: 0.8rem !important;
}

/* =============================================
   WooCommerce Blocks Overrides (Cart & Checkout Blocks)
   ============================================= */

/* Hide white image placeholder in Block Cart */
.wc-block-cart-item__image {
    display: none !important;
}

/* Block Buttons (Proceed to checkout, Pay now) */
.wc-block-cart .wc-block-cart__submit-button,
.wc-block-checkout .wc-block-checkout__actions .wc-block-components-button,
.wc-block-components-button:not(.is-link) {
    background: var(--color-gold) !important;
    color: #000 !important;
    border: none !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    font-size: 0.85rem !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    padding: 16px 32px !important;
    transition: background 0.2s ease !important;
    box-shadow: 0 4px 15px rgba(197,160,89,0.3) !important;
}

.wc-block-components-button:not(.is-link):hover {
    background: var(--color-gold-hover) !important;
}

/* Block Inputs and Fields (Bulletproof High-Specificity Override) */
/* 1. Target the outer container wrappers (WooCommerce blocks put white background on the outer wrapper for floating labels) */
.wc-block-checkout .wc-block-components-text-input,
.wc-block-checkout .wc-block-components-combobox,
.wc-block-checkout .wc-block-components-input-control,
.wc-block-checkout .wc-block-components-country-input,
.wc-block-checkout .wc-block-components-state-input,
.wc-block-checkout .wc-block-components-textarea,
.wc-block-cart .wc-block-components-text-input,
.wc-block-cart .wc-block-components-combobox,
.wc-block-cart .wc-block-components-input-control,
.wc-block-components-text-input,
.wc-block-components-combobox,
.wc-block-components-input-control,
.wc-block-components-country-input,
.wc-block-components-state-input,
.wc-block-components-textarea {
    background-color: #1a1a1a !important;
    border: 1px solid rgba(197, 160, 89, 0.35) !important;
    border-radius: 8px !important;
    color: #ffffff !important;
}

/* 2. Target the actual input/select elements inside the blocks */
.wc-block-checkout input.wc-block-components-text-input__input,
.wc-block-checkout input.wc-block-components-input-control__input,
.wc-block-checkout input.wc-block-components-combobox__input,
.wc-block-checkout select.wc-block-components-country-input__select,
.wc-block-checkout select.wc-block-components-state-input__select,
.wc-block-checkout textarea.wc-block-components-textarea__textarea,
.wc-block-cart input.wc-block-components-text-input__input,
.wc-block-cart input.wc-block-components-input-control__input,
.wc-block-cart input.wc-block-components-combobox__input,
input.wc-block-components-text-input__input,
input.wc-block-components-input-control__input,
input.wc-block-components-combobox__input,
select.wc-block-components-country-input__select,
select.wc-block-components-state-input__select,
textarea.wc-block-components-textarea__textarea,
/* Text-type inputs only — exclude radio/checkbox to avoid breaking payment options */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="password"],
input[type="search"],
select,
textarea {
    background-color: #1a1a1a !important;
    color: #ffffff !important;
    border-radius: 8px !important;
    outline: none !important;
    box-shadow: none !important;
}


input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus,
.wc-block-components-text-input input:focus,
.wc-block-components-combobox input:focus {
    border-color: var(--color-gold) !important;
    box-shadow: 0 0 0 1px var(--color-gold) !important;
    background-color: #111111 !important;
}

/* Field labels and placeholder text */
::-webkit-input-placeholder { color: #666666 !important; }
::-moz-placeholder          { color: #666666 !important; }
:-ms-input-placeholder      { color: #666666 !important; }
::-ms-input-placeholder     { color: #666666 !important; }
::placeholder               { color: #666666 !important; }

.wc-block-components-text-input label,
.wc-block-components-combobox label,
label {
    color: var(--color-gray) !important;
}

/* Block Summaries & Totals Cards */
.wc-block-cart__totals-title,
.wc-block-checkout__totals-title {
    color: var(--color-white) !important;
    font-family: var(--font-heading) !important;
    font-size: 1.4rem !important;
}

.wc-block-cart__totals-item-value,
.wc-block-checkout__totals-item-value,
.wc-block-formatted-money__amount {
    color: var(--color-gold) !important;
}

.wc-block-components-totals-item__label {
    color: var(--color-gray) !important;
}

/* Block Totals Container */
.wc-block-cart .wc-block-cart__totals-container,
.wc-block-checkout .wc-block-checkout__totals-container {
    background: #111111 !important;
    border: 1px solid rgba(197,160,89,0.2) !important;
    border-radius: 16px !important;
    padding: 24px !important;
}

/* Block Cart Item Rows */
.wc-block-cart-items {
    border-color: rgba(255,255,255,0.1) !important;
}

.wc-block-cart-item__product {
    color: var(--color-white) !important;
    font-family: var(--font-heading) !important;
    font-size: 1.1rem !important;
}

/* Quantity selector inside block */
.wc-block-components-quantity-selector input.wc-block-components-quantity-selector__input {
    background: #1a1a1a !important;
    color: var(--color-white) !important;
    border-color: rgba(197,160,89,0.3) !important;
}

/* Block notices / errors */
.wc-block-components-notice-banner {
    background: #111111 !important;
    border-color: var(--color-gold) !important;
    color: var(--color-white) !important;
}




/* =============================================
   Legal Pages
   ============================================= */
.legal-page { background: #0a0a0a; min-height: 100vh; }
.legal-page__hero { background: #111111; border-bottom: 1px solid rgba(255,255,255,0.07); padding: 80px 0 60px; text-align: center; }
.legal-page__inner { max-width: 780px; margin: 0 auto; padding: 0 24px; }
.legal-badge-tag { display: inline-block; padding: 4px 16px; border-radius: 50px; border: 1px solid rgba(197,160,89,0.4); color: #C5A059; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 20px; }
.legal-page__title { font-family: 'Playfair Display', serif; font-size: 2.8rem; font-weight: 400; color: #ffffff; margin: 0; line-height: 1.2; }
.legal-page__body { padding: 60px 0 100px; }
.legal-prose { color: #aaaaaa; font-size: 0.97rem; line-height: 1.85; }
.legal-prose p { margin: 0 0 1.2em; }
.legal-prose .legal-meta { font-size: 0.82rem; color: #666666; margin-bottom: 2em; padding-bottom: 1.5em; border-bottom: 1px solid rgba(255,255,255,0.07); }
.legal-prose h2 { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 400; color: #ffffff; margin: 2.5em 0 0.8em; padding-left: 14px; border-left: 2px solid #C5A059; }
.legal-prose h3 { font-size: 0.9rem; font-weight: 700; color: #cccccc; text-transform: uppercase; letter-spacing: 0.8px; margin: 2em 0 0.6em; }
.legal-prose ul, .legal-prose ol { padding-left: 1.4em; margin: 0 0 1.2em; }
.legal-prose ul li, .legal-prose ol li { margin-bottom: 0.5em; }
.legal-prose a { color: #C5A059; text-decoration: none; }
.legal-prose a:hover { text-decoration: underline; }
.legal-prose strong { color: #cccccc; font-weight: 600; }
.legal-prose table { width: 100%; border-collapse: collapse; margin: 1.5em 0; font-size: 0.85rem; border-radius: 10px; border: 1px solid rgba(255,255,255,0.08); }
.legal-prose table thead th { background: #1a1a1a; color: #C5A059; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 1px; padding: 12px 16px; text-align: left; border-bottom: 1px solid rgba(255,255,255,0.08); }
.legal-prose table tbody td { padding: 12px 16px; color: #aaaaaa; border-bottom: 1px solid rgba(255,255,255,0.05); vertical-align: top; }
.legal-prose table tbody tr:last-child td { border-bottom: none; }
.legal-page__back { margin-top: 60px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.07); }
.legal-page__back a { color: #666666; font-size: 0.85rem; text-decoration: none; transition: color 0.2s; }
.legal-page__back a:hover { color: #C5A059; }
