/* ══════════════════════════════════════
   Mi Portal (compartido)
══════════════════════════════════════ */

/* Access section */
.mp-access {
    max-width: 1200px; margin: 0 auto; padding: 72px 80px 64px;
}
.mp-access h2 { font-size: 1.85rem; color: #07193d; margin: 8px 0 40px; }

/* Service cards */
.mp-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 24px;
}
.mp-card {
    background: white;
    border-radius: 16px;
    padding: 32px 24px;
    box-shadow: 0 2px 14px rgba(7,25,61,.06);
    display: flex; flex-direction: column; gap: 12px;
    border-top: 4px solid transparent;
    transition: border-color .25s, transform .25s, box-shadow .25s;
}
.mp-card:hover { border-top-color: #dca84d; transform: translateY(-4px); box-shadow: 0 10px 32px rgba(7,25,61,.12); }
.mp-card__icon {
    width: 52px; height: 52px;
    background: linear-gradient(135deg, #07193d12, #0c2b6618);
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    color: #07193d;
}
.mp-card h3 { font-size: 1rem; color: #07193d; }
.mp-card p  { font-size: .875rem; color: #5a6a7e; line-height: 1.65; flex: 1; }
.mp-card__link {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: .85rem; font-weight: 700; color: #dca84d;
    text-decoration: none;
    transition: gap .2s;
}
.mp-card__link:hover { gap: 10px; }

/* Login CTA */
.mp-login-cta { background: #07193d; padding: 56px 80px; }
.mp-login-cta__inner {
    max-width: 900px; margin: 0 auto;
    display: flex; align-items: center; gap: 28px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(220,168,77,.25);
    border-radius: 16px; padding: 32px 36px;
}
.mp-login-cta__inner > i { color: #ffd76d; flex-shrink: 0; width: 36px; height: 36px; }
.mp-login-cta__inner h3 { font-size: 1.1rem; color: white; margin-bottom: 4px; }
.mp-login-cta__inner p  { font-size: .875rem; color: rgba(255,255,255,.7); }
.mp-login-cta__btn {
    margin-left: auto; flex-shrink: 0;
    display: inline-flex; align-items: center;
    padding: 12px 28px; border-radius: 30px;
    background: linear-gradient(135deg, #dca84d, #ffd76d);
    color: #0a1f45; font-weight: 700; font-size: .9rem; text-decoration: none;
    transition: transform .25s, box-shadow .25s;
}
.mp-login-cta__btn:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(220,168,77,.4); }

@media (max-width: 900px) {
    .mp-access, .mp-login-cta { padding-left: 24px; padding-right: 24px; }
    .mp-login-cta__inner { flex-direction: column; text-align: center; }
    .mp-login-cta__btn { margin-left: 0; }
}
