/* VisaGlobal styles — v1.5.3 mobile-safe globals */
*, *::before, *::after { box-sizing: border-box; }
html, body { max-width: 100%; overflow-x: hidden; }
body img, body video, body iframe { max-width: 100%; height: auto; }
.vg-main, main, section, article, header, footer { min-width: 0; }
@media (max-width: 768px) { body { font-size: 15.5px; } }
@media (max-width: 480px) { body { font-size: 15px; } }

.vg-main { max-width: 1100px; margin: 0 auto; padding: 2rem 1rem; }
.vg-breadcrumbs ol { display: flex; flex-wrap: wrap; gap: .5rem; list-style: none; padding: 0; margin: 0 0 1.5rem; font-size: .9rem; color: #64748b; }
.vg-breadcrumbs li:not(:last-child)::after { content: "›"; margin-left: .5rem; color: #94a3b8; }
.vg-breadcrumbs a { color: #0ea5e9; text-decoration: none; }

.vg-pais-hero, .vg-matriz-hero { display: flex; align-items: center; gap: 1.5rem; margin: 1rem 0 2rem; padding: 2rem; background: linear-gradient(135deg, #f0f9ff, #ffffff); border-radius: 12px; }
.vg-pais-hero h1, .vg-matriz-hero h1 { margin: 0 0 .5rem; font-size: 2rem; line-height: 1.2; }
.vg-flag-xl { font-size: 4rem; line-height: 1; }
.vg-lede { color: #475569; font-size: 1.1rem; margin: 0; }

.vg-verificador { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 1.5rem; margin: 1rem 0; }
.vg-verificador h2 { margin-top: 0; }
.vg-verificador-form { display: grid; grid-template-columns: 1fr 1fr auto; gap: .75rem; align-items: end; }
.vg-verificador-form label { display: flex; flex-direction: column; gap: .3rem; font-size: .9rem; color: #64748b; }
.vg-verificador-form select { padding: .65rem; border: 1px solid #cbd5e1; border-radius: 8px; font-size: 1rem; background: #fff; }
.vg-btn { padding: .75rem 1.5rem; background: #0ea5e9; color: #fff; border: 0; border-radius: 8px; font-weight: 600; cursor: pointer; font-size: 1rem; }
.vg-btn:hover { background: #0284c7; }
.vg-btn-secondary { background: #64748b; }
.vg-verificador-result { margin-top: 1.25rem; padding: 1rem; border-radius: 8px; background: #f8fafc; border-left: 4px solid #0ea5e9; display: none; }
.vg-verificador-result.vg-show { display: block; }
.vg-verificador-result h3 { margin: 0 0 .5rem; }

.vg-datos-grid { display: grid; grid-template-columns: max-content 1fr; gap: .5rem 1.5rem; margin: 1rem 0; }
.vg-datos-grid dt { font-weight: 600; color: #475569; }
.vg-datos-grid dd { margin: 0; }

.vg-nav-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1rem; margin: 1rem 0; }
.vg-nav-card { display: block; padding: 1.25rem; background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; text-decoration: none; color: inherit; transition: all .15s; }
.vg-nav-card:hover { border-color: #0ea5e9; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(14,165,233,.1); }
.vg-nav-card h3 { margin: 0 0 .3rem; color: #0f172a; }
.vg-nav-card p { margin: 0; color: #64748b; font-size: .9rem; }

.vg-grid-paises { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: .75rem; }
.vg-card-pais { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 1rem; background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; text-decoration: none; color: inherit; transition: all .15s; gap: .3rem; }
.vg-card-pais:hover { border-color: #0ea5e9; background: #f0f9ff; }
.vg-card-pais .vg-flag { font-size: 2.5rem; line-height: 1; }
.vg-card-pais .vg-name { font-weight: 600; }
.vg-card-pais .vg-meta { font-size: .8rem; color: #94a3b8; }

.vg-matriz-card { padding: 1.5rem; background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; margin: 1rem 0; }
.vg-answer { font-size: 1.25rem; color: #0f172a; margin: .5rem 0; }

.vg-steps { padding-left: 1.5rem; line-height: 1.8; }
.vg-steps li { margin-bottom: .5rem; }

.vg-disclaimer { margin-top: 3rem; padding: 1rem 1.25rem; background: #fef3c7; border-left: 4px solid #f59e0b; border-radius: 8px; font-size: .9rem; color: #78350f; }

.vg-badge { display: inline-block; padding: .2rem .6rem; background: #dcfce7; color: #166534; border-radius: 999px; font-size: .8rem; font-weight: 600; }

.vg-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 1rem; margin: 2rem 0; }
.vg-stat { text-align: center; padding: 1.25rem; background: #f0f9ff; border-radius: 10px; }
.vg-stat-num { display: block; font-size: 2.25rem; font-weight: 700; color: #0ea5e9; }
.vg-stat-label { color: #475569; font-size: .9rem; }

.vg-country-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: .4rem; list-style: none; padding: 0; }
.vg-country-list li { padding: .5rem .75rem; background: #f8fafc; border-radius: 6px; display: flex; justify-content: space-between; align-items: center; }
.vg-country-list a { color: #0f172a; text-decoration: none; }
.vg-country-list a:hover { color: #0ea5e9; }
.vg-days { font-size: .8rem; color: #64748b; }

.vg-mapa-legend { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem; font-size: .9rem; }
.vg-dot { display: inline-block; width: 12px; height: 12px; border-radius: 50%; margin-right: .25rem; vertical-align: middle; }
.vg-mapa-select { padding: .65rem; border: 1px solid #cbd5e1; border-radius: 8px; width: 100%; max-width: 400px; margin-bottom: 1rem; }
#vg-mapa-svg { background: #f8fafc; border-radius: 10px; min-height: 300px; padding: 1rem; }

.vg-ranking { padding-left: 2rem; }
.vg-ranking li { padding: .5rem 0; }
.vg-ranking-count { color: #64748b; font-size: .9rem; }

.vg-alertas { list-style: none; padding: 0; }
.vg-alertas li { padding: .75rem; background: #fef3c7; border-radius: 6px; margin-bottom: .5rem; border-left: 3px solid #f59e0b; }
.vg-date { color: #92400e; font-size: .85rem; }

.vg-search-input { width: 100%; padding: .75rem 1rem; border: 1px solid #cbd5e1; border-radius: 8px; font-size: 1rem; margin-bottom: 1rem; }

.vg-comparador-selects { display: grid; grid-template-columns: 1fr 1fr auto; gap: .75rem; margin-bottom: 1rem; }
.vg-comparador-selects select { padding: .65rem; border: 1px solid #cbd5e1; border-radius: 8px; }

.vg-calculadora { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 1.5rem; }
.vg-stay-row { display: grid; grid-template-columns: 1fr 1fr auto; gap: .5rem; margin: .5rem 0; }
.vg-stay-row input { padding: .5rem; border: 1px solid #cbd5e1; border-radius: 6px; }

.vg-empty { color: #94a3b8; font-style: italic; }

details summary { cursor: pointer; padding: .75rem; background: #f8fafc; border-radius: 6px; font-weight: 600; margin-bottom: .5rem; }
details[open] summary { background: #e0f2fe; }
details p { padding: 0 .75rem 1rem; color: #475569; }

@media (max-width: 640px) {
    .vg-pais-hero, .vg-matriz-hero { flex-direction: column; text-align: center; padding: 1.5rem 1rem; }
    .vg-verificador-form, .vg-comparador-selects { grid-template-columns: 1fr; }
    .vg-datos-grid { grid-template-columns: 1fr; }
}
