/* ==========================================================================
   SINGLE LOOT DEAL PAGE — V5 (.fp-dl-*)
   Premium app-grade design system that matches single-fp_coupon.php.
   100% design tokens — no hardcoded colors, spacing, radii or shadows.
   Mobile-first. Mesh hero. BuyHatke gauge. Chart.js price history.
   AI-themed cards with gradient borders. Animated bag CTA.
   ========================================================================== */

/* ══════════════════════════════════════════════════════════════
   PAGE SCAFFOLD
   ══════════════════════════════════════════════════════════════ */
.fp-dl {
    background: var(--fp-page-bg);
    min-height: 100vh;
    font-family: var(--fp-font);
    padding-bottom: 110px;
    color: var(--fp-text-main);
}

/* ── Breadcrumb ── */
.fp-dl-breadcrumb {
    max-width: 800px;
    margin: 0 auto;
    padding: var(--fp-space-3) var(--fp-space-4) 0;
    font-size: var(--fp-text-xs);
    font-weight: 600;
    color: var(--fp-slate-400);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--fp-space-1);
}
.fp-dl-breadcrumb a { color: var(--fp-slate-500); text-decoration: none; }
.fp-dl-breadcrumb a:hover { color: var(--fp-secondary); }
.fp-dl-bc-sep { color: var(--fp-slate-300); }
.fp-dl-breadcrumb [aria-current="page"] { color: var(--fp-text-main); font-weight: 700; }

/* ══════════════════════════════════════════════════════════════
   HERO — Mesh gradient card (matches coupon page treatment)
   ══════════════════════════════════════════════════════════════ */
.fp-dl-hero {
    position: relative;
    max-width: 800px;
    margin: var(--fp-space-3) auto 0;
    background: var(--fp-surface);
    border-radius: var(--fp-radius-xl);
    padding: var(--fp-space-5) var(--fp-space-4);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
    overflow: hidden;
    isolation: isolate;
}
.fp-dl-hero-mesh {
    position: absolute;
    inset: -2px;
    z-index: -1;
    background: var(--fp-gradient-mesh-ai);
    pointer-events: none;
}
.fp-dl-hero-inner {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: var(--fp-space-3);
}

/* ── Image side — compact square from mobile up ── */
.fp-dl-hero-img-wrap {
    position: relative;
    width: 130px;
    height: 130px;
    flex-shrink: 0;
    background: radial-gradient(circle at center, var(--fp-surface) 0%, var(--fp-slate-50) 100%);
    border-radius: var(--fp-radius-md);
    border: 1px solid var(--fp-slate-200);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--fp-space-2);
    overflow: hidden;
}
.fp-dl-hero-img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* Loot badge */
.fp-dl-badge {
    position: absolute;
    z-index: 5;
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    padding: var(--fp-space-1) var(--fp-space-3);
    border-radius: var(--fp-radius-pill);
    font-weight: 900;
    font-size: var(--fp-text-2xs);
    letter-spacing: 0.5px;
}
.fp-dl-badge-loot {
    top: var(--fp-space-2);
    left: var(--fp-space-2);
    background: var(--fp-gradient-loot);
    color: var(--fp-surface);
    box-shadow: 0 4px 16px rgba(239, 68, 68, 0.35);
    animation: fp-dl-pulse 2s ease-in-out infinite;
    font-size: var(--fp-text-3xs);
    padding: 2px var(--fp-space-2);
}
.fp-dl-badge-dot {
    width: 5px;
    height: 5px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-surface);
    animation: fp-dl-blink 1s infinite;
}
@keyframes fp-dl-pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.05); } }
@keyframes fp-dl-blink { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

/* ── Info side ── */
.fp-dl-hero-info {
    display: flex;
    flex-direction: column;
    gap: var(--fp-space-3);
}
.fp-dl-hero-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--fp-space-2);
}
.fp-dl-hero-top-left {
    display: flex;
    align-items: center;
    gap: var(--fp-space-2);
    flex-wrap: wrap;
}
.fp-dl-store-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    background: var(--fp-slate-50);
    border: 1px solid var(--fp-slate-200);
    border-radius: var(--fp-radius-pill);
    padding: var(--fp-space-1) var(--fp-space-3);
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-slate-700);
    text-decoration: none;
    letter-spacing: 0.3px;
    transition: all var(--fp-transition);
}
.fp-dl-store-chip svg { opacity: 0.5; }
.fp-dl-store-chip:hover { background: var(--fp-slate-100); border-color: var(--fp-slate-300); }

.fp-dl-fresh {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid var(--fp-slate-200);
    border-radius: var(--fp-radius-pill);
    padding: var(--fp-space-1) var(--fp-space-2);
    font-size: var(--fp-text-2xs);
    font-weight: 700;
    color: var(--fp-slate-600);
}
.fp-dl-fresh-dot {
    width: 5px;
    height: 5px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-green);
}

.fp-dl-wishlist {
    width: 36px;
    height: 36px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-slate-100);
    border: 1px solid var(--fp-slate-200);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--fp-slate-400);
    cursor: pointer;
    transition: all var(--fp-transition);
    flex-shrink: 0;
}
.fp-dl-wishlist:hover,
.fp-dl-wishlist[aria-pressed="true"] { color: var(--fp-red); border-color: rgba(239, 68, 68, 0.3); background: var(--fp-red-light); }
.fp-dl-wishlist[aria-pressed="true"] svg { fill: var(--fp-red); }

/* Title */
.fp-dl-title {
    font-size: var(--fp-text-lg2);
    font-weight: 900;
    color: var(--fp-text-main);
    line-height: 1.25;
    margin: 0;
    letter-spacing: -0.3px;
}

/* PRICE BLOCK */
.fp-dl-price-block {
    display: flex;
    flex-direction: column;
    gap: var(--fp-space-2);
}
.fp-dl-price-label {
    display: inline-flex;
    width: fit-content;
    font-size: var(--fp-text-2xs);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: var(--fp-surface);
    background: var(--fp-gradient-loot);
    padding: 2px var(--fp-space-2);
    border-radius: var(--fp-radius-xs);
    box-shadow: 0 2px 6px rgba(239, 68, 68, 0.3);
}
.fp-dl-price-row {
    display: flex;
    align-items: baseline;
    gap: var(--fp-space-3);
    flex-wrap: wrap;
}
.fp-dl-price-now {
    font-size: var(--fp-text-3xl);
    font-weight: 900;
    color: var(--fp-text-main);
    letter-spacing: -1.2px;
    line-height: 1;
}
.fp-dl-price-old {
    font-size: var(--fp-text-md);
    color: var(--fp-slate-400);
    text-decoration: line-through;
    font-weight: 600;
}

/* DISCOUNT STRIP */
.fp-dl-discount-strip {
    display: flex;
    align-items: center;
    gap: var(--fp-space-2);
    flex-wrap: wrap;
}
.fp-dl-discount-pct {
    background: var(--fp-green-light);
    color: var(--fp-green);
    padding: 3px var(--fp-space-3);
    border-radius: var(--fp-radius-6);
    font-size: var(--fp-text-xs);
    font-weight: 900;
    letter-spacing: 0.3px;
    border: 1px solid var(--fp-green-mint);
}
.fp-dl-discount-save {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-slate-700);
}
.fp-dl-discount-save svg { color: var(--fp-green); }

/* SOCIAL PROOF */
.fp-dl-social-proof {
    display: flex;
    flex-wrap: wrap;
    gap: var(--fp-space-3);
    padding-top: var(--fp-space-1);
    border-top: 1px dashed var(--fp-slate-200);
    padding-top: var(--fp-space-3);
}
.fp-dl-proof-hot,
.fp-dl-proof-view,
.fp-dl-proof-stock {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    font-size: var(--fp-text-xs2);
    font-weight: 700;
    color: var(--fp-slate-600);
}
.fp-dl-proof-hot svg { color: var(--fp-red); }
.fp-dl-proof-stock svg { color: var(--fp-amber); }
.fp-dl-proof-hot strong,
.fp-dl-proof-view strong,
.fp-dl-proof-stock strong { color: var(--fp-text-main); font-weight: 900; }
.fp-dl-dot-live {
    width: 6px;
    height: 6px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-green);
    animation: fp-dl-blink 1.5s infinite;
}

