/* =============================================
   HedgeLists — WooCommerce Page Styles
   Cart, Checkout, My Account
   ============================================= */

/* --- Shared --- */
.woocommerce .entry-content,
.woocommerce-page .entry-content {
    max-width: 1100px;
    margin: 0 auto;
    padding: 40px 20px;
}

/* =============================================
   WooCommerce Buttons
   ============================================= */
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
    background: var(--hl-accent) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--hl-radius) !important;
    padding: 12px 28px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
    text-decoration: none !important;
    display: inline-block;
    line-height: 1.4 !important;
}

.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
    background: var(--hl-accent-hover) !important;
    color: #fff !important;
}

/* Disabled buttons */
.woocommerce button.button:disabled,
.woocommerce button.button:disabled:hover {
    background: var(--hl-border) !important;
    color: var(--hl-text-muted) !important;
    cursor: not-allowed !important;
}

/* =============================================
   Form Inputs
   ============================================= */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-page form .form-row input.input-text,
.woocommerce-page form .form-row textarea,
.woocommerce-page form .form-row select,
.woocommerce form .form-row .select2-container .select2-selection--single {
    border: 1px solid var(--hl-border) !important;
    border-radius: var(--hl-radius) !important;
    padding: 10px 14px !important;
    font-size: 15px !important;
    color: var(--hl-text) !important;
    background: var(--hl-bg-white) !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    width: 100%;
    box-sizing: border-box;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
    border-color: var(--hl-accent) !important;
    box-shadow: 0 0 0 3px rgba(46, 163, 242, 0.15) !important;
    outline: none !important;
}

.woocommerce form .form-row label {
    font-size: 14px;
    font-weight: 600;
    color: var(--hl-black);
    margin-bottom: 6px;
    display: block;
}

/* =============================================
   Tables (Cart, Orders, Downloads)
   ============================================= */
.woocommerce table.shop_table,
.woocommerce table.woocommerce-orders-table,
.woocommerce table.woocommerce-table--order-downloads {
    border: 0.5px solid var(--hl-border) !important;
    border-radius: var(--hl-radius-lg) !important;
    overflow: hidden;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    width: 100%;
}

.woocommerce table.shop_table th,
.woocommerce table.woocommerce-orders-table th,
.woocommerce table.woocommerce-table--order-downloads th {
    background: var(--hl-bg-subtle) !important;
    color: var(--hl-black) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--hl-border) !important;
}

.woocommerce table.shop_table td,
.woocommerce table.woocommerce-orders-table td,
.woocommerce table.woocommerce-table--order-downloads td {
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--hl-border) !important;
    color: var(--hl-text) !important;
    font-size: 14px !important;
    vertical-align: middle !important;
}

.woocommerce table.shop_table tr:last-child td,
.woocommerce table.woocommerce-orders-table tr:last-child td,
.woocommerce table.woocommerce-table--order-downloads tr:last-child td {
    border-bottom: none !important;
}

/* =============================================
   Section Headings
   ============================================= */
.woocommerce h2,
.woocommerce h3,
.woocommerce-account h2,
.woocommerce-account h3 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--hl-black) !important;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--hl-border);
    margin-bottom: 20px;
}

/* =============================================
   WooCommerce Notices
   ============================================= */
.woocommerce .woocommerce-message {
    border-top-color: var(--hl-accent) !important;
    background: #EFF8FF !important;
    border-radius: var(--hl-radius) !important;
    color: var(--hl-text) !important;
    padding: 14px 20px !important;
}

.woocommerce .woocommerce-error {
    border-top-color: #DC2626 !important;
    background: #FEF2F2 !important;
    border-radius: var(--hl-radius) !important;
    color: #991B1B !important;
    padding: 14px 20px !important;
}

.woocommerce .woocommerce-info {
    border-top-color: var(--hl-accent) !important;
    background: #EFF8FF !important;
    border-radius: var(--hl-radius) !important;
    color: var(--hl-text) !important;
    padding: 14px 20px !important;
}

.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before {
    color: var(--hl-accent) !important;
}

/* =============================================
   Cart Page
   ============================================= */
.woocommerce-cart .cart-collaterals .cart_totals {
    background: var(--hl-bg-subtle);
    border-radius: var(--hl-radius-lg);
    padding: 24px;
    border: 1px solid var(--hl-border);
}

.woocommerce-cart .cart-collaterals .cart_totals h2 {
    border-bottom: none;
    padding-bottom: 0;
}

.woocommerce-cart .coupon .input-text {
    border: 1px solid var(--hl-border) !important;
    border-radius: var(--hl-radius) !important;
    padding: 10px 14px !important;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
    display: block !important;
    text-align: center !important;
    font-size: 16px !important;
    padding: 14px 28px !important;
}

/* =============================================
   Checkout Page
   ============================================= */
