/* ============================================================================
 *  GPU Admin Panel - UI Component Primitives
 *  -------------------------------------------------------------------------
 *  First-batch ui-* component primitives. All values consumed from
 *  tokens.css. No hardcoded sizes, colors, or radii.
 *
 *  Catalog:
 *    - ui-page-header      page title + actions block
 *    - ui-tabs             pill / underline tab strip
 *    - ui-card             surface container with header/body/footer
 *    - ui-table            data table with header / row / cell
 *    - ui-pill             status / count badge
 *    - ui-notice           inline banner (info / success / warning / danger)
 *    - ui-empty-state      placeholder for empty data
 *    - ui-button           primary / secondary / ghost / danger
 *    - ui-iconbutton       square / round single-icon button
 *    - ui-input            text inputs
 *    - ui-select           native select with consistent chrome
 *    - ui-textarea         multiline input
 *    - ui-form-section     grouped block of fields with optional title
 *    - ui-form-row         label + control + help row
 *    - ui-form-actions     sticky footer for form save/cancel
 *    - ui-checkbox         checkbox + label
 *
 *  See docs/UI_SYSTEM.md for usage examples.
 * ========================================================================== */

/* ===== ui-page-header ===================================================== */
.ui-page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--space-6);
}
.ui-page-header__main { min-width: 0; flex: 1 1 auto; }
.ui-page-header__title {
    margin: 0;
    font-size: var(--type-2xl);
    font-weight: var(--type-weight-semibold);
    line-height: var(--type-leading-tight);
    color: var(--color-text);
}
.ui-page-header__subtitle {
    margin: var(--space-1) 0 0;
    font-size: var(--type-sm);
    color: var(--color-text-muted);
}
.ui-page-header__actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex: 0 0 auto;
}

/* ===== ui-tabs ============================================================ */
.ui-tabs {
    display: flex;
    align-items: stretch;
    gap: var(--space-1);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--space-6);
    overflow-x: auto;
    scrollbar-width: none;
}
.ui-tabs::-webkit-scrollbar { display: none; }
.ui-tabs__tab {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    border: 0;
    background: transparent;
    color: var(--color-text-muted);
    font-family: inherit;
    font-size: var(--type-sm);
    font-weight: var(--type-weight-medium);
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color var(--motion-fast), border-color var(--motion-fast), background var(--motion-fast);
    white-space: nowrap;
}
.ui-tabs__tab:hover {
    color: var(--color-text);
    background: var(--color-hover);
}
.ui-tabs__tab.is-active,
.ui-tabs__tab[aria-selected="true"] {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
    background: transparent;
}
.ui-tabs__tab:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--color-focus-ring);
    border-radius: var(--radius-sm);
}
.ui-tabs__count {
    display: inline-block;
    margin-left: var(--space-1);
    padding: 0 var(--space-2);
    background: var(--color-hover);
    color: var(--color-text-muted);
    font-size: var(--type-xs);
    font-weight: var(--type-weight-medium);
    border-radius: var(--radius-full);
    min-width: 20px;
    text-align: center;
}
/* Secondary (sub) tabs: pill-shaped, no underline. Used as the second
 * level under a primary `.ui-tabs` strip (e.g. Settings buckets ->
 * leaves), or as an in-page filter strip nested inside a card body
 * (e.g. Trust filter, Settings sub-sections). The shape change makes
 * the primary/secondary hierarchy obvious at a glance. */
.ui-tabs--sub {
    border-bottom: 0;
    gap: var(--space-1);
    margin-bottom: var(--space-4);
}
.ui-tabs--sub .ui-tabs__tab {
    padding: var(--space-2) var(--space-3);
    font-size: var(--type-xs);
    border-bottom: none;
    margin-bottom: 0;
    border-radius: var(--radius-full);
    background: transparent;
}
.ui-tabs--sub .ui-tabs__tab:hover {
    background: var(--color-hover);
    color: var(--color-text);
    border-bottom: none;
}
.ui-tabs--sub .ui-tabs__tab.is-active,
.ui-tabs--sub .ui-tabs__tab[aria-selected="true"] {
    background: var(--color-primary);
    color: var(--color-on-primary);
    border-bottom: none;
}
.ui-tabs--sub .ui-tabs__tab:focus-visible {
    border-radius: var(--radius-full);
}

/* Two-tier tab strip wrapper: a primary `.ui-tabs` (underline buckets)
 * directly followed by a `.ui-tabs--sub` (pill leaves). Tightens the
 * spacing between the two strips so they read as one cohesive group. */