/* ══════════════════════════════════════════════════════════════
   RECOMMENDATION CARD — Gauge + 3-tier pills
   ══════════════════════════════════════════════════════════════ */
.fp-dl-rec-card {
    margin-top: var(--fp-space-4);
    display: flex;
    flex-direction: column;
    gap: var(--fp-space-4);
    background: var(--fp-surface);
    border-radius: var(--fp-radius-lg);
    padding: var(--fp-space-4);
    border: 1px solid var(--fp-slate-200);
}
.fp-dl-rec-header {
    display: flex;
    align-items: center;
    gap: var(--fp-space-4);
}
.fp-dl-rec-gauge-box {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 96px;
}
.fp-dl-rec-gauge { width: 100%; height: auto; overflow: visible; }
.fp-dl-rec-needle {
    transform-origin: 50px 50px;
    transform: rotate(0deg);
    transition: transform 1.1s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.fp-dl-rec-score-text {
    margin-top: var(--fp-space-1);
    font-size: var(--fp-text-3xs);
    color: var(--fp-slate-500);
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: var(--fp-space-1);
    flex-wrap: wrap;
    justify-content: center;
}
.fp-dl-rec-legend {
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: var(--fp-radius-1);
}
.fp-dl-rec-legend-bad  { background: var(--fp-red); }
.fp-dl-rec-legend-good { background: var(--fp-green); }
.fp-dl-rec-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.fp-dl-rec-subtitle {
    font-size: var(--fp-text-xs);
    color: var(--fp-slate-500);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.fp-dl-rec-title {
    font-size: var(--fp-text-md2);
    font-weight: 900;
    line-height: 1.2;
    color: var(--fp-text-main);
    margin: 0;
}
.fp-dl-rec-desc { font-size: var(--fp-text-sm2); color: var(--fp-slate-600); font-weight: 500; }

/* 3-tier price pills */
.fp-dl-ps-row {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: var(--fp-space-2);
}
.fp-dl-ps-pill {
    flex: 1;
    min-width: 0;
    border-radius: var(--fp-radius-14);
    padding: var(--fp-space-3) var(--fp-space-2);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--fp-space-1);
    box-shadow: var(--fp-shadow-sm), inset 0 2px 0 rgba(255, 255, 255, 1);
    border: 1px solid var(--fp-slate-200);
    position: relative;
    overflow: hidden;
}
.fp-dl-ps-red    { border-bottom: 3px solid var(--fp-red);   background: linear-gradient(180deg, var(--fp-surface) 0%, var(--fp-red-light) 100%); }
.fp-dl-ps-amber  { border-bottom: 3px solid var(--fp-amber); background: linear-gradient(180deg, var(--fp-surface) 0%, var(--fp-amber-lighter) 100%); }
.fp-dl-ps-green  { border-bottom: 3px solid var(--fp-green); background: linear-gradient(180deg, var(--fp-surface) 0%, var(--fp-green-light) 100%); }
.fp-dl-psp-label {
    font-size: var(--fp-text-xs);
    font-weight: 800;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: var(--fp-space-1);
    color: var(--fp-slate-500);
}
.fp-dl-ps-red   .fp-dl-psp-label svg { stroke: var(--fp-red); }
.fp-dl-ps-amber .fp-dl-psp-label svg { stroke: var(--fp-amber); }
.fp-dl-ps-green .fp-dl-psp-label svg { stroke: var(--fp-green); }
.fp-dl-psp-val { font-size: var(--fp-text-md); font-weight: 900; color: var(--fp-text-main); line-height: 1; letter-spacing: -0.3px; }

/* ══════════════════════════════════════════════════════════════
   CTA ZONE
   ══════════════════════════════════════════════════════════════ */
.fp-dl-cta-zone {
    display: flex;
    flex-direction: column;
    gap: var(--fp-space-3);
    margin-top: var(--fp-space-4);
}
.fp-dl-grab-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--fp-space-3);
    background: var(--fp-primary);
    color: var(--fp-text-main);
    padding: var(--fp-space-5) var(--fp-space-6);
    border-radius: var(--fp-radius-lg);
    font-weight: 900;
    font-size: var(--fp-text-md);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: transform 0.1s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.1s cubic-bezier(0.4, 0, 0.2, 1);
    border: 2px solid var(--fp-surface);
    box-shadow: 0 6px 0 var(--fp-amber-deep), 0 12px 20px rgba(217, 119, 6, 0.25);
    cursor: pointer;
    width: 100%;
    position: relative;
    overflow: hidden;
}
.fp-dl-grab-btn:hover { transform: translateY(-1px); box-shadow: 0 7px 0 var(--fp-amber-deep), 0 14px 26px rgba(217, 119, 6, 0.3); }
.fp-dl-grab-btn:active { transform: translateY(6px); box-shadow: 0 0 0 var(--fp-amber-deep), 0 4px 10px rgba(217, 119, 6, 0.3); }

.fp-dl-grab-icon-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fp-dl-float-bag 3s ease-in-out infinite;
    filter: drop-shadow(0 2px 2px rgba(0, 0, 0, 0.15));
    flex-shrink: 0;
}
@keyframes fp-dl-float-bag {
    0%, 100% { transform: translateY(0) rotate(0); }
    50%      { transform: translateY(-4px) rotate(4deg); }
}
.fp-dl-grab-bag { overflow: visible; }
.fp-dl-grab-label { flex: 1; text-align: center; }

/* Savings breakdown */
.fp-dl-savings-breakdown {
    background: var(--fp-slate-50);
    border: 1px dashed var(--fp-slate-300);
    border-radius: var(--fp-radius-lg);
    padding: var(--fp-space-3) var(--fp-space-4);
    display: flex;
    align-items: center;
    gap: var(--fp-space-3);
    box-shadow: var(--fp-shadow-sm);
    position: relative;
    overflow: hidden;
}
.fp-dl-savings-breakdown::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 50%;
    height: 200%;
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
    transform: rotate(30deg);
    animation: fp-dl-shine 6s infinite;
    pointer-events: none;
}
@keyframes fp-dl-shine {
    0%       { transform: translateX(-200%) rotate(30deg); }
    20%, 100% { transform: translateX(400%) rotate(30deg); }
}
.fp-dl-sb-plus {
    width: 32px;
    height: 32px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-gradient-green);
    color: var(--fp-surface);
    font-weight: 900;
    font-size: var(--fp-text-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 4px 10px rgba(46, 204, 113, 0.3);
    border: 2px solid var(--fp-surface);
}
.fp-dl-sb-items { flex: 1; display: flex; flex-direction: column; gap: var(--fp-space-1); min-width: 0; }
.fp-dl-sb-item {
    display: flex;
    align-items: center;
    gap: var(--fp-space-1);
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-slate-700);
}
.fp-dl-sb-item svg { color: var(--fp-green); flex-shrink: 0; }
.fp-dl-sb-final {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    flex-shrink: 0;
    gap: 2px;
    background: var(--fp-surface);
    padding: var(--fp-space-2) var(--fp-space-3);
    border-radius: var(--fp-radius-10);
    border: 1px solid var(--fp-slate-200);
    box-shadow: var(--fp-shadow-sm);
}
.fp-dl-sb-final-label {
    font-size: var(--fp-text-2xs);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--fp-slate-500);
}
.fp-dl-sb-final-price { font-size: var(--fp-text-lg); font-weight: 900; color: var(--fp-green); line-height: 1; }

/* ══════════════════════════════════════════════════════════════
   CONTENT AREA & UNIVERSAL CARD
   ══════════════════════════════════════════════════════════════ */
.fp-dl-content {
    max-width: 800px;
    margin: 0 auto;
    padding: var(--fp-space-4);
    display: flex;
    flex-direction: column;
    gap: var(--fp-space-4);
}

