/* ============================================================
   Toggle — token-driven on/off switch
   Variants: default | outlined | filled
   States:   checked | disabled | error | focus
   ============================================================ */

/* --- Wrapper --- */

.ui-toggle-wrapper {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* --- Label layout --- */

.ui-toggle {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}

.ui-toggle input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

/* --- Track --- */

.toggle-track {
    width: 40px;
    height: 22px;
    background: var(--toggle-background, var(--meb-border-subtle));
    border: 1px solid var(--toggle-border, var(--meb-border-subtle));
    border-radius: 999px;
    position: relative;
    transition: background 150ms ease, border-color 150ms ease;
}

/* --- Thumb --- */

.toggle-thumb {
    width: 18px;
    height: 18px;
    background: var(--toggle-foreground, var(--meb-text-inverse));
    border-radius: 999px;
    position: absolute;
    top: 1px;
    left: 1px;
    transition: transform 150ms ease;
}

/* --- Checked state --- */

.ui-toggle input:checked + .toggle-track {
    background: var(--toggle-background-active, var(--meb-accent-primary));
    border-color: var(--toggle-border-active, var(--meb-border-accent));
}

.ui-toggle input:checked + .toggle-track .toggle-thumb {
    transform: translateX(18px);
}

/* --- Label text --- */

.toggle-label {
    color: var(--toggle-text, var(--meb-text-default));
    font-size: var(--text-md);
    font-weight: var(--weight-regular);
    user-select: none;
}

/* --- Error message --- */

.toggle-error {
    color: var(--toggle-border-error, var(--meb-accent-danger));
    font-size: var(--text-xs);
    margin-top: 2px;
}

/* ============================================================
   Variants
   ============================================================ */

.ui-toggle-wrapper.variant-default .toggle-track {
    background: var(--toggle-background, var(--meb-border-subtle));
}

.ui-toggle-wrapper.variant-outlined .toggle-track {
    background: transparent;
    border: 1px solid var(--toggle-border, var(--meb-border-subtle));
}

.ui-toggle-wrapper.variant-filled .toggle-track {
    background: var(--toggle-background, var(--meb-surface-input-filled));
}

/* ============================================================
   Focus state
   ============================================================ */

.ui-toggle input:focus-visible + .toggle-track {
    box-shadow: var(--toggle-focus-shadow, var(--meb-button-primary-focus-shadow));
}

/* ============================================================
   Disabled state
   ============================================================ */

.ui-toggle-wrapper.disabled {
    opacity: 0.6;
    pointer-events: none;
}

/* ============================================================
   Error state
   ============================================================ */

.ui-toggle-wrapper.error .toggle-track {
    border-color: var(--toggle-border-error, var(--meb-accent-danger));
}
