/**
 * MedNexus Design System — CSS Global
 * Fonte única da verdade para todos os templates.
 * Baseado 100% no single-especialista.php v9 (padrão aprovado).
 *
 * Uso: enfileirado via functions.php (BLOCO 95)
 * Importado por: single-especialista.php, archive-especialidade.php,
 *                archive-cidade.php, archive-estado.php, archive-cruzada.php,
 *                front-page.php
 */

/* ════════════════════════════════════════════════════════════
   1. VARIÁVEIS (fonte única)
════════════════════════════════════════════════════════════ */
:root {
    --mn-dark:       #0E4857;
    --mn-darker:     #07313A;
    --mn-teal:       #1A8FA0;
    --mn-teal-med:   #5BB5C2;
    --mn-teal-lite:  #B8E0E8;
    --mn-teal-soft:  #E0F4F7;
    --mn-teal-bg:    #F2F7F9;
    --mn-blue-deep:  #2C5F7F;
    --mn-blue-lite:  #C9DDEC;
    --mn-blue-lav:   #EEF5FB;
    --mn-green:      #2EA04E;
    --mn-green-dk:   #1F8F3F;
    --mn-green-soft: #D6F5DE;
    --mn-amber:      #BA7517;
    --mn-amber-soft: #FAEEDA;
    --mn-amber-text: #633806;
    --mn-ink:        #07131A;
    --mn-ink-soft:   #4A6572;
    --mn-ink-mid:    #768995;
    --mn-rule:       #DDE8EC;
    --mn-rule-soft:  #ECF2F4;
    --mn-sh-sm: 0 2px 8px rgba(7,19,26,0.06);
    --mn-sh-md: 0 4px 16px rgba(7,19,26,0.08);
    --mn-sh-wa: 0 8px 24px rgba(46,160,78,0.35);

    /* Tipografia — tamanhos fixos */
    --mn-fs-h1:       26px;   /* H1 desktop (nome/título principal) */
    --mn-fs-h1-tab:   24px;   /* H1 tablet */
    --mn-fs-h1-mob:   22px;   /* H1 mobile */
    --mn-fs-h2:       18px;   /* H2 (cabeçalho de card) */
    --mn-fs-h2-mob:   19px;   /* H2 mobile */
    --mn-fs-h3:       15px;   /* H3 (sub-item interno) */
    --mn-fs-body:     17px;   /* corpo */
    --mn-fs-sub:      14px;   /* subtítulo/lead */
    --mn-fs-small:    13px;   /* labels, pills, badges */
    --mn-fs-xs:       11px;   /* uppercase labels */
    --mn-fs-nav:      14px;   /* nav links */
    --mn-fs-icon-nav: 15px;   /* ícone na nav */
    --mn-fs-icon-hd:  20px;   /* ícone no cabeçalho de card */
    --mn-fs-icon-in:  16px;   /* ícone inline */
}

/* ════════════════════════════════════════════════════════════
   2. BASE
════════════════════════════════════════════════════════════ */
.mn-page {
    background: var(--mn-blue-lav);
    font-family: 'Red Hat Display', system-ui, -apple-system, sans-serif;
    color: var(--mn-ink);
    font-size: var(--mn-fs-body);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}
