/* ════════════════════════════════════════════════════════════════════
   PREMIUM OFFER MODAL  —  floating-offer-popup.css
   Refined, minimal, conversion-focused. Single accent per theme,
   calm motion, no gradients/glows/confetti.
   ════════════════════════════════════════════════════════════════════ */

:root {
    --fop-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ─── THEME TOKENS ──────────────────────────────────────────────────────
   Each theme = one muted accent. Card always stays white. */
.fop {
    --fop-accent:        #018771;
    --fop-accent-dark:   #016a59;
    --fop-accent-tint:   #ecfdf8;
    --fop-accent-border: #c9eadf;
    --fop-accent-soft:   rgba(1, 135, 113, 0.28);

    --fop-ink:           #0f172a;
    --fop-body-text:     #475569;
    --fop-muted:         #94a3b8;
    --fop-line:          #e8edf3;

    --fop-card-bg:       #ffffff;
    --fop-overlay:       rgba(15, 23, 42, 0.48);
    --fop-radius:        20px;
}

.fop[data-theme="warm"] {
    --fop-accent:        #b45309;
    --fop-accent-dark:   #92400e;
    --fop-accent-tint:   #fffbeb;
    --fop-accent-border: #f3e0bb;
    --fop-accent-soft:   rgba(180, 83, 9, 0.28);
}

.fop[data-theme="cool"] {
    --fop-accent:        #4f46e5;
    --fop-accent-dark:   #4338ca;
    --fop-accent-tint:   #eef2ff;
    --fop-accent-border: #d6dbf8;
    --fop-accent-soft:   rgba(79, 70, 229, 0.28);
}

.fop[data-theme="dark"] {
    --fop-accent:        #1e293b;
    --fop-accent-dark:   #0f172a;
    --fop-accent-tint:   #f1f5f9;
    --fop-accent-border: #dbe3ec;
    --fop-accent-soft:   rgba(30, 41, 59, 0.28);
}

.fop[data-theme="festive"] {
    --fop-accent:        #7e22ce;
    --fop-accent-dark:   #6b21a8;
    --fop-accent-tint:   #faf5ff;
    --fop-accent-border: #e7d4f8;
    --fop-accent-soft:   rgba(126, 34, 206, 0.28);
}

/* ─── BACKDROP OVERLAY ──────────────────────────────────────────────── */
.fop-overlay {
    position: fixed;
    inset: 0;
    z-index: 9980;
    background: var(--fop-overlay, rgba(15, 23, 42, 0.48));
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    opacity: 0;
    transition: opacity 280ms ease;
    pointer-events: none;
}
.fop-overlay[data-state="visible"] { opacity: 1; pointer-events: auto; }
.fop-overlay[data-state="leaving"] { opacity: 0; pointer-events: none; }

/* ─── MODAL POSITIONER ──────────────────────────────────────────────── */
.fop {
    position: fixed;
    inset: 0;
    z-index: 9990;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    pointer-events: none;
    font-family: 'Manrope', 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
}
.fop[hidden] { display: none !important; }

/* ─── MODAL CARD ────────────────────────────────────────────────────── */
.fop__card {
    position: relative;
    width: min(420px, 100%);
    background: var(--fop-card-bg);
    border: 1px solid #eef2f6;
    border-radius: var(--fop-radius);
    overflow: hidden;
    pointer-events: auto;
    box-shadow:
        0 4px 16px rgba(15, 23, 42, 0.06),
        0 24px 64px -16px rgba(15, 23, 42, 0.25);
    opacity: 0;
    transform: translateY(12px) scale(0.975);
    transition: opacity 320ms var(--fop-ease), transform 320ms var(--fop-ease);
    will-change: transform, opacity;
}
.fop[data-state="visible"] .fop__card {
    opacity: 1;
    transform: none;
}
.fop[data-state="leaving"] .fop__card {
    opacity: 0;
    transform: translateY(8px) scale(0.985);
    transition: opacity 200ms ease-in, transform 200ms ease-in;
}

/* Thin accent line across the top — quiet brand signal */
.fop__accent {
    display: block;
    height: 4px;
    background: var(--fop-accent);
}

/* ─── CLOSE BUTTON ──────────────────────────────────────────────────── */
.fop__close {
    position: absolute;
    top: 16px;
    right: 16px;
    z-index: 5;
    width: 36px;
    height: 36px;
    padding: 0;
    border: 1px solid var(--fop-line);
    border-radius: 50%;
    background: #f8fafc;
    color: #64748b;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 160ms ease, color 160ms ease, border-color 160ms ease;
}
.fop__close:hover {
    background: #eef2f6;
    color: var(--fop-ink);
    border-color: #d8e0e9;
}
.fop__close:focus-visible {
    outline: 2px solid var(--fop-accent);
    outline-offset: 2px;
}

/* Touch devices: 44px minimum target (WCAG 2.5.5) */
@media (pointer: coarse) {
    .fop__close {
        width: 44px;
        height: 44px;
    }
}

/* ─── BODY ──────────────────────────────────────────────────────────── */
.fop__body {
    padding: 32px 32px 22px;
    text-align: center;
    display: flex;
    flex-direction: column;
}

/* ─── BADGE ROW (eyebrow) ───────────────────────────────────────────── */
.fop__badge-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 18px;
}
.fop__badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 6px 14px;
    border-radius: 999px;
    background: var(--fop-accent-tint);
    border: 1px solid var(--fop-accent-border);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fop-accent);
}
.fop__badge-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--fop-accent);
}
.fop__counter {
    font-size: 11px;
    font-weight: 600;
    color: var(--fop-muted);
    font-variant-numeric: tabular-nums;
}

