@import url(./global/global.css);
@import url(./objects/header.css);
@import url(./objects/footer.css);

/* Contenedor principal de páginas de autenticación */
.auth-container {
    display: grid;
    place-items: center;
    min-height: calc(100vh - 6rem);
    padding: var(--spacing-2xl) var(--spacing-md);
    background: linear-gradient(180deg, var(--gradient-primary-light), transparent 40%),
                linear-gradient(0deg, var(--gradient-secondary-light), transparent 60%);
}

/* Tarjeta del formulario */
.form-card {
    width: 100%;
    max-width: 480px;
    background-color: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: var(--spacing-2xl) var(--spacing-xl);
}

.form-header {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.form-title {
    margin-bottom: var(--spacing-xs);
}

.form-subtitle {
    color: var(--text-secondary);
    font-size: var(--font-size-sm);
}

/* Formulario y campos */
.auth-form {
    width: 100%;
}

.form-group-enhanced {
    margin-bottom: var(--spacing-lg);
}

.form-label-enhanced {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-weight: 500;
    font-size: var(--font-size-sm);
    color: var(--text-primary);
}

.form-control-enhanced {
    display: block;
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background-color: var(--surface);
    color: var(--text-primary);
    font-size: var(--font-size-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    min-height: 2.5rem;
}

.form-control-enhanced:focus {
    border-color: var(--primary-500);
    box-shadow: 0 0 0 3px rgb(14 165 233 / 0.1);
    outline: none;
}

.form-control-enhanced::placeholder {
    color: var(--text-muted);
}

.form-error {
    color: var(--error-600);
    font-size: var(--font-size-xs);
    margin-top: var(--spacing-xs);
    min-height: 1.25rem;
}

.form-actions {
    display: flex;
    gap: var(--spacing-md);
    margin-top: var(--spacing-lg);
}

.form-feedback {
    margin-top: var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}

.form-feedback.success {
    color: var(--success-600);
    font-weight: 500;
}

.form-feedback.error {
    color: var(--error-600);
    font-weight: 500;
}

/* Estados de carga para botones */
.btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Responsivo */
@media (max-width: 480px) {
    .form-card {
        padding: var(--spacing-xl);
    }

    .form-actions {
        flex-direction: column;
    }

    .form-actions .btn {
        width: 100%;
    }
}