.fp-dl-card {
    background: var(--fp-surface);
    border-radius: var(--fp-radius-xl);
    padding: var(--fp-space-5);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
    position: relative;
    overflow: hidden;
}
.fp-dl-card-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--fp-space-3);
    gap: var(--fp-space-3);
    flex-wrap: wrap;
}
.fp-dl-card-head h2 {
    margin: 0;
    font-size: var(--fp-text-md2);
    font-weight: 900;
    color: var(--fp-text-main);
    display: flex;
    align-items: center;
    gap: var(--fp-space-2);
    line-height: 1.3;
}
.fp-dl-h2-ic {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: var(--fp-radius-sm);
    flex-shrink: 0;
}
.fp-dl-h2-ic-ai     { background: linear-gradient(135deg, var(--fp-violet-50), var(--fp-blue-light)); color: var(--fp-ai-purple); }
.fp-dl-h2-ic-green  { background: linear-gradient(135deg, var(--fp-green-soft), var(--fp-green-mint)); color: var(--fp-green-dark); }
.fp-dl-h2-ic-amber  { background: linear-gradient(135deg, var(--fp-amber-light), var(--fp-amber-200)); color: var(--fp-amber-dark); }
.fp-dl-h2-ic-blue   { background: linear-gradient(135deg, var(--fp-blue-light), var(--fp-blue-soft)); color: var(--fp-blue-deep); }
.fp-dl-h2-ic-slate  { background: linear-gradient(135deg, var(--fp-slate-100), var(--fp-slate-200)); color: var(--fp-slate-700); }

/* AI tag pill */
.fp-dl-ai-tag {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    font-size: var(--fp-text-2xs);
    background: linear-gradient(135deg, var(--fp-violet-50), var(--fp-blue-light));
    color: var(--fp-ai-purple);
    font-weight: 800;
    padding: 3px var(--fp-space-3);
    border-radius: var(--fp-radius-pill);
    letter-spacing: 0.5px;
    text-transform: uppercase;
    white-space: nowrap;
}
.fp-dl-ai-dot {
    width: 5px;
    height: 5px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-ai-purple);
    animation: fp-dl-blink 1.5s infinite;
}

/* AI orb */
.fp-dl-card-orb {
    position: absolute;
    top: -50px;
    right: -50px;
    width: 160px;
    height: 160px;
    background: radial-gradient(circle, rgba(108, 99, 255, 0.08) 0%, transparent 70%);
    border-radius: var(--fp-radius-circle);
    pointer-events: none;
}

/* AI DNA THEME — gradient-bordered cards */
.fp-dl-desc-card,
.fp-dl-review-card,
.fp-dl-ai-card {
    background: linear-gradient(var(--fp-surface), var(--fp-surface)) padding-box,
                linear-gradient(135deg, var(--fp-ai-purple), var(--fp-green)) border-box;
    border: 2px solid transparent;
    box-shadow: 0 8px 28px rgba(108, 99, 255, 0.10);
}

/* ══════════════════════════════════════════════════════════════
   SEO NARRATIVE
   ══════════════════════════════════════════════════════════════ */
.fp-dl-updated {
    font-size: var(--fp-text-xs);
    color: var(--fp-slate-500);
    font-weight: 600;
}
.fp-dl-seo-narrative {
    font-size: var(--fp-text-base);
    line-height: 1.65;
    color: var(--fp-slate-700);
}
.fp-dl-seo-narrative p { margin: 0 0 var(--fp-space-2); }
.fp-dl-seo-narrative p:last-child { margin-bottom: 0; }
.fp-dl-seo-narrative strong { color: var(--fp-text-main); font-weight: 800; }

/* ══════════════════════════════════════════════════════════════
   DESCRIPTION
   ══════════════════════════════════════════════════════════════ */
.fp-dl-desc-body {
    font-size: var(--fp-text-md);
    line-height: 1.65;
    color: var(--fp-slate-700);
    position: relative;
    z-index: 1;
}
.fp-dl-desc-body p { margin: 0 0 var(--fp-space-3); }
.fp-dl-desc-body p:last-child { margin-bottom: 0; }

/* ══════════════════════════════════════════════════════════════
   PRICE HISTORY
   ══════════════════════════════════════════════════════════════ */
.fp-dl-hist-tabs { display: flex; gap: var(--fp-space-1); }
.fp-dl-hist-tab {
    padding: var(--fp-space-1) var(--fp-space-3);
    border-radius: var(--fp-radius-pill);
    border: 1.5px solid var(--fp-slate-200);
    background: var(--fp-surface);
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-slate-500);
    cursor: pointer;
    transition: all var(--fp-transition);
}
.fp-dl-hist-tab-active {
    background: var(--fp-ai-purple);
    color: var(--fp-surface);
    border-color: var(--fp-ai-purple);
}
.fp-dl-hist-tab:hover:not(.fp-dl-hist-tab-active) {
    border-color: var(--fp-ai-purple);
    color: var(--fp-ai-purple);
}

.fp-dl-chart-wrap { position: relative; height: 220px; margin-bottom: var(--fp-space-3); }
.fp-dl-chart-wrap canvas { width: 100% !important; }

.fp-dl-ph-stats { display: flex; gap: var(--fp-space-2); }
.fp-dl-ph-stat {
    flex: 1;
    display: flex;
    align-items: center;
    gap: var(--fp-space-3);
    padding: var(--fp-space-3) var(--fp-space-4);
    background: var(--fp-surface);
    border-radius: var(--fp-radius-md);
    border: 1px solid var(--fp-slate-200);
    box-shadow: var(--fp-shadow-sm);
}
.fp-dl-ph-stat-teal { border-color: rgba(46, 204, 113, 0.2); }
.fp-dl-ph-stat-red  { border-color: rgba(239, 68, 68, 0.2); }
.fp-dl-ph-dot {
    width: 10px;
    height: 10px;
    border-radius: var(--fp-radius-circle);
    flex-shrink: 0;
}
.fp-dl-ph-dot-green { background: var(--fp-green); box-shadow: 0 2px 6px rgba(46, 204, 113, 0.4); }
.fp-dl-ph-dot-red   { background: var(--fp-red);   box-shadow: 0 2px 6px rgba(239, 68, 68, 0.4); }
.fp-dl-ph-val { display: block; font-size: var(--fp-text-md); font-weight: 900; color: var(--fp-text-main); line-height: 1.1; margin-bottom: 2px; }
.fp-dl-ph-lbl { display: block; font-size: var(--fp-text-xs); font-weight: 700; color: var(--fp-slate-400); text-transform: uppercase; letter-spacing: 0.5px; }

.fp-dl-chart-verdict {
    display: flex;
    align-items: center;
    gap: var(--fp-space-2);
    margin-top: var(--fp-space-3);
    font-size: var(--fp-text-base);
    font-weight: 700;
    color: var(--fp-green-dark);
    padding: var(--fp-space-3) var(--fp-space-3);
    background: var(--fp-green-light);
    border-radius: var(--fp-radius-10);
    border: 1px solid var(--fp-green-mint);
}
.fp-dl-alert-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--fp-space-2);
    width: 100%;
    margin-top: var(--fp-space-3);
    padding: var(--fp-space-3) var(--fp-space-4);
    border-radius: var(--fp-radius-md);
    border: none;
    background: var(--fp-gradient-ai);
    font-size: var(--fp-text-base);
    font-weight: 800;
    color: var(--fp-surface);
    cursor: pointer;
    transition: all var(--fp-transition);
    box-shadow: 0 4px 15px rgba(108, 99, 255, 0.3);
}
.fp-dl-alert-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 25px rgba(108, 99, 255, 0.4); }

/* ══════════════════════════════════════════════════════════════
   AI REVIEW SUMMARY
   ══════════════════════════════════════════════════════════════ */
