/* ==========================================================================
   SIGDA Custom UI Styles
   - Changelist row hover highlight (primary colors)
   - FilteredSelectMultiple widget redesign
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. CHANGELIST ROW HOVER — Destaque nas linhas da listagem
   O hover é aplicado APENAS na primeira linha (tr:first-of-type) dentro do tbody,
   que corresponde à linha de dados do registro. O segundo tr (sections/ações
   expandidas) permanece com seu estilo padrão.
   -------------------------------------------------------------------------- */

/* Desktop (lg) */
@media (min-width: 1024px) {

    /* Aplica fundo primary apenas no primeiro tr (linha de dados) */
    #result_list > tbody:hover > tr:first-of-type {
        background-color: var(--color-primary-100) !important;
    }

    /* Cor do texto nas células da linha de dados */
    #result_list > tbody:hover > tr:first-of-type > td,
    #result_list > tbody:hover > tr:first-of-type > th {
        color: var(--color-primary-700) !important;
    }

    /* Texto de elementos inline dentro das células (links, spans, etc.) —
       exceto badges/pills que têm suas próprias cores definidas por classe */
    #result_list > tbody:hover > tr:first-of-type > td > *:not([class*="bg-"]),
    #result_list > tbody:hover > tr:first-of-type > td > *:not([class*="bg-"]) * {
        color: var(--color-primary-700) !important;
    }

    /* Dark mode */
    .dark #result_list > tbody:hover > tr:first-of-type {
        background-color: color-mix(in oklab, var(--color-primary-500) 20%, transparent) !important;
    }

    .dark #result_list > tbody:hover > tr:first-of-type > td,
    .dark #result_list > tbody:hover > tr:first-of-type > th {
        color: var(--color-primary-400) !important;
    }

    .dark #result_list > tbody:hover > tr:first-of-type > td > *:not([class*="bg-"]),
    .dark #result_list > tbody:hover > tr:first-of-type > td > *:not([class*="bg-"]) * {
        color: var(--color-primary-400) !important;
    }

    /* Suaviza a transição apenas na linha de dados */
    #result_list > tbody > tr:first-of-type {
        transition: background-color 0.15s ease;
    }

    #result_list > tbody > tr:first-of-type > td,
    #result_list > tbody > tr:first-of-type > th {
        transition: color 0.15s ease;
    }

    /* Garante que o segundo tr (sections expandidas) nunca herde o fundo colorido */
    #result_list > tbody > tr:not(:first-of-type) {
        background-color: transparent !important;
    }

    /* Anula o shadow-raised do Unfold no hover para não conflitar */
    #result_list > tbody:hover {
        box-shadow: none !important;
    }
}

/* Mobile — aplica somente no primeiro tr (o único com borda visível) */
@media (max-width: 1023px) {
    #result_list > tbody:hover > tr:first-of-type {
        border-color: var(--color-primary-200) !important;
        background-color: var(--color-primary-100) !important;
    }

    .dark #result_list > tbody:hover > tr:first-of-type {
        border-color: var(--color-primary-700) !important;
        background-color: color-mix(in oklab, var(--color-primary-500) 15%, transparent) !important;
    }
}


/* --------------------------------------------------------------------------
   2. FILTERED SELECT MULTIPLE — Widget de seleção múltipla
   Estilos aplicados nas classes nativas do Django admin (.selector,
   .selector-available, .selector-chosen, etc.)
   -------------------------------------------------------------------------- */

/* Contêiner global do widget */
.selector {
    font-family: var(--font-sans, system-ui, sans-serif);
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-start;
    margin-top: 8px;
    margin-bottom: 16px;
}

