/* =========================================================================
   COMPONENTS.CSS — Componentes base del sistema visual.
   Botones, cards, formularios según SYSTEM_DESIGN.md secciones 9-11.
   Convención BEM, prefijo imp-.
   ========================================================================= */

/* =========================================================================
   BOTONES
   .imp-btn        — base
   .imp-btn--primary  .imp-btn--secondary  .imp-btn--outline
   .imp-btn--ghost    .imp-btn--danger
   .imp-btn--sm       .imp-btn--lg         .imp-btn--full   .imp-btn--icon
   ========================================================================= */

.imp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    font-family: var(--font-body);
    font-weight: var(--font-weight-semibold);
    font-size: var(--text-base);
    line-height: 1.25;
    text-decoration: none;
    border: 2px solid transparent;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition:
        background-color var(--transition-fast),
        color var(--transition-fast),
        border-color var(--transition-fast),
        box-shadow var(--transition-fast),
        opacity var(--transition-fast);
    user-select: none;
    white-space: nowrap;
}

/* ── Variantes ─────────────────────────────────────── */

/* Primary */
.imp-btn--primary {
    background-color: var(--color-primary-500);
    color: #ffffff;
    border-color: var(--color-primary-500);
}

.imp-btn--primary:hover {
    background-color: var(--color-primary-600);
    border-color: var(--color-primary-600);
}

.imp-btn--primary:active {
    background-color: var(--color-primary-700);
    border-color: var(--color-primary-700);
}

/* Secondary */
.imp-btn--secondary {
    background-color: var(--color-neutral-100);
    color: var(--color-neutral-800);
    border-color: var(--color-neutral-300);
}

.imp-btn--secondary:hover {
    background-color: var(--color-neutral-200);
    border-color: var(--color-neutral-400);
}

.imp-btn--secondary:active {
    background-color: var(--color-neutral-300);
    border-color: var(--color-neutral-500);
}

/* Outline */
.imp-btn--outline {
    background-color: transparent;
    color: var(--color-primary-600);
    border-color: var(--color-primary-300);
}

.imp-btn--outline:hover {
    background-color: var(--color-primary-50);
    border-color: var(--color-primary-500);
}

.imp-btn--outline:active {
    background-color: var(--color-primary-100);
}

/* Ghost */
.imp-btn--ghost {
    background-color: transparent;
    color: var(--color-neutral-600);
    border-color: transparent;
}

.imp-btn--ghost:hover {
    background-color: var(--color-neutral-100);
    color: var(--color-neutral-900);
}

.imp-btn--ghost:active {
    background-color: var(--color-neutral-200);
}

/* Danger */
.imp-btn--danger {
    background-color: var(--color-danger);
    color: #ffffff;
    border-color: var(--color-danger);
}

.imp-btn--danger:hover {
    background-color: #b91c1c;
    border-color: #b91c1c;
}

.imp-btn--danger:active {
    background-color: #991b1b;
    border-color: #991b1b;
}

/* ── Tamaños ───────────────────────────────────────── */

.imp-btn--sm {
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-sm);
    border-radius: var(--radius-sm);
}

.imp-btn--lg {
    padding: var(--space-4) var(--space-8);
    font-size: var(--text-lg);
    border-radius: var(--radius-lg);
}

.imp-btn--full {
    width: 100%;
}

.imp-btn--icon {
    padding: var(--space-3);
    border-radius: var(--radius-full);
    aspect-ratio: 1;
}

/* ── Estados ───────────────────────────────────────── */

/* Focus-visible */
.imp-btn:focus-visible {
    outline: 2px solid var(--color-primary-500);
    outline-offset: 2px;
}

/* Active */
.imp-btn:active {
    transform: scale(0.98);
}

/* Disabled */
.imp-btn:disabled,
.imp-btn[aria-disabled="true"] {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* Loading */
.imp-btn[aria-busy="true"] {
    position: relative;
    color: transparent !important;
    pointer-events: none;
}

.imp-btn[aria-busy="true"]::after {
    content: '';
    position: absolute;
    width: 1em;
    height: 1em;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: imp-spin 0.6s linear infinite;
}

@keyframes imp-spin {
    to {
        transform: rotate(360deg);
    }
}

/* =========================================================================
   CARDS
   .imp-card            — base
   .imp-card__media     — contenedor de imagen
   .imp-card__body      — contenido textual
   .imp-card__title     — título
   .imp-card__cta       — llamado a la acción
   ========================================================================= */

.imp-card {
    display: flex;
    flex-direction: column;
    background-color: var(--surface-primary);
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition:
        box-shadow var(--transition-base),
        transform var(--transition-base);
}

.imp-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.imp-card__media {
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background-color: var(--surface-secondary);
}

.imp-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}