.fp-dl-review-overall {
    display: flex;
    align-items: center;
    gap: var(--fp-space-3);
    margin-bottom: var(--fp-space-4);
    position: relative;
    z-index: 1;
}
.fp-dl-review-big {
    font-size: var(--fp-text-4xl);
    font-weight: 900;
    color: var(--fp-text-main);
    line-height: 1;
    letter-spacing: -1.5px;
}
.fp-dl-review-stars-row { display: flex; align-items: center; gap: 2px; flex-wrap: wrap; }
.fp-dl-star      { fill: var(--fp-slate-200); }
.fp-dl-star-on   { fill: var(--fp-primary); }
.fp-dl-review-count { font-size: var(--fp-text-xs); font-weight: 700; color: var(--fp-slate-400); margin-left: var(--fp-space-1); }

.fp-dl-star-bars {
    display: flex;
    flex-direction: column;
    gap: var(--fp-space-2);
    margin-bottom: var(--fp-space-4);
    position: relative;
    z-index: 1;
}
.fp-dl-star-row { display: flex; align-items: center; gap: var(--fp-space-2); }
.fp-dl-star-cat {
    font-size: var(--fp-text-xs);
    font-weight: 700;
    color: var(--fp-slate-600);
    width: 110px;
    flex-shrink: 0;
}
.fp-dl-star-track {
    flex: 1;
    height: 6px;
    background: var(--fp-slate-100);
    border-radius: var(--fp-radius-pill);
    overflow: hidden;
}
.fp-dl-star-fill {
    width: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--fp-primary), var(--fp-green));
    border-radius: var(--fp-radius-pill);
    transition: width 1.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.fp-dl-star-val { font-size: var(--fp-text-xs); font-weight: 800; color: var(--fp-text-main); width: 28px; text-align: right; flex-shrink: 0; }

.fp-dl-procon-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--fp-space-3);
    margin-bottom: var(--fp-space-4);
    position: relative;
    z-index: 1;
}
.fp-dl-pros, .fp-dl-cons {
    background: var(--fp-slate-50);
    border-radius: var(--fp-radius-md);
    padding: var(--fp-space-3) var(--fp-space-4);
    border: 1px solid var(--fp-slate-200);
}
.fp-dl-pros { border-left: 3px solid var(--fp-green); }
.fp-dl-cons { border-left: 3px solid var(--fp-red); }
.fp-dl-pros h3, .fp-dl-cons h3 {
    display: flex;
    align-items: center;
    gap: var(--fp-space-1);
    font-size: var(--fp-text-xs);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0 0 var(--fp-space-2);
}
.fp-dl-pros h3 { color: var(--fp-green-dark); }
.fp-dl-cons h3 { color: var(--fp-red-dark); }
.fp-dl-pros ul, .fp-dl-cons ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--fp-space-2); }
.fp-dl-pros li, .fp-dl-cons li {
    display: flex;
    align-items: flex-start;
    gap: var(--fp-space-2);
    font-size: var(--fp-text-base);
    line-height: 1.5;
    color: var(--fp-slate-700);
}
.fp-dl-pro-ic, .fp-dl-con-ic {
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    border-radius: var(--fp-radius-circle);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 2px;
}
.fp-dl-pro-ic { background: var(--fp-green); color: var(--fp-surface); }
.fp-dl-con-ic { background: var(--fp-red); color: var(--fp-surface); }

.fp-dl-review-verdict {
    display: flex;
    align-items: flex-start;
    gap: var(--fp-space-2);
    padding: var(--fp-space-3) var(--fp-space-4);
    background: linear-gradient(135deg, var(--fp-violet-50), var(--fp-blue-light));
    border-radius: var(--fp-radius-md);
    font-size: var(--fp-text-base);
    color: var(--fp-slate-700);
    line-height: 1.5;
    font-style: italic;
    position: relative;
    z-index: 1;
}
.fp-dl-review-verdict svg { color: var(--fp-ai-purple); flex-shrink: 0; margin-top: 2px; }

/* ══════════════════════════════════════════════════════════════
   SAVINGS CALCULATOR
   ══════════════════════════════════════════════════════════════ */
.fp-dl-calc-toggles { display: flex; flex-direction: column; gap: var(--fp-space-2); }
.fp-dl-calc-opt {
    display: grid;
    grid-template-columns: 22px 1fr auto;
    align-items: center;
    gap: var(--fp-space-3);
    padding: var(--fp-space-3) var(--fp-space-4);
    background: var(--fp-slate-50);
    border-radius: var(--fp-radius-md);
    border: 1px solid var(--fp-slate-200);
    cursor: pointer;
    transition: all var(--fp-transition);
}
.fp-dl-calc-opt:hover { border-color: var(--fp-green); background: var(--fp-green-light); }
.fp-dl-calc-cb { position: absolute; opacity: 0; pointer-events: none; }
.fp-dl-calc-check {
    width: 22px;
    height: 22px;
    border-radius: var(--fp-radius-6);
    border: 2px solid var(--fp-slate-300);
    background: var(--fp-surface);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--fp-transition);
    position: relative;
}
.fp-dl-calc-check::after {
    content: '';
    width: 6px;
    height: 10px;
    border-right: 2.5px solid var(--fp-surface);
    border-bottom: 2.5px solid var(--fp-surface);
    transform: rotate(45deg) translateY(-1px);
    opacity: 0;
}
.fp-dl-calc-cb:checked ~ .fp-dl-calc-check {
    background: var(--fp-green);
    border-color: var(--fp-green);
}
.fp-dl-calc-cb:checked ~ .fp-dl-calc-check::after { opacity: 1; }
.fp-dl-calc-text {
    font-size: var(--fp-text-base);
    font-weight: 700;
    color: var(--fp-slate-700);
}
.fp-dl-calc-amount {
    font-size: var(--fp-text-base);
    font-weight: 800;
    color: var(--fp-green-dark);
}
.fp-dl-calc-result {
    margin-top: var(--fp-space-2);
    padding: var(--fp-space-4);
    background: var(--fp-gradient-slate);
    border-radius: var(--fp-radius-md);
    color: var(--fp-surface);
}
.fp-dl-calc-final { display: flex; justify-content: space-between; align-items: baseline; }
.fp-dl-calc-final > span:first-child { font-size: var(--fp-text-sm2); font-weight: 700; opacity: 0.85; }
.fp-dl-calc-total { font-size: var(--fp-text-xl); font-weight: 900; color: var(--fp-primary); letter-spacing: -0.5px; }
.fp-dl-calc-saved { margin-top: var(--fp-space-1); font-size: var(--fp-text-xs); font-weight: 700; opacity: 0.85; }
.fp-dl-calc-saved-amt { color: var(--fp-green); font-weight: 900; }

/* ══════════════════════════════════════════════════════════════
   SHOULD YOU BUY — checks
   ══════════════════════════════════════════════════════════════ */
