/* ==========================================================================
   Responsive Styles
   ========================================================================== */

/* Tablet */
@media (max-width: 1024px) {
    :root {
        --basic-font-size-3xl: 36px;
        --basic-font-size-2xl: 28px;
        --basic-spacing-3xl: 48px;
    }
}

/* Mobile */
@media (max-width: 768px) {
    :root {
        --basic-font-size-3xl: 28px;
        --basic-font-size-2xl: 24px;
        --basic-font-size-xl: 20px;
        --basic-spacing-2xl: 32px;
        --basic-spacing-3xl: 40px;
    }

    .basic-container {
        padding: 0 var(--basic-spacing-md);
    }

    .basic-footer-widgets {
        grid-template-columns: 1fr;
    }

    /* VE: Columns responsive */
    .fve-cols-stack { grid-template-columns: 1fr !important; }
    .fve-cols-2 { grid-template-columns: repeat(2, 1fr) !important; }
    .fve-cols-3 { grid-template-columns: repeat(3, 1fr) !important; }
    /* fve-cols-keep: no override */

    .fve-hide-mobile { display: none !important; }

    /* Mobile text style overrides */
    [data-m-font-size] { font-size: attr(data-m-font-size) !important; }
    [data-m-text-align] { text-align: attr(data-m-text-align) !important; }
}

@media (min-width: 769px) {
    .fve-hide-desktop { display: none !important; }
}

/* Small Mobile */
@media (max-width: 480px) {
    :root {
        --basic-font-size-3xl: 24px;
        --basic-font-size-2xl: 20px;
    }
}