.ui-tab-group {
    margin-bottom: var(--space-5);
}
.ui-tab-group .ui-tabs {
    margin-bottom: var(--space-3);
}
.ui-tab-group .ui-tabs--sub {
    margin-bottom: 0;
}

/* ===== ui-toolbar ========================================================= */
.ui-toolbar {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    box-shadow: var(--elevation-1);
    margin-bottom: var(--space-4);
}
.ui-toolbar__group {
    display: flex;
    align-items: flex-end;
    gap: var(--space-3);
    flex-wrap: wrap;
    min-width: 0;
}
.ui-toolbar__grow {
    flex: 1 1 260px;
    min-width: 220px;
}
.ui-toolbar__actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex: 0 0 auto;
}
.ui-toolbar--site-picker {
    margin-bottom: var(--space-3);
}

/* ===== ui-site-switcher ================================================== */
.ui-site-switcher {
    display: flex;
    align-items: stretch;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin: 0 0 var(--space-4);
}
.ui-site-switcher__item {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 148px;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    color: var(--color-text-muted);
    text-decoration: none;
    box-shadow: var(--elevation-1);
    transition: border-color var(--motion-fast), background var(--motion-fast),
                color var(--motion-fast), box-shadow var(--motion-fast);
}
.ui-site-switcher__item:hover {
    border-color: var(--color-primary);
    background: var(--color-primary-light);
    color: var(--color-text);
}
.ui-site-switcher__item.is-active {
    border-color: var(--color-primary);
    background: var(--color-primary-light);
    color: var(--color-primary-dark);
    box-shadow: 0 0 0 1px var(--color-primary-light), var(--elevation-1);
}
.ui-site-switcher__name {
    font-size: var(--type-sm);
    font-weight: var(--type-weight-semibold);
    line-height: var(--type-leading-tight);
}
.ui-site-switcher__domain {
    font-size: var(--type-xs);
    color: var(--color-text-soft);
}
.ui-site-switcher__more {
    position: relative;
}
.ui-site-switcher__more summary {
    display: flex;
    align-items: center;
    height: 100%;
    min-height: 48px;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    color: var(--color-text-muted);
    font-size: var(--type-sm);
    font-weight: var(--type-weight-semibold);
    cursor: pointer;
    box-shadow: var(--elevation-1);
}
.ui-site-switcher__more[open] summary {
    border-color: var(--color-primary);
    color: var(--color-primary-dark);
}
.ui-site-switcher__more-list {
    position: absolute;
    z-index: var(--z-popover);
    top: calc(100% + var(--space-2));
    left: 0;
    display: grid;
    gap: var(--space-2);
    min-width: 220px;
    padding: var(--space-2);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface-raised);
    box-shadow: var(--elevation-3);
}
@media (max-width: 720px) {
    .ui-toolbar {
        align-items: stretch;
        flex-direction: column;
    }
    .ui-toolbar__actions {
        justify-content: flex-start;
        flex-wrap: wrap;
    }
    .ui-site-switcher__item {
        flex: 1 1 100%;
    }
    .ui-site-switcher__more,
    .ui-site-switcher__more summary {
        width: 100%;
    }
    .ui-site-switcher__more-list {
        position: static;
        margin-top: var(--space-2);
    }
}