.fp-dl-checks {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--fp-space-2);
    margin-bottom: var(--fp-space-4);
    position: relative;
    z-index: 1;
}
.fp-dl-check {
    display: flex;
    align-items: center;
    gap: var(--fp-space-3);
    padding: var(--fp-space-3) var(--fp-space-4);
    background: var(--fp-slate-50);
    border-radius: var(--fp-radius-md);
    border: 1px solid var(--fp-slate-200);
    font-size: var(--fp-text-base);
    color: var(--fp-slate-700);
}
.fp-dl-check strong { color: var(--fp-text-main); font-weight: 800; }
.fp-dl-ci {
    width: 20px;
    height: 20px;
    border-radius: var(--fp-radius-circle);
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.fp-dl-ci-yes { background: var(--fp-green); }
.fp-dl-ci-yes::after {
    content: '';
    width: 5px;
    height: 9px;
    border-right: 2.5px solid var(--fp-surface);
    border-bottom: 2.5px solid var(--fp-surface);
    transform: rotate(45deg) translateY(-1px);
}
.fp-dl-ci-warn { background: var(--fp-amber); }
.fp-dl-ci-warn::after {
    content: '!';
    color: var(--fp-surface);
    font-weight: 900;
    font-size: var(--fp-text-xs);
    line-height: 1;
}
.fp-dl-verdict {
    display: flex;
    align-items: center;
    gap: var(--fp-space-3);
    padding: var(--fp-space-3) var(--fp-space-4);
    background: var(--fp-gradient-green);
    border-radius: var(--fp-radius-md);
    color: var(--fp-surface);
    font-weight: 700;
    font-size: var(--fp-text-base);
    box-shadow: 0 4px 14px rgba(46, 204, 113, 0.25);
    position: relative;
    z-index: 1;
}
.fp-dl-verdict-badge {
    background: var(--fp-surface);
    color: var(--fp-green-dark);
    padding: var(--fp-space-1) var(--fp-space-3);
    border-radius: var(--fp-radius-pill);
    font-size: var(--fp-text-2xs);
    font-weight: 900;
    letter-spacing: 0.8px;
    flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════
   BANK OFFERS
   ══════════════════════════════════════════════════════════════ */
.fp-dl-banks { display: flex; flex-direction: column; gap: var(--fp-space-2); }
.fp-dl-bank-row {
    display: grid;
    grid-template-columns: 60px 1fr auto;
    align-items: center;
    gap: var(--fp-space-3);
    padding: var(--fp-space-3) var(--fp-space-4);
    background: var(--fp-slate-50);
    border-radius: var(--fp-radius-md);
    border: 1px solid var(--fp-slate-200);
}
.fp-dl-bank-badge {
    padding: var(--fp-space-1) var(--fp-space-2);
    border-radius: var(--fp-radius-6);
    color: var(--fp-surface);
    font-weight: 900;
    font-size: var(--fp-text-2xs);
    text-align: center;
    letter-spacing: 0.5px;
}
.fp-dl-bank-hdfc  { background: linear-gradient(135deg, var(--fp-bank-hdfc-from),  var(--fp-blue)); }
.fp-dl-bank-sbi   { background: linear-gradient(135deg, var(--fp-bank-sbi-from),   var(--fp-ai-violet)); }
.fp-dl-bank-axis  { background: linear-gradient(135deg, var(--fp-bank-axis-from),  var(--fp-red)); }
.fp-dl-bank-icici { background: linear-gradient(135deg, var(--fp-bank-icici-from), var(--fp-bank-icici-to)); }
.fp-dl-bank-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.fp-dl-bank-info strong { font-size: var(--fp-text-base); font-weight: 800; color: var(--fp-text-main); }
.fp-dl-bank-info span { font-size: var(--fp-text-xs); color: var(--fp-slate-500); }
.fp-dl-bank-save {
    font-size: var(--fp-text-md);
    font-weight: 900;
    color: var(--fp-green-dark);
    white-space: nowrap;
}

/* ══════════════════════════════════════════════════════════════
   DEAL VOTING
   ══════════════════════════════════════════════════════════════ */
.fp-dl-vote-q {
    margin: 0 0 var(--fp-space-3);
    font-size: var(--fp-text-md);
    font-weight: 900;
    color: var(--fp-text-main);
    text-align: center;
}
.fp-dl-reactions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--fp-space-2);
}
.fp-dl-react {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--fp-space-1);
    padding: var(--fp-space-3) var(--fp-space-2);
    background: var(--fp-slate-50);
    border: 2px solid var(--fp-slate-200);
    border-radius: var(--fp-radius-md);
    cursor: pointer;
    transition: all var(--fp-transition);
    position: relative;
}
.fp-dl-react:hover { transform: translateY(-2px); border-color: var(--fp-amber); background: var(--fp-amber-lighter); box-shadow: var(--fp-shadow-md); }
.fp-dl-react-emoji { position: relative; display: flex; align-items: center; justify-content: center; }
.fp-dl-emoji-main { display: flex; transition: transform var(--fp-transition); }
.fp-dl-react:hover .fp-dl-emoji-main { transform: scale(1.08) rotate(-3deg); }
.fp-dl-emoji-burst {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
}
.fp-dl-react-label {
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-slate-700);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}
.fp-dl-react-count {
    font-size: var(--fp-text-2xs);
    font-weight: 700;
    color: var(--fp-slate-500);
}
.fp-dl-react-voted { opacity: 0.5; transform: scale(0.95); }
.fp-dl-react-selected {
    border-color: var(--fp-amber);
    background: var(--fp-amber-lighter);
    box-shadow: 0 8px 24px rgba(245, 158, 11, 0.25);
}
.fp-dl-react-selected .fp-dl-emoji-burst { animation: fp-dl-burst 1.2s ease-out forwards; }
@keyframes fp-dl-burst {
    0%   { opacity: 1; transform: scale(0.3); }
    100% { opacity: 0; transform: scale(2.2); }
}
.fp-dl-count-pop { animation: fp-dl-count-pop 0.5s ease; }
@keyframes fp-dl-count-pop {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.4); color: var(--fp-amber); }
    100% { transform: scale(1); }
}

.fp-dl-vote-bar-wrap { margin-top: var(--fp-space-3); }
.fp-dl-vote-bar {
    display: flex;
    height: 22px;
    border-radius: var(--fp-radius-pill);
    overflow: hidden;
    box-shadow: var(--fp-shadow-sm);
}
.fp-dl-vb {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--fp-surface);
    font-weight: 800;
    font-size: var(--fp-text-2xs);
    transition: width 0.8s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.fp-dl-vb-hot  { background: var(--fp-gradient-green); }
.fp-dl-vb-meh  { background: var(--fp-amber); }
.fp-dl-vb-dead { background: var(--fp-red); }

.fp-dl-report-link {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    margin: var(--fp-space-3) auto 0;
    background: transparent;
    border: none;
    font-size: var(--fp-text-xs);
    color: var(--fp-slate-400);
    cursor: pointer;
    font-weight: 600;
}
.fp-dl-report-link:hover { color: var(--fp-red); }

/* ══════════════════════════════════════════════════════════════
   STACK A COUPON — mfs-style cards (matches coupon page)
   ══════════════════════════════════════════════════════════════ */
.fp-dl-stack-sub {
    margin: 0 0 var(--fp-space-3);
    font-size: var(--fp-text-xs);
    color: var(--fp-slate-500);
    font-weight: 600;
}
.fp-dl-stack-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--fp-space-3);
}
.fp-dl-stack-card-item {
    display: flex;
    flex-direction: column;
    gap: var(--fp-space-2);
    padding: var(--fp-space-4);
    background: var(--fp-surface);
    border: 1px solid var(--fp-slate-200);
    border-radius: var(--fp-radius-14);
    transition: all var(--fp-transition);
    position: relative;
}
.fp-dl-stack-card-item:hover {
    border-color: var(--fp-ai-purple);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(94, 87, 230, 0.10);
}
.fp-dl-stack-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.fp-dl-stack-tag {
    font-size: var(--fp-text-2xs);
    font-weight: 900;
    padding: 3px var(--fp-space-2);
    border-radius: var(--fp-radius-5);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}