.imp-card:hover .imp-card__media img {
    transform: scale(1.03);
}

.imp-card__body {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-4);
    flex: 1;
}

.imp-card__title {
    font-family: var(--font-body);
    font-weight: var(--font-weight-semibold);
    font-size: var(--text-base);
    line-height: 1.3;
    color: var(--color-neutral-900);
    margin: 0;
}

.imp-card__title a {
    color: inherit;
    text-decoration: none;
}

.imp-card__title a:hover {
    color: var(--color-primary-600);
}

.imp-card__cta {
    margin-top: auto;
    align-self: flex-start;
}

/* =========================================================================
   FORMULARIOS
   .imp-form        — contenedor de formulario
   .imp-label       — label
   .imp-input       — input / textarea / select
   .imp-input--sm   .imp-input--lg
   .imp-input--error .imp-input--valid
   ========================================================================= */

.imp-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/* ── Labels ────────────────────────────────────────── */

.imp-label {
    display: block;
    font-family: var(--font-body);
    font-weight: var(--font-weight-semibold);
    font-size: var(--text-sm);
    color: var(--color-neutral-700);
    margin-bottom: var(--space-2);
}

/* ── Inputs ────────────────────────────────────────── */

.imp-input,
input[type="text"].imp-input,
input[type="email"].imp-input,
input[type="tel"].imp-input,
input[type="number"].imp-input,
input[type="password"].imp-input,
input[type="search"].imp-input,
input[type="url"].imp-input,
textarea.imp-input,
select.imp-input {
    display: block;
    width: 100%;
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-body);
    font-weight: var(--font-weight-normal);
    font-size: var(--text-base);
    line-height: 1.5;
    color: var(--color-neutral-800);
    background-color: var(--surface-primary);
    border: 2px solid var(--color-neutral-300);
    border-radius: var(--radius-md);
    transition:
        border-color var(--transition-fast),
        box-shadow var(--transition-fast);
    appearance: none;
}

.imp-input::placeholder {
    color: var(--color-neutral-400);
}

/* Focus */
.imp-input:focus {
    border-color: var(--color-primary-400);
    box-shadow: 0 0 0 3px rgb(245 166 35 / 0.15);
    outline: none;
}

/* Error */
.imp-input--error,
.imp-input--error:focus {
    border-color: var(--color-danger);
    box-shadow: 0 0 0 3px rgb(220 38 38 / 0.15);
}

/* Valid */
.imp-input--valid,
.imp-input--valid:focus {
    border-color: var(--color-success);
    box-shadow: 0 0 0 3px rgb(22 163 74 / 0.15);
}

/* Disabled */
.imp-input:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background-color: var(--surface-secondary);
}

/* Tamaños */
.imp-input--sm {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
}

.imp-input--lg {
    padding: var(--space-4) var(--space-5);
    font-size: var(--text-lg);
}

/* textarea */
textarea.imp-input {
    min-height: 120px;
    resize: vertical;
}

/* select */
select.imp-input {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23737373' d='M1.41 0L6 4.58 10.59 0 12 1.41l-6 6-6-6z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-3) center;
    background-size: 12px 8px;
    padding-right: var(--space-10);
}

/* ── Mensajes de error ─────────────────────────────── */
.imp-form-error {
    font-size: var(--text-sm);
    color: var(--color-danger);
    margin-top: var(--space-1);
}

/* ── Fieldset y legend ─────────────────────────────── */
.imp-form fieldset {
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-md);
    padding: var(--space-6);
    margin: 0;
}

.imp-form legend {
    font-family: var(--font-body);
    font-weight: var(--font-weight-semibold);
    font-size: var(--text-base);
    color: var(--color-neutral-800);
    padding: 0 var(--space-3);
}

/* ── Checkbox y radio ──────────────────────────────── */
.imp-checkbox,
.imp-radio {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    cursor: pointer;
    font-size: var(--text-base);
    color: var(--color-neutral-700);
}

.imp-checkbox input[type="checkbox"],
.imp-radio input[type="radio"] {
    width: 1.125em;
    height: 1.125em;
    accent-color: var(--color-primary-500);
    cursor: pointer;
}
