/* ==========================================
   4. COMPONENTES GLOBALES (Botones, Inputs)
   ========================================== */
.form-group {
    margin-bottom: 1.25rem;
    text-align: left;
}

.form-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text-main);
    margin-bottom: 0.5rem;
}

.form-input, .form-select {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: 0.5rem;
    outline: none;
    transition: border-color var(--transition-speed), box-shadow var(--transition-speed);
}

.form-input:focus, .form-select:focus {
    border-color: var(--color-gold);
    box-shadow: 0 0 0 3px rgba(213, 176, 103, 0.2);
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
    font-weight: 600;
    transition: background-color var(--transition-speed), transform 0.1s;
}

.btn:active { transform: scale(0.98); }
.btn-full { width: 100%; }

.btn-primary {
    background-color: var(--color-gold);
    color: var(--color-white);
}
.btn-primary:hover:not(:disabled) { background-color: var(--color-gold-dark); }

.btn-secondary {
    background-color: var(--color-blue-main);
    color: var(--color-white);
}
.btn-secondary:hover:not(:disabled) { background-color: var(--color-blue-dark); }

.btn-danger {
    background-color: var(--color-error);
    color: var(--color-white);
}

.btn:disabled {
    background-color: var(--color-border);
    color: var(--color-text-muted);
    cursor: not-allowed;
    transform: none;
}

.link {
    color: var(--color-blue-main);
    cursor: pointer;
    text-decoration: underline transparent;
    transition: text-decoration var(--transition-speed);
}
.link:hover { text-decoration-color: var(--color-blue-main); }

.icon { width: 1.25rem; height: 1.25rem; }
.icon-lg { width: 2rem; height: 2rem; }

/* BADGES MOCKUPS */
.badge {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    border-radius: 9999px;
    font-size: 0.7rem;
    font-weight: bold;
}
.badge-green { background-color: rgba(39, 78, 45, 0.1); color: var(--color-green); }
.badge-orange { background-color: rgba(213, 176, 103, 0.15); color: #b48530; }
.badge-blue { background-color: rgba(44, 66, 88, 0.1); color: var(--color-blue-main); }
.badge-gray { background-color: var(--color-border); color: var(--color-text-muted); }

/* SKELETON LOADERS */
.skeleton-box { background: #e2e8f0; border-radius: 4px; animation: pulse 1.5s infinite; }
@keyframes pulse { 0% { opacity: 1; } 50% { opacity: 0.5; } 100% { opacity: 1; } }