/* Colunas disponível / escolhida */
.selector-available,
.selector-chosen {
    border: 1.5px solid var(--color-primary-200) !important;
    border-radius: 8px;
    overflow: hidden;
    background-color: var(--color-white, #fff);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
    min-width: 200px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.selector-available:hover,
.selector-chosen:hover {
    border-color: var(--color-primary-400) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.10);
}

/* Dark mode */
.dark .selector-available,
.dark .selector-chosen {
    border-color: color-mix(in oklab, var(--color-primary-500) 35%, transparent) !important;
    background-color: var(--color-base-900, #1a1a2e);
}

.dark .selector-available:hover,
.dark .selector-chosen:hover {
    border-color: var(--color-primary-500) !important;
}

/* Títulos das colunas (Disponível / Escolhido) */
.selector-available h2,
.selector-chosen h2,
.selector-available-title,
.selector-chosen-title {
    background-color: var(--color-primary-100) !important;
    color: var(--color-primary-700) !important;
    font-weight: 600 !important;
    font-size: 0.82rem !important;
    letter-spacing: 0.02em;
    text-transform: capitalize !important; /* Primeira letra maiúscula, não tudo em caps */
    padding: 8px 12px !important;
    margin: 0 !important;
    border-bottom: 1.5px solid var(--color-primary-200) !important;
}

.dark .selector-available h2,
.dark .selector-chosen h2,
.dark .selector-available-title,
.dark .selector-chosen-title {
    background-color: color-mix(in oklab, var(--color-primary-500) 20%, transparent) !important;
    color: var(--color-primary-400) !important;
    border-bottom-color: color-mix(in oklab, var(--color-primary-500) 30%, transparent) !important;
}

/* Helptext (subtexto "Escolha os itens e clique no botão...") —
   sem fundo colorido, texto normal sem maiúsculas,
   separado do título por uma linha sutil e mais compacto */
.selector .helptext {
    display: block;
    text-transform: none !important;
    font-size: 0.75rem !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    color: var(--color-font-subtle-light, var(--color-base-500)) !important;
    background-color: transparent !important;
    padding: 4px 12px 6px !important;
    margin: 0 !important;
    border-top: 1px dashed var(--color-primary-200) !important;
    line-height: 1.4;
}

.dark .selector .helptext {
    color: var(--color-font-subtle-dark, var(--color-base-400)) !important;
    border-top-color: color-mix(in oklab, var(--color-primary-500) 25%, transparent) !important;
    background-color: transparent !important;
}

/* Lista select (o <select> múltiplo em si) */
.selector select {
    border: none !important;
    border-radius: 0 !important;
    outline: none !important;
    background-color: transparent !important;
    width: 100% !important;
    min-height: 160px;
    font-size: 0.875rem;
    color: var(--color-font-default-light, #374151);
    padding: 4px 0;
}

.dark .selector select {
    color: var(--color-font-default-dark, #d1d5db);
}

/* Item selecionado — linear-gradient força o fundo primary (único método
   confiável cross-browser). Para o texto, usamos TAMBÉM -webkit-text-fill-color
   pois o Chrome ignora a propriedade `color` em option:checked com renderização
   nativa do sistema operacional. */
.selector select option:checked,
.selector select option:checked:focus,
.selector select option:checked:active,
.selector select option:focus {
    background: linear-gradient(
        var(--color-primary-100),
        var(--color-primary-100)
    ) !important;
    color: var(--color-primary-700) !important;
    -webkit-text-fill-color: var(--color-primary-700) !important;
}

/* Dark mode — fundo opaco primary-900 + texto primary-300 legível */
.dark .selector select option:checked,
.dark .selector select option:checked:focus,
.dark .selector select option:checked:active,
.dark .selector select option:focus {
    background: linear-gradient(
        var(--color-primary-900),
        var(--color-primary-900)
    ) !important;
    color: var(--color-primary-300) !important;
    -webkit-text-fill-color: var(--color-primary-300) !important;
}

/* accent-color para navegadores que respeitam o highlight nativo.
   NÃO definimos color-scheme pois isso faz o Chrome usar cores do sistema
   para selected items, interferindo no nosso override. */
.selector select {
    accent-color: var(--color-primary-600);
}

/* Campo de filtro/busca dentro do widget */
.selector .selector-filter {
    padding: 6px 10px !important;
    background-color: var(--color-base-50, #f9fafb) !important;
    border-bottom: 1px solid var(--color-primary-100) !important;
}

.dark .selector .selector-filter {
    background-color: var(--color-base-800, #1f2937) !important;
    border-bottom-color: color-mix(in oklab, var(--color-primary-500) 20%, transparent) !important;
}

.selector-filter input {
    border: 1px solid var(--color-base-200) !important;
    border-radius: 6px !important;
    padding: 4px 8px !important;
    font-size: 0.85rem !important;
    width: calc(100% - 20px) !important;
    background-color: var(--color-white, #fff) !important;
    color: var(--color-font-default-light) !important;
}

.dark .selector-filter input {
    border-color: var(--color-base-700) !important;
    background-color: var(--color-base-900) !important;
    color: var(--color-font-default-dark) !important;
}

.selector-filter input:focus {
    border-color: var(--color-primary-400) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px color-mix(in oklab, var(--color-primary-500) 20%, transparent) !important;
}

/* Coluna do meio — botões de arrow */
ul.selector-chooser {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    align-self: center;
}

.selector-chooser li {
    margin: 0 !important;
}

/* Botões de seleção (→) e remoção (←) */
.selector-add,
.selector-remove,
:enabled.selector-add,
:enabled.selector-remove {
    border-radius: 6px !important;
    border: 1.5px solid var(--color-primary-300) !important;
    background-color: var(--color-primary-100) !important;
    transition: background-color 0.15s ease, border-color 0.15s ease, transform 0.1s ease !important;
    width: 28px !important;
    height: 28px !important;
    cursor: pointer !important;
}

:enabled.selector-add:hover,
:enabled.selector-remove:hover {
    background-color: var(--color-primary-600) !important;
    border-color: var(--color-primary-600) !important;
    transform: scale(1.1) !important;
    filter: brightness(1.1) invert(1) !important;
}

.dark .selector-add,
.dark .selector-remove,
.dark :enabled.selector-add,
.dark :enabled.selector-remove {
    border-color: color-mix(in oklab, var(--color-primary-500) 40%, transparent) !important;
    background-color: color-mix(in oklab, var(--color-primary-500) 15%, transparent) !important;
    filter: invert(1) brightness(1.5) !important;
}

.dark :enabled.selector-add:hover,
.dark :enabled.selector-remove:hover {
    background-color: var(--color-primary-700) !important;
    border-color: var(--color-primary-500) !important;
    filter: invert(0) brightness(1) !important;
}

/* Botões "Escolher todos" / "Remover todos" —
   fundo neutro (base), texto na mesma cor do título (primary-700) */
.selector-chooseall,
.selector-clearall,
:enabled.selector-chooseall,
:enabled.selector-clearall {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    padding: 4px 10px !important;
    border-radius: 6px !important;
    border: 1px solid var(--color-base-200) !important;
    background-color: var(--color-white, #fff) !important;
    color: var(--color-primary-700) !important;
    cursor: pointer !important;
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease !important;
    text-decoration: none !important;
    width: auto !important;
}

:enabled.selector-chooseall:hover,
:enabled.selector-clearall:hover {
    background-color: var(--color-primary-50) !important;
    border-color: var(--color-primary-300) !important;
    color: var(--color-primary-700) !important;
}

.dark .selector-chooseall,
.dark .selector-clearall,
.dark :enabled.selector-chooseall,
.dark :enabled.selector-clearall {
    background-color: var(--color-base-800) !important;
    color: var(--color-primary-400) !important;
    border-color: var(--color-base-700) !important;
}

.dark :enabled.selector-chooseall:hover,
.dark :enabled.selector-clearall:hover {
    background-color: var(--color-base-700) !important;
    border-color: color-mix(in oklab, var(--color-primary-500) 40%, transparent) !important;
    color: var(--color-primary-300) !important;
}

/* Rodapé da coluna "escolhidos" com total */
.selector-chosen .list-footer-display {
    background-color: var(--color-primary-50, #f5f3ff) !important;
    border-top: 1px solid var(--color-primary-100) !important;
    padding: 4px 10px !important;
    font-size: 0.78rem;
    color: var(--color-primary-700) !important;
}

.dark .selector-chosen .list-footer-display {
    background-color: color-mix(in oklab, var(--color-primary-500) 10%, transparent) !important;
    border-top-color: color-mix(in oklab, var(--color-primary-500) 20%, transparent) !important;
    color: var(--color-primary-400) !important;
}

/* Stacked layout (vertical) */
.stacked .selector-available,
.stacked .selector-chosen {
    width: 100% !important;
}

select.filtered[id$="_from"],
select.filtered[id$="_to"] {
    content-visibility: auto;
    contain: layout style paint;
    contain-intrinsic-size: 1px 5000px;
}
