/* ============================================================
   SHOP.CSS — MERGED: CART + CHECKOUT
   Covers: cart.php  and  checkout.php
   Primary: #0d1117 / #1a2638   Accent: #ff773f
   ============================================================ */

/* ── Shared root variables ──────────────────────────────────
   --co-*        checkout-specific (form borders, bg, etc.)
   --co-primary  checkout primary / button colour
   --ct-*        cart-specific (text, card, radius, shadow)
   --cart-border orange accent border used in cart cards
   ─────────────────────────────────────────────────────────── */
:root {
    /* Shared primary palette */
    --co:            #0d1117;
    --co-dk:         #1a2638;
    --co-lt:         #fff5f0;

    /* Checkout form / layout borders (gray) */
    --co-border:     #e5e7eb;
    --co-bg:         #f4f5f7;
    --co-card:       #ffffff;
    --co-radius:     14px;
    --co-shadow:     0 2px 16px rgba(0,0,0,0.07);
    --co-shadow-md:  0 8px 32px rgba(0,0,0,0.10);
    --co-transition: all 0.22s ease;
    --co-muted:      #6b7280;
    --co-text:       #1e2329;

    /* Checkout primary colour (used for buttons, active states) */
    --co-primary:    #0d1117;
    --co-primary-dk: #1a2638;
    --co-primary-lt: #fff5f0;

    /* Cart orange accent border (peach) */
    --cart-border:   #ffe0d0;

    /* Cart text / card theme */
    --ct-dark:   #1a1f36;
    --ct-text:   #374151;
    --ct-muted:  #6b7280;
    --ct-border: #e8eaf0;
    --ct-bg:     #f7f8fc;
    --ct-card:   #ffffff;
    --ct-radius: 12px;
    --ct-shadow: 0 2px 16px rgba(0,0,0,0.07);

    /* Thank-you page accent colours */
    --ty-gold:   #f59e0b;
    --ty-orange: #ff773f;
}


/* ════════════════════════════════════════════════════════════
   COMMON CARD HEADER MODULE
   Shared by cart.php and checkout.php
   .pg-card-hd   — flat header strip: icon + title
   .pg-card-icon — accent icon box inside the header
   .co-summary-hero — dark gradient hero (checkout sidebar)
   ════════════════════════════════════════════════════════════ */

/* Standard flat header */
.pg-card-hd {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    background: #fafafa;
    border-bottom: 1px solid var(--ct-border);
}
.pg-card-hd h3 {
    font-size: 17px;
    font-weight: 700;
    color: var(--ct-dark);
    margin: 0;
    line-height: 1.2;
    font-family: 'Poppins', sans-serif;
}

/* Accent icon box */
.pg-card-icon {
    width: 38px; height: 38px;
    border-radius: 10px;
    background: var(--co-lt);
    border: 1px solid var(--cart-border);
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; color: var(--co);
    flex-shrink: 0;
    margin: 0;
}

/* Gradient hero header — checkout order summary sidebar */
.co-summary-hero {
    background: linear-gradient(135deg, var(--co-primary) 0%, var(--co-primary-dk) 100%);
    padding: 18px 24px;
    position: relative;
    overflow: hidden;
    text-align: left;
}
.co-summary-hero::before {
    content: '';
    position: absolute;
    top: -30px; right: -30px;
    width: 110px; height: 110px;
    border-radius: 50%;
    background: rgba(255,255,255,0.10);
}
.co-summary-hero::after {
    content: '';
    position: absolute;
    bottom: -20px; left: -10px;
    width: 80px; height: 80px;
    border-radius: 50%;
    background: rgba(255,255,255,0.07);
}
.co-summary-hero-top {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 4px;
    position: relative;
    z-index: 1;
}
.co-summary-hero-top i {
    font-size: 20px;
    color: rgba(255,255,255,0.9);
    margin: 0;
}
.co-summary-hero-top h3 {
    font-size: 19px;
    font-weight: 700;
    color: #fff;
    margin: 0;
    font-family: 'Poppins', sans-serif;
    letter-spacing: 0.01em;
}
.co-summary-hero p {
    font-size: 13px;
    color: rgba(255,255,255,0.75);
    margin: 0;
    position: relative;
    z-index: 1;
    float: none;
    text-align: left;
}

/* Responsive — common header */
@media (max-width: 991px) {
    .pg-card-hd h3 { font-size: 16px; }
    .co-page .container,.cart-area-wrapper .container {
        width: 100% !important;
    }
    .checkbox-form {
        background: #f5f5f5;
        padding: 15px;
        margin: 0px !important;
    }
}
@media (max-width: 767px) {
    .pg-card-hd { padding: 13px 14px; gap: 10px; }
    .pg-card-hd h3 { font-size: 15px; }
    .pg-card-icon { width: 34px; height: 34px; font-size: 15px; border-radius: 8px; }
}
@media (max-width: 480px) {
    .pg-card-hd { padding: 11px 12px; gap: 9px; }
    .pg-card-hd h3 { font-size: 14px; }
    .pg-card-icon { width: 30px; height: 30px; font-size: 13px; border-radius: 7px; }
}


/* ════════════════════════════════════════════════════════════
   CART PAGE STYLES
   ════════════════════════════════════════════════════════════ */

/* ── Page wrapper ── */
.cart-area-wrapper {
    background: var(--ct-bg);
    padding-bottom: 60px;
}

/* ── Hero ── */
.cart-hero {
    background: #fff;
    border-bottom: 1px solid var(--ct-border);
    padding: 14px 20px 14px;
    text-align: center;
}
.cart-hero-inner { position: relative; z-index: 1; }
.cart-hero-icon {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--co-lt);
    border: 2px solid var(--cart-border);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 18px; color: var(--co);
    margin-bottom: 8px;
}
.cart-hero h1 {
    font-size: 22px; font-weight: 800;
    color: var(--ct-dark);
    font-family: 'Poppins', sans-serif;
    letter-spacing: -0.02em;
}
.cart-hero p {
    font-size: 13px; color: var(--ct-muted); margin: 0;
}

/* ── Layout — sticky sidebar right ── */
.cart-page-layout {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 24px;
    padding: 28px 0 0;
}
.cart-area-wrapper .container {
    width: 90%;
}
.cart-left {
    flex: 1;
    min-width: 0;
}
.cart-sidebar {
    width: 360px;
    flex-shrink: 0;
    position: sticky;
    top: 16px;
    align-self: flex-start;
}

/* ── Cart items card ── */
.cart-items-card {
    background: var(--ct-card);
    border-radius: var(--ct-radius);
    box-shadow: var(--ct-shadow);
    border: 1px solid var(--ct-border);
    overflow: hidden;
    margin-bottom: 20px;
}
.cart-items-card .cart-top { margin: 0; }

