/**
 * Promo CTA — server-rendered featured promotion card.
 * Replaces the prior coupon-style dashed-border card + iframe-content
 * combo. Uses the new design system.
 */

.promo-cta {
    background: var(--ink, #011635);
    color: var(--text-on-dark, #F2EFE7);
    padding-block: clamp(2.5rem, 1.5rem + 4vw, 5rem);
    margin: 0;
    border-radius: 0;
    /* Drop the previous max-width and dashed-coupon pseudo-elements. */
}

/* Defensive resets — kill any lingering pseudo-element decorations from
   the previous coupon styling so they don't bleed through cache. */
.promo-cta::before,
.promo-cta::after {
    content: none !important;
    display: none !important;
}

.promo-cta__shell {
    max-width: var(--container-max-width, 1306px);
    margin-inline: auto;
    padding-inline: clamp(1rem, 4vw, 3rem);
}

.promo-cta__card {
    position: relative;
    margin-inline: auto;
    max-width: 720px;
    padding: clamp(1.75rem, 1rem + 2vw, 2.75rem);
    background: var(--paper, #FAF7F1);
    color: var(--text, #0E1729);
    border-radius: var(--radius-md, 6px);
    border: 1px solid var(--paper-edge, #D7D0C2);
    box-shadow: var(--shadow-lg, 0 16px 40px rgba(14, 23, 41, 0.14));
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
}

/* ---- Discount badge ---- */
.promo-cta__discount {
    margin: 0;
    align-self: flex-start;
    padding: 0.375rem 0.75rem;
    background: var(--gold, #D4A24A);
    color: var(--text-on-gold, #011635);
    font-family: 'General Sans', system-ui, sans-serif;
    font-size: var(--t-caption, 0.8125rem);
    font-weight: 700;
    letter-spacing: 0.04em;
    border-radius: var(--radius-pill, 999px);
    text-transform: none;
}

/* ---- Eyebrow (fallback card variant) ---- */
.promo-cta__eyebrow {
    margin: 0;
    font-family: 'General Sans', system-ui, sans-serif;
    font-size: var(--t-caption, 0.8125rem);
    font-weight: 600;
    letter-spacing: var(--ls-eyebrow, 0.12em);
    text-transform: uppercase;
    color: var(--gold-deep, #A37D2A);
}

/* ---- Title ---- */
.promo-cta__title {
    margin: 0;
    font-family: 'Fraunces', Georgia, serif;
    font-size: var(--t-display-m, clamp(2rem, 1.6rem + 2vw, 3rem));
    line-height: var(--lh-heading, 1.15);
    letter-spacing: var(--ls-display, -0.02em);
    font-weight: 500;
    color: var(--ink, #011635);
}

/* ---- Description ---- */
.promo-cta__description {
    margin: 0;
    font-family: 'General Sans', system-ui, sans-serif;
    font-size: var(--t-body-l, 1.125rem);
    line-height: var(--lh-body, 1.55);
    color: var(--text, #0E1729);
    max-width: 60ch;
}

/* ---- Code row ---- */
.promo-cta__code-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.625rem;
    margin-top: 0.25rem;
}

.promo-cta__code-label {
    font-family: 'General Sans', system-ui, sans-serif;
    font-size: var(--t-caption, 0.8125rem);
    font-weight: 600;
    letter-spacing: var(--ls-eyebrow, 0.12em);
    text-transform: uppercase;
    color: var(--text-muted, #5A6378);
}

.promo-cta__code {
    flex: 1 1 auto;
    min-width: 0;
    padding: 0.625rem 1rem;
    background: var(--ink, #011635);
    color: var(--text-on-dark, #F2EFE7);
    border-radius: var(--radius-sm, 4px);
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-align: center;
    user-select: all;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.promo-cta__copy {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.625rem 1rem;
    min-height: 44px;
    background: var(--paper-2, #F2EDE3);
    color: var(--ink, #011635);
    border: 1px solid var(--paper-edge, #D7D0C2);
    border-radius: var(--radius-sm, 4px);
    font-family: 'General Sans', system-ui, sans-serif;
    font-size: var(--t-body-s, 0.9375rem);
    font-weight: 600;
    cursor: pointer;
    transition: background-color var(--dur-base, 220ms) var(--ease-out-soft, cubic-bezier(0.22, 1, 0.36, 1)),
                color var(--dur-base, 220ms) var(--ease-out-soft, cubic-bezier(0.22, 1, 0.36, 1)),
                transform var(--dur-fast, 120ms) var(--ease-out-soft, cubic-bezier(0.22, 1, 0.36, 1));
}

.promo-cta__copy:hover {
    background: var(--ink, #011635);
    color: var(--text-on-dark, #F2EFE7);
}

.promo-cta__copy:active {
    transform: scale(0.98);
}

.promo-cta__copy:focus-visible {
    outline: 2px solid var(--gold, #D4A24A);
    outline-offset: 2px;
}

.promo-cta__copy-icon-success {
    display: none;
    color: var(--success, #2D8259);
}

.promo-cta__copy[data-copied="true"] {
    background: var(--success, #2D8259);
    color: #fff;
    border-color: transparent;
}

.promo-cta__copy[data-copied="true"] .promo-cta__copy-icon-success {
    display: inline-flex;
    color: #fff;
}

/* ---- Date range ---- */
.promo-cta__dates {
    margin: 0;
    font-family: 'General Sans', system-ui, sans-serif;
    font-size: var(--t-body-s, 0.9375rem);
    color: var(--text-muted, #5A6378);
    font-variant-numeric: tabular-nums;
}

/* ---- Actions ---- */
.promo-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.625rem;
    margin-top: 0.5rem;
}

.promo-cta__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.5rem;
    min-height: 48px;
    flex: 1 1 220px;
    border-radius: var(--radius-sm, 4px);
    font-family: 'General Sans', system-ui, sans-serif;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    transition: transform var(--dur-fast, 120ms) var(--ease-out-soft, cubic-bezier(0.22, 1, 0.36, 1)),
                background-color var(--dur-base, 220ms) var(--ease-out-soft, cubic-bezier(0.22, 1, 0.36, 1));
}

.promo-cta__btn--primary {
    background: var(--gold, #D4A24A);
    color: var(--text-on-gold, #011635);
    box-shadow: var(--shadow-gold, 0 6px 18px rgba(212, 162, 74, 0.32));
}

.promo-cta__btn--primary:hover {
    background: var(--gold-bright, #F0CB6F);
    transform: translateY(-1px);
}

.promo-cta__btn--secondary {
    background: transparent;
    color: var(--ink, #011635);
    border: 1px solid var(--paper-edge, #D7D0C2);
}

.promo-cta__btn--secondary:hover {
    background: var(--paper-2, #F2EDE3);
    transform: translateY(-1px);
}

.promo-cta__btn:focus-visible {
    outline: 2px solid var(--gold, #D4A24A);
    outline-offset: 3px;
}

/* ---- Fallback variant (no live promo) ---- */
.promo-cta__card--fallback {
    text-align: left;
}

@media (min-width: 768px) {
    .promo-cta__btn {
        flex: 0 0 auto;
    }
}
