/**
 * VS Product Blocks v2.0 — Front Office Styles
 * Base wrapper styles + discount badge for rendered blocks on product pages
 *
 *  @author    vsteq.com
 *  @copyright 2007-2026 PrestaShop SA
 *  @license   http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
 */

/* Block wrapper */
.vsblocks-block {
    margin: 10px 0;
}

.vsblocks-block-content {
    /* Let the user's HTML/CSS fully control the look */
}

/* Hook-specific subtle spacing defaults */
.vsblocks-block-displayProductAdditionalInfo {
    margin-top: 15px;
    margin-bottom: 15px;
}

.vsblocks-block-displayFooterProduct {
    margin-top: 20px;
    padding-top: 15px;
}

.vsblocks-block-displayProductExtraContent .vsblocks-block-content {
    padding: 15px 0;
}

.vsblocks-block-displayRightColumnProduct,
.vsblocks-block-displayLeftColumnProduct {
    margin-bottom: 20px;
}

.vsblocks-block-displayReassurance {
    margin-top: 10px;
}

/* =========================================================================
   Discount Badge
   ========================================================================= */

.vsblocks-discount-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    padding: 6px 14px;
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    color: #fff;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.25);
    cursor: pointer;
    transition: all 0.2s ease;
    animation: vsblocksBadgePulse 2s ease-in-out infinite;
}

.vsblocks-discount-badge:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.35);
}

.vsblocks-discount-badge i {
    font-size: 16px;
}

.vsblocks-discount-badge strong {
    font-weight: 700;
    letter-spacing: 0.5px;
}

@keyframes vsblocksBadgePulse {
    0%, 100% { box-shadow: 0 2px 8px rgba(99, 102, 241, 0.25); }
    50% { box-shadow: 0 2px 16px rgba(99, 102, 241, 0.45); }
}

/* Copied notification */
.vsblocks-discount-copied {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    background: #10b981;
    color: #fff;
    padding: 10px 24px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
    z-index: 9999;
    animation: vsblocksSlideUp 0.3s ease;
}

@keyframes vsblocksSlideUp {
    from { opacity: 0; transform: translateX(-50%) translateY(20px); }
    to { opacity: 1; transform: translateX(-50%) translateY(0); }
}
