/* Namari Landing Page Dynamic Style Index

1. Website Default Styling
2. Navigation
3. Primary and Secondary Colors
4. Banner
5. Typography
6. Buttons
7. Footer


/*------------------------------------------------------------------------------------------*/
/* 1. Website Default Styling */
/*------------------------------------------------------------------------------------------*/


body {
    background:#fff;
}


/* Default Link Color */

a, .la-ball-triangle-path {
    color:#054672;
}

a:hover, #header.nav-solid nav a:hover {
    color:#054672;
}

/* Default Icon Color */

.icon i {
    color:#054672;
}

/* Border Color */

#banner .section-heading:before, .testimonial.classic footer:before {
    background: #054672;
}

.pricing-block-content:hover {
    border-color:#054672;
}


/*------------------------------------------------------------------------------------------*/
/* 2. Navigation */
/*------------------------------------------------------------------------------------------*/


/* Transparent Navigation Color on a Banner */

#header nav a, #header i {
    color:#111;
}


/* Navigation Colors when the Navigation is sticky and solid */ 

#header.nav-solid, #header.nav-solid a, #header.nav-solid i, #nav-mobile ul li a {
    color:#333;
}


/* Navigation Active State */

#header.nav-solid .active {
    color: #054672;
    border-color: #054672;
}    



/*------------------------------------------------------------------------------------------*/
/* 3. Primary and Secondary Colors */
/*------------------------------------------------------------------------------------------*/


/* Primary Background and Text Colors */

.primary-color, .featured .pricing {
    background-color:#054672;
}

.primary-color, .primary-color .section-title, .primary-color .section-subtitle, .featured .pricing, .featured .pricing p {
    color:#fff;    
}

.section-heading h2:after {
    background:#054672;
    content:"";
    display:block;
    width:30px;
    height:5px;
    margin-top:30px;
}

.text-center .section-heading h2:after {
    margin:30px auto 25px auto;
}

/* Primary Icon Colors */

.primary-color .icon i, .primary-color i {
    color:#fff;
}


/* Secondary Background and Text Colors */

.secondary-color {
    background-color:#f5f5f5;
}


/*------------------------------------------------------------------------------------------*/
/* 4. Banner */
/*------------------------------------------------------------------------------------------*/


/* Banner Background and Text Colors */

#banner {
    background:#fff;
}


/*------------------------------------------------------------------------------------------*/
/* 5. Typography */
/*------------------------------------------------------------------------------------------*/


body {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size:15px;
    font-weight:normal;
    color:#111;
}

/* Logo, if you are using Fonts as Logo and not image

#logo h1 {
    font-family:;
    font-size:; 
    font-weight:;
    color:;
}

#logo h2 {
    font-family:;
    font-size:; 
    font-weight:;
    color:;
}

*/


/* Banner Typography */

#banner h1 {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size:62px;
    line-height:60px;
    font-weight:800;
    color:#111;
}

#banner h2 {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size:18px;
    font-weight:300;
    color:#111;
}


/* Section Title and Subtitle */

.section-title {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 34px; 
    font-weight:700;
    color:#111;
}

.section-subtitle {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 16px;
    font-weight:300;
    color:#9c9c9c;
}

/* Testimonial */

.testimonial q {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 17px; 
    font-weight:300;
}

.testimonial.classic q, .testimonial.classic footer {
    color:#111;
}


/* Standard Headings h1-h6 */

h1 {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 40px; 
    font-weight:300;
    color:#111;
}

h2 {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 34px; 
    font-weight:300;
    color:#111;
}

h3 {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 30px; 
    font-weight:700;
    color:#111;
}

h4 {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 18px; 
    font-weight:400;
    color:#111;
}

h5 {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 16px; 
    font-weight:400;
    color:#111;
}

h6 {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size: 14px; 
    font-weight:400;
    color:#111;
}


/*------------------------------------------------------------------------------------------*/
/* 6. Buttons */
/*------------------------------------------------------------------------------------------*/

/* ----------Default Buttons---------- */


/* Button Text */

.button, input[type="submit"]  {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size:14px;
    font-weight:bold;
    color:#111;
}


/* Button Color */

.button, input[type="submit"] {
    border-color:#111;
}


/* Button Hover Color */

.button:hover,  input[type="submit"]:hover {
    border-color:#054672;
    color:#054672;
}


/* ----------Banner Buttons---------- */


/* Button Text */

#banner .button {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size:16px;
    color:#111;
}


/* Button Color */

#banner .button {
    border-color:#111;
}


/* Button Hover Color */