/* ===== ui-help-panel ====================================================== */
.ui-help-panel {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: color-mix(in srgb, var(--color-primary-light) 45%, var(--color-surface));
    box-shadow: var(--elevation-1);
    margin-bottom: var(--space-4);
    overflow: hidden;
}
.ui-help-panel__summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    cursor: pointer;
    color: var(--color-text);
    list-style: none;
}
.ui-help-panel__summary::-webkit-details-marker { display: none; }
.ui-help-panel__summary::after {
    content: "";
    width: 8px;
    height: 8px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg);
    transition: transform var(--motion-fast);
    flex: 0 0 auto;
}
.ui-help-panel[open] .ui-help-panel__summary::after {
    transform: rotate(225deg);
}
.ui-help-panel__summary-main {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.ui-help-panel__title {
    font-size: var(--type-sm);
    font-weight: var(--type-weight-semibold);
}
.ui-help-panel__hint {
    font-size: var(--type-xs);
    color: var(--color-text-muted);
}
.ui-help-panel:not([open]) .ui-help-panel__hint {
    display: none;
}
.ui-help-panel__body {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
    padding: 0 var(--space-4) var(--space-4);
    border-top: 1px solid var(--color-border);
}
.ui-help-panel__section {
    padding-top: var(--space-4);
    min-width: 0;
}
.ui-help-panel__section--full {
    grid-column: 1 / -1;
}
.ui-help-panel__heading {
    margin: 0 0 var(--space-2);
    color: var(--color-text);
    font-size: var(--type-xs);
    font-weight: var(--type-weight-semibold);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.ui-help-panel__text,
.ui-help-panel__list {
    margin: 0;
    color: var(--color-text-muted);
    font-size: var(--type-sm);
    line-height: var(--type-leading-normal);
}
.ui-help-panel__list {
    padding-left: var(--space-4);
}
.ui-help-panel__list li + li {
    margin-top: var(--space-1);
}
.ui-help-panel__list strong {
    color: var(--color-text);
}
.ui-help-panel__deep-dive {
    margin-top: var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-surface);
}
.ui-help-panel__deep-dive summary {
    padding: var(--space-2) var(--space-3);
    cursor: pointer;
    color: var(--color-primary-dark);
    font-size: var(--type-sm);
    font-weight: var(--type-weight-semibold);
}
.ui-help-panel__deep-dive-body {
    padding: 0 var(--space-3) var(--space-3);
}
.ui-help-panel__deep-dive-intro {
    margin: 0 0 var(--space-3);
    font-size: var(--type-xs);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ui-help-panel__deep-dive-section {
    margin-top: var(--space-4);
    padding-top: var(--space-4);
    border-top: 1px solid var(--color-border);
}
.ui-help-panel__deep-dive-section:first-of-type {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
}
.ui-help-panel__deep-dive-heading {
    margin: 0 0 var(--space-2);
    color: var(--color-text);
    font-size: var(--type-sm);
    font-weight: var(--type-weight-semibold);
}
.ui-help-panel__deep-dive-text {
    margin: 0 0 var(--space-2);
    color: var(--color-text-muted);
    font-size: var(--type-sm);
    line-height: var(--type-leading-normal);
}
.ui-help-panel__deep-dive-text:last-child { margin-bottom: 0; }
.ui-help-panel__deep-dive-section .ui-help-panel__list { margin-top: var(--space-2); }
@media (max-width: 720px) {
    .ui-help-panel__body {
        grid-template-columns: minmax(0, 1fr);
    }
}

/* ===== ui-card ============================================================ */
.ui-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--elevation-1);
    overflow: hidden;
}
.ui-card + .ui-card { margin-top: var(--space-4); }
.ui-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    border-bottom: 1px solid var(--color-border);
    background: var(--color-surface-raised);
}
.ui-card__title {
    margin: 0;
    font-size: var(--type-md);
    font-weight: var(--type-weight-semibold);
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.ui-card__subtitle {
    margin: var(--space-1) 0 0;
    font-size: var(--type-sm);
    color: var(--color-text-muted);
    font-weight: var(--type-weight-regular);
}
.ui-card__actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex: 0 0 auto;
}
.ui-card__body {
    padding: var(--space-5);
}
.ui-card__body--flush { padding: 0; }
.ui-card__footer {
    padding: var(--space-3) var(--space-5);
    border-top: 1px solid var(--color-border);
    background: var(--color-surface-raised);
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--space-2);
}

/* ===== ui-table =========================================================== */
.ui-table-wrap {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: auto;
}
.ui-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: var(--type-sm);
    color: var(--color-text);
}
.ui-table thead th {
    position: sticky;
    top: 0;
    background: var(--color-surface-raised);
    text-align: left;
    font-weight: var(--type-weight-semibold);
    color: var(--color-text-muted);
    font-size: var(--type-xs);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border);
    white-space: nowrap;
}
.ui-table tbody td {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
}
.ui-table tbody tr:last-child td { border-bottom: 0; }
.ui-table tbody tr:hover td { background: var(--color-hover); }
.ui-table__id {
    font-family: var(--ff-mono);
    color: var(--color-text-soft);
    font-size: var(--type-xs);
}
.ui-table__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--space-1);
}
.ui-table__numeric { text-align: right; font-variant-numeric: tabular-nums; }
.ui-table__empty {
    padding: var(--space-10) var(--space-5);
    text-align: center;
    color: var(--color-text-muted);
    font-size: var(--type-sm);
}