.fp-dl-stack-tag-code  { background: var(--fp-violet-50);  color: var(--fp-violet-800); }
.fp-dl-stack-tag-offer { background: var(--fp-green-soft); color: var(--fp-green-dark); }
.fp-dl-stack-tag-bank  { background: var(--fp-amber-300);  color: var(--fp-amber-900); }
.fp-dl-stack-tag-flash { background: var(--fp-red-soft);   color: var(--fp-red-dark); }
.fp-dl-stack-rate {
    font-size: var(--fp-text-xs);
    font-weight: 700;
    color: var(--fp-slate-500);
}
.fp-dl-stack-title {
    margin: 0;
    font-size: var(--fp-text-base);
    font-weight: 800;
    color: var(--fp-text-main);
    line-height: 1.35;
}
.fp-dl-stack-code-row {
    display: flex;
    align-items: stretch;
    margin: var(--fp-space-1) 0;
}
.fp-dl-stack-code {
    flex: 1;
    font-family: var(--fp-font-mono);
    font-size: var(--fp-text-base);
    font-weight: 800;
    background: var(--fp-slate-50);
    padding: var(--fp-space-2) var(--fp-space-3);
    border-radius: var(--fp-radius-7) 0 0 var(--fp-radius-7);
    border: 1px dashed var(--fp-slate-300);
    border-right: none;
    color: var(--fp-slate-900);
    letter-spacing: 1.2px;
    display: inline-flex;
    align-items: center;
    line-height: 1;
    transition: all var(--fp-transition);
}
.fp-dl-stack-reveal {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    padding: var(--fp-space-2) var(--fp-space-3);
    background: var(--fp-text-main);
    color: var(--fp-surface);
    font-size: var(--fp-text-xs);
    font-weight: 900;
    font-family: var(--fp-font);
    border-radius: 0 var(--fp-radius-7) var(--fp-radius-7) 0;
    border: 1px solid var(--fp-text-main);
    cursor: pointer;
    white-space: nowrap;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    transition: all var(--fp-transition);
    line-height: 1;
}
.fp-dl-stack-reveal:hover {
    background: var(--fp-ai-purple);
    border-color: var(--fp-ai-purple);
}
.fp-dl-stack-reveal svg { flex-shrink: 0; }
.fp-dl-stack-code.fp-dl-stack-revealed {
    background: var(--fp-green-light);
    border-color: var(--fp-green-mint);
    border-right: 1px dashed var(--fp-green-mint);
    border-radius: var(--fp-radius-7);
    color: var(--fp-green-dark);
    letter-spacing: 0.5px;
}
.fp-dl-stack-reveal.fp-dl-stack-reveal-hidden { display: none; }
.fp-dl-stack-detail {
    margin: 0;
    font-size: var(--fp-text-xs);
    color: var(--fp-slate-500);
    line-height: 1.5;
}
.fp-dl-stack-foot {
    margin-top: auto;
    padding-top: var(--fp-space-2);
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-top: 1px dashed var(--fp-slate-200);
}
.fp-dl-stack-save {
    font-size: var(--fp-text-xs);
    font-weight: 900;
    color: var(--fp-green-dark);
}
.fp-dl-stack-cta {
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-ai-purple);
}
.fp-dl-stack-more {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    margin-top: var(--fp-space-3);
    color: var(--fp-ai-purple);
    font-size: var(--fp-text-xs);
    font-weight: 800;
    text-decoration: none;
}
.fp-dl-stack-more:hover { color: var(--fp-secondary); }

/* ══════════════════════════════════════════════════════════════
   FLASHAI BANNER (matches coupon page)
   ══════════════════════════════════════════════════════════════ */
.fp-dl-flashai-banner {
    position: relative;
    border-radius: var(--fp-radius-lg);
    overflow: hidden;
    background: linear-gradient(145deg, var(--fp-slate-900) 0%, var(--fp-black-pure) 100%);
    display: flex;
    align-items: center;
    padding: var(--fp-space-3) var(--fp-space-4);
    gap: var(--fp-space-3);
    border: 2px solid var(--fp-surface);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35), 0 2px 4px rgba(0, 0, 0, 0.04);
    text-decoration: none;
}
.fp-dl-flashai-banner:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0, 0, 0, 0.45), 0 4px 8px rgba(0, 0, 0, 0.1); }
.fp-dl-flashai-icon-wrap { position: relative; flex-shrink: 0; }
.fp-dl-flashai-pulse {
    position: absolute;
    inset: -4px;
    border-radius: var(--fp-radius-circle);
    background: radial-gradient(circle, rgba(168, 85, 247, 0.3), transparent 70%);
    animation: fp-dl-pulse-soft 2s ease-in-out infinite;
}
@keyframes fp-dl-pulse-soft {
    0%, 100% { opacity: 0.4; }
    50%      { opacity: 1; }
}
.fp-dl-flashai-info { flex: 1; min-width: 0; }
.fp-dl-flashai-title { margin: 0 0 2px; font-size: var(--fp-text-base); font-weight: 800; color: var(--fp-surface); }
.fp-dl-flashai-prompt { margin: 0; font-size: var(--fp-text-xs); color: var(--fp-slate-300); }
.fp-dl-flashai-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    background: var(--fp-gradient-ai);
    color: var(--fp-surface);
    padding: var(--fp-space-2) var(--fp-space-3);
    border-radius: var(--fp-radius-pill);
    font-size: var(--fp-text-xs);
    font-weight: 800;
    text-decoration: none;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.4);
    transition: all var(--fp-transition);
    flex-shrink: 0;
}
.fp-dl-flashai-banner:hover .fp-dl-flashai-btn { transform: scale(1.05); box-shadow: 0 6px 14px rgba(99, 102, 241, 0.5); }

/* ══════════════════════════════════════════════════════════════
   TRENDING SLIDER (matches coupon page namespace)
   ══════════════════════════════════════════════════════════════ */
.fp-dl-trending-section {
    padding: 0;
    background: transparent;
    box-shadow: none;
}
.fp-dl-trending-h2 {
    display: flex;
    align-items: center;
    gap: var(--fp-space-2);
    margin: 0;
    font-size: var(--fp-text-md2);
    font-weight: 900;
    color: var(--fp-text-main);
}

.fp-cpg-trending-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--fp-space-3);
}
.fp-cpg-view-all {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-ai-purple);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: var(--fp-space-1) var(--fp-space-3);
    border-radius: var(--fp-radius-pill);
    background: linear-gradient(135deg, var(--fp-violet-50), var(--fp-blue-light));
    transition: all var(--fp-transition);
}
.fp-cpg-view-all:hover { transform: translateX(2px); }

.fp-cpg-slider-wrap { position: relative; }
.fp-cpg-trending-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 160px;
    gap: var(--fp-space-3);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: var(--fp-space-2);
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.fp-cpg-trending-grid::-webkit-scrollbar { display: none; }

.fp-cpg-tcard {
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    background: var(--fp-surface);
    border-radius: var(--fp-radius-md);
    border: 1px solid var(--fp-slate-200);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: all var(--fp-transition);
}
.fp-cpg-tcard:hover { transform: translateY(-3px); box-shadow: var(--fp-shadow-md); border-color: var(--fp-ai-purple); }
.fp-cpg-tcard-img {
    position: relative;
    aspect-ratio: 1 / 1;
    background: var(--fp-slate-50);
    overflow: hidden;
}
.fp-cpg-tcard-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--fp-transition);
}
.fp-cpg-tcard:hover .fp-cpg-tcard-img img { transform: scale(1.06); }
.fp-cpg-tcard-badge {
    position: absolute;
    top: var(--fp-space-2);
    left: var(--fp-space-2);
    background: var(--fp-green);
    color: var(--fp-surface);
    font-size: var(--fp-text-2xs);
    font-weight: 900;
    padding: 3px var(--fp-space-2);
    border-radius: var(--fp-radius-6);
}
.fp-cpg-tcard-flame {
    position: absolute;
    top: var(--fp-space-2);
    right: var(--fp-space-2);
    width: 22px;
    height: 22px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-red);
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fp-dl-pulse 1.6s ease-in-out infinite;
}
.fp-cpg-tcard-body {
    padding: var(--fp-space-3);
    display: flex;
    flex-direction: column;
    gap: var(--fp-space-1);
}
.fp-cpg-tcard-title {
    margin: 0;
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-text-main);
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.7em;
}
.fp-cpg-tcard-prices { display: flex; align-items: baseline; gap: var(--fp-space-1); }
.fp-cpg-tcard-prices { margin-top: auto; margin-bottom: var(--fp-space-2); }
.fp-cpg-tcard-price { font-size: var(--fp-text-md); font-weight: 900; color: var(--fp-green-deep); letter-spacing: -0.4px; }
.fp-cpg-tcard-old { font-size: var(--fp-text-2xs); color: var(--fp-slate-400); text-decoration: line-through; font-weight: 700; }
.fp-cpg-tcard-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--fp-space-1);
    background: var(--fp-gradient-yellow-pill);
    color: var(--fp-text-main);
    padding: var(--fp-space-2) var(--fp-space-3);
    border-radius: var(--fp-radius-sm);
    font-size: var(--fp-text-xs);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    transition: all var(--fp-transition);
    box-shadow: 0 2px 0 var(--fp-amber-deep);
}
.fp-cpg-tcard:hover .fp-cpg-tcard-cta {
    transform: translateY(-1px);
    box-shadow: 0 4px 10px var(--fp-yellow-glow), 0 2px 0 var(--fp-amber-deep);
}
.fp-cpg-slider-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-surface);
    border: 1px solid var(--fp-slate-200);
    color: var(--fp-slate-700);
    display: none;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: var(--fp-shadow-md);
    z-index: 2;
    transition: all var(--fp-transition);
}
.fp-cpg-slider-btn:hover { color: var(--fp-ai-purple); transform: translateY(-50%) scale(1.05); }
.fp-cpg-slider-btn.prev { left: var(--fp-space-2); }
.fp-cpg-slider-btn.next { right: var(--fp-space-2); }