#banner .button:hover {
    color:#054672;
    border-color:#054672;
}


/*------------------------------------------------------------------------------------------*/
/* 7. Footer */
/*------------------------------------------------------------------------------------------*/

#landing-footer, #landing-footer p, #landing-footer a {
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
    font-size:12px;
    font-weight:normal;
    color:#999;
}

/* Footer Icon Color */

#landing-footer i {
    color:#999;
}

/* =========================================================================
   ACCESIBILIDAD: WCAG AA contrast + jerarquía de headings
   ========================================================================= */

/* FontAwesome con font-display: swap (mejora FCP ~90ms) */
@font-face {
    font-family: 'FontAwesome';
    src: url('../fonts/fontawesome-webfont.woff2?v=4.7.0') format('woff2'),
         url('../fonts/fontawesome-webfont.woff?v=4.7.0') format('woff'),
         url('../fonts/fontawesome-webfont.ttf?v=4.7.0') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

/* Eyebrow (antes .section-heading h3 = #ccc, ratio 1.6:1 → falla AA) */
.section-heading h3,
.section-heading .section-eyebrow {
    color: #054672 !important;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    line-height: 1.4;
    padding-bottom: 0;
    display: block;
    margin: 0 0 6px;
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
}

/* Subtitulo: gris medio (era #9c9c9c, ratio 3.1:1 → falla AA) */
.section-subtitle {
    color: #5a6b7a !important;
}

/* Footer: gris medio (era #999, ratio 2.8:1) */
#landing-footer,
#landing-footer p,
#landing-footer a,
#landing-footer i {
    color: #5a6b7a !important;
}

/* Comunidad card tag: cyan oscuro (era #1cabc4, ratio 3.0:1) */
.community-card-tag {
    color: #0d6e7e;
    background: rgba(13, 110, 126, .1);
}

/* Producto labels más oscuros */
.product-soon-label {
    color: #5a6b7a;
}
.product-active .product-soon-label {
    color: #0d6e7e;
}

/* Cuando el banner de idioma está visible, marco y contenido bajan
   para no taparse. Animación suave en ambos lados. */
.page-border > .top-border,
.page-border > .left-border,
.page-border > .right-border,
#wrapper {
    transition: top .35s cubic-bezier(.2,.8,.2,1),
                height .35s cubic-bezier(.2,.8,.2,1),
                margin-top .35s cubic-bezier(.2,.8,.2,1);
}
body.has-lang-banner .page-border > .top-border {
    top: var(--lang-banner-h, 50px);
}
body.has-lang-banner .page-border > .left-border,
body.has-lang-banner .page-border > .right-border {
    top: var(--lang-banner-h, 50px);
    height: calc(100% - var(--lang-banner-h, 50px));
}
body.has-lang-banner #wrapper {
    margin-top: var(--lang-banner-h, 50px);
}

/* Banner de sugerencia de idioma (lang-banner.js)
 * Posicionado al top como un app-bar; cuando aparece, empuja
 * el frame y el contenido hacia abajo (estilo GitHub/Stripe).
 */
.lang-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: #054672;
    color: #fff;
    padding: 12px 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
    font-size: 14px;
    line-height: 1.4;
    z-index: 1000000;
    transform: translateY(-100%);
    transition: transform .35s cubic-bezier(.2,.8,.2,1);
    box-shadow: 0 2px 12px rgba(0,0,0,.18);
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
}
.lang-banner.lang-banner-visible {
    transform: translateY(0);
}
.lang-banner-text { color: #fff; }
.lang-banner-text strong { color: #fff; font-weight: 700; }
.lang-banner-switch {
    background: #fff;
    color: #054672 !important;
    padding: 6px 14px;
    border-radius: 4px;
    font-weight: 700;
    text-decoration: none;
    font-size: 13px;
    transition: background .2s ease-out;
    line-height: 1;
}
.lang-banner-switch:hover {
    background: #e6f0f5;
    color: #054672 !important;
}
.lang-banner-dismiss {
    background: transparent;
    color: #fff;
    border: 1px solid rgba(255,255,255,.4);
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 13px;
    cursor: pointer;
    font-family: inherit;
    line-height: 1;
    transition: background .2s ease-out;
}
.lang-banner-dismiss:hover {
    background: rgba(255,255,255,.1);
}
/* Mobile: el .page-border se oculta (style.css max-width: 767px), padding más compacto */
@media (max-width: 767px) {
    .lang-banner {
        padding: 10px 14px;
        font-size: 13px;
        gap: 10px;
    }
}

/* Language switcher en el header */
.lang-switcher {
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
    display: flex;
    gap: 6px;
    align-items: center;
}
.lang-switcher li {
    display: inline-block;
    margin: 0;
    padding: 0;
}
.lang-switcher a {
    color: #054672;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    text-decoration: none;
    padding: 4px 7px;
    border-radius: 3px;
    border: 1px solid transparent;
    transition: background .2s ease-out, color .2s ease-out, border-color .2s ease-out;
    line-height: 1;
}
.lang-switcher a:hover {
    background: rgba(5,70,114,.08);
    color: #054672;
}
.lang-switcher a.active {
    background: #054672;
    color: #fff;
}
#header.nav-solid .lang-switcher a {
    color: #054672;
}
#header.nav-solid .lang-switcher a.active {
    background: #054672;
    color: #fff;
}

