/* ============================================================================
   FORMONIX POS — CMS Frontend Redesign Layer  ·  v2 (VIP / sky-blue + white)
   Loaded AFTER cms.css. Override-only, additive. cms.css NEVER touched.
   Brand: #0474ba sky-blue + white · Fonts: Plus Jakarta Sans + Inter
   ============================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800&family=Inter:wght@400;500;600;700&display=swap');

/* ---------- 1. DESIGN TOKENS ---------- */
:root {
    /* brand */
    --primary: #0474ba;
    --primary-deep: #035d96;
    --primary-bright: #1e90d6;
    --accent-cyan: #00d8ff;
    --secondary: #102a54;          /* navy headings / dark band */
    --secondary-deep: #0b1b3b;
    --primary-invert: #ffffff;
    --secondary-invert: #ffffff;

    /* text */
    --text-primary: #16243d;
    --ink: #16243d;
    --muted: #5b6b86;

    /* surfaces */
    --surface: #ffffff;
    --surface-alt: #f1f6fc;
    --surface-tint: #e3f0ff;
    --border-soft: #e2eaf5;

    /* semantic */
    --success: #16b364;
    --warning: #f5b301;
    --danger: #e5484d;
    --whatsapp: #25d366;

    /* radius */
    --r-sm: 10px;
    --r-md: 14px;
    --r-card: 18px;
    --r-lg: 26px;
    --r-pill: 999px;
    --elements-roundness: 12px;

    /* shadows (soft, blue-tinted) */
    --shadow-xs: 0 1px 2px rgba(4,116,186,.05);
    --shadow-sm: 0 4px 16px rgba(16,42,84,.06);
    --shadow-md: 0 12px 32px rgba(4,116,186,.10);
    --shadow-lg: 0 24px 60px rgba(4,116,186,.16);
    --shadow-cta: 0 30px 70px rgba(11,27,59,.30);
    --shadow-btn: 0 10px 24px rgba(4,116,186,.30);

    /* gradients */
    --grad-primary: linear-gradient(135deg, #0474ba 0%, #035d96 100%);
    --grad-sky: linear-gradient(135deg, #1e90d6 0%, #0474ba 100%);
    --grad-cta: linear-gradient(135deg, #102a54 0%, #0b1b3b 55%, #035d96 100%);
    --grad-text: linear-gradient(90deg, #0474ba, #1e90d6);

    /* spacing */
    --space-between-blocks: 6rem;
    --space-between-blocks-small-screens: 3.25rem;
}

/* ---------- 2. BASE / TYPOGRAPHY ---------- */
body {
    font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif !important;
    color: var(--text-primary);
    background: var(--surface);
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
h1, h2, h3, h4, h5, h6,
.hero__title, .block__title, .block__title--big,
.card-1__title, .block-2-card__title, .content-block__title,
.block-29__title, .stats__number, .price-card__name {
    font-family: 'Plus Jakarta Sans', 'Inter', system-ui, sans-serif !important;
    color: var(--secondary);
    letter-spacing: -0.02em;
}
.hero__title { font-weight: 800 !important; line-height: 1.08; font-size: clamp(2.3rem, 4.8vw, 3.75rem) !important; }
.block__title--big { font-weight: 800 !important; font-size: clamp(1.9rem, 3vw, 2.7rem) !important; }
.block__title { font-weight: 700 !important; }
.block__paragraph, .block__paragraph--big,
.card-1__paragraph, .block-2-card__paragraph,
.content-block__paragraph, .hero__paragraph { color: var(--muted); }
.hero__paragraph { font-size: 1.12rem; max-width: 560px; }
a { transition: color .18s ease; }
html { scroll-behavior: smooth; }
::selection { background: rgba(4,116,186,.22); color: #fff; }
img { max-width: 100%; }

@media only screen and (min-width: 992px) {
    .container { max-width: 1200px !important; }
}

/* ---------- 3. EYEBROW PILL ---------- */
.eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: .8rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
    color: var(--primary-deep);
    background: var(--surface-tint);
    border: 1px solid rgba(4,116,186,.18);
    padding: .4rem .9rem; border-radius: var(--r-pill);
    margin-bottom: 1.1rem;
}
.eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent-cyan); box-shadow: 0 0 0 4px rgba(0,216,255,.18); }

/* ---------- 4. BUTTONS ---------- */
.btn {
    border-radius: var(--r-pill) !important;
    font-family: 'Plus Jakarta Sans', 'Inter', sans-serif !important;
    font-weight: 600 !important;
    padding: .82rem 1.85rem !important;
    border: none !important; text-transform: none !important; letter-spacing: 0;
    cursor: pointer;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease !important;
    display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
}
.btn-primary {
    background: var(--grad-primary) !important; color: #fff !important;
    box-shadow: var(--shadow-btn) !important;
}
.btn-primary:hover, .btn-primary:focus {
    transform: translateY(-2px); color: #fff !important;
    box-shadow: 0 16px 34px rgba(4,116,186,.42) !important;
}
.btn-secondary {
    background: #fff !important; color: var(--primary-deep) !important;
    box-shadow: var(--shadow-sm) !important; border: 1px solid var(--border-soft) !important;
}
.btn-secondary:hover, .btn-secondary:focus {
    transform: translateY(-2px); background: #fff !important; color: var(--primary-deep) !important;
    box-shadow: var(--shadow-md) !important;
}
.btn-ghost {
    background: rgba(4,116,186,.08) !important; color: var(--primary-deep) !important;
    border: 1.5px solid rgba(4,116,186,.32) !important; box-shadow: none !important;
}
.btn-ghost:hover { transform: translateY(-2px); background: rgba(4,116,186,.14) !important; color: var(--primary-deep) !important; }
.btn-whatsapp {
    background: var(--whatsapp) !important; color: #fff !important;
    box-shadow: 0 10px 24px rgba(37,211,102,.30) !important;
}
.btn-whatsapp:hover { transform: translateY(-2px); background: #1eb955 !important; color: #fff !important; box-shadow: 0 16px 32px rgba(37,211,102,.40) !important; }

/* ---------- 5. NAVBAR (sticky condense) ---------- */
.fixed-nav-container {
    position: fixed; top: .6rem; left: 0; right: 0; margin-inline: auto;
    width: calc(100% - 1.5rem); max-width: 1232px; z-index: 1000;
    background: #ffffff;
    box-shadow: 0 8px 30px rgba(16,42,84,.08);
    border: 1px solid rgba(226,234,245,.7);
    border-radius: 16px;
    transition: box-shadow .25s ease, background .25s ease, top .25s ease;
}
/* clear the fixed nav */
body { padding-top: 96px; }
@media (max-width: 991px) {
    body { padding-top: 80px; }
    .fixed-nav-container { top: .4rem; width: calc(100% - 1rem); }
}
.fixed-nav-container.is-stuck { box-shadow: var(--shadow-md); background: rgba(255,255,255,.98); }
.hero-nav { padding: .55rem 1.4rem !important; }
.hero-nav__logo { height: 66px; width: auto; transition: height .25s ease; }
@media (min-width: 992px) {
    .hero__menu-content { flex-wrap: nowrap !important; gap: .15rem; align-items: center; }
    .hero-nav__item { white-space: nowrap; }
    .hero-nav__item .btn { white-space: nowrap; margin-left: .45rem; }
}
.is-stuck .hero-nav__logo { height: 56px; }
.hero-nav__link {
    font-family: 'Inter', sans-serif !important; font-weight: 600 !important;
    color: #1c2b4a !important; padding: .55rem .9rem !important; border-radius: 8px;
    position: relative; transition: color .16s ease;
}
.hero-nav__link:hover, .hero-nav__link:focus { color: var(--primary) !important; background: transparent !important; }
.hero-nav__link::after {
    content: ''; position: absolute; left: .9rem; right: .9rem; bottom: .26rem; height: 2px;
    background: var(--grad-text); border-radius: 2px;
    transform: scaleX(0); transform-origin: left; transition: transform .22s ease;
}
.hero-nav__link:hover::after, .hero-nav__link:focus::after { transform: scaleX(1); }
.hero-nav__item .btn-primary { padding: .58rem 1.4rem !important; }
.hero-nav__dropdown { box-shadow: var(--shadow-md) !important; border-radius: var(--r-md) !important; border: 1px solid var(--border-soft); }
.fmx-nav-phone {
    display: inline-flex; align-items: center; gap: .5rem;
    color: var(--primary-deep) !important; font-weight: 600; font-size: .92rem;
    padding: .45rem .8rem; border-radius: var(--r-pill); background: var(--surface-tint);
}

/* ---------- 6. HERO ---------- */
.hero {
    background:
        radial-gradient(1200px 520px at 85% -10%, rgba(4,116,186,.14), transparent 60%),
        radial-gradient(900px 520px at -5% 10%, rgba(0,216,255,.08), transparent 55%),
        linear-gradient(180deg, #ffffff 0%, #f1f6fc 100%);
    overflow: hidden;
}
.hero__btn { font-size: 1.02rem !important; }
.hero__image-column {
    background-size: contain !important; background-repeat: no-repeat !important;
    background-position: center right !important; min-height: 440px;
    filter: drop-shadow(0 30px 60px rgba(16,42,84,.18));
}
.fmx-trust-row {
    display: flex; flex-wrap: wrap; gap: 1.2rem; margin-top: 1.5rem;
    color: var(--muted); font-size: .9rem; font-weight: 500;
}
.fmx-trust-row span { display: inline-flex; align-items: center; gap: .45rem; }
.fmx-trust-row i { color: var(--success); }

/* ---------- 7. SECTION RHYTHM ---------- */
.space-between-blocks {
    padding-top: var(--space-between-blocks-small-screens);
    padding-bottom: var(--space-between-blocks-small-screens);
}
@media (min-width: 992px) {
    .space-between-blocks { padding-top: var(--space-between-blocks); padding-bottom: var(--space-between-blocks); }
}
.block-38, .block-39 { background: var(--surface-alt); border-radius: var(--r-lg); }
.fmx-section-head { max-width: 720px; margin: 0 auto 3rem; text-align: center; }
.fmx-section-head .block__paragraph { font-size: 1.08rem; }

/* ---------- 8. FEATURE / MODULE CARDS ---------- */
.card-1 {
    background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-card);
    padding: 1.7rem 1.5rem; height: 100%; box-shadow: var(--shadow-sm);
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card-1:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: rgba(4,116,186,.35); }
.fr-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 56px; height: 56px; border-radius: var(--r-md);
    background: var(--grad-primary); color: #fff !important; margin-bottom: 1.1rem;
    box-shadow: 0 8px 18px rgba(4,116,186,.30);
}
.fr-icon i { color: #fff !important; }
.fr-icon--large { width: 68px; height: 68px; border-radius: 18px; }
.card-1__title, .block-2-card__title { font-weight: 700 !important; font-size: 1.12rem; }
.card-1__paragraph { font-size: .96rem; }

/* ---------- 9. INDUSTRY CARDS ---------- */
.block-2-card {
    background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-card);
    padding: 1.6rem; box-shadow: var(--shadow-sm);
    transition: transform .22s ease, box-shadow .22s ease;
}
.block-2-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.block-2__splide-btn {
    background: #fff !important; border: 1px solid var(--border-soft) !important;
    box-shadow: var(--shadow-sm) !important; color: var(--primary-deep) !important;
    width: 2.9rem !important; height: 2.9rem !important; border-radius: 50% !important;
}

/* ---------- 10. STATS (count-up) ---------- */
.stats__number {
    font-weight: 800 !important; font-size: clamp(2.2rem, 4vw, 3.2rem);
    background: var(--grad-text); -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; line-height: 1;
}
.stats__text { color: var(--muted); font-weight: 600; }

/* ---------- 11. TESTIMONIALS ---------- */
.testimonial-card-1 {
    background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-card);
    padding: 1.9rem; box-shadow: var(--shadow-sm); height: 100%; position: relative;
    transition: transform .22s ease, box-shadow .22s ease;
}
.testimonial-card-1:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.block-20-person__avatar { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; border: 2px solid var(--surface-tint); }
.block-20-person__rating i { color: var(--warning); font-size: .85rem; }
.block-20-person__name { font-weight: 700; color: var(--secondary); }
.block-20-person__info { color: var(--muted); font-size: .85rem; }
.testimonial-card-1__quote-symbol i { color: rgba(4,116,186,.20); font-size: 2.6rem; }

/* ---------- 12. CTA BAND ---------- */
.block-29 {
    background: var(--grad-cta); border-radius: var(--r-lg); padding: 3.25rem 2.75rem !important;
    box-shadow: var(--shadow-cta); color: #fff; position: relative; overflow: hidden;
}
.block-29::after {
    content: ""; position: absolute; right: -80px; top: -80px; width: 320px; height: 320px;
    background: radial-gradient(circle, rgba(0,216,255,.25), transparent 70%); pointer-events: none;
}
.block-29__title { color: #fff !important; font-weight: 800 !important; }
.block-29__paragraph { color: rgba(255,255,255,.85) !important; }

/* ---------- 13. FAQ ---------- */
.content-block {
    background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-md);
    padding: 1.3rem 1.5rem; margin-bottom: 1rem; box-shadow: var(--shadow-xs);
    transition: box-shadow .2s ease, border-color .2s ease;
}
.content-block:hover { box-shadow: var(--shadow-sm); border-color: rgba(4,116,186,.3); }
.content-block__title { font-weight: 700 !important; font-size: 1.05rem; color: var(--secondary); }
.content-block__paragraph { color: var(--muted); margin: 0; }

/* ---------- 14. FOOTER ---------- */
.block-44 { background: var(--surface-alt); padding: 2.6rem 0 1.6rem; margin-top: 2rem; }
.block-44__divider { border-color: var(--border-soft); opacity: 1; }
.block-44__link {
    display: inline-flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; border-radius: 50%; background: #fff;
    color: var(--primary-deep) !important; border: 1px solid var(--border-soft);
    transition: transform .15s ease, background .15s ease, color .15s ease;
}
.block-44__link:hover { transform: translateY(-2px); background: var(--primary); color: #fff !important; }
.block-41__copyrights { color: var(--muted); margin: 0; align-self: center; }
.fmx-foot-col h5 { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; color: var(--secondary); font-size: 1rem; margin-bottom: 1rem; }
.fmx-foot-col a { display: block; color: var(--muted); padding: .28rem 0; font-size: .94rem; }
.fmx-foot-col a:hover { color: var(--primary-deep); }

/* ---------- 15. SCREENSHOT FRAME (browser mockup) ---------- */
.shot-frame {
    background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-lg);
    box-shadow: var(--shadow-lg); overflow: hidden;
}
.shot-frame__bar {
    display: flex; align-items: center; gap: .45rem; padding: .7rem 1rem;
    background: #f6f9fd; border-bottom: 1px solid var(--border-soft);
}
.shot-frame__dot { width: 11px; height: 11px; border-radius: 50%; }
.shot-frame__dot--r { background: #ff5f57; } .shot-frame__dot--y { background: #febc2e; } .shot-frame__dot--g { background: #28c840; }
.shot-frame__url { margin-left: .8rem; flex: 1; height: 22px; border-radius: var(--r-pill); background: #fff; border: 1px solid var(--border-soft); font-size: .72rem; color: var(--muted); display: flex; align-items: center; padding: 0 .8rem; }
.shot-frame img { display: block; width: 100%; height: auto; }

/* ---------- 16. PRICING CARD ---------- */
.price-card {
    background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-lg);
    padding: 2rem 1.75rem; box-shadow: var(--shadow-sm); position: relative; height: 100%;
    transition: transform .22s ease, box-shadow .22s ease;
}
.price-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.price-card--featured { border: 2px solid var(--primary); box-shadow: var(--shadow-lg); transform: scale(1.035); }
.price-card--featured:hover { transform: scale(1.035) translateY(-4px); }
.price-ribbon {
    position: absolute; top: 1.1rem; right: 1.1rem; background: var(--grad-primary); color: #fff;
    font-size: .72rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
    padding: .35rem .8rem; border-radius: var(--r-pill); box-shadow: var(--shadow-btn);
}
.price-card__price { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 2.6rem; color: var(--secondary); }
.price-card__list { list-style: none; padding: 0; margin: 1.3rem 0; }
.price-card__list li { display: flex; gap: .6rem; padding: .42rem 0; color: var(--ink); font-size: .95rem; }
.price-card__list li i { color: var(--success); margin-top: .2rem; }

/* ---------- 17. COMPARE TABLE + MAP ---------- */
.compare-table { width: 100%; border-collapse: separate; border-spacing: 0; border: 1px solid var(--border-soft); border-radius: var(--r-card); overflow: hidden; }
.compare-table th, .compare-table td { padding: .9rem 1.1rem; text-align: left; border-bottom: 1px solid var(--border-soft); }
.compare-table thead th { background: var(--surface-alt); font-family: 'Plus Jakarta Sans', sans-serif; color: var(--secondary); position: sticky; top: 0; }
.compare-table td i.yes { color: var(--success); } .compare-table td i.no { color: #c5cdda; }
.map-frame { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid var(--border-soft); }
.map-frame iframe { display: block; width: 100%; border: 0; }

/* ---------- 18. CONTACT INFO CARDS ---------- */
.fmx-contact-card { display: flex; gap: 1rem; align-items: flex-start; background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-card); padding: 1.25rem 1.4rem; box-shadow: var(--shadow-xs); margin-bottom: 1rem; }
.fmx-contact-card .ic { flex: 0 0 auto; width: 46px; height: 46px; border-radius: var(--r-md); background: var(--surface-tint); color: var(--primary-deep); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; }
.fmx-contact-card h6 { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; margin: 0 0 .2rem; color: var(--secondary); }
.fmx-contact-card p { margin: 0; color: var(--muted); font-size: .95rem; }

/* ---------- 19. SCROLL-REVEAL + COUNT-UP ---------- */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: .08s; }
.reveal[data-delay="2"] { transition-delay: .16s; }
.reveal[data-delay="3"] { transition-delay: .24s; }

/* ---------- 20. A11Y + MOTION ---------- */
a:focus-visible, .btn:focus-visible, button:focus-visible, .hero-nav__link:focus-visible {
    outline: 3px solid rgba(4,116,186,.45); outline-offset: 2px; border-radius: 6px;
}
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .reveal { opacity: 1 !important; transform: none !important; }
    * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* ---------- 21. RESPONSIVE TWEAKS ---------- */
@media (max-width: 991px) {
    .hero__image-column { min-height: 300px; margin-top: 1.5rem; }
    .block-29 { padding: 2.25rem 1.5rem !important; }
    .price-card--featured { transform: none; }
}

/* ---------- 22. PHASE-4: hero + new home sections ---------- */
.fmx-hero-row { padding: 1.25rem 0 4.5rem; }
.fmx-hero-pills { display: flex; flex-wrap: wrap; gap: .5rem; }
.fmx-pill {
    display: inline-flex; align-items: center; gap: .4rem;
    font-size: .82rem; font-weight: 600; color: var(--primary-deep);
    background: #fff; border: 1px solid var(--border-soft); box-shadow: var(--shadow-xs);
    padding: .35rem .8rem; border-radius: var(--r-pill);
}
.fmx-pill i { color: var(--primary); font-size: .8rem; }
.fmx-hero-shot { max-width: 600px; margin-left: auto; }
.fmx-hero-shot img { background: #f6f9fd; }

/* anchor offset for sticky nav */
.fmx-anchor { display: block; position: relative; top: -90px; visibility: hidden; height: 0; }

/* check lists (spotlight) */
.fmx-check-list { list-style: none; padding: 0; margin: 0 0 1.4rem; }
.fmx-check-list li { display: flex; align-items: flex-start; gap: .65rem; padding: .4rem 0; color: var(--ink); font-weight: 500; }
.fmx-check-list li i { color: var(--success); margin-top: .25rem; background: rgba(22,179,100,.12); width: 22px; height: 22px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: .7rem; flex: 0 0 auto; }

/* spotlight band */
.fmx-spotlight { background: linear-gradient(180deg, #ffffff 0%, var(--surface-alt) 100%); }

/* gallery shot labels */
.fmx-shot-label { text-align: center; font-weight: 600; color: var(--secondary); margin: .9rem 0 0; font-family: 'Plus Jakarta Sans', sans-serif; font-size: .98rem; }

/* generic section head reused */
.fmx-section-head .eyebrow { margin-left: auto; margin-right: auto; }

/* ---------- 23. Inner pages (contact / about / modules / pricing) ---------- */
.fmx-page-hero {
    background: radial-gradient(900px 380px at 80% -20%, rgba(4,116,186,.12), transparent 60%), linear-gradient(180deg, #ffffff 0%, #f1f6fc 100%);
    padding: 3.75rem 0 2.75rem; text-align: center;
}
.fmx-page-hero .eyebrow { margin-left: auto; margin-right: auto; }
.fmx-form-card { background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-lg); box-shadow: var(--shadow-md); padding: 2rem 1.9rem; }
.fmx-input {
    width: 100%; border: 1px solid var(--border-soft) !important; border-radius: var(--r-md) !important;
    padding: .8rem 1rem !important; margin-bottom: 1rem !important; background: #fff !important;
    font-family: 'Inter', sans-serif; color: var(--ink); transition: border-color .15s ease, box-shadow .15s ease;
}
.fmx-input:focus { border-color: var(--primary) !important; box-shadow: 0 0 0 3px rgba(4,116,186,.12) !important; outline: none; }
.map-frame iframe { width: 100%; display: block; }

/* generic content (about/blog body typography) */
.fmx-rich h2 { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; color: var(--secondary); margin: 2rem 0 1rem; }
.fmx-rich h3 { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 600; color: var(--secondary); margin: 1.5rem 0 .75rem; }
.fmx-rich p { color: var(--muted); margin-bottom: 1rem; }
.fmx-rich ul { color: var(--muted); }
.fmx-rich blockquote { border-left: 4px solid var(--primary); background: var(--surface-alt); padding: 1rem 1.25rem; border-radius: 0 var(--r-md) var(--r-md) 0; color: var(--ink); margin: 1.5rem 0; }

/* ---------- 24. Blog ---------- */
.fmx-blog-card { background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-card); overflow: hidden; box-shadow: var(--shadow-sm); height: 100%; display: flex; flex-direction: column; transition: transform .2s ease, box-shadow .2s ease; }
.fmx-blog-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.fmx-blog-card__img { display: block; height: 200px; background-size: cover; background-position: center; background-color: var(--surface-tint); }
.fmx-blog-card__body { padding: 1.3rem 1.4rem; display: flex; flex-direction: column; flex: 1; }
.fmx-blog-date { color: var(--muted); font-size: .82rem; font-weight: 600; margin-bottom: .5rem; }
.fmx-blog-title-link { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; color: var(--secondary); font-size: 1.12rem; text-decoration: none; line-height: 1.35; }
.fmx-blog-title-link:hover { color: var(--primary-deep); }
.fmx-blog-card__body p { color: var(--muted); font-size: .94rem; margin: .6rem 0 1rem; flex: 1; }
.fmx-blog-more { color: var(--primary-deep); font-weight: 600; text-decoration: none; font-size: .92rem; }
.fmx-blog-more:hover { color: var(--primary); }
.fmx-article-img { width: 100%; border-radius: var(--r-lg); box-shadow: var(--shadow-md); margin-bottom: 1.75rem; display: block; }

/* ---------- 25. Feature Explorer + annotated pins ---------- */
.fx-explorer { background: linear-gradient(180deg, #ffffff 0%, var(--surface-alt) 100%); }
.fx-pills { gap: .4rem; position: sticky; top: 110px; }
.fx-group-label { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin: 1.1rem .4rem .4rem; }
.fx-group-label:first-child { margin-top: 0; }
.fx-pill { display: flex; align-items: center; gap: .7rem; width: 100%; text-align: left; background: #fff; border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: .7rem .9rem; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease; color: var(--secondary); font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 600; font-size: .96rem; }
.fx-pill:hover { border-color: rgba(4,116,186,.4); box-shadow: var(--shadow-sm); }
.fx-pill__ic { flex: 0 0 auto; width: 34px; height: 34px; border-radius: 9px; background: var(--surface-tint); color: var(--primary-deep); display: flex; align-items: center; justify-content: center; transition: background .18s ease, color .18s ease; }
.fx-pill__name { flex: 1; }
.fx-pill__arrow { font-size: .7rem; color: var(--muted); opacity: 0; transition: opacity .18s ease; }
.fx-pill.active { background: var(--grad-primary); border-color: transparent; color: #fff; box-shadow: var(--shadow-btn); }
.fx-pill.active .fx-pill__ic { background: rgba(255,255,255,.2); color: #fff; }
.fx-pill.active .fx-pill__arrow { opacity: 1; color: #fff; }
.fx-frame { margin-bottom: 1.25rem; }
.fx-stage { position: relative; }
.fx-stage img { display: block; width: 100%; height: auto; background: #f6f9fd; min-height: 120px; }
.fx-pin { position: absolute; width: 30px; height: 30px; transform: translate(-50%,-50%); border-radius: 50%; border: 2px solid #fff; background: var(--grad-primary); color: #fff; font-weight: 700; font-size: .85rem; display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: 0 4px 12px rgba(4,116,186,.45); z-index: 3; padding: 0; }
.fx-pin::after { content: ''; position: absolute; inset: -6px; border-radius: 50%; border: 2px solid rgba(4,116,186,.5); animation: fx-pulse 2s ease-out infinite; }
@keyframes fx-pulse { 0% { transform: scale(.8); opacity: .8; } 100% { transform: scale(1.7); opacity: 0; } }
.fx-explain__title { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; color: var(--secondary); font-size: 1.2rem; display: flex; align-items: center; gap: .6rem; margin-bottom: .9rem; }
.fx-explain__ic { flex: 0 0 auto; width: 38px; height: 38px; border-radius: 10px; background: var(--grad-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1rem; box-shadow: 0 6px 14px rgba(4,116,186,.3); }
.fx-points { list-style: none; padding: 0; margin: 0; }
.fx-points li { display: flex; align-items: flex-start; gap: .7rem; padding: .45rem 0; color: var(--ink); font-weight: 500; }
.fx-num { flex: 0 0 auto; width: 24px; height: 24px; border-radius: 50%; background: var(--surface-tint); color: var(--primary-deep); font-weight: 700; font-size: .8rem; display: flex; align-items: center; justify-content: center; }
.popover { border: 1px solid var(--border-soft) !important; border-radius: var(--r-md) !important; box-shadow: var(--shadow-md) !important; font-family: 'Inter', sans-serif; max-width: 260px; }
.popover-body { color: var(--ink); font-weight: 500; font-size: .9rem; }
@media (max-width: 991px) { .fx-pills { position: static; } .fx-pin { width: 26px; height: 26px; font-size: .75rem; } }
@media (prefers-reduced-motion: reduce) { .fx-pin::after { animation: none; } }

/* ---------- 26. Mobile nav menu (responsive fix) ---------- */
@media (max-width: 991px) {
    .hero__menu-content {
        gap: 0 !important;
        padding: 4.5rem 1.4rem 3rem !important;
        background: #fff !important;
        align-items: stretch !important;
    }
    #hero-menu.ft-menu--js-show .hero__menu-content {
        position: fixed !important; margin: 0 !important;
        left: 0 !important; right: 0 !important; top: 0 !important; bottom: 0 !important;
        width: 100vw !important; max-width: 100vw !important;
        height: 100vh !important; max-height: 100vh !important;
        flex-direction: column !important; flex-wrap: nowrap !important;
        overflow-y: auto !important; -webkit-overflow-scrolling: touch; z-index: 1050;
    }
    .hero-nav__item { width: 100%; margin: 0 !important; }
    .hero-nav__link {
        display: flex !important; align-items: center; width: 100%;
        padding: .8rem .25rem !important; font-size: 1.04rem !important;
        border-bottom: 1px solid var(--border-soft); border-radius: 0;
    }
    .hero-nav__link:hover { background: transparent !important; }
    .hero-nav__link::after { display: none !important; }
    .hero-nav__item--with-dropdown > .hero-nav__link { justify-content: space-between; }
    .hero-nav__dropdown {
        position: static !important; box-shadow: none !important; border: none !important;
        background: transparent !important; padding: .25rem 0 .25rem .9rem;
    }
    .hero-nav__dropdown .dropdown__link { display: block; padding: .55rem 0; }
    .hero-nav__dropdown .dropdown__item-title { color: var(--muted); font-weight: 500; }
    /* CTA buttons full-width, stacked at bottom */
    .hero-nav__item .btn {
        display: flex !important; width: 100% !important; justify-content: center;
        margin: .7rem 0 0 !important; padding: .9rem 1.4rem !important; font-size: 1rem !important;
    }
    /* visible close button */
    .ft-menu__close-btn {
        display: flex !important; position: fixed !important; top: 1.45rem; right: 1.6rem;
        width: 42px; height: 42px; align-items: center; justify-content: center;
        background: var(--surface-tint) !important; border-radius: 50% !important;
        color: var(--secondary) !important; z-index: 1100; border: none; box-shadow: var(--shadow-sm);
    }
    /* keep logo reasonable on small screens */
    .hero-nav__logo { height: 50px; }
    .hero-nav { padding: .4rem .9rem !important; }
}
@media (max-width: 420px) {
    .hero-nav__logo { height: 44px; }
}

/* ---------- 27. Floating WhatsApp button (desktop) ---------- */
.fmx-wa-float {
    position: fixed; bottom: 24px; right: 24px; z-index: 1200;
    width: 58px; height: 58px; border-radius: 50%;
    background: var(--whatsapp); color: #fff !important;
    align-items: center; justify-content: center; font-size: 1.85rem;
    box-shadow: 0 10px 26px rgba(37,211,102,.45); transition: transform .2s ease; text-decoration: none;
}
.fmx-wa-float:hover { transform: scale(1.08); color: #fff !important; }
.fmx-wa-float::after { content: ''; position: absolute; inset: 0; border-radius: 50%; border: 2px solid var(--whatsapp); animation: fx-pulse 2.2s ease-out infinite; }
@media (prefers-reduced-motion: reduce) { .fmx-wa-float::after { animation: none; } }

/* tighten desktop nav so all items fit without WhatsApp */
@media (min-width: 992px) {
    .hero-nav__link { padding: .5rem .58rem !important; font-size: .95rem !important; }
    .hero-nav__item .btn-primary { padding: .54rem 1.1rem !important; }
    .hero-nav__item .btn { margin-left: .3rem !important; }
    .hero__menu-content { gap: .05rem !important; }
}