/* ══════════════════════════════════════════════════════════════
   BOTTOM GRID — Extension + Alerts (matches coupon page)
   ══════════════════════════════════════════════════════════════ */
.fp-dl-bottom-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--fp-space-3);
}
/* ── Extension banner — centered card with animated glow orbs (coupon-page parity) ── */
.fp-dl-ext-compact {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: var(--fp-space-3);
    padding: var(--fp-space-4) var(--fp-space-5);
    background: var(--fp-slate-900);
    border: 2px solid var(--fp-surface);
    border-radius: var(--fp-radius-lg);
    overflow: hidden;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35), 0 2px 4px rgba(0, 0, 0, 0.04);
    transition: all var(--fp-transition);
    text-decoration: none;
}
.fp-dl-ext-compact::before,
.fp-dl-ext-compact::after {
    content: '';
    position: absolute;
    pointer-events: none;
    z-index: 0;
    border-radius: var(--fp-radius-circle);
    filter: blur(50px);
    animation: fp-dl-ext-glow 8s ease-in-out infinite alternate;
}
.fp-dl-ext-compact::before {
    top: -20%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: var(--fp-violet-glow);
}
.fp-dl-ext-compact::after {
    bottom: -30%;
    left: 20%;
    width: 250px;
    height: 250px;
    background: var(--fp-sky-glow);
    animation-delay: -4s;
}
@keyframes fp-dl-ext-glow {
    0%   { transform: translate(0, 0)     scale(1); }
    100% { transform: translate(10px, 6px) scale(1.08); }
}
.fp-dl-ext-compact:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.45), 0 4px 8px rgba(0, 0, 0, 0.1);
}
.fp-dl-ext-c-left {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--fp-space-1);
}
.fp-dl-ext-c-title {
    margin: 0;
    font-size: var(--fp-text-md2);
    font-weight: 900;
    color: var(--fp-surface);
    line-height: 1.25;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
    letter-spacing: -0.2px;
}
.fp-dl-ext-c-sub {
    margin: 0;
    font-size: var(--fp-text-base);
    color: var(--fp-slate-300);
    line-height: 1.4;
}
.fp-dl-ext-c-browsers {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: var(--fp-space-1);
}
.fp-dl-ext-c-browser {
    width: 32px;
    height: 32px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-surface);
    border: 2px solid var(--fp-slate-900);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.4);
    margin-left: -10px;
    position: relative;
    transition: transform var(--fp-transition);
}
.fp-dl-ext-c-browser:first-child  { margin-left: 0; z-index: 5; }
.fp-dl-ext-c-browser:nth-child(2) { z-index: 4; }
.fp-dl-ext-c-browser:nth-child(3) { z-index: 3; }
.fp-dl-ext-c-browser:nth-child(4) { z-index: 2; }
.fp-dl-ext-c-browser:hover { transform: translateY(-4px); z-index: 10; }
.fp-dl-ext-c-browser img { width: 18px; height: 18px; object-fit: contain; }
.fp-dl-ext-c-right {
    position: relative;
    z-index: 1;
    width: 100%;
    display: flex;
    justify-content: center;
}
.fp-dl-ext-c-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--fp-space-1);
    width: 100%;
    padding: var(--fp-space-3) var(--fp-space-4);
    background: var(--fp-purple-500);
    color: var(--fp-surface);
    border: 2px solid rgba(255, 255, 255, 0.35);
    border-radius: var(--fp-radius-10);
    font-size: var(--fp-text-base);
    font-weight: 800;
    text-decoration: none;
    box-shadow: 0 4px 0 var(--fp-purple-700), 0 6px 16px var(--fp-purple-glow);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    white-space: nowrap;
    transition: all var(--fp-transition);
}
.fp-dl-ext-c-cta:hover {
    transform: translateY(-3px);
    box-shadow: 0 4px 0 var(--fp-purple-700), 0 8px 24px var(--fp-purple-glow);
}

/* ── Loot Deal alerts card — centered, dark, green LIVE pill (coupon-page parity) ── */
.fp-dl-alerts-card {
    position: relative;
    border-radius: var(--fp-radius-lg);
    overflow: hidden;
    background: var(--fp-slate-900);
    border: 2px solid var(--fp-surface);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35), 0 2px 4px rgba(0, 0, 0, 0.04);
    transition: all var(--fp-transition);
    display: flex;
    align-items: center;
    justify-content: center;
}
.fp-dl-alerts-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.45), 0 4px 8px rgba(0, 0, 0, 0.1);
}
.fp-dl-alerts-mesh {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 80% -20%, rgba(168, 85, 247, 0.30), transparent 60%),
        radial-gradient(circle at 20% 120%, rgba(46, 204, 113, 0.20), transparent 60%);
    pointer-events: none;
}
.fp-dl-alerts-inner {
    position: relative;
    z-index: 2;
    padding: var(--fp-space-4) var(--fp-space-4);
    text-align: center;
    width: 100%;
}
.fp-dl-alerts-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-1);
    background: rgba(46, 204, 113, 0.15);
    border: 1px solid rgba(46, 204, 113, 0.3);
    color: var(--fp-green);
    padding: 3px var(--fp-space-2);
    border-radius: var(--fp-radius-pill);
    font-size: var(--fp-text-3xs);
    font-weight: 900;
    letter-spacing: 1px;
    margin-bottom: var(--fp-space-2);
    box-shadow: 0 2px 8px rgba(46, 204, 113, 0.2);
}
.fp-dl-alerts-dot {
    width: 4px;
    height: 4px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-green);
    box-shadow: 0 0 8px rgba(46, 204, 113, 0.8);
    animation: fp-dl-blink 1.5s infinite;
}
.fp-dl-alerts-title {
    margin: 0 0 var(--fp-space-1);
    font-size: var(--fp-text-md);
    font-weight: 900;
    color: var(--fp-surface);
    line-height: 1.2;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}
.fp-dl-alerts-title span { color: var(--fp-slate-400); }
.fp-dl-alerts-sub {
    margin: 0 0 var(--fp-space-2);
    font-size: var(--fp-text-xs);
    color: var(--fp-slate-400);
    line-height: 1.4;
    font-weight: 600;
}
.fp-dl-alerts-stats {
    display: flex;
    justify-content: center;
    gap: var(--fp-space-3);
    margin-bottom: var(--fp-space-2);
}
.fp-dl-alerts-stats span {
    font-size: var(--fp-text-xs);
    font-weight: 800;
    color: var(--fp-slate-300);
}
.fp-dl-alerts-btns {
    display: flex;
    flex-direction: row;
    gap: var(--fp-space-2);
    margin-bottom: var(--fp-space-2);
    width: 100%;
}
.fp-dl-alerts-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--fp-space-1);
    flex: 1;
    padding: var(--fp-space-2) var(--fp-space-3);
    border-radius: var(--fp-radius-10);
    border: 2px solid rgba(255, 255, 255, 0.35);
    text-decoration: none;
    font-size: var(--fp-text-base);
    font-weight: 800;
    color: var(--fp-surface);
    transition: all var(--fp-transition);
}
.fp-dl-btn-tg { background: var(--fp-brand-telegram); }
.fp-dl-btn-wa { background: var(--fp-brand-whatsapp); }
.fp-dl-alerts-btn:hover { transform: translateY(-3px); }
.fp-dl-alerts-trust {
    font-size: var(--fp-text-xs);
    color: var(--fp-slate-500);
    font-weight: 700;
}