/* ── Cart table ── */
.mycart { margin: 0; border: none !important; }
.cart-total-price del { color: #9b9b9b; }

.mycart thead tr td {
    background: #f4f6fb !important;
    color: var(--ct-dark) !important;
    font-weight: 700 !important;
    border-color: var(--ct-border) !important;
    border-bottom: 2px solid var(--ct-border) !important;
    padding: 11px 16px;
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.mycart tbody tr {
    border-bottom: 1px solid #f0f2f7 !important;
    transition: background 0.15s;
}
.mycart tbody tr:last-child { border-bottom: none !important; }
.mycart tbody tr:hover { background: #fafbfe !important; }
.mycart tbody tr td {
    padding: 16px 16px;
    line-height: 1.4;
    vertical-align: top !important;
    border: none !important;
    border-bottom: 1px solid #f0f2f7 !important;
}
.mycart tbody tr:last-child td { border-bottom: none !important; }

/* Action icons */
.mycart tbody td:first-child {
    vertical-align: top !important;
    padding-top: 20px;
}
@media (min-width: 768px) {
.mycart td .glyphicon-trash,
.mycart td .glyphicon-pencil {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 32px; height: 32px;
    border-radius: 8px;
    font-size: 13px;
    cursor: pointer;
    margin-bottom: 6px;
    transition: all 0.18s ease;
    border: 1px solid var(--ct-border);
    background: #fff;
    color: var(--ct-muted);
}
.mycart td .glyphicon-trash:hover {
    background: #fef2f2 !important;
    border-color: #fca5a5 !important;
    color: #dc2626 !important;
}
.mycart td .glyphicon-pencil:hover {
    background: #f0fdf4 !important;
    border-color: #86efac !important;
    color: #16a34a !important;
}
.cart-banners .ckbnr {
    padding: 0 6px 12px !important;
}
}

/* Product image */
.mycart tbody td .cart-td-img {
    width: 110px;
}
.mycart tbody td .cart-td-img img,
.mycart tbody td > img {
    display: block;
    width: 110px !important;
    height: auto !important;
    border-radius: 10px;
    border: 1px solid var(--ct-border);
    object-fit: cover;
    background: #f8f9fc;
}

/* Product title */
.mycart tbody td h4 {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ct-dark) !important;
    margin: 0 0 12px !important;
    line-height: 1.45;
    font-family: 'Poppins', sans-serif;
}
.mycart tbody td h4 a {
    color: var(--ct-dark) !important;
    text-decoration: none;
}
.mycart tbody td h4 a:hover { color: var(--co) !important; }

/* Spec rows */
.mycart tbody td > p {
    align-items: baseline;
    gap: 6px;
    font-size: 13px !important;
    color: var(--ct-muted) !important;
    margin: 0 0 5px !important;
    line-height: 1.55;
    flex-wrap: wrap;
    text-transform: capitalize;
}
.mycart tbody td > p span {
    font-size: 13px !important;
    text-transform: none !important;
    /* display: inline-block; */
}
.mycart tbody td > p:last-of-type span {
    background: #fff5f0;
    border-color: var(--cart-border);
    color: var(--co) !important;
}

/* Free qty badge */
.mycart .freeQtys {
    display: inline-block;
    background: #f0fdf4;
    color: #16a34a;
    border: 1px solid #bbf7d0;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 9px;
    margin-left: 4px;
}

/* Proof notice */
.mycart tbody td h4[style*="color:#a10000"] {
    font-size: 12px !important;
    color: #b91c1c !important;
    background: #fef2f2;
    border: 1px solid #fca5a5;
    border-radius: 6px;
    padding: 7px 12px;
    margin-top: 10px !important;
    font-weight: 600 !important;
}

/* Price */
.mycart tbody td.cart-total-price,
.mycart tbody td.text-right.cart-total-price {
    font-size: 18px !important;
    font-weight: 800 !important;
    color: var(--co) !important;
    vertical-align: middle !important;
    white-space: nowrap;
}
.mycart .text-right.cart-total-price {
    font-size: 18px !important;
    font-weight: 800 !important;
    color: var(--co) !important;
}

/* ── Quantity / subscription controls ── */
.cart-qty-wrap {
    text-align: center;
    width: auto; min-width: 150px; display: inline-block;
}
button.qty-number { width: auto; height: auto; }
.cart-qty-wrap .qtyInput-wrap { width: auto; display: inline-block; }
.qtyInput-wrap .inputBx { width: 100%; max-width: 60px; text-align: center; }

.subscription-info ul { list-style: none; }
.subscription-info ul li:before { content: '\2713'; font-size: 11px; }
.subscription-info { text-align: left; font-size: 11px; color: #222; }

select.og-select {
    width: 100%; max-width: 125px; height: 30px;
    padding: 6px; font-size: 12px; cursor: pointer;
    border-radius: 2px; border: 1px solid #acabab; color: #222;
    appearance: none; -webkit-appearance: none; -moz-appearance: none;
    background: transparent url("https://static.promoprints.com/data/banner/br_down.png") no-repeat 104px center;
    background-size: 10px; margin-right: 7px;
}
select.og-select::-ms-expand { display: none; }
select.og-select:hover,
select.og-select:focus { color: #222; background-color: white; }
input[type="radio"].og-on-radio {
    -webkit-appearance: checkbox;
    -moz-appearance: checkbox;
    -ms-appearance: checkbox;
}

/* ── Order summary card (sidebar) ── */
.cart-summary-card {
    background: var(--ct-card);
    border-radius: var(--ct-radius);
    box-shadow: 0 4px 24px rgba(255,119,63,0.10), 0 1px 4px rgba(0,0,0,0.06);
    border: 1px solid var(--cart-border);
    overflow: hidden;
}

/* Total rows */
.cart-total-area { padding: 0; }
.cart-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 11px 20px;
    font-size: 13px;
    color: var(--ct-text);
    border-bottom: 1px solid #f3f4f8;
}
.cart-total-row:last-child { border-bottom: none; }
.cart-subtotal span:first-child { color: var(--ct-muted); }
.cart-discount .cart-discount-val { color: #16a34a; font-weight: 700; }

.cart-total-row.order-total {
    background: var(--co-lt);
    border-top: 2px solid var(--cart-border);
    border-bottom: none !important;
    padding: 14px 20px;
    font-weight: 700;
    font-size: 14px;
}
.cart-total-row.order-total span:first-child { color: var(--ct-dark); font-size: 13px; font-weight: 700; }
.cart-total.cart-total-price {
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--co) !important;
}

/* BandBucks */
.store_credit.cart-bandbucks {
    /* display: flex; align-items: flex-start; gap: 8px; flex-wrap: wrap; */
    padding: 11px 20px;
    font-size: 14px; color: var(--ct-text);
    background: #f0fdf4;
    border-bottom: 1px solid #bbf7d0;
    line-height: 1.5;
    text-align: left;
}
.store_credit.cart-bandbucks i { color: #16a34a; font-size: 13px; margin-top: 1px; flex-shrink: 0; }
.store_credit.cart-bandbucks b { color: var(--ct-dark); }
.store_credit { text-align: right; color: #325277; font-size: 16px; }
.store_credit b { color: #d74352; }

/* Coupon */
.cart-coupon-wrap { padding: 14px 20px; border-bottom: 1px solid #f3f4f8; }
.cart-coupon-label {
    font-size: 14px; font-weight: 700; letter-spacing: 0.04em;
    text-transform: uppercase; color: var(--ct-dark);
    display: flex; align-items: center; gap: 8px; margin-bottom: 9px;
}
.cart-coupon-label i { color: var(--co); font-size: 15px; margin: 0px; }
.cart-coupon-row { display: flex; gap: 8px; }
.cart-coupon-input {
    flex: 1; height: 40px;
    border: 1.5px solid var(--ct-border) !important;
    border-radius: 7px !important;
    padding: 0 11px !important;
    font-size: 14px !important; outline: none;
    transition: border-color 0.2s; background: #fff;
    color: var(--ct-dark);
}
.cart-coupon-input:focus { border-color: var(--co) !important; }
.cart-coupon-btn {
    height: 40px; padding: 0 18px !important;
    background: var(--co) !important; color: #fff !important;
    border: none !important; border-radius: 7px !important;
    font-size: 14px !important; font-weight: 700 !important;
    cursor: pointer; white-space: nowrap;
    transition: background 0.2s;
    line-height: 40px;
}
.cart-coupon-btn:hover { background: var(--co-dk) !important; }

/* ── Coupon Applied — ticket badge ── */
.cart-coupon-applied {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px 12px 18px;
    background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
    border-radius: 10px;
    border: 1.5px solid #86efac;
    position: relative;
    overflow: hidden;
}
.cart-coupon-applied::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 5px;
    background: linear-gradient(180deg, #16a34a 0%, #22c55e 100%);
    border-radius: 10px 0 0 10px;
}
.cca-icon-wrap {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, #16a34a 0%, #22c55e 100%);
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 3px 10px rgba(22,163,74,0.35);
}
.cca-icon-wrap i { color: #fff !important; font-size: 15px !important; }
.cca-body {
    flex: 1; display: flex; flex-direction: column; gap: 4px; min-width: 0;
}
.cca-label {
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.09em; color: #15803d; line-height: 1;
    display: flex; align-items: center; gap: 5px;
}
.cca-label i { font-size: 10px; }
.cca-code {
    font-size: 14px; font-weight: 800;
    font-family: 'Courier New', Courier, monospace;
    color: #14532d; letter-spacing: 0.1em;
    padding: 3px 10px;
    background: rgba(22,163,74,0.10);
    border: 1.5px dashed #4ade80;
    border-radius: 6px; display: inline-block;
    line-height: 1.5; text-transform: uppercase;
}
.cca-remove {
    width: 28px; height: 28px; border-radius: 50%;
    background: #fff; border: 1.5px solid #fca5a5;
    display: inline-flex !important; align-items: center; justify-content: center;
    color: #dc2626 !important; font-size: 11px;
    cursor: pointer; flex-shrink: 0;
    transition: all 0.2s ease; text-decoration: none; line-height: 1;
}
.cca-remove i { color: #dc2626; font-size: 11px; line-height: 1; }
.cca-remove:hover {
    background: #fef2f2 !important; border-color: #dc2626 !important;
    transform: scale(1.12); box-shadow: 0 2px 8px rgba(220,38,38,0.25);
}

/* ── Login prompt trigger ── */
.cart-login-prompt { padding: 12px 20px; border-bottom: 1px solid #f3f4f8; }
.conLogin .btnLogin {
    cursor: pointer; color: #2a6496; font-size: 15px;
    display: inline-flex; align-items: center; gap: 6px;
    text-decoration: none; font-weight: 600;
}
.conLogin .btnLogin:hover { color: var(--co); text-decoration: none; }

/* ── Login modal redesign ── */
.co-login-modal { max-width: 420px; margin: 60px auto; }
#loginPopup .modal-content {
    border: none;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,0.22);
}
.co-login-hd {
    background: linear-gradient(135deg, var(--co-primary) 0%, var(--co-primary-dk) 100%);
    padding: 36px 28px 28px;
    text-align: center;
    position: relative;
}
.co-login-close {
    position: absolute;
    top: 14px; right: 16px;
    background: rgba(255,255,255,0.15);
    border: none;
    color: #fff;
    width: 30px; height: 30px;
    border-radius: 50%;
    font-size: 17px;
    line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background 0.2s;
    padding: 0;
}
.co-login-close:hover { background: rgba(255,255,255,0.3); }
.co-login-icon-wrap {
    width: 58px; height: 58px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    border: 2px solid rgba(255,255,255,0.3);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 22px; color: #fff;
    margin-bottom: 14px;
}
.co-login-hd h3 {
    font-size: 20px; font-weight: 700; color: #fff;
    margin: 0 0 6px;
    font-family: 'Poppins', sans-serif;
}
.co-login-hd p { font-size: 13px; color: rgba(255,255,255,0.7); margin: 0; }
.co-login-body { padding: 28px 28px 24px; background: #fff; }
.co-login-field { margin-bottom: 18px; }
.co-login-field-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 7px;
}
.co-login-field > label,
.co-login-field-row label {
    font-size: 13px; font-weight: 600;
    color: #374151; margin: 0;
    font-family: 'Poppins', sans-serif;
}
.co-login-forgot {
    font-size: 12px; color: var(--co);
    text-decoration: none; font-weight: 500;
    display: contents;
}
.co-login-forgot:hover { text-decoration: underline; color: var(--co); }
.co-login-field > label { display: block; margin-bottom: 7px; }
.co-login-input-wrap { position: relative;display: flex;}
.co-login-input-wrap i {
    position: absolute; left: 14px; top: 50%;
    transform: translateY(-50%);
    color: #9ca3af; font-size: 14px;
    pointer-events: none; z-index: 1;
}
.co-login-input-wrap input.form-control {
    width: 100% !important;
    height: 46px !important;
    border: 1.5px solid var(--co-border) !important;
    border-radius: 8px !important;
    padding: 0 14px 0 42px !important;
    font-size: 14px !important;
    color: var(--co-text) !important;
    background: #fff !important;
    font-family: 'Poppins', sans-serif !important;
    box-shadow: none !important;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    margin-bottom: 0 !important;
}
.co-login-input-wrap input.form-control:focus {
    border-color: var(--co-primary) !important;
    box-shadow: 0 0 0 3px rgba(13,17,23,0.08) !important;
}
.co-login-input-wrap input.form-control.error {
    border-color: #ef4444 !important;
    background: #fff5f5 !important;
}
.co-login-btn {
    display: block;
    width: 100%;
    height: 50px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--co-primary) 0%, var(--co-primary-dk) 100%);
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    border: none;
    cursor: pointer;
    letter-spacing: 0.02em;
    font-family: 'Poppins', sans-serif;
    box-shadow: 0 4px 16px rgba(13,17,23,0.22);
    transition: all 0.22s ease;
    margin-top: 6px;
}
.co-login-btn:hover {
    opacity: 0.9;
    transform: translateY(-1px);
    box-shadow: 0 6px 22px rgba(13,17,23,0.3);
}
@media (max-width: 480px) {
    .co-login-modal { margin: 30px 12px; }
    .co-login-hd { padding: 28px 20px 22px; }
    .co-login-body { padding: 20px 20px 18px; }
}

/* Amazon Pay */
.cart-amazonpay { padding: 12px 20px; border-bottom: 1px solid #f3f4f8; }
span.or-text {
    background: #00aeef; padding: 4px 10px; border-radius: 12px;
    color: #fff; font-weight: bold; font-size: 11px;
}

/* Checkout button */
.cart-checkout-wrap { padding: 16px 20px 18px; }
.checkout-button.cart-checkout-btn {
    display: block !important; width: 100% !important;
    background: linear-gradient(135deg, var(--co) 0%, var(--co-dk) 100%) !important;
    color: #fff !important; text-align: center !important;
    padding: 14px 20px !important; border-radius: 9px !important;
    font-size: 15px !important; font-weight: 700 !important;
    text-decoration: none !important; letter-spacing: 0.01em;
    transition: opacity 0.2s, transform 0.15s;
    box-shadow: 0 4px 16px rgba(255,119,63,0.30);
}
.checkout-button.cart-checkout-btn:hover {
    opacity: 0.93; transform: translateY(-1px);
    color: #fff !important; text-decoration: none !important;
}
.cart-email-quote {
    text-align: center; margin: 10px 0 0; font-size: 14px;
}
.cart-email-quote a.QEm {
    color: var(--ct-muted); text-decoration: none;
    display: inline-flex; align-items: center; gap: 5px;
    transition: color 0.2s;
}
.cart-email-quote a.QEm:hover { color: var(--co); }

/* ── Discount meter — full width ── */
.cart-discount-meter-full {
    background: #fff;
    border-radius: var(--ct-radius);
    box-shadow: var(--ct-shadow);
    border: 1px solid var(--ct-border);
    padding: 0;
    margin-top: 24px;
    overflow: hidden;
}
.cart-meter-inner {
    align-items: center;
    gap: 32px;
    padding: 20px 28px 24px;
}
.cart-meter-left {
    flex-shrink: 0;
    min-width: 200px;
}
.cart-meter-bar {
    flex: 1;
    min-width: 0;
}
.cart-discount-meter-full .conOffer {
    font-size: 13px; color: var(--ct-muted);
    margin: 0; line-height: 1.5;
}
.cart-discount-meter-full .conOffer a {
    color: #d74352; text-decoration: none; font-weight: 700;
}
.cart-discount-meter-full .conOffer a:hover { text-decoration: underline; }
.cart-discount-meter-full .progress-holder {
    margin: 50px 16px 36px;
    position: relative;
}
.cart-discount-meter-full .progress {
    height: 8px;
    border-radius: 4px;
    background: #e8eaf0;
    box-shadow: none;
}
.cart-discount-meter-full .progress-bar-success {
    background: linear-gradient(90deg, var(--co), #f59e0b);
    border-radius: 4px;
    transition: width 0.6s ease;
}
.cart-discount-meter-full .marker .dot {
    width: 20px; height: 20px;
    border: 3px solid #fff;
    background: #d1d5db;
    box-shadow: 0 0 0 2px #d1d5db;
    margin-top: -7px;
}
.cart-discount-meter-full .marker .dot.active {
    background: var(--co);
    box-shadow: 0 0 0 2px var(--co);
}
.cart-discount-meter-full .marker .top {
    font-size: 11px; font-weight: 700;
    color: #16a34a; white-space: nowrap;
    margin-top: -38px;
}
.cart-discount-meter-full .marker .bottom {
    font-size: 11px; color: var(--ct-muted);
    white-space: nowrap; margin-top: 18px;
}
@media (max-width: 767px) {
    .cart-meter-inner { flex-direction: column; gap: 16px; padding: 16px 16px 20px; }
    .cart-meter-left { min-width: 0; width: 100%; }
    .cart-discount-meter-full .progress-holder { margin: 44px 10px 32px; }
}

/* ── Related products ── */
.cart-related-full {
    margin-top: 32px;
    padding-top: 8px;
    border-top: 1px solid var(--ct-border);
    width: 100%;
}
.container-fluid.related-products-sec {
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    margin-top: 0;
    border-radius: var(--ct-radius);
    overflow: hidden;
}
.related-products-sec .lanyard-wrapper h3 {
    font-size: 20px !important; color: var(--ct-dark) !important;
    font-weight: 700 !important; text-decoration: none !important;
    margin-bottom: 24px; text-transform: uppercase; letter-spacing: 0.03em;
}

/* ── Misc ── */
.aws-errors {
    color: #b91c1c; text-align: center; padding: 14px;
    border: 1px solid #fca5a5; background: #fef2f2;
    margin: 14px 0; border-radius: 8px; font-size: 13px;
}
.cart-delivery-msg { padding: 8px 0; }
#cartmsg {
    color: #92400e; font-size: 13px; display: block;
    text-align: center; background: #fffbeb;
    border: 1px solid #fde68a; border-radius: 8px;
    padding: 10px 16px; margin-bottom: 16px;
}
.cart-banners {
    margin: 24px 0 8px;
}
.cart-banners .ckbnr {
    padding: 15px 0px;
}
.cart-banner-card {
    background: var(--ct-card);
    border-radius: var(--ct-radius);
    border: 1px solid var(--ct-border);
    box-shadow: var(--ct-shadow);
    overflow: hidden;
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}
.cart-banner-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 28px rgba(0,0,0,0.11);
}
.cart-banner-card img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: var(--ct-radius);
}
.cart-banner-card-body {
    padding: 28px 20px 26px;
    text-align: center;
}
.cart-banner-card-icon {
    width: 60px; height: 60px;
    border-radius: 50%;
    background: var(--co-lt);
    border: 2px solid var(--cart-border);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 24px; color: var(--co);
    margin-bottom: 14px;
    transition: background 0.22s, color 0.22s;
}
.cart-banner-card:hover .cart-banner-card-icon {
    background: var(--co);
    color: #fff;
    border-color: var(--co);
}
.cart-banner-card-title {
    font-size: 15px; font-weight: 700;
    color: var(--ct-dark); margin: 0 0 8px;
    font-family: 'Poppins', sans-serif;
    line-height: 1.3;
}
.cart-banner-card-desc {
    font-size: 13px; color: var(--ct-muted);
    margin: 0; line-height: 1.6;
}

.cart-continue-wrap { margin-top: 16px; }
.continue-button {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 10px 22px 10px 10px !important;
    border: 2px solid var(--ct-border) !important;
    border-radius: 50px !important;
    color: var(--ct-dark) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    background: var(--ct-card) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
    transition: all 0.22s ease !important;
    height: auto !important;
    line-height: normal !important;
    text-transform: none !important;
    text-shadow: none !important;
    width: 200px !important;
}
.continue-button .cb-icon {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: var(--ct-bg);
    border: 1.5px solid var(--ct-border);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 13px; color: var(--ct-muted) !important;
    flex-shrink: 0;
    transition: all 0.22s ease;
}
.continue-button:hover {
    border-color: var(--co) !important;
    color: var(--co) !important;
    text-decoration: none !important;
    background: var(--co-lt) !important;
    box-shadow: 0 4px 14px rgba(255,119,63,0.18) !important;
}
.continue-button:hover .cb-icon {
    background: var(--co) !important;
    border-color: var(--co) !important;
    color: #fff !important;
    transform: translateX(-2px);
}
.continue-button.btn-block { display: flex !important; justify-content: center; width: 100%; }

.more-products span.mp-span { text-align: center; margin-top: 20px; }
.more-products span.mp-span a { margin: 0 auto; }
p.mp-title { color: #3b3b3b; text-transform: uppercase; margin-bottom: 3px; }
span.mp-span-img { height: 90px; display: block; }

.fa.fa-question {
    font-size: 9px; font-weight: normal;
    padding: 4px 6px; background: #e5e7eb;
    border-radius: 50%; vertical-align: middle;
}
body.modal-open { padding-right: 0 !important; }

/* ── Mobile cart row ── */
.mobile-cart > td {
    padding: 14px 12px 16px !important;
    border: none !important;
    border-bottom: 1px solid #f0f2f7 !important;
    background: #fff;
    vertical-align: top !important;
}
.mobile-cart:last-child > td {
    border-bottom: none !important;
}
.mobile-cart .mobi-img br,
.mobile-cart .mobi-details br { display: none !important; }
.mobile-cart .mobi-img {
    padding-left: 10 !important;
    padding-right: 10px !important;
}
.mobile-cart .mobi-img .box {
    display: block;
}
.mobile-cart .mobi-img .box img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid var(--ct-border);
    background: #f8f9fc;
}
.mobi-details p.price {
    margin-top: 15px;
    width: 100%;
}
.mobi-details .input-group {
    margin-top: 15px;
    width: 100%;
    display: flex;
}
.btn-delete.mobi-delete {
    float: right;
}
.mobile-cart .btn-delete.mobi-delete.glyphicon-trash {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 30px !important;
    padding: 0 14px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    border-radius: 6px !important;
    background: #fef2f2 !important;
    color: #dc2626 !important;
    border: 1.5px solid #fca5a5 !important;
    width: auto !important;
    box-shadow: none !important;
    text-shadow: none !important;
    line-height: 1 !important;
    margin: 0 !important;
    min-width: 0 !important;
    min-height: 0 !important;
    transition: background 0.18s, color 0.18s, border-color 0.18s;
}

/* ── Cart responsive ── */
@media (max-width: 1199px) {
    .cart-sidebar { width: 320px; }
    .cart-left { margin-left: 4rem; }
}
@media (max-width: 991px) {
    .cart-page-layout { flex-direction: column; gap: 20px; }
    .cart-sidebar { width: 100%; position: static; align-self: auto; }
    .cart-left { width: 100%; margin-left: 0; }
    .cart-total.cart-total-price { font-size: 20px !important; }
}
@media (max-width: 767px) {
    .cart-hero { padding: 10px 16px 10px !important }
    .cart-hero h1 { font-size: 19px; }
    .cart-hero-icon { width: 38px; height: 38px; font-size: 16px; }
    .cart-summary-card { box-shadow: var(--ct-shadow); }
    .store_credit { font-size: 13px; text-align: center; }
    .conLogin { margin: 0; }
    #cartmsg { font-size: 12px; }
    .checkout-button.cart-checkout-btn { font-size: 14px !important; padding: 13px 16px !important; }
    .cart-total.cart-total-price { font-size: 19px !important; }
    .cart-area-wrapper { padding: 0px 15px; }
    .mobi-img .box { border: none; }
}
@media (max-width: 480px) {
    .cart-coupon-row { flex-wrap: wrap; }
    .cart-coupon-btn { width: 100%; }
    .cart-page-layout { padding-top: 18px; }
}


/* ════════════════════════════════════════════════════════════
   CHECKOUT PAGE STYLES
   ════════════════════════════════════════════════════════════ */

/* ── Page wrap ── */
.co-page { background: var(--co-bg); padding: 30px 0 60px; }
.co-page .container { width: 90%; }

/* ── Progress bar ── */
.co-progress-wrap {
    background: #fff;
    border-bottom: 1px solid var(--co-border);
    padding: 16px 0;
    margin-bottom: 30px;
}
.co-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
}
.co-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    position: relative;
}
.co-step-num {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #e9eaec;
    color: #9ca3af;
    font-size: 14px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--co-transition);
    z-index: 1;
}
.co-step.done .co-step-num,
.co-step.active .co-step-num {
    background: var(--co-primary);
    color: #fff;
    box-shadow: 0 4px 12px rgba(255,119,63,0.35);
}
.co-step span {
    font-size: 13px;
    font-weight: 600;
    color: var(--co-muted);
    letter-spacing: 0.03em;
    text-transform: uppercase;
}
.co-step.active span, .co-step.done span { color: var(--co-primary); }
.co-step-line {
    flex: 1;
    height: 2px;
    background: var(--co-border);
    min-width: 80px;
    max-width: 120px;
    margin: 0 8px;
    margin-bottom: 22px;
    position: relative;
}
.co-step-line.done { background: var(--co-primary); }

/* ── Cards ── */
.co-card {
    background: var(--co-card);
    border-radius: var(--co-radius);
    box-shadow: var(--co-shadow);
    margin-bottom: 22px;
    overflow: hidden;
}
/* co-card header uses .pg-card-hd — override padding to match checkout spacing */
.co-card > .pg-card-hd {
    padding: 18px 24px;
    border-bottom-color: var(--co-border);
}
.co-card > .pg-card-hd h3 {
    font-size: 16px;
    color: var(--co-text);
    padding: 0px;
}
.co-card-body { padding: 24px; }

/* ── Form fields ── */
.co-field { margin-bottom: 16px; }
.co-field label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #374151;
    margin-bottom: 6px;
    font-family: 'Poppins', sans-serif;
}
.co-field .requiredx { color: var(--co-primary); margin-left: 2px; }
.co-field input[type=text],
.co-field input[type=tel],
.co-field input[type=email],
.co-field select,
.checkout-form-list input,
.checkout-form-list select {
    width: 100%;
    height: 46px;
    border: 1.5px solid var(--co-border);
    border-radius: 8px;
    padding: 0 14px;
    font-size: 14px;
    color: var(--co-text);
    background: #fff;
    font-family: 'Poppins', sans-serif;
    transition: var(--co-transition);
    box-shadow: none !important;
    outline: none;
}
.checkout-form-list input:focus,
.checkout-form-list select:focus {
    border-color: var(--co-primary);
    box-shadow: 0 0 0 3px rgba(255,119,63,0.12) !important;
}
.checkout-form-list input.error,
.checkout-form-list select.error {
    border-color: #ef4444;
}
.checkout-form-list em {
    display: block;
    font-size: 12px;
    color: var(--co-muted);
    margin-top: 4px;
    font-style: normal;
}
.checkout-form-list { margin-bottom: 14px; }

/* ── Billing address toggle ── */
.co-billing-toggle {
    margin: 15px;
    text-align: left;
}
.co-billing-toggle-label {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    background: #fff;
    border: 1.5px solid var(--co-border);
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    user-select: none;
}
.co-billing-toggle-label:hover {
    border-color: var(--co-primary);
    background: var(--co-primary-lt);
}
.co-billing-toggle-box {
    position: relative;
    flex-shrink: 0;
    margin: 0px;
}
.co-billing-toggle-box input[type=checkbox] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}
.co-billing-toggle-check {
    width: 22px;
    height: 22px;
    border-radius: 6px;
    border: 2px solid var(--co-border);
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    transition: all 0.2s ease;
    font-size: 11px;
    color: transparent;
    margin: 0px;
}
.co-billing-toggle-box input:checked ~ .co-billing-toggle-check {
    background: var(--co-primary);
    border-color: var(--co-primary);
    color: #fff;
}
.co-billing-toggle-label:has(input:checked) {
    border-color: var(--co-primary);
    background: var(--co-primary-lt);
}
.co-billing-toggle-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    text-align: left;
    align-items: flex-start;
    margin-left: 0px;
}
.co-billing-toggle-text strong {
    font-size: 15px;
    font-weight: 600;
    color: var(--co-text);
    margin-left: 0px;
}
.co-billing-toggle-text small {
    font-size: 13px;
    color: var(--co-muted);
}