.mn-page .site-main,
.mn-page .entry-content {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    max-width: none !important;
    width: 100% !important;
}
header#site-header,
.elementor-location-header {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

/* Box model */
.mn-wrap * { box-sizing: border-box; }
.mn-wrap img { max-width: 100%; height: auto; display: block; }
.mn-wrap a { text-decoration: none; transition: color 0.15s; }
.mn-wrap a:focus-visible,
.mn-wrap button:focus-visible {
    outline: 3px solid var(--mn-teal);
    outline-offset: 2px;
    border-radius: 4px;
}

/* Ícone base */
.mn-i {
    display: inline-flex;
    flex-shrink: 0;
    vertical-align: middle;
    line-height: 1;
}

/* Âncoras com offset da nav */
.mn-anchor { scroll-margin-top: 80px; }

/* Skip link acessibilidade */
.mn-skip {
    position: absolute;
    left: -9999px;
    z-index: 9999;
    padding: 14px 22px;
    background: var(--mn-ink);
    color: #fff;
    font-weight: 700;
    border-radius: 0 0 8px 0;
    text-decoration: none;
}
.mn-skip:focus { left: 0; top: 0; }

/* ════════════════════════════════════════════════════════════
   3. WRAPPER CENTRAL
════════════════════════════════════════════════════════════ */
.mn-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ════════════════════════════════════════════════════════════
   4. BREADCRUMB
════════════════════════════════════════════════════════════ */
.mn-bc-bar {
    background: var(--mn-teal-bg);
    border-top: 1px solid var(--mn-rule-soft);
    border-bottom: 1px solid var(--mn-rule-soft);
    padding: 12px 0;
}
.mn-bc {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 6px;
    font-size: var(--mn-fs-small);
    color: var(--mn-ink-soft);
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
    overflow-x: auto;
    scrollbar-width: none;
}
.mn-bc::-webkit-scrollbar { display: none; }
.mn-bc a {
    color: var(--mn-teal);
    font-weight: 500;
    white-space: nowrap;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.mn-bc a:hover { color: var(--mn-dark); }
.mn-bc .sep { color: var(--mn-rule); flex-shrink: 0; }
.mn-bc .now { color: var(--mn-ink); font-weight: 600; white-space: nowrap; flex-shrink: 0; }

/* ════════════════════════════════════════════════════════════
   5. NAV STICKY
════════════════════════════════════════════════════════════ */
.mn-nav-wrap {
    background: #fff;
    border-bottom: 1px solid var(--mn-rule-soft);
    box-shadow: var(--mn-sh-sm);
    position: sticky;
    top: 0;
    z-index: 50;
}
.mn-nav-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 6px 24px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.mn-nav-inner::-webkit-scrollbar { display: none; }
.mn-nav-list {
    display: flex;
    gap: 2px;
    list-style: none;
    padding: 0;
    margin: 0;
    min-width: max-content;
}
.mn-nav a {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 11px 16px;
    border-radius: 8px;
    font-size: var(--mn-fs-nav);
    font-weight: 600;
    color: var(--mn-ink-soft);
    white-space: nowrap;
    transition: background 0.15s, color 0.15s;
    min-height: 44px;
}
.mn-nav a:hover { background: var(--mn-teal-soft); color: var(--mn-dark); }
.mn-nav a.is-active { background: var(--mn-teal); color: #fff; font-weight: 700; }
.mn-nav a .mn-i { color: var(--mn-teal); }
.mn-nav a.is-active .mn-i { color: #fff; }

/* ════════════════════════════════════════════════════════════
   6. GRID PRINCIPAL (main + sidebar)
════════════════════════════════════════════════════════════ */
.mn-layout {
    max-width: 1280px;
    margin: 0 auto;
    padding: 28px 24px 160px;
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 24px;
    align-items: start;
}
.mn-main { min-width: 0; }

/* ════════════════════════════════════════════════════════════
   7. CARD (bloco principal de conteúdo)
════════════════════════════════════════════════════════════ */
.mn-card {
    background: #fff;
    border: 1px solid var(--mn-rule-soft);
    border-radius: 14px;
    padding: 20px 24px;
    box-shadow: var(--mn-sh-sm);
    margin-bottom: 12px;
}

/* Cabeçalho do card */
.mn-card-head { margin-bottom: 14px; }
.mn-card-head-row { display: flex; align-items: flex-start; gap: 10px; }
.mn-card-head-icon {
    width: 38px;
    height: 38px;
    border-radius: 8px;
    background: var(--mn-teal-soft);
    color: var(--mn-teal);
    display: grid;
    place-items: center;
    flex-shrink: 0;
    margin-top: 2px;
}
.mn-card-head-text { flex: 1; min-width: 0; }

/* H2 — tamanho único para todos os templates */
.mn-card-title {
    font-size: var(--mn-fs-h2) !important;
    font-weight: 800 !important;
    color: var(--mn-ink) !important;
    margin: 0 !important;
    line-height: 1.2 !important;
    letter-spacing: -0.01em !important;
}
.mn-card-sub {
    font-size: var(--mn-fs-sub);
    color: var(--mn-ink-soft);
    margin: 6px 0 0;
}

/* ════════════════════════════════════════════════════════════
   8. CARD ESPECIALISTA (lista de médicos)
════════════════════════════════════════════════════════════ */
.mn-esp-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }

.mn-esp-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--mn-rule-soft);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: var(--mn-sh-sm);
    transition: transform 0.15s, box-shadow 0.15s;
    display: flex;
    flex-direction: column;
}
.mn-esp-card:hover { transform: translateY(-2px); box-shadow: var(--mn-sh-md); }

/* Overlay link — cobre o card inteiro */
.mn-esp-card-link {
    position: absolute;
    inset: 0;
    z-index: 1;
    border-radius: 14px;
    text-indent: -9999px;
    overflow: hidden;
}

/* Topo do card */
.mn-esp-card-top {
    position: relative; z-index: 2;
    background: var(--mn-teal-bg);
    padding: 8px 14px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--mn-rule-soft);
    pointer-events: none;
}