/* ===== ui-pill ============================================================ */
.ui-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 3px var(--space-2);
    background: var(--color-hover);
    color: var(--color-text-muted);
    font-size: var(--type-xs);
    font-weight: var(--type-weight-semibold);
    border-radius: var(--radius-full);
    line-height: 1.4;
    border: 1px solid transparent;
    white-space: nowrap;
}
.ui-pill--primary {
    background: var(--color-primary-light);
    color: var(--color-primary);
    border-color: transparent;
}
.ui-pill--success {
    background: var(--color-success-light);
    color: var(--color-success);
    border-color: var(--color-success-border);
}
.ui-pill--warning {
    background: var(--color-warning-light);
    color: var(--color-warning);
    border-color: var(--color-warning-border);
}
.ui-pill--danger {
    background: var(--color-danger-light);
    color: var(--color-danger);
    border-color: var(--color-danger-border);
}
.ui-pill--neutral {
    background: var(--color-hover);
    color: var(--color-text-muted);
    border-color: var(--color-border);
}
.ui-pill__dot {
    width: 6px;
    height: 6px;
    border-radius: var(--radius-full);
    background: currentColor;
    flex: 0 0 auto;
}

/* ===== ui-notice ========================================================== */
.ui-notice {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--color-hover);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text);
    font-size: var(--type-sm);
    margin-bottom: var(--space-4);
}
.ui-notice__icon {
    flex: 0 0 auto;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
}
.ui-notice__body { flex: 1 1 auto; min-width: 0; }
.ui-notice__title {
    margin: 0 0 var(--space-1);
    font-weight: var(--type-weight-semibold);
}
.ui-notice--info {
    background: var(--color-primary-light);
    border-color: transparent;
    color: var(--color-primary-dark);
}
.ui-notice--info .ui-notice__icon { color: var(--color-primary); }
.ui-notice--success {
    background: var(--color-success-light);
    border-color: var(--color-success-border);
    color: var(--color-success);
}
.ui-notice--warning {
    background: var(--color-warning-light);
    border-color: var(--color-warning-border);
    color: var(--color-warning);
}
.ui-notice--danger {
    background: var(--color-danger-light);
    border-color: var(--color-danger-border);
    color: var(--color-danger-dark);
}

/* ===== ui-empty-state ===================================================== */
.ui-empty-state {
    padding: var(--space-10) var(--space-5);
    text-align: center;
    color: var(--color-text-muted);
}
.ui-empty-state__icon {
    color: var(--color-text-soft);
    margin: 0 auto var(--space-3);
    display: inline-flex;
    width: 48px;
    height: 48px;
    align-items: center;
    justify-content: center;
    background: var(--color-hover);
    border-radius: var(--radius-full);
}
.ui-empty-state__title {
    margin: 0 0 var(--space-1);
    font-size: var(--type-md);
    font-weight: var(--type-weight-semibold);
    color: var(--color-text);
}
.ui-empty-state__body {
    margin: 0 auto;
    max-width: 420px;
    font-size: var(--type-sm);
}
.ui-empty-state__actions {
    margin-top: var(--space-4);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
}

/* ===== ui-button ========================================================== */
.ui-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: 0 var(--space-4);
    height: var(--control-height-md);
    background: var(--color-surface);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: inherit;
    font-size: var(--type-sm);
    font-weight: var(--type-weight-medium);
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    transition: background var(--motion-fast), border-color var(--motion-fast),
                color var(--motion-fast), box-shadow var(--motion-fast);
}
.ui-button:hover {
    background: var(--color-hover);
    color: var(--color-text);
}
.ui-button:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--color-focus-ring);
}
.ui-button:disabled,
.ui-button[aria-disabled="true"] {
    opacity: 0.55;
    cursor: not-allowed;
    pointer-events: none;
}
.ui-button--primary {
    background: var(--color-primary);
    color: var(--color-on-primary);
    border-color: var(--color-primary);
}
.ui-button--primary:hover {
    background: var(--color-primary-dark);
    color: var(--color-on-primary);
    border-color: var(--color-primary-dark);
}
.ui-button--secondary {
    background: var(--color-surface);
    color: var(--color-text);
    border-color: var(--color-border);
}
.ui-button--ghost {
    background: transparent;
    border-color: transparent;
    color: var(--color-text-muted);
}
.ui-button--ghost:hover {
    background: var(--color-hover);
    color: var(--color-text);
}
.ui-button--danger {
    background: var(--color-danger);
    color: #fff;
    border-color: var(--color-danger);
}
.ui-button--danger:hover {
    background: var(--color-danger-dark);
    border-color: var(--color-danger-dark);
}
.ui-button--sm { height: var(--control-height-sm); padding: 0 var(--space-3); font-size: var(--type-xs); }
.ui-button--lg { height: var(--control-height-lg); padding: 0 var(--space-5); font-size: var(--type-base); }
.ui-button__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