.woocommerce-checkout .col2-set {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
}

.woocommerce-checkout #order_review_heading {
    margin-top: 32px;
}

.woocommerce-checkout #order_review {
    background: var(--hl-bg-subtle);
    border-radius: var(--hl-radius-lg);
    padding: 24px;
    border: 1px solid var(--hl-border);
}

.woocommerce-checkout #payment {
    background: var(--hl-bg-subtle) !important;
    border-radius: var(--hl-radius-lg) !important;
    border: 1px solid var(--hl-border) !important;
}

.woocommerce-checkout #payment ul.payment_methods {
    border-bottom: 1px solid var(--hl-border) !important;
    padding: 16px !important;
}

.woocommerce-checkout #payment div.place-order {
    padding: 16px !important;
}

.woocommerce-checkout #place_order {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    font-size: 16px !important;
    padding: 14px 28px !important;
}

/* =============================================
   My Account Page
   ============================================= */
.woocommerce-account .woocommerce-MyAccount-navigation {
    background: var(--hl-bg-subtle);
    border-radius: var(--hl-radius-lg);
    padding: 16px;
    border: 1px solid var(--hl-border);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    margin: 0;
    padding: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 10px 16px;
    color: var(--hl-text);
    text-decoration: none;
    border-radius: var(--hl-radius);
    font-size: 14px;
    font-weight: 500;
    transition: background 0.2s ease, color 0.2s ease;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
    background: #E0F2FE;
    color: var(--hl-accent);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--downloads.is-active a {
    background: var(--hl-accent);
    color: #fff;
    font-weight: 600;
}

/* Downloads button in My Account */
.woocommerce-account .woocommerce-table--order-downloads .download-file a.button {
    font-size: 13px !important;
    padding: 8px 18px !important;
}

/* Login / Register forms */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
    background: var(--hl-bg-subtle);
    border: 1px solid var(--hl-border);
    border-radius: var(--hl-radius-lg);
    padding: 32px;
    max-width: 480px;
}

.woocommerce-account .u-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
}

/* =============================================
   Thank You / Order Received
   ============================================= */
.woocommerce-order-received .woocommerce-order {
    max-width: 700px;
    margin: 0 auto;
}

/* =============================================
   Mobile Responsive
   ============================================= */