/* ─── DISCOUNT STATEMENT ────────────────────────────────────────────── */
.fop__media {
    margin: 0 auto 14px;
}
.fop__media-fallback {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 8px;
    line-height: 1;
}
.fop__media-fallback [data-fop-discount] {
    font-size: 48px;
    font-weight: 800;
    color: var(--fop-accent);
    letter-spacing: -0.03em;
}
.fop__media-off-label {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--fop-accent);
}
.fop__media-img {
    width: 88px;
    height: 88px;
    object-fit: cover;
    border-radius: 16px;
    display: block;
    margin: 0 auto;
    border: 1px solid var(--fop-line);
}

/* ─── TITLE + DESCRIPTION ───────────────────────────────────────────── */
.fop__title {
    font-size: 22px;
    font-weight: 700;
    color: var(--fop-ink);
    margin: 0 0 8px;
    line-height: 1.3;
    letter-spacing: -0.01em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.fop__description {
    font-size: 14px;
    font-weight: 500;
    color: var(--fop-body-text);
    margin: 0 0 22px;
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ─── COUNTDOWN TIMER ───────────────────────────────────────────────── */
.fop__countdown {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 22px;
    flex-wrap: wrap;
}
.fop__countdown-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--fop-muted);
    white-space: nowrap;
}
.fop__countdown-units {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.fop__cd-unit {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: 46px;
    padding: 8px 5px 6px;
    background: #f8fafc;
    border: 1px solid var(--fop-line);
    border-radius: 10px;
    font-variant-numeric: tabular-nums;
}
.fop__cd-unit b {
    font-size: 18px;
    font-weight: 700;
    color: var(--fop-ink);
    line-height: 1;
    letter-spacing: -0.01em;
}
.fop__cd-unit i {
    font-style: normal;
    font-size: 8.5px;
    font-weight: 600;
    color: var(--fop-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-top: 3px;
}
.fop__cd-sep {
    font-size: 15px;
    font-weight: 700;
    color: #cbd5e1;
    margin-bottom: 10px;
}

/* ─── CTA ───────────────────────────────────────────────────────────── */
.fop__cta-section {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.fop__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    width: 100%;
    min-height: 52px;
    padding: 14px 28px;
    background: var(--fop-accent);
    color: #ffffff;
    border-radius: 12px;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-decoration: none;
    text-align: center;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06), 0 10px 24px -8px var(--fop-accent-soft);
    transition: background-color 180ms ease, transform 180ms var(--fop-ease), box-shadow 180ms ease;
}
.fop__cta:hover {
    background: var(--fop-accent-dark);
    color: #ffffff;
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(15, 23, 42, 0.08), 0 14px 28px -8px var(--fop-accent-soft);
}
.fop__cta:active {
    transform: translateY(0);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}
.fop__cta:focus-visible {
    outline: 2px solid var(--fop-accent);
    outline-offset: 3px;
}
.fop__cta-icon {
    display: flex;
    align-items: center;
    transition: transform 200ms var(--fop-ease);
}
.fop__cta:hover .fop__cta-icon { transform: translateX(3px); }

/* ─── SOCIAL PROOF ──────────────────────────────────────────────────── */
.fop__social-proof {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 500;
    color: var(--fop-muted);
}
.fop__social-proof-stars {
    display: flex;
    gap: 1px;
}
.fop__social-proof-stars svg {
    fill: #d9a514;
}

/* ─── FOOTER ────────────────────────────────────────────────────────── */
.fop__footer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid #f1f5f9;
}
.fop__snooze {
    background: transparent;
    border: 0;
    padding: 6px 8px;
    font-size: 12px;
    font-weight: 500;
    color: var(--fop-muted);
    cursor: pointer;
    transition: color 160ms ease;
    font-family: inherit;
}
.fop__snooze:hover {
    color: var(--fop-ink);
    text-decoration: underline;
    text-underline-offset: 3px;
}
.fop__snooze:focus-visible {
    outline: 2px solid var(--fop-accent);
    outline-offset: 2px;
    border-radius: 4px;
}

