/* ════════════════════════════════════════════════════
   RECUPERAR CONTRASEÑA — recuperar.css
   Mismos tokens que el resto del proyecto
════════════════════════════════════════════════════ */

:root {
    --rec-primary:     #F39325;
    --rec-primary-dk:  #d97c18;
    --rec-dark:        #1a1a2e;
    --rec-dark2:       #16213e;
    --rec-card-bg:     #0f3460;
    --rec-text:        #e0e0e0;
    --rec-text-muted:  #a0aec0;
    --rec-success:     #38d39f;
    --rec-radius:      16px;
    --rec-shadow:      0 20px 60px rgba(0,0,0,.5);
    --rec-transition:  .25s ease;
}

/* ── Fondo ── */
.bg-login {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    background: linear-gradient(135deg, var(--rec-dark) 0%, var(--rec-dark2) 50%, var(--rec-card-bg) 100%);
    position: relative;
    overflow: hidden;
}
.bg-login::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 20% 80%, rgba(243,147,37,.15) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(56,211,159,.1)  0%, transparent 50%);
    pointer-events: none;
}

/* ── Card principal ── */
.rec-card {
    position: relative;
    background: rgba(15,52,96,.7);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(243,147,37,.2);
    border-radius: var(--rec-radius);
    box-shadow: var(--rec-shadow);
    width: 100%;
    max-width: 460px;
    overflow: hidden;
    animation: recFadeIn .4s ease both;
}
@keyframes recFadeIn {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Header ── */
.rec-card__header {
    padding: 2.5rem 2.5rem 0;
    text-align: center;
}
.rec-card__icon {
    width: 72px;
    height: 72px;
    margin: 0 auto 1.2rem;
    background: linear-gradient(135deg, var(--rec-primary), var(--rec-primary-dk));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    color: #fff;
    box-shadow: 0 8px 24px rgba(243,147,37,.4);
}
.rec-card__title {
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: .5rem;
}
.rec-card__subtitle {
    font-size: .9rem;
    color: var(--rec-text-muted);
    line-height: 1.5;
    margin-bottom: 0;
}

/* ── Body ── */
.rec-card__body {
    padding: 1.8rem 2.5rem 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

/* ── Grupo ── */
.rec-group { display: flex; flex-direction: column; gap: .5rem; }
.rec-label {
    font-size: .85rem;
    font-weight: 600;
    color: var(--rec-text);
    letter-spacing: .02em;
}

/* ── Toggle de roles ── */
.rec-role-toggle {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
}
.rec-role-opt { cursor: pointer; }
.rec-role-opt input { display: none; }
.rec-role-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .7rem 1rem;
    border-radius: 10px;
    border: 1.5px solid rgba(243,147,37,.3);
    background: rgba(255,255,255,.04);
    color: var(--rec-text-muted);
    font-size: .9rem;
    font-weight: 600;
    transition: var(--rec-transition);
    cursor: pointer;
    user-select: none;
}
.rec-role-btn--active,
.rec-role-opt input:checked + .rec-role-btn {
    border-color: var(--rec-primary);
    background: rgba(243,147,37,.15);
    color: var(--rec-primary);
}
.rec-role-btn:hover { border-color: var(--rec-primary); color: var(--rec-primary); }

/* ── Input ── */
.rec-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.rec-input-icon {
    position: absolute;
    left: 1rem;
    color: var(--rec-primary);
    font-size: .95rem;
    pointer-events: none;
}
.rec-input {
    width: 100%;
    padding: .85rem 1rem .85rem 2.8rem;
    border-radius: 10px;
    border: 1.5px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
    color: #fff;
    font-size: .95rem;
    transition: var(--rec-transition);
    outline: none;
}
.rec-input::placeholder { color: var(--rec-text-muted); }
.rec-input:focus {
    border-color: var(--rec-primary);
    background: rgba(243,147,37,.06);
    box-shadow: 0 0 0 3px rgba(243,147,37,.15);
}

/* ── Info box ── */
.rec-info {
    display: flex;
    align-items: flex-start;
    gap: .7rem;
    padding: .85rem 1rem;
    border-radius: 10px;
    background: rgba(243,147,37,.08);
    border-left: 3px solid var(--rec-primary);
    color: var(--rec-text-muted);
    font-size: .82rem;
    line-height: 1.5;
}
.rec-info .fas { color: var(--rec-primary); margin-top: .1rem; flex-shrink: 0; }

/* ── Botón submit ── */
.rec-submit {
    width: 100%;
    padding: .9rem;
    border: none;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--rec-primary), var(--rec-primary-dk));
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    transition: var(--rec-transition);
    box-shadow: 0 6px 20px rgba(243,147,37,.35);
    letter-spacing: .03em;
}
.rec-submit:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(243,147,37,.5);
}
.rec-submit:disabled {
    opacity: .65;
    cursor: not-allowed;
    transform: none;
}

/* ── Volver ── */
.rec-back-links { text-align: center; }
.rec-back-link {
    color: var(--rec-text-muted);
    font-size: .85rem;
    text-decoration: none;
    transition: var(--rec-transition);
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}
.rec-back-link:hover { color: var(--rec-primary); }

/* ── Estado éxito ── */
.rec-card__success {
    padding: 3rem 2.5rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.2rem;
}
.rec-success__icon {
    width: 90px;
    height: 90px;
    background: linear-gradient(135deg, var(--rec-success), #1a9e73);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.2rem;
    color: #fff;
    box-shadow: 0 12px 32px rgba(56,211,159,.4);
    animation: successPop .5s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes successPop {
    from { transform: scale(0); opacity: 0; }
    to   { transform: scale(1); opacity: 1; }
}
.rec-success__title {
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
}
.rec-success__msg {
    font-size: .9rem;
    color: var(--rec-text-muted);
    line-height: 1.6;
    max-width: 340px;
}
.rec-success__actions {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
}

/* ── Botones de acción en éxito ── */
.rec-btn {
    flex: 1;
    min-width: 140px;
    padding: .75rem 1rem;
    border-radius: 10px;
    font-size: .9rem;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    transition: var(--rec-transition);
}
.rec-btn--primary {
    background: linear-gradient(135deg, var(--rec-primary), var(--rec-primary-dk));
    color: #fff;
    box-shadow: 0 6px 20px rgba(243,147,37,.35);
}
.rec-btn--primary:hover { transform: translateY(-2px); color: #fff; box-shadow: 0 10px 28px rgba(243,147,37,.5); }
.rec-btn--secondary {
    background: rgba(255,255,255,.06);
    border: 1.5px solid rgba(255,255,255,.15);
    color: var(--rec-text);
}
.rec-btn--secondary:hover { border-color: var(--rec-primary); color: var(--rec-primary); }

/* ── Footer decorativo ── */
.rec-card__footer {
    height: 6px;
    background: linear-gradient(90deg, var(--rec-primary), #ff6b35, var(--rec-success));
}

/* ── Responsive ── */
@media (max-width: 480px) {
    .rec-card__header { padding: 2rem 1.5rem 0; }
    .rec-card__body   { padding: 1.5rem 1.5rem 1.8rem; }
    .rec-card__success { padding: 2rem 1.5rem; }
}