/* Copy billing button */
.cpyBill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0px 18px;
    border-radius: 8px;
    border: 1.5px solid var(--co-primary);
    color: var(--co-primary) !important;
    font-size: 13px;
    font-weight: 600;
    background: var(--co-primary-lt);
    transition: var(--co-transition);
    margin-top: 4px;
    text-decoration: none;
}
.cpyBill:hover { background: var(--co-primary); color: #fff; }

/* Same billing checkbox row */
.co-same-billing {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 24px;
    background: #fafafa;
    border-bottom: 1px solid var(--co-border);
    font-size: 14px;
    font-weight: 500;
    color: var(--co-text);
    cursor: pointer;
}
.co-same-billing input[type=checkbox] {
    width: 18px;
    height: 18px;
    accent-color: var(--co-primary);
    cursor: pointer;
    flex-shrink: 0;
}

/* ── Order summary card ── */
.co-summary-card {
    background: var(--co-card);
    border-radius: var(--co-radius);
    box-shadow: 0 4px 32px rgba(255,119,63,0.13), 0 1px 4px rgba(0,0,0,0.06);
    overflow: hidden;
    margin-bottom: 20px;
    border: 1px solid rgba(255,119,63,0.12);
}
/* co-summary-hero defined in Common Card Header Module above */
.co-summary-body { padding: 6px 22px 0; }
.co-summary-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 13px 0;
    border-bottom: 1px dashed #f0f0f0;
    font-size: 15px;
    color: var(--co-text);
    gap: 8px;
}
.co-summary-row:last-of-type { border-bottom: none; }
.co-summary-row-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    flex-shrink: 0;
}
.co-summary-row-icon.icon-sub  { background: #f0fdf4; color: #22c55e; }
.co-summary-row-icon.icon-ship { background: #eff6ff; color: #3b82f6; }
.co-summary-row-icon.icon-tax  { background: #fefce8; color: #ca8a04; }
.co-summary-row-icon.icon-disc { background: #f0fdf4; color: #16a34a; }
.co-summary-row .label {
    flex: 1;
    color: #4b5563;
    font-weight: 500;
    font-size: 15px;
    display: flex;
}
.co-summary-row .value {
    font-weight: 700;
    font-size: 15px;
    color: var(--co-text);
    white-space: nowrap;
}

/* Protection toggle row */
.co-protect-row {
    background: linear-gradient(135deg, #fff8f5 0%, #fff3ee 100%);
    border: 1.5px dashed rgba(255,119,63,0.3);
    border-radius: 10px;
    padding: 12px 14px;
    margin: 6px 0 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.co-protect-label {
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--co-text);
    flex: 1;
    line-height: 1.4;
}
.co-protect-label img { height: 20px; flex-shrink: 0; }
.co-protect-label .info_circle {
    display: inline-flex;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #e5e7eb;
    color: var(--co-muted);
    font-size: 9px;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    text-decoration: none;
}
.co-protect-price {
    font-size: 15px;
    font-weight: 700;
    color: var(--co-primary);
    white-space: nowrap;
}

/* Grand total strip */
.co-summary-total {
    background: linear-gradient(135deg, #1e2329 0%, #2d3748 100%);
    padding: 18px 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.co-summary-total .t-label {
    font-size: 15px;
    font-weight: 600;
    color: rgba(255,255,255,0.75);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.co-summary-total .t-value {
    font-size: 26px;
    font-weight: 800;
    color: var(--co-primary-lt);
    font-family: 'Poppins', sans-serif;
    letter-spacing: -0.02em;
}

/* Trust badges strip */
.co-trust-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    padding: 12px 22px;
    background: #fafafa;
    border-top: 1px solid #f0f0f0;
    flex-wrap: wrap;
}
.co-trust-badge {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    font-weight: 600;
    color: #6b7280;
    white-space: nowrap;
}
.co-trust-badge i { font-size: 14px; }
.co-trust-badge.green i { color: #22c55e; }
.co-trust-badge.blue  i { color: #3b82f6; }
.co-trust-badge.orange i { color: var(--co-primary); }

/* Sticky sidebar */
@media(min-width: 992px) {
    .co-page .row {
        display: flex;
        flex-wrap: wrap;
        /* stretch (default) so right column = left column height, giving sticky room */
    }
    .co-page .col-lg-8,
    .co-page .col-md-7,
    .co-page .col-lg-4,
    .co-page .col-md-5 { float: none; }

    .co-sidebar-sticky {
        position: sticky;
        top: 16px;
    }
}
@media(max-width: 991px) {
    .co-sidebar-sticky { position: static; }
}

/* ── Payment tabs ── */
.co-pay-tabs { padding: 0 20px 20px; }
.co-pay-tab-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 16px 0 12px;
    border-bottom: 1px solid var(--co-border);
    margin-bottom: 16px;
}
.co-pay-tab-btn {
    display: flex;
    flex: 1 1 auto;
    min-width: 80px;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
    padding: 10px 8px;
    border-radius: 8px;
    border: 1.5px solid var(--co-border);
    background: #fff;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    color: var(--co-muted);
    transition: var(--co-transition);
    white-space: nowrap;
    user-select: none;
    text-align: center;
}
.co-pay-tab-btn img,
.co-pay-tab-btn svg {
    height: 22px;
    width: auto;
    max-width: 38px;
    flex-shrink: 0;
    margin-bottom: 2px;
}
.co-pay-tab-btn:hover {
    border-color: var(--co-primary);
    color: var(--co-primary);
    background: var(--co-primary-lt);
}
.co-pay-tab-btn.active {
    border-color: var(--co-primary);
    background: var(--co-primary-lt);
    color: var(--co-primary);
    box-shadow: 0 2px 10px rgba(255,119,63,0.18);
}

/* Hide original filter list */
.mixitup-menu.methods { display: none !important; }

/* Payment content panels */
.co-pay-panel { display: none; }
.co-pay-panel.active { display: block; animation: coPanelIn 0.2s ease; }
@keyframes coPanelIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.co-pay-panel .ltpush {
    padding: 16px;
    background: #f9fafb;
    border-radius: 10px;
    border: 1px solid var(--co-border);
    margin-top: 4px;
}
.co-pay-panel .ltpush img { max-width: 140px; margin-bottom: 10px; display: block; }
.co-pay-panel .ltpush p { font-size: 14px; color: var(--co-muted); line-height: 1.7; margin: 0; }

/* Stripe card fields wrapper */
.payment-content { padding: 4px 0; background: none; }
.checkout-form-list label strong { font-weight: 600; font-size: 14px; }

/* Stripe fields */
.custom-field {
    height: 46px;
    border: 1.5px solid var(--co-border);
    border-radius: 8px;
    padding: 12px 14px;
    background: #fff;
    transition: var(--co-transition);
}
.custom-field.StripeElement--focus {
    border-color: var(--co-primary);
    box-shadow: 0 0 0 3px rgba(255,119,63,0.12);
}

/* Klarna list */
.list-display li { margin-bottom: .4rem; font-size: 14px; }
.list-checkmarks { padding-left: 0; margin: 10px 0; }
.list-checkmarks li {
    list-style-type: none;
    padding: 6px 0 6px 24px;
    position: relative;
    font-size: 14px;
    color: #374151;
}
.list-checkmarks li:before {
    font-family: 'FontAwesome';
    content: "\f00c";
    position: absolute;
    left: 0;
    color: var(--co-primary);
}

/* ── Terms + Place Order area ── */
.co-terms-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 0px;
    border-top: 1px solid var(--co-border);
    font-size: 14px;
    color: var(--co-muted);
    margin: 0px 20px;
}
.co-terms-row span { margin-left: 0px; }
.co-terms-row input[type=checkbox] {
    width: 16px;
    height: 16px;
    accent-color: var(--co-primary);
    margin-top: 2px;
    flex-shrink: 0;
}
.co-terms-row a { color: var(--co-primary); text-decoration: underline; }

.co-place-btn-wrap {
    padding: 16px 20px 20px;
    background: #fff;
    border-radius: 0 0 var(--co-radius) var(--co-radius);
}
#submit-btn, .btn-green {
    display: block;
    width: 100%;
    height: 54px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--co-primary) 0%, var(--co-primary-dk) 100%);
    color: #fff;
    font-size: 17px;
    font-weight: 700;
    border: none;
    cursor: pointer;
    letter-spacing: 0.02em;
    font-family: 'Poppins', sans-serif;
    box-shadow: 0 6px 20px rgba(255,119,63,0.35);
    transition: var(--co-transition);
}
#submit-btn:hover, .btn-green:hover {
    background: linear-gradient(135deg, var(--co-primary-dk) 0%, #c94c10 100%);
    box-shadow: 0 8px 28px rgba(255,119,63,0.45);
    transform: translateY(-1px);
}
.co-secure-note {
    text-align: center;
    font-size: 13px;
    color: var(--co-muted);
    margin-top: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}
.co-secure-note i { color: #22c55e; }

/* PayPal / GPay containers */
#paypalCheckoutContainer, #payment-request-button { margin-top: 12px; }
div#payment-request-button {
    background-repeat: no-repeat;
    background-position: center;
    border-radius: 8px;
    cursor: pointer;
    padding: 0;
    max-width: 100%;
    margin: 12px 0 0;
}

/* SMS / checkbox fields */
.smsClass { font-size: 11px; color: var(--co-muted); margin-top: 8px; line-height: 1.5; }
.smsClass input { width: auto !important; }
.texasP, .interS, .interSt { margin-top: 8px; }
.checkLoad { margin-top: 12px; text-align: center; }
.your-order h3 { border: none; }

/* ── Checkout responsive ── */
@media(max-width: 768px) {
    .co-progress-wrap { padding: 12px 0; }
    .co-step-line { min-width: 40px; }
    .co-page { padding: 16px 0 40px; }
    .co-card-body { padding: 16px; }
    .co-pay-tabs { padding: 0 14px 16px; }
}

@media (max-width: 576px) {
    .co-page .container, .cart-area-wrapper .container {
        margin: 0px !important;
    }
}


/* ════════════════════════════════════════════════════════════
   THANK-YOU PAGE STYLES
   All classes prefixed .ty-  or scoped via .thanks / .ty-hero ~ sibling selector
   ════════════════════════════════════════════════════════════ */

/* ── Hero ── */
.ty-hero {
    background: linear-gradient(135deg,#0a0e1a 0%,#0d1117 40%,#162033 100%);
    padding: 34px 20px 65px; text-align: center;
    position: relative; overflow: hidden;
}
.ty-hero-orb {
    position: absolute; border-radius: 50%; pointer-events: none;
}
.ty-hero-orb-a {
    width: 700px; height: 700px;
    background: radial-gradient(circle,rgba(255,119,63,.13) 0%,transparent 70%);
    top: -280px; left: -180px;
    animation: tyOrbFloat 9s ease-in-out infinite alternate;
}
.ty-hero-orb-b {
    width: 500px; height: 500px;
    background: radial-gradient(circle,rgba(245,158,11,.11) 0%,transparent 70%);
    bottom: -150px; right: -120px;
    animation: tyOrbFloat 12s ease-in-out infinite alternate-reverse;
}
.ty-hero-orb-c {
    width: 300px; height: 300px;
    background: radial-gradient(circle,rgba(59,130,246,.08) 0%,transparent 70%);
    top: 30px; right: 10%;
    animation: tyOrbFloat 7s ease-in-out infinite alternate;
}
@keyframes tyOrbFloat {
    from { transform: translate(0,0) scale(1); }
    to   { transform: translate(24px,18px) scale(1.08); }
}

/* Check ring */
.ty-hero-ring {
    width: 72px; height: 72px; border-radius: 50%;
    background: linear-gradient(135deg,var(--ty-orange),var(--ty-gold));
    display: inline-flex; align-items: center; justify-content: center;
    margin: 0 auto 16px;
    box-shadow: 0 0 0 18px rgba(255,119,63,.12),0 0 0 36px rgba(255,119,63,.06),0 0 0 54px rgba(255,119,63,.02);
    animation: tyRingIn .7s cubic-bezier(.34,1.56,.64,1) both, tyPulse 2.8s ease-in-out 1s infinite;
    position: relative; z-index: 2;
}
@keyframes tyRingIn {
    from { transform: scale(0) rotate(-90deg); opacity: 0; }
    to   { transform: scale(1) rotate(0); opacity: 1; }
}
@keyframes tyPulse {
    0%,100% { box-shadow: 0 0 0 18px rgba(255,119,63,.12),0 0 0 36px rgba(255,119,63,.06),0 0 0 54px rgba(255,119,63,.02); }
    50%      { box-shadow: 0 0 0 24px rgba(255,119,63,.08),0 0 0 48px rgba(255,119,63,.03),0 0 0 72px rgba(255,119,63,.01); }
}
.ty-hero-ring i { font-size: 32px; color: #fff; animation: tyCheckIn .35s .65s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes tyCheckIn { from { transform: scale(0); } to { transform: scale(1); } }

.ty-hero h1 {
    font-size: 30px; font-weight: 900; color: #fff;
    font-family: 'Poppins',sans-serif; margin: 0 0 10px;
    letter-spacing: -.03em; position: relative; z-index: 2;
    animation: tyFadeUp .5s .3s both;
}
.ty-hero h1 .ty-name {
    background: linear-gradient(135deg,var(--ty-gold) 0%,#fbbf24 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    background-clip: text;
}
.ty-hero-sub {
    font-size: 16px; color: rgba(255,255,255,.65); margin: 0 0 30px;
    position: relative; z-index: 2; animation: tyFadeUp .5s .45s both;
}

/* Pills */
.ty-hero-pills {
    display: flex; align-items: center; justify-content: center;
    gap: 12px; flex-wrap: wrap; position: relative; z-index: 2;
    animation: tyFadeUp .5s .6s both;
}
.ty-hero-pill {
    background: rgba(255,255,255,.09); border: 1px solid rgba(255,255,255,.18);
    border-radius: 50px; padding: 10px 22px;
    display: flex; align-items: center; gap: 8px;
    color: #fff; font-size: 20px; font-weight: 600;
    backdrop-filter: blur(10px); transition: background .2s,border-color .2s;
}
.ty-hero-pill:hover { background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.32); }
.ty-hero-pill i { color: var(--ty-gold); font-size: 15px; }
.ty-hero-pill .val { color: var(--ty-gold); font-weight: 800; font-size: 20px; }

/* SVG wave */
.ty-hero-wave { position: absolute; bottom: -1px; left: 0; right: 0; z-index: 3; line-height: 0; }
.ty-hero-wave svg { display: block; width: 100%; }

/* ── "What happens next" timeline ── */
.ty-timeline {
    display: grid; grid-template-columns: repeat(4,1fr); gap: 0;
    position: relative; padding: 28px 24px 24px;
}
@media(max-width: 600px) { .ty-timeline { grid-template-columns: 1fr 1fr; row-gap: 28px; } }
.ty-timeline-line {
    position: absolute; top: 46px; left: 12%; right: 12%; height: 3px;
    background: linear-gradient(90deg,var(--ty-orange) 0%,var(--ty-gold) 33%,#3b82f6 66%,#9333ea 100%);
    border-radius: 3px; z-index: 0;
}
@media(max-width: 600px) { .ty-timeline-line { display: none; } }
.ty-tl-step { text-align: center; position: relative; z-index: 1; }
.ty-tl-dot {
    width: 44px; height: 44px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 17px; margin: 0 auto 12px;
}
.ty-tl-step.done .ty-tl-dot {
    background: linear-gradient(135deg,var(--ty-orange),var(--ty-gold));
    color: #fff; box-shadow: 0 4px 18px rgba(255,119,63,.45);
}
.ty-tl-step.next .ty-tl-dot {
    background: linear-gradient(135deg,#3b82f6,#6366f1);
    color: #fff; box-shadow: 0 4px 16px rgba(99,102,241,.35);
}
.ty-tl-step.pending .ty-tl-dot {
    background: #f3f4f8; color: #9ca3af; border: 2px dashed #d1d5db;
}
.ty-tl-step.done .ty-tl-dot,
.ty-tl-step.next .ty-tl-dot { animation: tyTlPop .5s cubic-bezier(.34,1.56,.64,1) both; }
.ty-tl-step:nth-child(2) .ty-tl-dot { animation-delay: .15s; }
.thanks .ChkFrm h3 { margin: 0; }
@keyframes tyTlPop { from { transform: scale(0); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.ty-tl-title { font-size: 13px; font-weight: 700; color: var(--ct-dark,#1a1f36); margin-bottom: 3px; }
.ty-tl-step.pending .ty-tl-title { color: #9ca3af; }
.ty-tl-sub { font-size: 11px; color: var(--ct-muted,#6b7280); }

/* ── Section label ── */
.ty-lbl {
    font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
    color: var(--ct-muted,#6b7280); margin: 28px 0 12px;
    display: flex; align-items: center; gap: 10px;
}
.ty-lbl::after { content:''; flex:1; height:1px; background:var(--ct-border,#e8eaf0); }
.ty-lbl i { font-size: 12px; }

/* ── Address table ── */
.ty-addr-table td { font-size: 13px; line-height: 1.7; vertical-align: top; padding: 14px 18px !important; }
.ty-addr-table thead td { font-size: 14px; font-weight: 700; color: var(--ct-dark,#1a1f36); background: #f8f9fc; }

/* ── Products nav ── */
.ty-nav-body { padding: 16px 18px 20px; }
.ty-nav-body ul { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.ty-nav-body ul li a {
    display: flex; flex-direction: column; align-items: center; gap: 6px;
    padding: 12px 14px; border-radius: 12px;
    border: 1.5px solid var(--ct-border,#e8eaf0);
    text-decoration: none; font-size: 11px; font-weight: 600;
    color: var(--ct-dark,#1a1f36); min-width: 72px; text-align: center;
    background: #fff; transition: all .22s;
}
.ty-nav-body ul li a:hover {
    border-color: var(--ty-orange); background: rgba(255,119,63,.04);
    color: var(--ty-orange); transform: translateY(-3px);
    box-shadow: 0 6px 16px rgba(255,119,63,.18);
}
.ty-nav-body ul li a img { height: 34px; width: auto; transition: transform .22s; }
.ty-nav-body ul li a:hover img { transform: scale(1.15); }

/* ── Register card ── */
.ty-reg-body { padding: 20px 24px; }
.ty-reg-desc { font-size: 13px; color: var(--ct-muted,#6b7280); margin-bottom: 14px; }
.ty-reg-form { display: flex; gap: 10px; flex-wrap: wrap; }
.ty-reg-form input[type=email],.ty-reg-form input[type=password] {
    flex: 1; min-width: 130px; height: 44px;
    border: 1.5px solid var(--co-border,#e5e7eb); border-radius: 9px;
    padding: 0 14px; font-size: 14px; background: #f9fafb; outline: none;
    color: var(--co-text,#1e2329); transition: all .2s;
}
.ty-reg-form input[type=email]:focus,
.ty-reg-form input[type=password]:focus {
    border-color: var(--ty-orange); background: #fff;
    box-shadow: 0 0 0 3px rgba(255,119,63,.10);
}
.ty-reg-form input[type=submit] {
    height: 44px; padding: 0 24px;
    background: linear-gradient(135deg,var(--ty-orange),#e85a1a);
    color: #fff; border: none; border-radius: 9px;
    font-size: 14px; font-weight: 700; cursor: pointer; white-space: nowrap;
    box-shadow: 0 4px 14px rgba(255,119,63,.35); transition: all .2s;
}
.ty-reg-form input[type=submit]:hover { opacity: .9; transform: translateY(-1px); }

/* ── Order total footer ── */
.ty-order-footer {
    display: flex; align-items: center; justify-content: flex-end; gap: 18px;
    padding: 18px 24px;
    background: linear-gradient(135deg,#0d1117 0%,#1a2638 100%);
    border-top: 1px solid rgba(255,255,255,.06);
    flex-wrap: wrap;
}
.ty-order-footer .ot-label, .ty-order-footer .ot-val { font-size: 28px; font-weight: 900; color: #fff; font-family: 'Poppins',sans-serif; letter-spacing: -.02em; }

/* ── Share strip ── */
.ty-share-strip {
    background: linear-gradient(135deg,#0d1117 0%,#1a2638 100%);
    border-radius: 14px; padding: 26px 32px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 20px; flex-wrap: wrap;
    box-shadow: 0 6px 32px rgba(0,0,0,.18);
    position: relative; overflow: hidden;
}
.ty-share-strip::before {
    content:''; position: absolute; top:-50px; right:-50px;
    width: 180px; height: 180px; border-radius: 50%;
    background: rgba(255,119,63,.12);
}
.ty-share-strip::after {
    content:''; position: absolute; bottom:-40px; left: 20%;
    width: 120px; height: 120px; border-radius: 50%;
    background: rgba(245,158,11,.08);
}
.ty-share-left { position: relative; z-index: 1; }
.ty-share-left h4 { font-size: 20px; font-weight: 800; color: #fff; margin: 0 0 5px; }
.ty-share-left p  { font-size: 13px; color: rgba(255,255,255,.6); margin: 0; }
.ty-share-amount {
    font-size: 28px; font-weight: 900; color: var(--ty-gold);
    font-family: 'Poppins',sans-serif; line-height: 1;
    position: relative; z-index: 1; text-align: center;
}
.ty-share-amount small { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.55); display: block; margin-top: 4px; letter-spacing: .05em; text-transform: uppercase; }
#shareIcons { display: flex; align-items: center; gap: 10px; position: relative; z-index: 1; }

/* ── Note card ── */
.ty-note-card {
    background: linear-gradient(135deg,#fffbeb 0%,#fef9e5 100%);
    border: 1px solid #fde68a; border-radius: 14px;
    padding: 16px 22px; display: flex; gap: 14px; align-items: flex-start;
    font-size: 13px; color: #78350f; line-height: 1.75;
    box-shadow: 0 2px 12px rgba(245,158,11,.08);
}
.ty-note-card i { color: #f59e0b; font-size: 20px; flex-shrink: 0; margin-top: 2px; }

/* ── Card entry animation (thank-you page only — scoped via sibling selector) ── */
@keyframes tyFadeUp {
    from { opacity: 0; transform: translateY(18px); }
    to   { opacity: 1; transform: translateY(0); }
}
.ty-hero ~ .co-page .co-card { animation: tyFadeUp .5s both; }
.ty-hero ~ .co-page .co-card:nth-child(2) { animation-delay: .08s; }
.ty-hero ~ .co-page .co-card:nth-child(3) { animation-delay: .14s; }
.ty-hero ~ .co-page .co-card:nth-child(4) { animation-delay: .20s; }
.ty-hero ~ .co-page .co-card:nth-child(5) { animation-delay: .26s; }

/* ── Confetti particle ── */
@keyframes tyFall { to { transform: translateY(110vh) rotate(900deg); opacity: 0; } }

.thanks .text-right.cart-total-price { float: right; }

@media(max-width: 767px) {
    .ty-hero { padding: 24px 16px 55px; }
    .ty-hero h1 { font-size: 22px; }
    .ty-hero-pill { font-size: 12px; padding: 8px 14px; }
    .ty-reg-form { flex-direction: column; }
    .ty-order-footer .ot-val { font-size: 22px; }
    .ty-share-strip { padding: 20px; }
    .ty-share-amount { font-size: 36px; }
    .ty-share-left h4 { font-size: 16px; }
}