/* ─── ROTATION DOTS ─────────────────────────────────────────────────── */
.fop__dots {
    display: flex;
    align-items: center;
    gap: 6px;
}
.fop__dots:empty { display: none; }

.fop__dot {
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: #d6dee7;
    transition: width 240ms var(--fop-ease), background-color 240ms ease;
    cursor: pointer;
    border: 0;
    padding: 0;
}
.fop__dot:hover { background: #b6c2cf; }
.fop__dot:focus-visible {
    outline: 2px solid var(--fop-accent);
    outline-offset: 2px;
}
.fop__dot.is-active {
    width: 18px;
    background: var(--fop-accent);
}

/* ─── RESPONSIVE — MOBILE ───────────────────────────────────────────── */
@media (max-width: 480px) {
    .fop { padding: 16px; }
    .fop__body { padding: 28px 22px 18px; }
    .fop__close { top: 12px; right: 12px; }
    .fop__media-fallback [data-fop-discount] { font-size: 40px; }
    .fop__media-off-label { font-size: 14px; }
    .fop__title { font-size: 19px; }
    .fop__description { font-size: 13.5px; margin-bottom: 18px; }
    .fop__cd-unit { min-width: 42px; padding: 7px 4px 5px; }
    .fop__cd-unit b { font-size: 16px; }
    .fop__cta { min-height: 50px; padding: 13px 22px; font-size: 14.5px; }
}

@media (max-width: 360px) {
    .fop__body { padding: 26px 18px 16px; }
    .fop__media-fallback [data-fop-discount] { font-size: 34px; }
    .fop__title { font-size: 17px; }
    .fop__badge { font-size: 10px; padding: 5px 11px; }
}

/* ─── REDUCED MOTION ────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .fop__card, .fop-overlay, .fop__cta, .fop__cta-icon, .fop__dot, .fop__close {
        transition: none !important;
        animation: none !important;
    }
    .fop[data-state="visible"] .fop__card { opacity: 1; transform: none; }
    .fop-overlay[data-state="visible"]    { opacity: 1; }
}

/* ─── FORCED COLORS ─────────────────────────────────────────────────── */
@media (forced-colors: active) {
    .fop__card { background: Canvas; color: CanvasText; box-shadow: none; outline: 2px solid CanvasText; }
    .fop__accent { background: Highlight; }
    .fop__title, .fop__description { color: CanvasText; }
    .fop__cta { background: Highlight; color: HighlightText; outline: 2px solid Canvas; }
    .fop-overlay { background: rgba(0,0,0,0.6); backdrop-filter: none; }
}
