/* ===========================================================================
   ESCALA MRS — Portal médico (landing pública de suscripción).
   Paleta de marca: morado #772b95 + naranja #ff9300. Mobile-first. Sin JS.
   =========================================================================== */
:root {
    --pm-morado: #772b95;
    --pm-morado-osc: #5a1f72;
    --pm-naranja: #ff9300;
    --pm-naranja-osc: #e5881c;
    --pm-tinta: #131e30;
    --pm-gris: #5b6b73;
    --pm-lila: #f7effc;
    --pm-borde: #e7d4f2;
}

* { box-sizing: border-box; }
body.pm {
    margin: 0;
    font-family: "Segoe UI", system-ui, -apple-system, sans-serif;
    color: var(--pm-tinta);
    background: #fff;
    line-height: 1.55;
}
.pm a { color: var(--pm-morado); }
.pm-wrap { max-width: 1080px; margin: 0 auto; padding: 0 20px; }

/* ---- Barra superior ---- */
.pm-top {
    position: sticky; top: 0; z-index: 10;
    background: rgba(255,255,255,.95);
    border-bottom: 1px solid var(--pm-borde);
    backdrop-filter: saturate(1.2) blur(6px);
}
.pm-top__in { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 20px; max-width: 1080px; margin: 0 auto; }
.pm-marca { font-weight: 800; letter-spacing: .5px; color: var(--pm-morado); font-size: 1.05rem; display: flex; align-items: center; gap: 8px; }
.pm-marca__logo { height: 30px; width: auto; display: block; }
.pm-marca span { color: var(--pm-naranja-osc); font-weight: 600; }
.pm-top__nav { display: flex; align-items: center; gap: 10px; }
.pm-top__nav a.pm-link { display: none; color: var(--pm-tinta); text-decoration: none; font-size: .92rem; }

/* ---- Botones ---- */
.pm-btn { display: inline-block; border: 0; border-radius: 8px; padding: 11px 20px;
    font-size: .98rem; font-weight: 700; cursor: pointer; text-decoration: none; text-align: center; }
.pm-btn--primario { background: var(--pm-naranja); color: #fff; }
.pm-btn--primario:hover { background: var(--pm-naranja-osc); }
.pm-btn--morado { background: var(--pm-morado); color: #fff; }
.pm-btn--morado:hover { background: var(--pm-morado-osc); }
.pm-btn--ghost { background: transparent; color: var(--pm-morado); border: 1.5px solid var(--pm-morado); }
.pm-btn--ghost:hover { background: var(--pm-lila); }
.pm-btn--lg { padding: 14px 28px; font-size: 1.05rem; }

/* ---- Hero ---- */
.pm-hero { background: linear-gradient(135deg, var(--pm-morado) 0%, var(--pm-morado-osc) 100%); color: #fff; padding: 56px 0 64px; }
.pm-hero h1 { font-size: 2rem; line-height: 1.2; margin: 0 0 14px; }
.pm-hero p { font-size: 1.1rem; max-width: 640px; margin: 0 0 24px; color: #f3e9fa; }
.pm-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; }
.pm-hero__nota { margin-top: 14px; font-size: .85rem; color: #e3d2f0; }

/* ---- Secciones ---- */
.pm-sec { padding: 56px 0; }
.pm-sec--alt { background: var(--pm-lila); }
.pm-sec h2 { font-size: 1.5rem; color: var(--pm-morado-osc); text-align: center; margin: 0 0 8px; }
.pm-sec__sub { text-align: center; color: var(--pm-gris); max-width: 620px; margin: 0 auto 36px; }

/* ---- Grilla de tarjetas ---- */
.pm-grid { display: grid; grid-template-columns: 1fr; gap: 18px; }
.pm-card { background: #fff; border: 1px solid var(--pm-borde); border-radius: 12px; padding: 22px; }
.pm-card__ico { width: 44px; height: 44px; border-radius: 10px; background: var(--pm-lila);
    display: flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 12px; }
.pm-card h3 { margin: 0 0 6px; font-size: 1.08rem; color: var(--pm-morado-osc); }
.pm-card p { margin: 0; color: var(--pm-gris); font-size: .96rem; }

/* ---- Pasos ---- */
.pm-pasos { display: grid; grid-template-columns: 1fr; gap: 18px; counter-reset: paso; }
.pm-paso { position: relative; background: #fff; border: 1px solid var(--pm-borde); border-radius: 12px; padding: 22px 22px 22px 64px; }
.pm-paso::before { counter-increment: paso; content: counter(paso); position: absolute; left: 18px; top: 20px;
    width: 32px; height: 32px; border-radius: 50%; background: var(--pm-naranja); color: #fff;
    font-weight: 800; display: flex; align-items: center; justify-content: center; }
.pm-paso h3 { margin: 0 0 4px; font-size: 1.05rem; }
.pm-paso p { margin: 0; color: var(--pm-gris); font-size: .95rem; }

/* ---- Plan / precios ---- */
.pm-plan { max-width: 420px; margin: 0 auto; background: #fff; border: 2px solid var(--pm-morado);
    border-radius: 16px; overflow: hidden; box-shadow: 0 10px 30px rgba(119,43,149,.12); }
.pm-plan__cab { background: var(--pm-morado); color: #fff; text-align: center; padding: 20px; }
.pm-plan__nom { font-size: 1.2rem; font-weight: 700; }
.pm-plan__precio { font-size: 2.2rem; font-weight: 800; margin: 8px 0 0; }
.pm-plan__precio small { font-size: .9rem; font-weight: 500; color: #e3d2f0; }
.pm-plan__cuerpo { padding: 24px; }
.pm-plan__lista { list-style: none; margin: 0 0 22px; padding: 0; }
.pm-plan__lista li { padding: 8px 0 8px 28px; position: relative; color: var(--pm-tinta); border-bottom: 1px solid #f1e8f8; }
.pm-plan__lista li:last-child { border-bottom: 0; }
.pm-plan__lista li::before { content: "✓"; position: absolute; left: 0; color: #1e8a5a; font-weight: 800; }
.pm-plan__pago { text-align: center; margin-top: 14px; font-size: .82rem; color: var(--pm-gris); }

/* ---- Footer ---- */
.pm-pie { background: var(--pm-tinta); color: #c9d3dd; padding: 28px 0; font-size: .88rem; }
.pm-pie__in { display: flex; flex-wrap: wrap; gap: 12px; justify-content: space-between; align-items: center; }
.pm-pie a { color: #fff; }

/* ---- Responsive ---- */
@media (min-width: 720px) {
    .pm-hero h1 { font-size: 2.6rem; }
    .pm-grid { grid-template-columns: repeat(3, 1fr); }
    .pm-pasos { grid-template-columns: repeat(3, 1fr); }
    .pm-top__nav a.pm-link { display: inline; }
}
