/* ============================================
   MAGICK BUNDLES — Frontend Tier Selector
   Three themes: dark (default), light, mystical
   ============================================ */

/* ---------- Theme Variables ---------- */
.magick-bundle-selector[data-theme="dark"] {
    --mb-bg: #0d0d0d;
    --mb-card-bg: #1a1a1a;
    --mb-card-border: #2a2a2a;
    --mb-card-selected-border: #c9a96e;
    --mb-card-selected-bg: #1a1710;
    --mb-text: #e8e4df;
    --mb-text-muted: #8a857e;
    --mb-price: #c9a96e;
    --mb-original-price: #665e54;
    --mb-savings: #8b9e6b;
    --mb-badge-popular-bg: #c9a96e;
    --mb-badge-popular-text: #0d0d0d;
    --mb-badge-deal-bg: #8b9e6b;
    --mb-badge-deal-text: #0d0d0d;
    --mb-badge-starter-bg: #3a3a3a;
    --mb-badge-starter-text: #b0aaa2;
    --mb-radio-border: #444;
    --mb-radio-active: #c9a96e;
    --mb-heading-line: #2a2a2a;
    --mb-gift-bg: rgba(201, 169, 110, 0.08);
    --mb-gift-text: #c9a96e;
    --mb-font: 'Segoe UI', -apple-system, sans-serif;
    --mb-variation-bg: #141414;
    --mb-variation-border: #333;
    --mb-variation-label: #a09a92;
}

.magick-bundle-selector[data-theme="light"] {
    --mb-bg: #fafaf8;
    --mb-card-bg: #ffffff;
    --mb-card-border: #e5e2dc;
    --mb-card-selected-border: #1a1a1a;
    --mb-card-selected-bg: #f5f4f1;
    --mb-text: #1a1a1a;
    --mb-text-muted: #7a7670;
    --mb-price: #1a1a1a;
    --mb-original-price: #b0aaa2;
    --mb-savings: #4a7c3f;
    --mb-badge-popular-bg: #1a1a1a;
    --mb-badge-popular-text: #ffffff;
    --mb-badge-deal-bg: #4a7c3f;
    --mb-badge-deal-text: #ffffff;
    --mb-badge-starter-bg: #e5e2dc;
    --mb-badge-starter-text: #7a7670;
    --mb-radio-border: #ccc;
    --mb-radio-active: #1a1a1a;
    --mb-heading-line: #e5e2dc;
    --mb-gift-bg: rgba(74, 124, 63, 0.06);
    --mb-gift-text: #4a7c3f;
    --mb-font: 'Segoe UI', -apple-system, sans-serif;
    --mb-variation-bg: #f9f9f7;
    --mb-variation-border: #e0ddd7;
    --mb-variation-label: #666;
}

.magick-bundle-selector[data-theme="mystical"] {
    --mb-bg: #0f0a17;
    --mb-card-bg: #1a1226;
    --mb-card-border: #2d2040;
    --mb-card-selected-border: #9b7ec8;
    --mb-card-selected-bg: #1e1530;
    --mb-text: #e0d8ee;
    --mb-text-muted: #8878a0;
    --mb-price: #c4a8e8;
    --mb-original-price: #5a4d6e;
    --mb-savings: #7ec88a;
    --mb-badge-popular-bg: #9b7ec8;
    --mb-badge-popular-text: #0f0a17;
    --mb-badge-deal-bg: #7ec88a;
    --mb-badge-deal-text: #0f0a17;
    --mb-badge-starter-bg: #2d2040;
    --mb-badge-starter-text: #8878a0;
    --mb-radio-border: #3d3050;
    --mb-radio-active: #9b7ec8;
    --mb-heading-line: #2d2040;
    --mb-gift-bg: rgba(155, 126, 200, 0.08);
    --mb-gift-text: #c4a8e8;
    --mb-font: 'Segoe UI', -apple-system, sans-serif;
    --mb-variation-bg: #140e1e;
    --mb-variation-border: #352548;
    --mb-variation-label: #8878a0;
}

/* ---------- Container ---------- */
.magick-bundle-selector {
    font-family: var(--mb-font);
    margin: 1.5rem 0;
    max-width: 500px;
}

/* ---------- Heading ---------- */
.magick-bundle-heading {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.magick-bundle-heading .heading-line {
    flex: 1;
    height: 1px;
    background: var(--mb-heading-line);
}

.magick-bundle-heading .heading-text {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--mb-text);
    white-space: nowrap;
}

/* ---------- Tier Cards ---------- */
.magick-bundle-tiers {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.magick-tier-card {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    background: var(--mb-card-bg);
    border: 2px solid var(--mb-card-border);
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    user-select: none;
}

.magick-tier-card:hover {
    border-color: var(--mb-card-selected-border);
}

.magick-tier-card.selected {
    border-color: var(--mb-card-selected-border);
    background: var(--mb-card-selected-bg);
    box-shadow: 0 0 0 1px var(--mb-card-selected-border);
}

/* ---------- Radio Button ---------- */
.tier-radio {
    position: relative;
    flex-shrink: 0;
    width: 22px;
    height: 22px;
}

.tier-radio input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
    margin: 0;
    z-index: 2;
}

