/* =============================================================================
   LoyalStar — Rewards Page (loyalty-rewards.css, v1.38.0)
   Scoped to .ls-rewards-page. Relies on --ls-* tokens from loyalty.css.
   If loyalty.css is not on the page, tokens fall back gracefully via the
   :root block below (same values, kept in sync with loyalty.css v1.21.0).
   ============================================================================= */

.ls-rewards-page {
    /* Tokens come from loyalty.css :root — the 'loyalstar-rewards' style depends
       on the 'loyalstar' handle, so loyalty.css (+ the merchant-accent inline
       override) is always present. NEVER re-define --ls-* tokens here: a scoped
       definition shadows the :root override and kills the accent setting. */
    font-size: var(--ls-fs-body);
    color: var(--ls-ink);
    line-height: 1.6;
}

/* --- Headings ---------------------------------------------------------------- */
.ls-rewards-page h1,
.ls-rewards-page h2,
.ls-rewards-page h3 {
    font-weight: normal;
    color: var(--ls-ink);
    line-height: 1.2;
}

/* --- Hero -------------------------------------------------------------------- */
.ls-rw-hero {
    background: var(--ls-linen);
    border-bottom: 1px solid var(--ls-linen-line);
    margin: 0 calc(-1 * var(--ls-s-md, 24px));
    padding: var(--ls-s-xl) var(--ls-s-md);
    text-align: center;
}
.ls-rw-hero__inner {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--ls-s-sm);
}
.ls-rw-hero h1 {
    font-size: 3rem;
    line-height: 1.1;
    margin-top: var(--ls-s-2xs);
}
.ls-rw-hero__desc {
    font-size: var(--ls-fs-body);
    color: var(--ls-muted);
    max-width: 520px;
    margin: 0 auto;
}
.ls-rw-hero__actions {
    display: flex;
    gap: var(--ls-s-sm);
    margin-top: var(--ls-s-xs);
    flex-wrap: wrap;
    justify-content: center;
}

/* --- Buttons ----------------------------------------------------------------- */
.ls-rw-btn-primary {
    background-color: var(--ls-accent);
    color: var(--ls-paper);
    border: none;
    border-radius: var(--ls-r-sm);
    padding: 12px 24px;
    font-size: var(--ls-fs-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--ls-tracking-label);
    text-decoration: none;
    display: inline-block;
    cursor: pointer;
}
.ls-rw-btn-primary:hover {
    background-color: var(--ls-accent-hover);
    color: var(--ls-paper);
    text-decoration: none;
}
.ls-rw-btn-secondary {
    background-color: transparent;
    color: var(--ls-ink);
    border: 1px solid var(--ls-linen-line);
    border-radius: var(--ls-r-sm);
    padding: 12px 24px;
    font-size: var(--ls-fs-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--ls-tracking-label);
    text-decoration: none;
    display: inline-block;
    cursor: pointer;
}
.ls-rw-btn-secondary:hover {
    border-color: var(--ls-muted);
    background-color: var(--ls-linen);
    text-decoration: none;
}

/* --- Main container ---------------------------------------------------------- */
.ls-rw-main {
    max-width: 900px;
    margin: 0 auto;
    padding: var(--ls-s-xl) 0;
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-xl);
}

/* --- Section ----------------------------------------------------------------- */
.ls-rw-section {
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-md);
}
.ls-rw-section__header {
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-2xs);
}
.ls-rw-section h2 {
    font-size: var(--ls-fs-display-md);
}
.ls-rw-section__intro {
    font-size: var(--ls-fs-body);
    color: var(--ls-muted);
    max-width: 600px;
}

/* --- Shared primitives ------------------------------------------------------- */
.ls-rw-kicker {
    font-size: var(--ls-fs-label);
    letter-spacing: var(--ls-tracking-label);
    text-transform: uppercase;
    color: var(--ls-muted);
    font-weight: 600;
    display: block;
}
.ls-rw-card {
    background: var(--ls-paper);
    border: 1px solid var(--ls-linen-line);
    border-radius: var(--ls-r-sm);
    padding: var(--ls-s-md);
}
.ls-rw-card:hover {
    border-color: var(--ls-accent);
}
.ls-rw-surface {
    background: var(--ls-linen);
    border-radius: var(--ls-r-md);
    padding: var(--ls-s-md);
}
.ls-rw-badge {
    background: var(--ls-sage);
    color: var(--ls-sage-ink);
    padding: var(--ls-s-2xs) var(--ls-s-xs);
    border-radius: var(--ls-r-pill);
    font-size: var(--ls-fs-label);
    font-weight: 600;
    letter-spacing: var(--ls-tracking-label);
    text-transform: uppercase;
    white-space: nowrap;
    display: inline-block;
}

/* --- How It Works ------------------------------------------------------------ */
.ls-rw-steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ls-s-md);
}
.ls-rw-step {
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-xs);
}
.ls-rw-step__num {
    font-size: var(--ls-fs-display-lg);
    color: var(--ls-clay-ink);
    line-height: 1;
    font-weight: normal;
}
.ls-rw-step h3 {
    font-size: 1.15rem;
}
.ls-rw-step p {
    font-size: var(--ls-fs-sm);
    color: var(--ls-muted);
    line-height: 1.4;
}