/* Corpo do card */
.mn-esp-card-body {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 16px 14px 12px;
    flex: 1;
    pointer-events: none;
}

/* Foto */
.mn-esp-foto {
    width: 72px;
    height: 90px;
    border-radius: 10px;
    overflow: hidden;
    flex-shrink: 0;
    background: linear-gradient(135deg, var(--mn-teal-soft) 0%, var(--mn-teal-lite) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    font-weight: 300;
    color: var(--mn-teal);
}
.mn-esp-foto img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }

/* Info do especialista */
.mn-esp-info { flex: 1; min-width: 0; }
.mn-esp-nome { font-size: 15px; font-weight: 800; color: var(--mn-ink); margin: 0 0 3px; line-height: 1.25; letter-spacing: -0.01em; }
.mn-esp-esp  { font-size: var(--mn-fs-small); color: var(--mn-teal); font-weight: 600; margin: 0 0 4px; }
.mn-esp-crm  { font-size: 12px; color: var(--mn-ink-mid); font-weight: 600; margin: 0 0 4px; display: flex; align-items: center; gap: 5px; }
.mn-esp-crm .mn-i { color: var(--mn-teal); }
.mn-esp-loc  { font-size: 12px; color: var(--mn-ink-soft); display: flex; align-items: flex-start; gap: 4px; margin: 0 0 4px; line-height: 1.4; }
.mn-esp-loc .mn-i { color: var(--mn-teal); flex-shrink: 0; margin-top: 1px; }
.mn-esp-bio  { font-size: var(--mn-fs-small); color: var(--mn-ink-soft); line-height: 1.5; margin: 4px 0 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mn-esp-convs { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.mn-esp-conv  { font-size: 11px; background: var(--mn-teal-bg); color: var(--mn-dark); padding: 2px 8px; border-radius: 99px; border: 1px solid var(--mn-rule-soft); font-weight: 600; }

/* Badge verificado */
.mn-esp-badge { font-size: 11px; font-weight: 700; color: var(--mn-teal); display: flex; align-items: center; gap: 5px; }
.mn-esp-badge .mn-i { color: var(--mn-teal); }

/* Rating */
.mn-esp-rating { font-size: 12px; color: var(--mn-ink-soft); display: flex; align-items: center; gap: 3px; font-weight: 600; }
.mn-esp-rating .star { color: var(--mn-amber); font-size: 13px; }

/* Footer do card */
.mn-esp-card-foot {
    position: relative; z-index: 2;
    padding: 0 14px 14px;
    display: flex;
    gap: 8px;
    margin-top: auto;
    pointer-events: none;
}
.mn-esp-card-foot > * { pointer-events: auto; }

/* Botão WA no card */
.mn-btn-wa-card {
    position: relative; z-index: 3;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    background: var(--mn-green);
    color: #fff !important;
    padding: 10px 14px;
    border-radius: 9px;
    font-size: var(--mn-fs-small);
    font-weight: 700;
    transition: background 0.2s;
    text-decoration: none;
    border: none;
    cursor: pointer;
    font-family: 'Red Hat Display', system-ui, sans-serif;
}
.mn-btn-wa-card:hover { background: var(--mn-green-dk); color: #fff !important; }

/* Ver perfil */
.mn-btn-ver {
    position: relative; z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: var(--mn-teal-bg);
    color: var(--mn-dark) !important;
    padding: 10px 14px;
    border-radius: 9px;
    font-size: var(--mn-fs-small);
    font-weight: 600;
    border: 1px solid var(--mn-rule-soft);
    white-space: nowrap;
    text-decoration: none;
}
.mn-btn-ver .mn-i { color: var(--mn-teal); }
.mn-btn-ver:hover { background: var(--mn-teal-soft); border-color: var(--mn-teal); color: var(--mn-dark) !important; }

/* Empty state */
.mn-esp-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 40px 20px;
    color: var(--mn-ink-mid);
    background: var(--mn-blue-lav);
    border-radius: 10px;
    border: 1px dashed var(--mn-rule);
}
.mn-esp-empty p { margin: 8px 0 0; font-size: 14.5px; }

/* ════════════════════════════════════════════════════════════
   9. FAQ ACCORDION
════════════════════════════════════════════════════════════ */
.mn-faq-item {
    background: #fff;
    border: 1px solid var(--mn-rule-soft);
    border-radius: 10px;
    margin-bottom: 8px;
    overflow: hidden;
}
.mn-faq-item summary {
    padding: 18px 22px;
    cursor: pointer;
    font-weight: 700;
    color: var(--mn-dark);
    font-size: 15.5px;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    transition: background 0.15s;
    min-height: 56px;
    line-height: 1.35;
}
.mn-faq-item summary::-webkit-details-marker { display: none; }
.mn-faq-item summary:hover { background: var(--mn-teal-soft); }
.mn-faq-item summary::after { content: '+'; font-size: 24px; color: var(--mn-teal); font-weight: 300; line-height: 1; flex-shrink: 0; }
.mn-faq-item[open] summary { background: var(--mn-teal-soft); }
.mn-faq-item[open] summary::after { content: '−'; }
.mn-faq-body {
    padding: 18px 22px;
    font-size: 14.5px;
    color: var(--mn-ink-soft);
    line-height: 1.7;
    background: #fff;
}
.mn-faq-body p:first-child { margin-top: 0; }
.mn-faq-body p:last-child  { margin-bottom: 0; }

/* ════════════════════════════════════════════════════════════
   10. SIDEBAR
════════════════════════════════════════════════════════════ */
.mn-sidebar { position: sticky; top: 80px; min-width: 0; }
.mn-side-card {
    background: #fff;
    border: 1px solid var(--mn-rule-soft);
    border-radius: 14px;
    padding: 22px 24px;
    box-shadow: var(--mn-sh-sm);
    margin-bottom: 14px;
}
.mn-side-h {
    font-size: var(--mn-fs-xs) !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.10em !important;
    color: var(--mn-teal) !important;
    margin: 0 0 14px !important;
    display: flex !important;
    align-items: center !important;
    gap: 7px !important;
    line-height: 1.2 !important;
}
.mn-side-h .mn-i { color: var(--mn-teal); }
.mn-side-pills { display: flex; flex-wrap: wrap; gap: 6px; }
.mn-side-pill {
    background: var(--mn-teal-bg);
    color: var(--mn-dark);
    padding: 7px 12px;
    border-radius: 7px;
    font-size: var(--mn-fs-small);
    font-weight: 600;
    border: 1px solid var(--mn-rule-soft);
    text-decoration: none;
}
a.mn-side-pill:hover { background: var(--mn-teal-soft); border-color: var(--mn-teal); }

/* ════════════════════════════════════════════════════════════
   11. BOTÕES
════════════════════════════════════════════════════════════ */

/* WhatsApp — hero/sidebar (grande) */
.mn-btn-wa {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    background: var(--mn-green);
    color: #fff !important;
    padding: 16px 28px;
    border-radius: 14px;
    font-size: 17px;
    font-weight: 800;
    min-height: 60px;
    line-height: 1;
    box-shadow: var(--mn-sh-wa);
    transition: background 0.2s, transform 0.15s;
    border: none;
    cursor: pointer;
    text-decoration: none;
    width: 100%;
    font-family: 'Red Hat Display', system-ui, sans-serif;
}
.mn-btn-wa:hover { background: var(--mn-green-dk); transform: translateY(-2px); color: #fff !important; }
.mn-btn-wa svg, .mn-btn-wa path, .mn-btn-wa polygon, .mn-btn-wa circle {
    color: #fff !important;
    fill: currentColor !important;
    stroke: none !important;
}

/* Teal CTA */
.mn-btn-teal {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--mn-teal);
    color: #fff !important;
    padding: 15px 24px;
    border-radius: 14px;
    font-size: 15px;
    font-weight: 700;
    transition: background 0.2s, transform 0.15s;
    text-decoration: none;
    border: none;
    cursor: pointer;
    font-family: 'Red Hat Display', system-ui, sans-serif;
}
.mn-btn-teal:hover { background: var(--mn-dark); transform: translateY(-2px); color: #fff !important; }
.mn-btn-teal .mn-i { color: #fff; }

/* ════════════════════════════════════════════════════════════
   12. STEPS (seção fundo escuro)
════════════════════════════════════════════════════════════ */
.mn-steps-section {
    background: var(--mn-darker);
    padding: 52px 0;
}
.mn-steps-title {
    font-size: 22px !important;
    font-weight: 800 !important;
    color: #fff !important;
    text-align: center !important;
    margin: 0 0 36px !important;
    letter-spacing: -0.01em !important;
    line-height: 1.25 !important;
}
.mn-steps-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.mn-step {
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 14px;
    padding: 22px 16px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: background 0.2s, transform 0.15s;
}
.mn-step:hover { background: rgba(255,255,255,0.11); transform: translateY(-2px); }
.mn-step-circle {
    width: 44px;
    height: 44px;
    background: var(--mn-teal);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.mn-step-circle .mn-i { color: #fff !important; stroke: #fff !important; }
.mn-step-label {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #fff !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}
.mn-step-desc {
    font-size: var(--mn-fs-small) !important;
    color: rgba(255,255,255,0.7) !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}

/* ════════════════════════════════════════════════════════════
   13. DISCLAIMER + TRUST
════════════════════════════════════════════════════════════ */
.mn-disclaimer {
    background: var(--mn-blue-lav);
    border: 1px solid var(--mn-rule-soft);
    border-radius: 10px;
    padding: 16px 20px;
    margin-top: 14px;
    font-size: var(--mn-fs-small);
    color: var(--mn-ink-soft);
    line-height: 1.6;
}
.mn-disclaimer strong { color: var(--mn-dark); }

.mn-trust {
    background: var(--mn-teal-bg);
    border: 1px solid var(--mn-rule-soft);
    border-radius: 12px;
    padding: 20px 24px;
    text-align: center;
    margin-top: 14px;
}
.mn-trust-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--mn-ink);
    margin: 0 0 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
}
.mn-trust-sub { font-size: var(--mn-fs-small); color: var(--mn-ink-soft); margin: 0; }

/* ════════════════════════════════════════════════════════════
   14. CIDADES GRID
════════════════════════════════════════════════════════════ */
.mn-cities { display: grid; grid-template-columns: repeat(auto-fill, minmax(175px, 1fr)); gap: 8px; }
.mn-city {
    background: var(--mn-teal-bg);
    border: 1px solid var(--mn-rule-soft);
    border-radius: 8px;
    padding: 12px 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background 0.15s, border-color 0.15s, transform 0.1s;
    text-decoration: none;
    font-size: var(--mn-fs-sub);
    font-weight: 600;
    color: var(--mn-dark);
}
.mn-city:hover { background: var(--mn-teal-soft); border-color: var(--mn-teal); transform: translateY(-1px); }
.mn-city .mn-i { color: var(--mn-teal); flex-shrink: 0; }
.mn-city-sub { font-size: 12px; color: var(--mn-teal); margin-top: 2px; font-weight: 500; }

/* ════════════════════════════════════════════════════════════
   15. QUADRANTES (seção dor)
════════════════════════════════════════════════════════════ */
.mn-quadrants { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.mn-quadrant {
    background: var(--mn-teal-bg);
    border: 1px solid var(--mn-rule-soft);
    border-radius: 12px;
    padding: 20px 22px;
}
.mn-quadrant-h {
    font-size: var(--mn-fs-small);
    font-weight: 700;
    color: var(--mn-dark);
    margin: 0 0 12px;
    line-height: 1.3;
}
.mn-quadrant-h--warn { color: var(--mn-amber); }
.mn-check-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.mn-check-list li { display: flex; align-items: flex-start; gap: 8px; font-size: var(--mn-fs-sub); color: var(--mn-ink); line-height: 1.55; }
.mn-check-list li .mn-i { color: var(--mn-teal); flex-shrink: 0; margin-top: 2px; }
.mn-check-list--warn li .mn-i { color: var(--mn-amber); }

/* ════════════════════════════════════════════════════════════
   16. HERO COMUM (fundo branco)
════════════════════════════════════════════════════════════ */
.mn-hero-wrap {
    background: #fff;
    padding: 0 0 32px;
}
.mn-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--mn-teal-bg);
    color: var(--mn-teal);
    border: 1px solid var(--mn-rule-soft);
    padding: 4px 14px;
    border-radius: 99px;
    font-size: var(--mn-fs-small);
    font-weight: 600;
    margin-bottom: 14px;
}
.mn-hero-h1 {
    font-size: var(--mn-fs-h1) !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    color: var(--mn-ink) !important;
    letter-spacing: -0.018em !important;
    margin: 0 0 12px !important;
}
.mn-hero-sub {
    background: var(--mn-teal-bg);
    border-left: 3px solid var(--mn-teal);
    padding: 13px 16px;
    border-radius: 0 10px 10px 0;
    margin: 0 0 20px;
    font-size: var(--mn-fs-sub);
    color: var(--mn-ink-soft);
    line-height: 1.55;
    font-style: italic;
}

/* ════════════════════════════════════════════════════════════
   17. SERVIÇOS/TIPOS
════════════════════════════════════════════════════════════ */
.mn-tipos { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.mn-tipo {
    background: var(--mn-teal-bg);
    border: 1px solid var(--mn-rule-soft);
    border-radius: 10px;
    padding: 15px 17px;
    display: flex;
    align-items: center;
    gap: 11px;
    transition: background 0.15s, border-color 0.15s;
    font-size: var(--mn-fs-sub);
    font-weight: 700;
    color: var(--mn-ink);
}
.mn-tipo:hover { background: var(--mn-teal-soft); border-color: var(--mn-teal); }
.mn-tipo .mn-i { color: var(--mn-teal); flex-shrink: 0; }

/* ════════════════════════════════════════════════════════════
   18. MEDIA QUERIES — TABLET (1024px)
════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .mn-layout { grid-template-columns: 1fr 300px; padding: 22px 18px 140px; }
    .mn-sidebar { position: static; }
    .mn-steps-grid { grid-template-columns: repeat(2, 1fr); }
    .mn-hero-h1 { font-size: var(--mn-fs-h1-tab) !important; }
    .mn-quadrants { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   19. MEDIA QUERIES — MOBILE (720px)
════════════════════════════════════════════════════════════ */
@media (max-width: 720px) {
    .mn-inner { padding: 0 16px; }
    .mn-bc { padding: 0 16px; font-size: 12px; }

    /* H1 mobile */
    .mn-hero-h1 {
        font-size: var(--mn-fs-h1-mob) !important;
        font-weight: 600 !important;
        letter-spacing: -0.01em !important;
        white-space: normal !important;
    }

    /* H2 mobile */
    .mn-card-title {
        font-size: var(--mn-fs-h2-mob) !important;
        font-weight: 600 !important;
        letter-spacing: -0.005em !important;
    }

    /* Steps mobile — scroll horizontal */
    .mn-steps-title { font-size: 19px !important; }
    .mn-steps-grid {
        grid-template-columns: repeat(4, 72vw);
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        gap: 10px;
        padding-right: 16px;
        padding-bottom: 4px;
    }
    .mn-steps-grid::-webkit-scrollbar { display: none; }
    .mn-step { scroll-snap-align: start; }

    /* Layout */
    .mn-layout { grid-template-columns: 1fr; padding: 16px 12px 110px; gap: 14px; }
    .mn-card { padding: 20px 18px; }

    /* Grids */
    .mn-esp-grid { grid-template-columns: 1fr; }
    .mn-cities { grid-template-columns: repeat(2, 1fr); }
    .mn-tipos { grid-template-columns: 1fr; }
    .mn-quadrants { grid-template-columns: 1fr; }

    /* Nav */
    .mn-nav-inner { padding: 6px 12px; }
    .mn-nav a { font-size: var(--mn-fs-small); padding: 10px 13px; }

    /* "Ver perfil" some no mobile */
    .mn-btn-ver { display: none; }
}

@media (hover: none) {
    .mn-btn-wa:hover { transform: none; }
    .mn-esp-card:hover { transform: none; }
    .mn-btn-teal:hover { transform: none; }
}