/* ══════════════════════════════════════════════════════════════
   SHARE & EARN — Coupon-page premium panel
   ══════════════════════════════════════════════════════════════ */
.fp-dl-share-panel {
    position: relative;
    background: var(--fp-share-panel-bg);
    border-radius: var(--fp-radius-18);
    border: 1.5px solid var(--fp-share-panel-border);
    padding: var(--fp-space-5);
    overflow: hidden;
    isolation: isolate;
}
.fp-dl-share-panel::before {
    content: '';
    position: absolute;
    top: -60px;
    right: -60px;
    width: 180px;
    height: 180px;
    background: radial-gradient(circle, rgba(250, 204, 21, 0.18) 0%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}
.fp-dl-share-panel::after {
    content: '';
    position: absolute;
    bottom: -40px;
    left: -40px;
    width: 140px;
    height: 140px;
    background: radial-gradient(circle, rgba(34, 197, 94, 0.14) 0%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}
.fp-dl-share-panel-head {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-start;
    gap: var(--fp-space-3);
    margin-bottom: var(--fp-space-4);
}
.fp-dl-share-icon-wrap {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    border-radius: var(--fp-radius-md);
    background: var(--fp-gradient-cta);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--fp-text-main);
    box-shadow: 0 4px 14px rgba(245, 158, 11, 0.35);
}
.fp-dl-share-panel-info { flex: 1; min-width: 0; }
.fp-dl-share-panel-title {
    margin: 0 0 var(--fp-space-1);
    font-size: var(--fp-text-lg);
    font-weight: 900;
    color: var(--fp-text-main);
    line-height: 1.2;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--fp-space-2);
}
.fp-dl-share-panel-reward {
    background: var(--fp-green-light);
    color: var(--fp-green-dark);
    border: 1px solid var(--fp-green-mint);
    padding: 2px var(--fp-space-2);
    border-radius: var(--fp-radius-pill);
    font-size: var(--fp-text-xs);
    font-weight: 900;
}
.fp-dl-share-panel-desc {
    margin: 0;
    font-size: var(--fp-text-base);
    color: var(--fp-slate-600);
    font-weight: 600;
    line-height: 1.45;
}
.fp-dl-share-actions {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--fp-space-2);
}
.fp-dl-share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--fp-space-2);
    padding: var(--fp-space-3) var(--fp-space-4);
    border-radius: var(--fp-radius-md);
    border: none;
    cursor: pointer;
    font-size: var(--fp-text-base);
    font-weight: 800;
    color: var(--fp-surface);
    transition: all var(--fp-transition);
}
.fp-dl-share-wa   { background: var(--fp-brand-whatsapp);      box-shadow: 0 4px 12px var(--fp-brand-whatsapp-glow); }
.fp-dl-share-wa:hover   { box-shadow: 0 6px 18px var(--fp-brand-whatsapp-glow); }
.fp-dl-share-tg   { background: var(--fp-brand-telegram-deep); box-shadow: 0 4px 12px var(--fp-brand-telegram-glow); }
.fp-dl-share-tg:hover   { box-shadow: 0 6px 18px var(--fp-brand-telegram-glow); }
.fp-dl-share-tw   { background: var(--fp-text-main);           box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18); }
.fp-dl-share-copy {
    background: var(--fp-surface);
    color: var(--fp-slate-700);
    border: 1px solid var(--fp-slate-300);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
}
.fp-dl-share-copy:hover { background: var(--fp-slate-50); box-shadow: 0 6px 16px rgba(0, 0, 0, 0.06); }
.fp-dl-share-btn:hover  { transform: translateY(-2px); }
.fp-dl-share-btn svg    { flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════════
   STICKY BOTTOM CTA (mobile)
   ══════════════════════════════════════════════════════════════ */
.fp-dl-sticky {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 99;
    background: var(--fp-surface);
    border-top: 1px solid var(--fp-slate-200);
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.08);
    padding: var(--fp-space-2) var(--fp-space-3);
    display: flex;
    align-items: center;
    gap: var(--fp-space-3);
}
.fp-dl-sticky-left { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.fp-dl-sticky-label {
    font-size: var(--fp-text-3xs);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--fp-slate-500);
}
.fp-dl-sticky-price { font-size: var(--fp-text-md); font-weight: 900; color: var(--fp-green-dark); line-height: 1.1; }
.fp-dl-sticky-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--fp-space-2);
    background: var(--fp-primary);
    color: var(--fp-text-main);
    padding: var(--fp-space-3) var(--fp-space-5);
    border-radius: var(--fp-radius-pill);
    text-decoration: none;
    font-weight: 900;
    font-size: var(--fp-text-base);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 12px rgba(250, 204, 21, 0.35);
    transition: all var(--fp-transition);
}
.fp-dl-sticky-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(250, 204, 21, 0.45); }

/* ══════════════════════════════════════════════════════════════
   REDIRECT OVERLAY
   ══════════════════════════════════════════════════════════════ */
.fp-dl-redirect {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.6);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--fp-transition);
}
.fp-dl-redirect.fp-dl-active { opacity: 1; pointer-events: auto; }
.fp-dl-redirect-card {
    background: var(--fp-surface);
    border-radius: var(--fp-radius-xl);
    padding: var(--fp-space-6) var(--fp-space-5);
    max-width: 320px;
    width: calc(100% - var(--fp-space-8));
    text-align: center;
    box-shadow: var(--fp-shadow-xl);
    transform: scale(0.92);
    transition: transform var(--fp-transition);
}
.fp-dl-redirect.fp-dl-active .fp-dl-redirect-card { transform: scale(1); }
.fp-dl-redirect-icon {
    width: 64px;
    height: 64px;
    border-radius: var(--fp-radius-circle);
    background: var(--fp-green-light);
    color: var(--fp-green);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--fp-space-3);
}
.fp-dl-redirect-card h3 { margin: 0 0 var(--fp-space-2); font-size: var(--fp-text-md2); font-weight: 900; color: var(--fp-text-main); }
.fp-dl-redirect-card p { margin: 0 0 var(--fp-space-3); font-size: var(--fp-text-xs); color: var(--fp-slate-600); }
.fp-dl-redirect-bar-wrap {
    height: 4px;
    border-radius: var(--fp-radius-pill);
    background: var(--fp-slate-100);
    overflow: hidden;
    margin-bottom: var(--fp-space-2);
}
.fp-dl-redirect-bar {
    height: 100%;
    width: 0;
    background: var(--fp-gradient-green);
    transition: width 2s linear;
}
.fp-dl-redirect-trust {
    font-size: var(--fp-text-2xs);
    color: var(--fp-slate-400);
    font-weight: 700;
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE FIRST → TABLET → DESKTOP
   ══════════════════════════════════════════════════════════════ */
@media (min-width: 600px) {
    .fp-dl-hero-inner { gap: var(--fp-space-4); }
    .fp-dl-hero-img-wrap {
        width: 180px;
        height: 180px;
    }
    .fp-dl-hero-info { flex: 1; }
    .fp-dl-procon-row { grid-template-columns: 1fr 1fr; }
    .fp-dl-checks { grid-template-columns: 1fr 1fr; }
    .fp-dl-share-actions { grid-template-columns: repeat(4, 1fr); }
    .fp-dl-stack-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 768px) {
    .fp-dl { padding-bottom: 0; }
    .fp-dl-sticky { display: none; }
    .fp-dl-bottom-grid { grid-template-columns: 1fr 1fr; }
    .fp-cpg-slider-btn { display: inline-flex; }
    .fp-dl-hero-img-wrap { width: 220px; height: 220px; }
    .fp-dl-title { font-size: var(--fp-text-xl); }
    .fp-dl-price-now { font-size: var(--fp-text-3xl2); }
    .fp-cpg-trending-grid { grid-auto-columns: 180px; }
}

@media (min-width: 1024px) {
    .fp-dl-hero { padding: var(--fp-space-6); }
    .fp-dl-content { padding: var(--fp-space-5) var(--fp-space-4); }
    .fp-dl-card { padding: var(--fp-space-6); }
}