@media (max-width: 768px) {
    .woocommerce .entry-content,
    .woocommerce-page .entry-content {
        padding: 24px 16px;
    }

    /* Cart: horizontal scroll for table */
    .woocommerce-cart .woocommerce table.shop_table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Checkout: single column */
    .woocommerce-checkout .col2-set {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    /* My Account: horizontal scrollable tabs */
    .woocommerce-account .woocommerce-MyAccount-navigation {
        padding: 8px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        display: flex;
        gap: 4px;
        white-space: nowrap;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul li a {
        padding: 8px 14px;
        font-size: 13px;
    }

    /* Login/Register forms: single column */
    .woocommerce-account .u-columns {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .woocommerce-account .woocommerce-form-login,
    .woocommerce-account .woocommerce-form-register {
        max-width: 100%;
        padding: 24px;
    }
}

/* ── My Account Page Enhancements ── */

/* Container alignment */
.woocommerce-account .entry-content,
.woocommerce-account .woocommerce {
    max-width: 1120px;
    margin: 0 auto;
    padding: 40px 24px 60px;
}

/* ── Navigation: horizontal pills on desktop ── */
.woocommerce-account .woocommerce-MyAccount-navigation {
    background: #F8FAFC;
    border-radius: 12px;
    padding: 8px;
    margin-bottom: 32px;
    border: 1px solid #E2E8F0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    margin: 0;
    padding: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 10px 20px;
    color: #374151;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    border-radius: 8px;
    transition: all 0.15s;
    white-space: nowrap;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
    background: #E0F2FE;
    color: #2EA3F2;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
    background: #2EA3F2;
    color: #fff;
    font-weight: 600;
}
/* Downloads tab highlight */
.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--downloads a {
    position: relative;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--downloads a::before {
    content: '\2B07';
    margin-right: 6px;
}

/* ── Content area ── */
.woocommerce-account .woocommerce-MyAccount-content {
    font-size: 15px;
    line-height: 1.7;
    color: #374151;
}
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
    font-size: 22px;
    font-weight: 700;
    color: #111;
    margin-bottom: 16px;
}

/* ── Orders table ── */
.woocommerce-account .woocommerce-orders-table,
.woocommerce-account .shop_table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    overflow: hidden;
}
.woocommerce-account .woocommerce-orders-table thead th,
.woocommerce-account .shop_table thead th {
    background: #333;
    color: #fff;
    padding: 12px 16px;
    text-align: left;
    font-weight: 600;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.woocommerce-account .woocommerce-orders-table tbody td,
.woocommerce-account .shop_table tbody td {
    padding: 12px 16px;
    border-bottom: 1px solid #F1F5F9;
    color: #374151;
}
.woocommerce-account .woocommerce-orders-table tbody tr:hover,
.woocommerce-account .shop_table tbody tr:hover {
    background: #F8FAFC;
}
.woocommerce-account .woocommerce-orders-table .woocommerce-orders-table__cell-order-actions a,
.woocommerce-account .shop_table a.button {
    display: inline-block;
    padding: 6px 16px;
    background: #2EA3F2;
    color: #fff !important;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s;
}
.woocommerce-account .woocommerce-orders-table .woocommerce-orders-table__cell-order-actions a:hover,
.woocommerce-account .shop_table a.button:hover {
    background: #1a8cd8;
}

/* ── Downloads section ── */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-order-downloads,
.woocommerce-account .woocommerce-MyAccount-downloads {
    margin-top: 16px;
}
.woocommerce-account .download-product a {
    color: #2EA3F2;
    font-weight: 600;
}
.woocommerce-account td.download-file a {
    display: inline-block;
    padding: 8px 20px;
    background: #2EA3F2;
    color: #fff !important;
    border-radius: 6px;
    font-weight: 600;
    text-decoration: none;
}
.woocommerce-account td.download-file a:hover {
    background: #1a8cd8;
}

/* ── Login/Register form (logged out) ── */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
    max-width: 480px;
    margin: 40px auto;
    background: #F8FAFC;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    padding: 40px;
}
.woocommerce-account .woocommerce-form-login h2,
.woocommerce-account .woocommerce-form-register h2,
.woocommerce-account .u-column1 h2,
.woocommerce-account .u-column2 h2 {
    font-size: 24px;
    font-weight: 700;
    color: #111;
    text-align: center;
    margin-bottom: 24px;
}
.woocommerce-account .woocommerce-form-login .woocommerce-form-login__rememberme {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
}
.woocommerce-account .woocommerce-form-login p.form-row label,
.woocommerce-account .woocommerce-form-register p.form-row label {
    display: block;
    font-weight: 600;
    font-size: 14px;
    color: #374151;
    margin-bottom: 6px;
}
.woocommerce-account .woocommerce-form-login input[type="text"],
.woocommerce-account .woocommerce-form-login input[type="email"],
.woocommerce-account .woocommerce-form-login input[type="password"],
.woocommerce-account .woocommerce-form-register input[type="text"],
.woocommerce-account .woocommerce-form-register input[type="email"],
.woocommerce-account .woocommerce-form-register input[type="password"] {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid #D1D5DB;
    border-radius: 8px;
    font-size: 15px;
    transition: border-color 0.15s;
}
.woocommerce-account .woocommerce-form-login input:focus,
.woocommerce-account .woocommerce-form-register input:focus {
    border-color: #2EA3F2;
    outline: none;
    box-shadow: 0 0 0 3px rgba(46,163,242,0.1);
}
.woocommerce-account .woocommerce-form-login .woocommerce-button,
.woocommerce-account .woocommerce-form-register .woocommerce-button {
    width: 100%;
    padding: 12px;
    background: #2EA3F2;
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.15s;
}
.woocommerce-account .woocommerce-form-login .woocommerce-button:hover,
.woocommerce-account .woocommerce-form-register .woocommerce-button:hover {
    background: #1a8cd8;
}
.woocommerce-account .woocommerce-LostPassword a {
    color: #2EA3F2;
    font-size: 14px;
}

/* Two-column login/register layout */
.woocommerce-account .u-columns {
    display: flex;
    gap: 40px;
    max-width: 960px;
    margin: 40px auto;
}
.woocommerce-account .u-columns .u-column1,
.woocommerce-account .u-columns .u-column2 {
    flex: 1;
}

/* ── Responsive ── */
@media (max-width: 768px) {
    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        flex-direction: column;
    }
    .woocommerce-account .u-columns {
        flex-direction: column;
    }
    .woocommerce-account .woocommerce-form-login,
    .woocommerce-account .woocommerce-form-register {
        padding: 24px;
        margin: 20px auto;
    }
}

/* Free sample checkout info box */
.hl-sample-checkout-info {
    background: #F0F9FF;
    border: 1px solid #BAE6FD;
    border-radius: 8px;
    padding: 24px 32px;
    margin-bottom: 32px;
}
.hl-sample-checkout-info h2 {
    font-size: 22px;
    color: #111;
    margin-bottom: 12px;
}
.hl-sample-checkout-info p {
    font-size: 15px;
    color: #374151;
    margin-bottom: 12px;
}
.hl-sample-checkout-info ul {
    padding-left: 20px;
    font-size: 14px;
    color: #374151;
}
.hl-sample-checkout-info li {
    margin-bottom: 6px;
}