/* Card h3 (antes era h4): mantener visual de h4 */
.icon-block h3,
.icon-block-description h3 {
    font-size: 18px;
    font-weight: 700;
    color: #054672;
    margin: 0 0 8px;
    line-height: 1.35;
    padding-top: 0;
    font-family: 'Open Sans', sans-serif, Arial, Helvetica;
}

/* WhatsApp pulse: usar transform en lugar de box-shadow (composited GPU) */

/* Productos: layout asimétrico estilo Stripe/Linear/Vercel */
#productos .col-2-3 [class*='col-'] {
    padding: 0;
}
.products-grid {
    display: flex;
    gap: 20px;
    align-items: stretch;
}
.products-grid > * {
    width: auto !important;
    float: none !important;
}
.product-featured {
    flex: 2;
    position: relative;
    overflow: hidden;
    display: block;
    text-decoration: none;
    background: linear-gradient(135deg, #032d4a 0%, #054672 45%, #0a6ba6 100%);
    border-radius: 16px;
    padding: 44px 40px 38px;
    color: #fff !important;
    min-height: 320px;
    transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s cubic-bezier(.2,.8,.2,1);
    box-shadow: 0 10px 30px rgba(5, 70, 114, .25);
}
.product-featured:hover {
    transform: translateY(-6px);
    box-shadow: 0 24px 60px rgba(5, 70, 114, .42);
    color: #fff !important;
}
.product-featured-glow {
    position: absolute;
    top: -40%;
    right: -25%;
    width: 80%;
    height: 180%;
    background: radial-gradient(circle, rgba(28,171,196,.35) 0%, rgba(28,171,196,0) 60%);
    pointer-events: none;
    transition: opacity .35s ease-out;
}
.product-featured:hover .product-featured-glow {
    opacity: .7;
}
.product-featured-mark {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: rgba(255,255,255,.12);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 22px;
    position: relative;
    z-index: 1;
}
.product-featured-mark img {
    max-width: 36px;
    max-height: 36px;
    padding: 0 !important;
}
.product-featured-tag {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    color: rgba(255,255,255,.7);
    margin-bottom: 14px;
    position: relative;
    z-index: 1;
}
.product-featured h3 {
    color: #fff !important;
    font-size: 38px;
    font-weight: 700;
    line-height: 1.1;
    margin: 0 0 14px;
    letter-spacing: -.5px;
    position: relative;
    z-index: 1;
}
.product-featured p {
    color: rgba(255,255,255,.85);
    font-size: 16px;
    line-height: 1.55;
    margin: 0 0 30px;
    max-width: 420px;
    position: relative;
    z-index: 1;
}
.product-featured-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #fff;
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 1.5px;
    position: relative;
    z-index: 1;
    border-bottom: 1px solid rgba(255,255,255,.4);
    padding-bottom: 6px;
    transition: border-color .25s ease-out;
}
.product-featured:hover .product-featured-cta {
    border-color: #fff;
}
.product-featured-cta .fa {
    transition: transform .25s cubic-bezier(.2,.8,.2,1);
}
.product-featured:hover .product-featured-cta .fa {
    transform: translateX(8px);
}

.product-soon-stack {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.product-soon-mini {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    background: #f7f9fb;
    border: 1px solid #e6ecf1;
    border-radius: 16px;
    padding: 28px 26px;
    text-decoration: none;
    color: #5a6b7a !important;
    min-height: 150px;
    transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s ease-out, background .3s ease-out, color .3s ease-out;
}
.product-soon-mini:hover {
    transform: translateY(-3px);
    border-color: #054672;
    background: #fff;
    color: #054672 !important;
}
.product-soon-mini .fa {
    font-size: 22px;
    color: #b4c1cc;
    margin-bottom: 12px;
    transition: color .3s ease-out;
}
.product-soon-mini:hover .fa {
    color: #054672;
}
.product-soon-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #98a4b0;
    margin-bottom: 4px;
    transition: color .3s ease-out;
}
.product-soon-mini:hover .product-soon-label {
    color: #054672;
}
.product-soon-name {
    font-size: 16px;
    font-weight: 600;
}
.product-soon-desc {
    font-size: 13px;
    color: #7a8794;
    margin-top: 6px;
    line-height: 1.4;
    transition: color .3s ease-out;
}