/* ===== ui-iconbutton ====================================================== */
.ui-iconbutton {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--control-height-md);
    height: var(--control-height-md);
    padding: 0;
    background: transparent;
    color: var(--color-text-muted);
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background var(--motion-fast), color var(--motion-fast),
                border-color var(--motion-fast), box-shadow var(--motion-fast);
    flex: 0 0 auto;
}
.ui-iconbutton:hover {
    background: var(--color-hover);
    color: var(--color-text);
}
.ui-iconbutton:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--color-focus-ring);
}
.ui-iconbutton.is-active {
    background: var(--color-primary-light);
    color: var(--color-primary);
}
.ui-iconbutton--sm { width: var(--control-height-sm); height: var(--control-height-sm); }
.ui-iconbutton--lg { width: var(--control-height-lg); height: var(--control-height-lg); }
.ui-iconbutton--bordered { border-color: var(--color-border); background: var(--color-surface); }

/* ===== ui-input / ui-select / ui-textarea ================================= */
.ui-input,
.ui-select,
.ui-textarea {
    width: 100%;
    padding: 0 var(--space-3);
    height: var(--control-height-md);
    background: var(--color-surface);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: inherit;
    font-size: var(--type-sm);
    line-height: 1.4;
    transition: border-color var(--motion-fast), box-shadow var(--motion-fast),
                background var(--motion-fast);
}
.ui-input::placeholder,
.ui-textarea::placeholder { color: var(--color-text-soft); }
.ui-input:focus,
.ui-select:focus,
.ui-textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-focus-ring);
}
.ui-input[disabled],
.ui-select[disabled],
.ui-textarea[disabled] {
    background: var(--color-bg);
    color: var(--color-text-soft);
    cursor: not-allowed;
}
.ui-textarea {
    height: auto;
    min-height: calc(var(--control-height-md) * 2.4);
    padding: var(--space-2) var(--space-3);
    line-height: var(--type-leading-normal);
    resize: vertical;
}
.ui-select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat: no-repeat;
    background-position: right var(--space-3) center;
    background-size: 12px 12px;
    padding-right: var(--space-8);
}
.ui-input--invalid,
.ui-select--invalid,
.ui-textarea--invalid {
    border-color: var(--color-danger);
}
.ui-input--invalid:focus,
.ui-select--invalid:focus,
.ui-textarea--invalid:focus {
    box-shadow: 0 0 0 3px var(--color-danger-light);
}

/* ===== ui-form-section / ui-form-row / ui-form-actions ==================== */
.ui-form-section {
    padding: var(--space-5);
    border-bottom: 1px solid var(--color-border);
}
.ui-form-section:last-of-type { border-bottom: 0; }
.ui-form-section__title {
    margin: 0 0 var(--space-1);
    font-size: var(--type-base);
    font-weight: var(--type-weight-semibold);
    color: var(--color-text);
}
.ui-form-section__hint {
    margin: 0 0 var(--space-4);
    font-size: var(--type-sm);
    color: var(--color-text-muted);
}

.ui-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
}
.ui-form-grid--single { grid-template-columns: minmax(0, 1fr); }
@media (max-width: 720px) {
    .ui-form-grid { grid-template-columns: minmax(0, 1fr); }
}

.ui-form-row {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    min-width: 0;
}
.ui-form-row--full { grid-column: 1 / -1; }
.ui-form-row__label {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--type-xs);
    font-weight: var(--type-weight-medium);
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ui-form-row__required {
    color: var(--color-danger);
    font-weight: var(--type-weight-semibold);
}
.ui-form-row__hint {
    margin-top: var(--space-1);
    font-size: var(--type-xs);
    color: var(--color-text-muted);
}
.ui-form-row__error {
    margin-top: var(--space-1);
    font-size: var(--type-xs);
    color: var(--color-danger);
}

.ui-form-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    border-top: 1px solid var(--color-border);
    background: var(--color-surface-raised);
    position: sticky;
    bottom: 0;
}
.ui-form-actions--start { justify-content: flex-start; }
.ui-form-actions--between { justify-content: space-between; }
.ui-form-actions__hint {
    margin-right: auto;
    font-size: var(--type-xs);
    color: var(--color-text-muted);
}

/* ===== ui-checkbox ======================================================== */
.ui-checkbox {
    display: inline-flex;
    align-items: flex-start;
    gap: var(--space-2);
    cursor: pointer;
    color: var(--color-text);
    font-size: var(--type-sm);
    user-select: none;
}
.ui-checkbox__input {
    flex: 0 0 auto;
    width: 16px;
    height: 16px;
    margin: 2px 0 0;
    accent-color: var(--color-primary);
    cursor: pointer;
}
.ui-checkbox__label-text {
    line-height: var(--type-leading-normal);
}
.ui-checkbox__hint {
    display: block;
    margin-top: 2px;
    font-size: var(--type-xs);
    color: var(--color-text-muted);
}
