/* VisaMundial Home — modern, clean, mobile-first */
:root {
    --vm-primary: #2563eb;
    --vm-primary-dark: #1d4ed8;
    --vm-accent: #f59e0b;
    --vm-dark: #0f172a;
    --vm-text: #1e293b;
    --vm-muted: #64748b;
    --vm-light: #f8fafc;
    --vm-border: #e2e8f0;
    --vm-success: #10b981;
    --vm-warning: #f59e0b;
    --vm-danger: #ef4444;
    --vm-radius: 12px;
    --vm-radius-lg: 18px;
    --vm-shadow-sm: 0 1px 2px rgba(0,0,0,.05);
    --vm-shadow: 0 4px 12px rgba(0,0,0,.06);
    --vm-shadow-lg: 0 12px 40px rgba(0,0,0,.1);
}

.vg-home { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; color: var(--vm-text); line-height: 1.6; -webkit-font-smoothing: antialiased; }
.vg-home *, .vg-home *::before, .vg-home *::after { box-sizing: border-box; }
.vg-container { max-width: 1140px; margin: 0 auto; padding: 0 20px; }
.vg-container-narrow { max-width: 780px; }
.vg-center { text-align: center; margin-top: 2rem; }

.vg-hero { position: relative; padding: 5rem 20px 4rem; background: linear-gradient(180deg, #eff6ff 0%, #ffffff 70%); overflow: hidden; }
.vg-hero-bg, .vg-hero-blob { display: none; }
.vg-hero-inner { position: relative; max-width: 880px; margin: 0 auto; text-align: center; }
.vg-hero-badge { display: inline-flex; align-items: center; gap: .5rem; padding: .4rem 1rem; background: #fff; border: 1px solid var(--vm-border); border-radius: 999px; font-size: .8rem; color: var(--vm-muted); box-shadow: var(--vm-shadow-sm); margin-bottom: 1.25rem; }
.vg-dot-live { width: 8px; height: 8px; border-radius: 50%; background: var(--vm-success); animation: vm-pulse 2s infinite; }
@keyframes vm-pulse { 0%,100% { opacity: 1; } 50% { opacity: .4; } }

.vg-hero h1 { font-size: clamp(1.85rem, 5vw, 3.25rem); font-weight: 800; line-height: 1.1; letter-spacing: -0.025em; margin: 0 0 1rem; color: var(--vm-dark); }
.vg-hero-highlight { background: linear-gradient(135deg, var(--vm-primary), #8b5cf6); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.vg-hero-lede { font-size: clamp(1rem, 1.5vw, 1.15rem); color: var(--vm-muted); max-width: 620px; margin: 0 auto 2rem; }

.vg-hero-checker { background: #fff; border-radius: var(--vm-radius-lg); padding: 1.5rem; box-shadow: var(--vm-shadow-lg); border: 1px solid var(--vm-border); max-width: 780px; margin: 0 auto 2rem; }
.vg-hero-form { display: grid; gap: .75rem; align-items: end; grid-template-columns: 1fr; }
.vg-field { text-align: left; }
.vg-field-label { display: block; font-size: .72rem; color: var(--vm-muted); font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: .35rem; }
.vg-field select { width: 100%; padding: .9rem 1rem; border: 1.5px solid var(--vm-border); border-radius: 10px; background: #fff; font-size: 1rem; color: var(--vm-dark); cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%2364748b' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem; transition: all .15s; }
.vg-field select:focus { outline: none; border-color: var(--vm-primary); box-shadow: 0 0 0 4px rgba(37,99,235,.12); }
.vg-arrow { display: none; }

.vg-btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; padding: 1rem 1.5rem; background: var(--vm-primary); color: #fff; border: 0; border-radius: 10px; font-weight: 700; font-size: 1rem; cursor: pointer; text-decoration: none; transition: transform .15s, background .15s; width: 100%; }
.vg-btn:hover { background: var(--vm-primary-dark); transform: translateY(-1px); }
.vg-btn-outline { background: transparent; color: var(--vm-primary); border: 2px solid var(--vm-primary); width: auto; }
.vg-btn-outline:hover { background: var(--vm-primary); color: #fff; }

.vg-verificador-result { margin-top: 1.25rem; padding: 1.25rem; border-radius: 10px; background: #f8fafc; border-left: 4px solid var(--vm-primary); display: none; text-align: left; }
.vg-verificador-result.vg-show { display: block; }

.vg-hero-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; max-width: 500px; margin: 2rem auto 0; }
.vg-hero-stat { text-align: center; }
.vg-hero-stat strong { display: block; font-size: clamp(1.4rem, 3vw, 1.85rem); font-weight: 800; color: var(--vm-dark); letter-spacing: -0.02em; }
.vg-hero-stat span { font-size: .82rem; color: var(--vm-muted); font-weight: 500; }

.vg-scroll-indicator { display: none; }

.vg-trust-bar { background: var(--vm-dark); padding: 1rem 0; overflow: hidden; position: relative; }
.vg-trust-bar::before, .vg-trust-bar::after { content: ''; position: absolute; top: 0; bottom: 0; width: 80px; z-index: 2; pointer-events: none; }
.vg-trust-bar::before { left: 0; background: linear-gradient(90deg, var(--vm-dark), transparent); }
.vg-trust-bar::after { right: 0; background: linear-gradient(-90deg, var(--vm-dark), transparent); }
.vg-trust-track { display: flex; gap: 1.5rem; animation: vm-scroll-x 60s linear infinite; width: max-content; }
.vg-trust-flag { font-size: 1.75rem; flex-shrink: 0; opacity: .9; }
@keyframes vm-scroll-x { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.vg-section { padding: 3.5rem 20px; }
.vg-section-alt { background: var(--vm-light); }
.vg-section-header { text-align: center; max-width: 720px; margin: 0 auto 2.5rem; }
.vg-eyebrow { display: inline-block; padding: .3rem .85rem; background: rgba(37,99,235,.1); color: var(--vm-primary); border-radius: 999px; font-size: .75rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: .85rem; }
.vg-section-header h2 { font-size: clamp(1.6rem, 3.5vw, 2.25rem); font-weight: 800; color: var(--vm-dark); margin: 0 0 .6rem; letter-spacing: -0.02em; }
.vg-section-header p { color: var(--vm-muted); font-size: 1rem; margin: 0; }

.vg-paths { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.vg-path { display: block; padding: 1.75rem; background: #fff; border: 1px solid var(--vm-border); border-radius: var(--vm-radius-lg); text-decoration: none; color: inherit; transition: all .2s; }
.vg-path:hover { transform: translateY(-3px); border-color: var(--vm-primary); box-shadow: var(--vm-shadow-lg); }
.vg-path-featured { background: linear-gradient(135deg, var(--vm-primary), #6366f1); color: #fff; border: 0; }
.vg-path-icon { font-size: 2.5rem; margin-bottom: .75rem; }
.vg-path h3 { font-size: 1.25rem; font-weight: 700; margin: 0 0 .4rem; }
.vg-path p { margin: 0 0 1.25rem; color: var(--vm-muted); font-size: .95rem; }
.vg-path-featured p { color: rgba(255,255,255,.88); }
.vg-path-cta { font-weight: 700; color: var(--vm-primary); font-size: .92rem; }
.vg-path-featured .vg-path-cta { color: #fff; }

.vg-top-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .75rem; }
.vg-top-card { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 1.25rem .75rem; background: #fff; border: 1px solid var(--vm-border); border-radius: var(--vm-radius); text-decoration: none; color: inherit; transition: all .2s; }
.vg-top-card:hover { border-color: var(--vm-primary); transform: translateY(-2px); }
.vg-top-flag { font-size: 2.5rem; line-height: 1; margin-bottom: .5rem; }
.vg-top-card h3 { margin: 0; font-size: 1rem; font-weight: 700; color: var(--vm-dark); }
.vg-top-card p { margin: .2rem 0; font-size: .78rem; color: var(--vm-muted); }
.vg-top-link { margin-top: .35rem; font-size: .78rem; color: var(--vm-primary); font-weight: 600; }

.vg-hot-grid { display: grid; grid-template-columns: 1fr; gap: .85rem; }
.vg-hot-card { display: block; padding: 1.25rem; background: #fff; border: 1px solid var(--vm-border); border-radius: var(--vm-radius); text-decoration: none; color: inherit; transition: all .2s; }
.vg-hot-card:hover { border-color: var(--vm-primary); transform: translateY(-2px); }
.vg-hot-flags { display: flex; align-items: center; gap: .5rem; margin-bottom: .65rem; color: var(--vm-muted); }
.vg-hot-flags span { font-size: 1.75rem; }
.vg-hot-card h3 { font-size: .95rem; font-weight: 700; margin: 0 0 .65rem; color: var(--vm-dark); }
.vg-hot-badge { display: inline-block; padding: .3rem .7rem; color: #fff; border-radius: 6px; font-size: .75rem; font-weight: 600; }

.vg-purpose-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .85rem; }
.vg-purpose-card { display: block; padding: 1.5rem 1rem; background: #fff; border: 1px solid var(--vm-border); border-radius: var(--vm-radius-lg); text-decoration: none; color: inherit; transition: all .2s; text-align: center; }
.vg-purpose-card:hover { transform: translateY(-3px); border-color: var(--vm-primary); }
.vg-purpose-icon { display: inline-block; font-size: 2.25rem; margin-bottom: .6rem; }
.vg-purpose-card h3 { margin: 0 0 .35rem; font-size: 1rem; font-weight: 700; color: var(--vm-dark); }
.vg-purpose-card p { margin: 0; color: var(--vm-muted); font-size: .82rem; line-height: 1.4; }

.vg-ranking-grid { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: .5rem; }
.vg-rank-row { display: grid; grid-template-columns: 32px 28px 1fr 50px; gap: .75rem; align-items: center; padding: .85rem 1rem; background: #fff; border: 1px solid var(--vm-border); border-radius: 10px; text-decoration: none; color: inherit; transition: all .15s; }
.vg-rank-row:hover { border-color: var(--vm-primary); }
.vg-rank-pos { font-weight: 800; color: var(--vm-primary); font-size: .95rem; }
.vg-rank-flag { font-size: 1.6rem; }
.vg-rank-name { font-weight: 600; color: var(--vm-dark); font-size: .9rem; }
.vg-rank-bar-wrap { display: none; }
.vg-rank-num { text-align: right; font-weight: 800; color: var(--vm-dark); font-size: .9rem; }

.vg-regions { display: flex; flex-wrap: wrap; justify-content: center; gap: .5rem; margin-bottom: 2rem; }
.vg-region-chip { display: inline-flex; align-items: center; gap: .4rem; padding: .55rem 1rem; background: #fff; border: 1px solid var(--vm-border); border-radius: 999px; font-weight: 600; font-size: .85rem; color: var(--vm-dark); text-decoration: none; transition: all .15s; }
.vg-region-chip:hover { background: var(--vm-primary); color: #fff; border-color: var(--vm-primary); }
.vg-region-chip span { font-size: 1rem; }

.vg-alerts-grid { display: grid; grid-template-columns: 1fr; gap: .85rem; }
.vg-alert-card { display: block; padding: 1.25rem; background: #fffbeb; border-left: 3px solid var(--vm-warning); border-radius: var(--vm-radius); text-decoration: none; color: inherit; transition: all .2s; }
.vg-alert-card:hover { transform: translateX(3px); }
.vg-alert-card time { font-size: .8rem; color: #b45309; font-weight: 600; }
.vg-alert-card h3 { margin: .35rem 0; font-size: 1rem; color: var(--vm-dark); line-height: 1.35; }
.vg-alert-card p { margin: 0; color: var(--vm-muted); font-size: .85rem; }

.vg-section-tools { background: var(--vm-dark); color: #fff; }
.vg-section-tools .vg-section-header h2 { color: #fff; }
.vg-section-tools .vg-section-header p { color: rgba(255,255,255,.7); }
.vg-section-tools .vg-eyebrow { background: rgba(37,99,235,.25); color: #93c5fd; }
.vg-tools-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .85rem; }
.vg-tool-card { display: block; padding: 1.5rem 1rem; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--vm-radius-lg); text-decoration: none; color: #fff; transition: all .2s; }
.vg-tool-card:hover { background: rgba(255,255,255,.1); border-color: var(--vm-primary); transform: translateY(-3px); }
.vg-tool-icon { font-size: 2rem; display: block; margin-bottom: .6rem; }
.vg-tool-card h3 { margin: 0 0 .35rem; font-size: 1rem; color: #fff; }
.vg-tool-card p { margin: 0; color: rgba(255,255,255,.7); font-size: .82rem; line-height: 1.4; }

.vg-faq { display: flex; flex-direction: column; gap: .5rem; }
.vg-faq details { background: #fff; border: 1px solid var(--vm-border); border-radius: var(--vm-radius); overflow: hidden; transition: border-color .15s; }
.vg-faq details[open] { border-color: var(--vm-primary); }
.vg-faq summary { padding: 1.15rem 1.25rem; cursor: pointer; font-weight: 700; color: var(--vm-dark); font-size: .95rem; display: flex; justify-content: space-between; align-items: center; gap: 1rem; list-style: none; }
.vg-faq summary::-webkit-details-marker { display: none; }
.vg-faq summary::after { content: '+'; font-size: 1.5rem; color: var(--vm-primary); transition: transform .2s; flex-shrink: 0; font-weight: 400; }
.vg-faq details[open] summary::after { transform: rotate(45deg); }
.vg-faq details p { margin: 0; padding: 0 1.25rem 1.25rem; color: var(--vm-muted); line-height: 1.65; font-size: .92rem; }

.vg-cta-final { padding: 4rem 20px; text-align: center; background: linear-gradient(135deg, var(--vm-primary), #6366f1); color: #fff; }
.vg-cta-final h2 { font-size: clamp(1.5rem, 3.5vw, 2.25rem); font-weight: 800; margin: 0 0 .85rem; color: #fff; }
.vg-cta-final p { font-size: 1rem; color: rgba(255,255,255,.9); margin: 0 auto 1.75rem; max-width: 560px; }
.vg-cta-final .vg-btn { background: #fff; color: var(--vm-primary); box-shadow: 0 10px 30px rgba(0,0,0,.2); width: auto; padding: 1rem 2rem; }
.vg-cta-final .vg-btn:hover { background: #f1f5f9; }

@media (min-width: 680px) {
    .vg-hero { padding: 6rem 20px 5rem; }
    .vg-hero-form { grid-template-columns: 1fr auto 1fr auto; gap: .85rem; }
    .vg-arrow { display: block; color: var(--vm-primary); font-weight: 700; font-size: 1.5rem; padding-top: 1.5rem; }
    .vg-btn { width: auto; padding: 1rem 1.85rem; }
    .vg-hero-stats { grid-template-columns: repeat(4, 1fr); max-width: 700px; }
    .vg-top-grid { grid-template-columns: repeat(3, 1fr); }
    .vg-hot-grid { grid-template-columns: repeat(2, 1fr); }
    .vg-purpose-grid { grid-template-columns: repeat(3, 1fr); }
    .vg-tools-grid { grid-template-columns: repeat(2, 1fr); }
    .vg-alerts-grid { grid-template-columns: repeat(3, 1fr); }
    .vg-paths { grid-template-columns: repeat(3, 1fr); }
    .vg-section { padding: 5rem 20px; }
}
@media (min-width: 960px) {
    .vg-top-grid { grid-template-columns: repeat(4, 1fr); }
    .vg-hot-grid { grid-template-columns: repeat(3, 1fr); }
    .vg-tools-grid { grid-template-columns: repeat(4, 1fr); }
    .vg-rank-row { grid-template-columns: 40px 32px 1fr 2fr 60px; }
    .vg-rank-bar-wrap { display: block; height: 6px; background: var(--vm-light); border-radius: 999px; overflow: hidden; }
    .vg-rank-bar { display: block; height: 100%; background: linear-gradient(90deg, var(--vm-primary), #8b5cf6); border-radius: 999px; }
}

[data-aos] { opacity: 1 !important; transform: none !important; }