/* Variante "activa" del soon-mini: para productos reales (no placeholders) */
.product-active {
    background: #fff;
    border-color: #d6e1ea;
    color: #054672 !important;
}
.product-active .fa { color: #054672; }
.product-active .product-soon-label { color: #1cabc4; }
.product-active:hover {
    transform: translateY(-3px);
    border-color: #054672;
    background: #fff;
    box-shadow: 0 12px 28px rgba(5,70,114,.15);
    color: #054672 !important;
}

/* ---------- Comunidad / Open Source ---------- */
.community-grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
@media (min-width: 768px) {
    .community-grid {
        flex-direction: row;
    }
}
.community-card {
    flex: 1;
    display: block;
    background: #fff;
    border: 1px solid #e6ecf1;
    border-radius: 16px;
    padding: 32px 28px;
    margin: 12px;
    text-decoration: none;
    color: #1f2d3d !important;
    transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease-out, border-color .3s ease-out;
    position: relative;
    overflow: hidden;
}
.community-card:hover {
    transform: translateY(-5px);
    border-color: #054672;
    box-shadow: 0 16px 36px rgba(5,70,114,.18);
    color: #1f2d3d !important;
}
.community-card-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: linear-gradient(135deg, #054672, #1cabc4);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    margin-bottom: 18px;
}
.community-card-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.8px;
    color: #1cabc4;
    background: rgba(28,171,196,.08);
    padding: 4px 10px;
    border-radius: 999px;
    margin-bottom: 12px;
}
.community-card h3 {
    font-size: 22px;
    font-weight: 700;
    color: #054672 !important;
    margin: 0 0 10px;
    font-family: 'Open Sans', monospace;
}
.community-card p {
    font-size: 15px;
    line-height: 1.55;
    color: #4a5868;
    margin: 0 0 22px;
}
.community-card p code,
.product-soon-desc code,
.icon-block-description p code {
    background: rgba(5,70,114,.08);
    color: #054672;
    padding: 2px 7px;
    border-radius: 4px;
    font-size: 90%;
    font-family: 'SFMono-Regular', Menlo, Consolas, monospace;
}
.community-card-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #054672;
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 1px;
    text-transform: uppercase;
    border-bottom: 1px solid rgba(5,70,114,.25);
    padding-bottom: 4px;
    transition: border-color .25s ease-out;
}
.community-card:hover .community-card-cta {
    border-color: #054672;
}
.community-card-cta .fa {
    transition: transform .25s cubic-bezier(.2,.8,.2,1);
}
.community-card:hover .community-card-cta .fa {
    transform: translateX(6px);
}

@media (max-width: 768px) {
    .products-grid {
        flex-direction: column;
    }
    .product-featured h3 {
        font-size: 30px;
    }
    .product-featured {
        padding: 32px 26px;
        min-height: auto;
    }
}

/* ----- Stack de FABs flotantes (WhatsApp + Scroll-up) ----- */

/* WhatsApp: primario, abajo */
.wa-float {
    position: fixed;
    right: 24px;
    bottom: 24px;
    width: 60px;
    height: 60px;
    background: #25D366;
    color: #fff !important;
    border-radius: 50%;
    text-align: center;
    line-height: 60px;
    font-size: 30px;
    box-shadow: 0 6px 18px rgba(37, 211, 102, .35), 0 2px 6px rgba(0,0,0,.12);
    z-index: 99998;
    transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease-out;
}
.wa-float::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    border-radius: 50%;
    background: #25D366;
    z-index: -1;
    animation: wa-pulse 2.4s ease-out infinite;
    will-change: transform, opacity;
}
.wa-float:hover {
    transform: scale(1.08);
    box-shadow: 0 10px 28px rgba(37, 211, 102, .55), 0 4px 12px rgba(0,0,0,.18);
    color: #fff !important;
}
.wa-float:hover::after {
    animation-play-state: paused;
}
.wa-float i {
    line-height: 60px;
}
/* transform + opacity = composited en GPU, sin layout/paint */
@keyframes wa-pulse {
    0%   { transform: scale(1); opacity: .55; }
    80%  { transform: scale(1.6); opacity: 0; }
    100% { transform: scale(1.6); opacity: 0; }
}