/* --- Ways to Earn ------------------------------------------------------------ */
.ls-rw-earn-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--ls-s-sm);
}
.ls-rw-earn-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: var(--ls-s-sm);
}
.ls-rw-earn-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--ls-s-xs);
}
.ls-rw-earn-card h3 {
    font-size: 1.1rem;
    line-height: 1.3;
}
.ls-rw-earn-card p {
    font-size: var(--ls-fs-sm);
    color: var(--ls-muted);
    line-height: 1.4;
}

/* --- How to Redeem ----------------------------------------------------------- */
.ls-rw-redeem {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: var(--ls-s-lg);
    align-items: center;
}
.ls-rw-redeem__visual {
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-2xs);
}
.ls-rw-rate {
    font-size: 2.25rem;
    color: var(--ls-clay-ink);
    line-height: 1.1;
    font-weight: normal;
}
.ls-rw-redeem__copy {
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-xs);
}
.ls-rw-redeem__lead {
    font-size: 1.15rem;
    color: var(--ls-ink);
    line-height: 1.4;
    font-weight: normal;
}
.ls-rw-redeem__copy p {
    font-size: var(--ls-fs-body);
    color: var(--ls-muted);
    line-height: 1.5;
}

/* --- The Journey (Tiers) ----------------------------------------------------- */
.ls-rw-journey {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--ls-s-sm);
}
.ls-rw-tier-card {
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-sm);
}
.ls-rw-tier-card__header {
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-2xs);
}
.ls-rw-tier-card h3 {
    font-size: 1.2rem;
}
.ls-rw-tier-pill {
    display: inline-block;
    background: var(--ls-linen);
    color: var(--ls-muted);
    font-size: var(--ls-fs-label);
    padding: 2px 8px;
    border-radius: var(--ls-r-pill);
    align-self: flex-start;
    font-weight: 600;
    letter-spacing: 0.02em;
}
.ls-rw-multiplier {
    font-size: 2.5rem;
    color: var(--ls-clay-ink);
    line-height: 1;
    font-weight: normal;
}
.ls-rw-perks {
    list-style: none;
    border-top: 1px solid var(--ls-linen-line);
    padding-top: var(--ls-s-sm);
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-xs);
}
.ls-rw-perks li {
    font-size: var(--ls-fs-sm);
    color: var(--ls-muted);
    line-height: 1.3;
    position: relative;
    padding-left: 12px;
}
.ls-rw-perks li::before {
    content: '•';
    color: var(--ls-accent);
    position: absolute;
    left: 0;
}

/* --- FAQ Accordion ----------------------------------------------------------- */
.ls-rw-faq {
    display: flex;
    flex-direction: column;
}
.ls-rw-faq details {
    border-bottom: 1px solid var(--ls-linen-line);
    padding: var(--ls-s-sm) 0;
}
.ls-rw-faq summary {
    font-size: 1rem;
    color: var(--ls-ink);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    list-style: none;
    user-select: none;
    font-weight: normal;
}
.ls-rw-faq summary::-webkit-details-marker {
    display: none;
}
.ls-rw-faq summary::after {
    content: '+';
    font-size: 1.25rem;
    color: var(--ls-muted);
    font-weight: 300;
}
.ls-rw-faq details[open] summary::after {
    content: '\2212';
}
.ls-rw-faq details p {
    font-size: var(--ls-fs-sm);
    color: var(--ls-muted);
    margin-top: var(--ls-s-xs);
    line-height: 1.5;
}

/* --- Referral Band ----------------------------------------------------------- */
.ls-rw-referral {
    background-color: var(--ls-sage);
    border-radius: var(--ls-r-md);
    padding: var(--ls-s-lg);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--ls-s-lg);
}
.ls-rw-referral__content {
    display: flex;
    flex-direction: column;
    gap: var(--ls-s-2xs);
}
.ls-rw-referral__content h2 {
    font-size: var(--ls-fs-display-md);
    color: var(--ls-sage-ink);
}
.ls-rw-referral__content p {
    font-size: var(--ls-fs-body);
    color: var(--ls-sage-ink);
}

/* --- Closing line ------------------------------------------------------------ */
.ls-rw-closing {
    text-align: center;
    padding: var(--ls-s-md) 0 var(--ls-s-lg);
}
.ls-rw-closing p {
    font-size: var(--ls-fs-sm);
    color: var(--ls-muted);
    max-width: 500px;
    margin: 0 auto;
    line-height: 1.5;
}

/* --- Responsive -------------------------------------------------------------- */
@media (max-width: 640px) {
    .ls-rw-hero {
        padding: var(--ls-s-lg) var(--ls-s-md);
    }
    .ls-rw-hero h1 {
        font-size: var(--ls-fs-display-lg);
    }
    .ls-rw-steps {
        grid-template-columns: 1fr;
        gap: var(--ls-s-sm);
    }
    .ls-rw-earn-grid {
        grid-template-columns: 1fr;
        gap: var(--ls-s-sm);
    }
    .ls-rw-redeem {
        grid-template-columns: 1fr;
        gap: var(--ls-s-md);
    }
    .ls-rw-journey {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--ls-s-sm);
    }
    .ls-rw-referral {
        flex-direction: column;
        align-items: stretch;
        text-align: center;
        gap: var(--ls-s-md);
    }
}
@media (max-width: 420px) {
    .ls-rw-journey {
        grid-template-columns: 1fr;
    }
}