.tier-radio .radio-dot {
    display: block;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid var(--mb-radio-border);
    background: transparent;
    transition: all 0.2s ease;
    position: relative;
}

.tier-radio .radio-dot::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--mb-radio-active);
    transition: transform 0.15s ease;
}

.magick-tier-card.selected .radio-dot {
    border-color: var(--mb-radio-active);
}

.magick-tier-card.selected .radio-dot::after {
    transform: translate(-50%, -50%) scale(1);
}

/* ---------- Tier Info ---------- */
.tier-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}

.tier-label {
    font-size: 15px;
    font-weight: 600;
    color: var(--mb-text);
    line-height: 1.3;
}

.tier-savings {
    font-size: 12px;
    font-weight: 500;
    color: var(--mb-savings);
}

/* Strip WooCommerce price wrapper styling inside savings */
.tier-savings .woocommerce-Price-amount {
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
}

.tier-gift {
    font-size: 12px;
    font-weight: 500;
    color: var(--mb-gift-text);
    background: var(--mb-gift-bg);
    padding: 2px 8px;
    border-radius: 4px;
    display: inline-block;
    margin-top: 2px;
    width: fit-content;
}

/* BOGO summary */
.tier-bogo-summary {
    font-size: 13px;
    font-weight: 600;
    color: var(--mb-savings);
    margin-top: 2px;
}

.tier-bogo-total {
    font-size: 11px;
    font-weight: 400;
    color: var(--mb-text-muted);
    margin-left: 4px;
}

/* ---------- Tier Pricing ---------- */
.tier-pricing {
    flex-shrink: 0;
    text-align: right;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.tier-price {
    font-size: 17px;
    font-weight: 700;
    color: var(--mb-price);
}

.tier-price .woocommerce-Price-amount {
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
}

.tier-original-price {
    font-size: 13px;
    font-weight: 400;
    color: var(--mb-original-price);
    text-decoration: line-through;
}

.tier-original-price .woocommerce-Price-amount {
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
    text-decoration: inherit;
}

/* ---------- Badges ---------- */
.magick-tier-badge {
    position: absolute;
    top: -10px;
    right: 16px;
    padding: 3px 12px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    line-height: 1.4;
    z-index: 1;
}

.magick-tier-badge.badge-most_popular {
    background: var(--mb-badge-popular-bg);
    color: var(--mb-badge-popular-text);
}

.magick-tier-badge.badge-best_deal {
    background: var(--mb-badge-deal-bg);
    color: var(--mb-badge-deal-text);
}

.magick-tier-badge.badge-starter {
    background: var(--mb-badge-starter-bg);
    color: var(--mb-badge-starter-text);
}

/* ---------- Variation Selectors ---------- */
.tier-variations {
    width: 100%;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--mb-card-border);
}

.magick-variation-row {
    margin-bottom: 10px;
    padding: 10px 12px;
    background: var(--mb-variation-bg);
    border: 1px solid var(--mb-variation-border);
    border-radius: 6px;
}

.magick-variation-row:last-child {
    margin-bottom: 0;
}

.variation-row-label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--mb-text-muted);
    margin-bottom: 6px;
}

.variation-selects {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.variation-attribute {
    flex: 1;
    min-width: 120px;
}

.variation-attribute label {
    display: block;
    font-size: 11px;
    color: var(--mb-variation-label);
    margin-bottom: 3px;
    font-weight: 500;
}

.variation-attribute select {
    width: 100%;
    padding: 6px 8px;
    font-size: 13px;
    border-radius: 4px;
    border: 1px solid var(--mb-variation-border);
    background: var(--mb-card-bg);
    color: var(--mb-text);
    cursor: pointer;
}

/* ---------- Gift qty in cart ---------- */
.magick-gift-qty {
    display: inline-block;
    padding: 4px 10px;
    background: var(--mb-gift-bg, rgba(201,169,110,0.08));
    color: var(--mb-gift-text, #c9a96e);
    border-radius: 4px;
    font-weight: 600;
    font-size: 13px;
}

/* ---------- Bundle qty in cart ---------- */
.magick-bundle-qty {
    display: inline-block;
    padding: 4px 10px;
    font-weight: 600;
    font-size: 13px;
}

/* ---------- Responsive ---------- */
@media (max-width: 480px) {
    .magick-tier-card {
        padding: 14px 14px;
        gap: 10px;
    }

    .tier-label {
        font-size: 14px;
    }

    .tier-price {
        font-size: 15px;
    }

    .tier-original-price {
        font-size: 12px;
    }

    .magick-tier-badge {
        font-size: 10px;
        padding: 2px 8px;
    }

    .variation-selects {
        flex-direction: column;
    }

    .variation-attribute {
        min-width: 100%;
    }
}