/* Scroll-to-top: secundario, encima del WhatsApp; sobreescribe el estilo del template */
#scrollUp {
    bottom: 96px !important;       /* 24 (gap inferior) + 60 (WA) + 12 (espacio entre) */
    right: 30px !important;
    width: 44px !important;
    height: 44px !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
    color: #054672 !important;
    border-radius: 50% !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.14) !important;
    z-index: 99997 !important;
    transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease-out !important;
}
#scrollUp:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 22px rgba(5,70,114,.22) !important;
    margin: 0 !important;
}
#scrollUp:before {
    background: transparent !important;
    color: #054672 !important;
    width: 44px !important;
    height: 44px !important;
    line-height: 44px !important;
    font-size: 20px !important;
    border-radius: 50%;
    display: block !important;
}

/* Mobile: WA más chico, scroll-up oculto (ya lo hace el template > 768px) */
@media (max-width: 600px) {
    .wa-float {
        width: 52px;
        height: 52px;
        line-height: 52px;
        font-size: 26px;
        right: 16px;
        bottom: 16px;
    }
    .wa-float i {
        line-height: 52px;
    }
}

/* =========================================================================
   MOBILE-FIRST OVERRIDES
   Base = mobile (sin media query); luego escalamos hacia arriba.
   ========================================================================= */

/* ---------- Hero / banner ---------- */
#banner-content.row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding: 110px 18px 50px;
}
#banner-content > .col-2 {
    flex: 1 1 100%;
    width: 100% !important;
    text-align: center;
    padding: 0 !important;
    margin: 0;
    float: none;
}
#banner-content img {
    max-width: 88%;
    max-height: 320px;
    width: auto;
    height: auto;
    margin: 28px auto 0;
    display: block;
}
#banner h1 {
    font-size: 30px !important;
    line-height: 1.18;
    padding-top: 0 !important;
}
#banner h2 {
    font-size: 15px !important;
    line-height: 1.5;
}
#banner .section-heading:before {
    margin: 18px auto 14px;
}

/* ---------- Productos: featured card en mobile ---------- */
.product-featured {
    padding: 32px 26px;
    min-height: auto;
    border-radius: 14px;
}
.product-featured h3 {
    font-size: 28px;
}
.product-featured p {
    font-size: 15px;
}
.product-soon-mini {
    padding: 24px 22px;
    min-height: 110px;
}

/* ---------- Section headings y typography mobile ---------- */
.section-title {
    font-size: 26px !important;
    line-height: 1.25;
}
h2.section-title {
    font-size: 26px !important;
}
.section-subtitle {
    font-size: 15px !important;
}
.row {
    padding: 50px 0;
}

/* ---------- Tablet portrait (≥600px) ---------- */
@media (min-width: 600px) {
    #banner h1 { font-size: 38px !important; }
    .section-title, h2.section-title { font-size: 30px !important; }
    .product-featured h3 { font-size: 32px; }
}

/* ---------- Tablet landscape / desktop pequeño (≥768px) ---------- */
@media (min-width: 768px) {
    #banner-content.row {
        padding: 150px 30px 80px;
    }
    #banner-content > .col-2:first-child {
        flex: 0 1 50%;
        width: 50% !important;
        text-align: left;
    }
    #banner-content > .col-2:last-child {
        flex: 0 1 50%;
        width: 50% !important;
        text-align: right;
    }
    #banner-content img {
        max-width: 100%;
        max-height: 480px;
        margin: 0 0 0 auto;
    }
    #banner h1 { font-size: 44px !important; line-height: 1.1; }
    #banner h2 { font-size: 17px !important; }
    #banner .section-heading:before { margin-left: 0; margin-right: 0; }
    .section-title, h2.section-title { font-size: 32px !important; }
    .row { padding: 75px 0; }
    .product-featured { padding: 40px 36px; }
    .product-featured h3 { font-size: 36px; }
}

/* ---------- Desktop (≥1024px) ---------- */
@media (min-width: 1024px) {
    #banner-content.row {
        padding: 170px 0 100px;
    }
    #banner h1 { font-size: 54px !important; }
    #banner h2 { font-size: 18px !important; }
    #banner-content img { max-height: 560px; }
    .section-title, h2.section-title { font-size: 34px !important; }
    .product-featured { padding: 44px 40px 38px; min-height: 320px; }
    .product-featured h3 { font-size: 38px; }
}