/* ══════════════════════════════════════════
   Login · Cuenta del portal CYL
   Extiende portal.css (requiere sus tokens)
   Clases compartidas (.t-login-*, .t-field, .t-label, .t-hint,
   .u-pwd-wrap, .u-pwd-toggle) → portal.css
══════════════════════════════════════════ */

/* ── Full-height layout so footer stays at bottom ── */
#login-portal {
  display: flex; flex-direction: column; min-height: 100vh;
}

/* ── Login centered layout ── */
.login-main {
  flex: 1; display: grid; place-items: center; padding: 60px 20px;
}

/* ── Pane switching ── */
.u-pane { display: none; }
.u-pane.active { display: block; animation: uFade .18s ease-out; }
@keyframes uFade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

/* ── Two-column row ── */
.u-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ── Terms checkbox row ── */
.u-check-row {
  display: grid; grid-template-columns: 18px 1fr; gap: 10px;
  align-items: flex-start; font-size: 12.5px; color: var(--ink-soft);
  line-height: 1.55; margin: 4px 0 18px; cursor: pointer;
}
.u-check-row input[type="checkbox"] {
  width: 18px; height: 18px; margin: 1px 0 0;
  accent-color: var(--green-text-str); cursor: pointer;
}
.u-check-row a { color: var(--green-text-str); text-decoration: underline; text-underline-offset: 2px; }
.u-check-row a:hover { color: var(--green-text); }

/* ── Full-width button modifier ── */
.btn.btn-full { width: 100%; justify-content: center; padding: 12px 16px; font-size: 14px; }

/* ── Card footer links ── */
.u-foot {
  margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 10px; font-size: 12.5px; color: var(--ink-muted);
}
.u-foot a { color: var(--green-text-str); font-weight: 600; text-decoration: none; }
.u-foot a:hover { color: var(--green-text); text-decoration: underline; text-underline-offset: 3px; }

@media (max-width: 640px) {
  .p-header { padding: 0 20px; }
  .login-main { padding: 32px 16px 48px; }
  .u-row-2 { grid-template-columns: 1fr; }
}
