/* =============================================================================
 * ui.css — apenas o que Tailwind direto não cobre.
 * =============================================================================
 *
 * Tokens de cor vivem em design-system.css (4 brand vars + 11 slates).
 * Paletas semânticas (red/emerald/amber/sky/violet) são usadas via classes
 * Tailwind no HTML — não devem ser tokenizadas aqui.
 *
 * Permitido aqui:
 *   1. Reset/base + scrollbar + is-invalid + input[type=number]
 *   2. Layout (workspace-shell, sidebar, submenu drawer, transitions)
 *   3. Gradientes 3D (pm-btn-*, pm-toast-*, overrides em bg-primary-6 e bg-white+border)
 *   4. Animações/keyframes (pm-stagger, pm-toast-drain, pm-dropdown-in, slideIn)
 *   5. Pseudo-elementos (ui-timeline ::after/::before, submenu-drawer ::after)
 *   6. Componentes com selector lógico (ui-switch :checked sibling, sidebar.pm-active)
 *
 * NÃO permitido:
 *   - Variantes de cor que Tailwind já dá (badge-success, table-action-edit, etc.)
 *   - Hex semânticos sem comentário de paleta (red-500, emerald-600, etc.)
 *   - Tokens CSS com nome custom para algo que vem da paleta Tailwind
 *
 * Convenções:
 *   - Brand-aware:    var(--brand-primary | hover | contrast | soft)
 *   - Slate (neutro): rgb(var(--slate-X) / <alpha>)
 *   - Semântico fixo: hex Tailwind COM comentário identificando a paleta
 *                     (ex.: red-500, emerald-600, sky-500)
 * ========================================================================== */

html {
    scroll-behavior: smooth;
}

:root {
    --ui-header-height: 4rem;
    --ui-sidebar-open-width: 14rem;
    --ui-sidebar-collapsed-width: 5rem;
    --ui-sidebar-current-width: var(--ui-sidebar-open-width);
    --premium-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

body.sidebar-collapsed {
    --ui-sidebar-current-width: var(--ui-sidebar-collapsed-width);
}

body {
    text-rendering: optimizeLegibility;
}

::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: rgb(var(--slate-300) / 1);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

::-webkit-scrollbar-thumb:hover {
    background: rgb(var(--slate-400) / 1);
}

.dark ::-webkit-scrollbar-thumb {
    background: rgb(var(--slate-600) / 1);
}

.global-page-loader {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgb(var(--slate-50) / 0.85);
    backdrop-filter: blur(8px) saturate(140%);
    transition: opacity 0.2s ease, visibility 0.2s ease;
}

.dark .global-page-loader {
    background: rgb(var(--slate-900) / 0.82);
}

.global-page-loader.hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.global-page-loader__box {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.875rem;
    padding: 0;
    color: rgb(var(--slate-500) / 1);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dark .global-page-loader__box {
    color: rgb(var(--slate-300) / 1);
}

.global-page-loader__spinner {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 9999px;
    border: 2px solid rgb(var(--slate-300) / 0.24);
    border-top-color: var(--brand-primary);
    border-right-color: color-mix(in srgb, var(--brand-primary) 56%, transparent);
    animation: global-loader-spin 0.8s linear infinite;
}

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

main[class*="bg-slate-50"],
main[class*="bg-slate-50"] > .flex-1[class*="bg-slate-50"] {
    background-color: rgb(var(--slate-100) / 1) !important;
    background-image: none !important;
}

.dark main[class*="dark:bg-slate-900"],
.dark main[class*="dark:bg-slate-900"] > .flex-1[class*="dark:bg-slate-900"] {
    background-color: rgb(var(--slate-900) / 1) !important;
    background-image: none !important;
}

button,
a,
input,
select,
textarea {
    transition: background-color 150ms var(--premium-ease),
        border-color 150ms var(--premium-ease),
        box-shadow 150ms var(--premium-ease),
        color 150ms var(--premium-ease),
        transform 150ms var(--premium-ease);
}

header.bg-white.dark\:bg-slate-800.border-b,
.dropdown-menu {
    backdrop-filter: saturate(140%) blur(8px);
}

input.is-invalid,
select.is-invalid,
textarea.is-invalid {
    border-color: #ef4444 !important; /* red-500 */
}

input[type="number"] {
    appearance: textfield;
    -moz-appearance: textfield;
}

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input.is-invalid:focus,
select.is-invalid:focus,
textarea.is-invalid:focus {
    border-color: #ef4444 !important;                            /* red-500 */
    --tw-ring-color: rgb(239 68 68 / 0.45) !important;           /* red-500 / 0.45 */
    outline: none !important;
    box-shadow: 0 0 0 2px rgb(239 68 68 / 0.32) !important;      /* red-500 / 0.32 */
}

.dark input.is-invalid,
.dark select.is-invalid,
.dark textarea.is-invalid,
.dark input.is-invalid:focus,
.dark select.is-invalid:focus,
.dark textarea.is-invalid:focus {
    border-color: #f87171 !important;                            /* red-400 */
    --tw-ring-color: rgb(248 113 113 / 0.36) !important;         /* red-400 / 0.36 */
    outline: none !important;
    box-shadow: 0 0 0 2px rgb(248 113 113 / 0.28) !important;    /* red-400 / 0.28 */
}

.dropdown-menu:not(.hidden) {
    animation: pm-dropdown-in 0.15s var(--premium-ease) both;
    transform-origin: top right;
}

@keyframes pm-dropdown-in {
    from { opacity: 0; transform: scale(0.95) translateY(-4px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}

.pm-btn-primary {
    background-image: linear-gradient(180deg, var(--brand-primary), var(--brand-hover));
    border: 1px solid var(--brand-primary);
    box-shadow: none !important;
}

.pm-btn-primary:hover {
    background-image: linear-gradient(180deg, var(--brand-hover), var(--brand-contrast));
    border-color: var(--brand-hover);
    filter: none;
    transform: none;
}

.pm-btn-primary:active {
    background-image: none;
    transform: translateY(1px);
}

/* Botão Danger 3D — paleta red (semântico fixo, não brand-aware). */
.pm-btn-danger {
    background-color: #dc2626;                                                /* red-600 */
    background-image: linear-gradient(180deg, #ef4444, #dc2626);              /* red-500 → red-600 */
    border: 1px solid #ef4444;                                                /* red-500 */
    box-shadow: none !important;
}

.pm-btn-danger:hover {
    background-image: linear-gradient(180deg, #dc2626, #b91c1c);              /* red-600 → red-700 */
    transform: none;
}

.pm-btn-danger:active {
    background-image: none;
    transform: translateY(1px);
}

.dark .pm-btn-danger {
    background-image: linear-gradient(180deg, #ef4444, #b91c1c);              /* red-500 → red-700 */
}

.dark .pm-btn-danger:hover {
    background-image: linear-gradient(180deg, #dc2626, #991b1b);              /* red-600 → red-800 */
}

.ui-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
}

.ui-switch-input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

.ui-switch-track {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: 2.75rem;
    height: 1.5rem;
    flex-shrink: 0;
    border-radius: 9999px;
    background-color: rgb(var(--slate-300) / 1);
    transition: background-color 150ms var(--premium-ease), box-shadow 150ms var(--premium-ease);
}

.ui-switch-thumb {
    position: absolute;
    left: 0.125rem;
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 9999px;
    background-color: #fff;
    box-shadow: none;
    transition: transform 150ms var(--premium-ease);
}

.ui-switch-input:checked + .ui-switch-track {
    background-color: var(--brand-hover);
}

.ui-switch-input:checked + .ui-switch-track .ui-switch-thumb {
    transform: translateX(1.25rem);
}

.ui-switch-input:focus-visible + .ui-switch-track {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-primary) 28%, transparent);
}

.ui-switch-input:disabled + .ui-switch-track,
.ui-switch[aria-disabled="true"] .ui-switch-track {
    opacity: 0.55;
    cursor: not-allowed;
}

.dark .ui-switch-track {
    background-color: rgb(var(--slate-600) / 1);
}

.dark .ui-switch-input:checked + .ui-switch-track {
    background-color: var(--brand-primary);
}

/* Variant: small size — usado em controles auxiliares (limit per row, etc.).
   Track 36×20 (w-9 h-5), thumb 16×16 (h-4 w-4). */
.ui-switch--sm .ui-switch-track {
    width: 2.25rem;
    height: 1.25rem;
}

.ui-switch--sm .ui-switch-thumb {
    width: 1rem;
    height: 1rem;
}

.ui-switch--sm .ui-switch-input:checked + .ui-switch-track .ui-switch-thumb {
    transform: translateX(1rem);
}

button[class*="bg-primary-6"],
a[class*="bg-primary-6"] {
    background-image: linear-gradient(180deg, var(--brand-primary), var(--brand-hover));
    border: 1px solid var(--brand-primary);
    box-shadow: none !important;
}

button[class*="bg-primary-6"]:hover,
a[class*="bg-primary-6"]:hover {
    background-image: linear-gradient(180deg, var(--brand-hover), var(--brand-contrast));
    border-color: var(--brand-hover);
    box-shadow: none !important;
}

button[class*="bg-primary-6"]:active,
a[class*="bg-primary-6"]:active {
    background-image: none;
    transform: translateY(1px);
}

button[class*="bg-primary-6"]:disabled,
button[class*="bg-primary-6"][disabled],
button[class*="bg-primary-6"].disabled,
a[class*="bg-primary-6"][aria-disabled="true"] {
    background-image: none;
    transform: none;
    box-shadow: none !important;
}

button[class*="bg-white"][class*="border"],
a[class*="bg-white"][class*="border"],
button[class*="border-slate-200"],
a[class*="border-slate-200"] {
    background-color: rgb(255 255 255 / 1);
    background-image: linear-gradient(
        to bottom,
        rgb(255 255 255 / 1) 0%,
        rgb(var(--slate-50) / 1) 100%
    );
    box-shadow: none !important;
}

button[class*="bg-white"][class*="border"]:hover,
a[class*="bg-white"][class*="border"]:hover,
button[class*="border-slate-200"]:hover,
a[class*="border-slate-200"]:hover {
    background-image: linear-gradient(
        to bottom,
        rgb(var(--slate-50) / 1) 0%,
        rgb(var(--slate-100) / 1) 100%
    );
    box-shadow: none !important;
}

button[class*="bg-white"][class*="border"]:active,
a[class*="bg-white"][class*="border"]:active,
button[class*="border-slate-200"]:active,
a[class*="border-slate-200"]:active {
    background-image: none;
    transform: translateY(1px);
}

button[class*="bg-white"][class*="border"]:disabled,
button[class*="bg-white"][class*="border"][disabled],
button[class*="border-slate-200"]:disabled,
button[class*="border-slate-200"][disabled],
a[class*="bg-white"][class*="border"][aria-disabled="true"],
a[class*="border-slate-200"][aria-disabled="true"] {
    background-image: none;
    transform: none;
    box-shadow: none !important;
}

.dark button[class*="bg-white"][class*="border"],
.dark a[class*="bg-white"][class*="border"],
.dark button[class*="border-slate-200"],
.dark a[class*="border-slate-200"] {
    background-color: transparent;
    background-image: linear-gradient(
        to bottom,
        rgb(255 255 255 / 0.06) 0%,
        rgb(0 0 0 / 0.10) 100%
    );
}

.dark button[class*="bg-white"][class*="border"]:hover,
.dark a[class*="bg-white"][class*="border"]:hover,
.dark button[class*="border-slate-200"]:hover,
.dark a[class*="border-slate-200"]:hover {
    background-image: linear-gradient(
        to bottom,
        rgb(255 255 255 / 0.10) 0%,
        rgb(0 0 0 / 0.14) 100%
    );
}

.pm-brand-soft,
.pm-brand-avatar,
.pm-option-selected {
    background-color: var(--brand-soft) !important;
}

.dark .pm-brand-soft,
.dark .pm-brand-avatar,
.dark .pm-option-selected {
    background-color: color-mix(in srgb, var(--brand-contrast) 24%, transparent) !important;
}

.pm-brand-avatar {
    border: 1px solid color-mix(in srgb, var(--brand-primary) 24%, transparent);
    box-shadow: none !important;
}

.dark .pm-brand-avatar {
    background-color: rgb(var(--slate-800) / 1) !important;
    border-color: color-mix(in srgb, var(--brand-primary) 28%, transparent);
    box-shadow: none !important;
}

.ui-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 9999px;
    border: 1px solid transparent;
    padding: 0.125rem 0.625rem;
    font-size: 0.75rem;
    line-height: 1rem;
    font-weight: 500;
}

/* Variantes coloridas de .ui-badge foram REMOVIDAS desta folha.
   Aplicar a cor diretamente via classes Tailwind no HTML, mantendo .ui-badge
   como classe estrutural (forma/padding/tipografia). Exemplos canônicos:

   success : bg-emerald-100 text-emerald-700 border-emerald-500/20
             dark:bg-emerald-900/40 dark:text-emerald-300 dark:border-emerald-400/20
   danger  : bg-red-100 text-red-700 border-red-500/20
             dark:bg-red-900/40 dark:text-red-300 dark:border-red-400/20
   warning : bg-amber-100 text-amber-700 border-amber-500/25
             dark:bg-amber-900/40 dark:text-amber-300 dark:border-amber-400/25
   info    : bg-sky-100 text-sky-700 border-sky-500/20
             dark:bg-sky-900/40 dark:text-sky-300 dark:border-sky-400/20
   edit    : bg-violet-100 text-violet-700 border-violet-500/20
             dark:bg-violet-900/40 dark:text-violet-300 dark:border-violet-400/25
   brand   : bg-primary-50 text-primary-700 border-primary-500/25
             dark:bg-primary-900/30 dark:text-primary-400 dark:border-primary-400/30
   neutral : bg-slate-200 text-slate-700 border-slate-300/70
             dark:bg-slate-700 dark:text-slate-200 dark:border-slate-600/70
   muted   : bg-slate-100 text-slate-500 border-slate-200/90
             dark:bg-slate-800 dark:text-slate-400 dark:border-slate-700/90
*/

.ui-timeline {
    position: relative;
    display: grid;
    gap: 1rem;
    padding-left: 3.5rem;
}

.ui-timeline-item {
    position: relative;
}

.ui-timeline-item:not(:last-child)::after {
    content: "";
    position: absolute;
    left: -2.5rem;
    top: 2rem;
    width: 1px;
    height: calc(100% + 1rem);
    background-color: rgb(var(--slate-300) / 0.72);
}

.dark .ui-timeline-item:not(:last-child)::after {
    background-color: rgb(var(--slate-600) / 0.72);
}

.ui-timeline-icon {
    position: absolute;
    left: -3.5rem;
    top: 1rem;
    z-index: 1;
    display: inline-flex;
    height: 2rem;
    width: 2rem;
    align-items: center;
    justify-content: center;
    border-radius: 9999px;
    border: 1px solid transparent;
    background-color: rgb(var(--slate-100) / 1);
    color: rgb(var(--slate-500) / 1);
}

.dark .ui-timeline-icon {
    background-color: rgb(var(--slate-800) / 1);
    color: rgb(var(--slate-400) / 1);
}

.ui-timeline-card {
    position: relative;
    border-radius: 1rem;
    border: 1px solid rgb(var(--slate-200) / 1);
    background-color: rgb(255 255 255 / 1);
    padding: 1rem;
}

.ui-timeline-card::before {
    content: "";
    position: absolute;
    left: -2.5rem;
    top: 2rem;
    width: 2.5rem;
    height: 1px;
    background-color: rgb(var(--slate-200) / 1);
}

.ui-timeline-card-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
    gap: 0.5rem;
    align-items: start;
}

.ui-timeline-message {
    margin-top: 0.625rem;
    font-size: 0.875rem;
    line-height: 1.25rem;
    font-weight: 500;
    color: rgb(var(--slate-700) / 1);
}

.dark .ui-timeline-message {
    color: rgb(var(--slate-200) / 1);
}

.ui-timeline-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.875rem;
}

.ui-timeline-control-row {
    margin-top: 0.875rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.ui-timeline-toggle-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border-radius: 0.75rem;
    border: 1px solid rgb(var(--slate-300) / 0.85);
    background-color: rgb(255 255 255 / 0.7);
    padding: 0.375rem 0.75rem;
    color: rgb(var(--slate-600) / 1);
}

.dark .ui-timeline-toggle-chip {
    border-color: rgb(var(--slate-600) / 0.85);
    background-color: rgb(var(--slate-900) / 0.45);
    color: rgb(var(--slate-300) / 1);
}

.ui-timeline-toggle-chip .ui-switch-track {
    height: 1.25rem;
    width: 2.25rem;
}

.ui-timeline-toggle-chip .ui-switch-thumb {
    left: 0.125rem;
    top: 0.125rem;
    height: 1rem;
    width: 1rem;
}

.ui-timeline-toggle-chip .ui-switch-input:checked + .ui-switch-track .ui-switch-thumb {
    transform: translateX(1rem);
}

.ui-timeline-action-group {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    margin-left: auto;
}

.ui-timeline-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 2.25rem;
    width: 2.25rem;
    border-radius: 0.75rem;
    border: 1px solid rgb(var(--slate-300) / 0.85);
    background-color: rgb(255 255 255 / 0.7);
}

.dark .ui-timeline-action-btn {
    border-color: rgb(var(--slate-600) / 0.85);
    background-color: rgb(var(--slate-900) / 0.45);
}

.dark .ui-timeline-card {
    border-color: rgb(var(--slate-700) / 1);
    background-color: rgb(var(--slate-900) / 1);
}

.dark .ui-timeline-card::before {
    background-color: rgb(var(--slate-700) / 1);
}

.ui-timeline-date {
    display: inline-flex;
    flex: none;
    align-items: center;
    border-radius: 9999px;
    border: 1px solid rgb(var(--slate-200) / 1);
    background-color: rgb(var(--slate-50) / 1);
    padding: 0.125rem 0.625rem;
    font-size: 0.75rem;
    line-height: 1rem;
    font-weight: 500;
    color: rgb(var(--slate-500) / 1);
    white-space: nowrap;
}

.dark .ui-timeline-date {
    border-color: rgb(var(--slate-700) / 1);
    background-color: rgb(var(--slate-800) / 1);
    color: rgb(var(--slate-300) / 1);
}

/* Variantes semânticas de timeline (info/edit/warning) foram REMOVIDAS.
   Aplicar via Tailwind direto nos sub-elementos. A variante BRAND permanece
   abaixo porque consome var(--brand-*) (white-label). Padrão por variante:

   info    icon  : bg-sky-100 text-sky-700 border-sky-500/25
                   dark:bg-sky-900/40 dark:text-sky-300 dark:border-sky-400/25
           card  : bg-sky-50 border-sky-500/20 before:bg-sky-500/25
                   dark:bg-sky-900/25 dark:border-sky-400/25 dark:before:bg-sky-400/25
           date  : bg-sky-100 text-sky-700 border-sky-500/25
                   dark:bg-sky-900/40 dark:text-sky-300 dark:border-sky-400/25

   edit    : trocar `sky` por `violet` na lista acima
   warning : trocar `sky` por `amber` na lista acima
*/

.ui-timeline-item-brand .ui-timeline-icon {
    border-color: color-mix(in srgb, var(--brand-primary) 24%, transparent);
    background-color: var(--brand-soft);
    color: var(--brand-contrast);
}

.ui-timeline-item-brand .ui-timeline-card {
    border-color: color-mix(in srgb, var(--brand-primary) 28%, transparent);
    background-color: color-mix(in srgb, var(--brand-soft) 54%, white);
}

.ui-timeline-item-brand .ui-timeline-card::before {
    background-color: color-mix(in srgb, var(--brand-primary) 28%, transparent);
}

.ui-timeline-item-brand .ui-timeline-date {
    background-color: var(--brand-soft);
    border-color: color-mix(in srgb, var(--brand-primary) 24%, transparent);
    color: var(--brand-contrast);
}

.dark .ui-timeline-item-brand .ui-timeline-icon {
    border-color: color-mix(in srgb, var(--brand-primary) 28%, transparent);
    background-color: color-mix(in srgb, var(--brand-contrast) 24%, transparent);
    color: var(--brand-primary);
}

.dark .ui-timeline-item-brand .ui-timeline-card {
    border-color: color-mix(in srgb, var(--brand-primary) 32%, transparent);
    background-color: color-mix(in srgb, var(--brand-contrast) 18%, rgb(var(--slate-900)));
}

.dark .ui-timeline-item-brand .ui-timeline-card::before {
    background-color: color-mix(in srgb, var(--brand-primary) 32%, transparent);
}

.dark .ui-timeline-item-brand .ui-timeline-date {
    background-color: color-mix(in srgb, var(--brand-contrast) 24%, transparent);
    border-color: color-mix(in srgb, var(--brand-primary) 28%, transparent);
    color: var(--brand-primary);
}

@media (max-width: 640px) {
    .ui-timeline-card-header {
        grid-template-columns: 1fr;
    }
}

/* Ícones de ação em tabelas foram REMOVIDOS desta folha.
   Aplicar via Tailwind direto no HTML do <button>:

   neutral : text-slate-400 hover:text-slate-700 dark:hover:text-slate-200
   edit    : text-slate-400 hover:text-violet-600 dark:hover:text-violet-400
   info    : text-slate-400 hover:text-sky-600    dark:hover:text-sky-400
   success : text-slate-400 hover:text-emerald-600 dark:hover:text-emerald-400
   warning : text-slate-400 hover:text-amber-600  dark:hover:text-amber-400
   danger  : text-slate-400 hover:text-red-600    dark:hover:text-red-400
*/

.pm-toast {
    position: relative;
    overflow: hidden;
    border: 1px solid transparent;
    box-shadow: none !important;
}

.pm-toast-icon {
    background-color: rgb(255 255 255 / 0.16);
    color: #ffffff;
}

.dark .pm-toast-icon {
    background-color: rgb(255 255 255 / 0.14);
}

.pm-toast-close {
    color: #ffffff;
    opacity: 0.78;
}

.pm-toast-close:hover,
.pm-toast-close:focus-visible {
    background-color: rgb(255 255 255 / 0.16);
    opacity: 1;
}

.dark .pm-toast-close:hover,
.dark .pm-toast-close:focus-visible {
    background-color: rgb(255 255 255 / 0.14);
}

/* Toasts 3D — paletas semânticas fixas (NÃO brand-aware).
   Mantidos em CSS porque Tailwind classe direta não dá linear-gradient brand-aware
   em variantes de cor. Hex são da paleta Tailwind padrão. */

.pm-toast-success {                                                /* emerald */
    background-color: #059669;                                     /* emerald-600 */
    background-image: linear-gradient(180deg, #10b981, #059669);   /* emerald-500 → 600 */
    border-color: #10b981;                                         /* emerald-500 */
    color: #ffffff;
}

.dark .pm-toast-success {
    background-color: #047857;                                     /* emerald-700 */
    background-image: linear-gradient(180deg, #059669, #047857);   /* emerald-600 → 700 */
    border-color: #10b981;                                         /* emerald-500 */
    color: #ffffff;
}

.pm-toast-danger {                                                 /* red */
    background-color: #dc2626;                                     /* red-600 */
    background-image: linear-gradient(180deg, #ef4444, #dc2626);   /* red-500 → 600 */
    border-color: #ef4444;                                         /* red-500 */
    color: #ffffff;
}

.dark .pm-toast-danger {
    background-color: #b91c1c;                                     /* red-700 */
    background-image: linear-gradient(180deg, #dc2626, #b91c1c);   /* red-600 → 700 */
    border-color: #ef4444;                                         /* red-500 */
    color: #ffffff;
}

.pm-toast-warning {                                                /* amber */
    background-color: #d97706;                                     /* amber-600 */
    background-image: linear-gradient(180deg, #f59e0b, #d97706);   /* amber-500 → 600 */
    border-color: #f59e0b;                                         /* amber-500 */
    color: #ffffff;
}

.dark .pm-toast-warning {
    background-color: #b45309;                                     /* amber-700 */
    background-image: linear-gradient(180deg, #d97706, #b45309);   /* amber-600 → 700 */
    border-color: #f59e0b;                                         /* amber-500 */
    color: #ffffff;
}

.pm-toast-info {                                                   /* sky */
    background-color: #0284c7;                                     /* sky-600 */
    background-image: linear-gradient(180deg, #0ea5e9, #0284c7);   /* sky-500 → 600 */
    border-color: #0ea5e9;                                         /* sky-500 */
    color: #ffffff;
}

.dark .pm-toast-info {
    background-color: #0369a1;                                     /* sky-700 */
    background-image: linear-gradient(180deg, #0284c7, #0369a1);   /* sky-600 → 700 */
    border-color: #38bdf8;                                         /* sky-400 */
    color: #ffffff;
}

.dark .tippy-box[data-theme~='light-border'] {
    background-color: #ffffff;
    color: rgb(var(--slate-700) / 1);
    border: 1px solid rgb(var(--slate-200) / 1);
}

.dark .tippy-box[data-theme~='light-border'] .tippy-arrow {
    color: #ffffff;
}

.pm-toast-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    width: 100%;
    border-radius: 0 0 0.5rem 0.5rem;
    background: rgb(255 255 255 / 0.62);
    opacity: 1;
    transform-origin: left;
    animation: pm-toast-drain 5s linear forwards;
}

@keyframes pm-toast-drain {
    from { transform: scaleX(1); }
    to { transform: scaleX(0); }
}

.workspace-shell {
    display: grid !important;
    grid-template-columns: var(--ui-sidebar-current-width) minmax(0, 1fr);
    grid-template-rows: var(--ui-header-height) minmax(0, 1fr);
    transition: grid-template-columns 0.32s var(--premium-ease);
}

.workspace-shell > .workspace-topbar {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
}

.workspace-shell > .sidebar-shell {
    grid-column: 1;
    grid-row: 1 / span 2;
    width: var(--ui-sidebar-current-width);
    min-width: var(--ui-sidebar-current-width);
    max-width: var(--ui-sidebar-current-width);
    transition: width 0.32s var(--premium-ease), min-width 0.32s var(--premium-ease), max-width 0.32s var(--premium-ease);
    position: relative;
    z-index: 30;
    background-color: rgb(var(--slate-50) / 1);
    border-right: 1px solid rgb(var(--slate-200) / 1);
}

.dark .workspace-shell > .sidebar-shell {
    background-color: rgb(var(--slate-900) / 1);
    border-right-color: rgb(var(--slate-700) / 0.6);
}

.sidebar-nav {
    width: 100% !important;
    transition: width 0.32s var(--premium-ease);
}

.sidebar-nav .sidebar-section-title {
    opacity: 1;
    max-height: 2rem;
    overflow: hidden;
    transition: opacity 0.14s ease, max-height 0.14s ease, margin 0.14s ease, padding 0.14s ease;
}

.sidebar-child-link {
    padding-left: 0.625rem;
}

.sidebar-child-link .sidebar-label {
    font-size: 0.92rem;
}

.sidebar-child-link i,
.sidebar-child-link .lucide,
.sidebar-child-link svg {
    flex-shrink: 0;
}

.sidebar-collapsed .sidebar-nav .sidebar-section-title {
    opacity: 0;
    max-height: 0;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    pointer-events: none;
}

.sidebar-submenu-chevron {
    transition: none;
    transform: none !important;
}

.sidebar-collapsed .sidebar-submenu-chevron {
    display: none !important;
}

.pm-submenu-drawer {
    position: absolute;
    top: 0;
    right: auto;
    bottom: 0;
    left: 100%;
    width: 15.5rem;
    max-height: none;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    border: 0;
    border-radius: 0;
    background: rgb(255 255 255 / 1);
    backdrop-filter: none;
    box-shadow: none;
    padding: 0;
    z-index: 31;
    opacity: 0;
    transform: translateX(-18px);
    pointer-events: none;
    transition: opacity 0.22s ease, transform 0.3s var(--premium-ease);
    will-change: opacity, transform;
}

.pm-submenu-drawer.pm-submenu-open {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

.pm-submenu-drawer::after {
    content: "";
    position: absolute;
    top: 0;
    right: -14px;
    bottom: 0;
    width: 14px;
    pointer-events: none;
    background: linear-gradient(
        to right,
        rgb(15 23 42 / 0.18) 0%,
        rgb(15 23 42 / 0.08) 42%,
        transparent 100%
    );
}

.pm-submenu-backdrop {
    position: fixed;
    inset: 0;
    z-index: 25;
    background: rgb(15 23 42 / 0.16);
    backdrop-filter: blur(1px);
}

.dark .pm-submenu-backdrop {
    background: rgb(2 6 23 / 0.26);
}

.dark .pm-submenu-drawer {
    background: rgb(var(--slate-800) / 1);
    box-shadow: none;
}

.dark .pm-submenu-drawer::after {
    background: linear-gradient(
        to right,
        rgb(2 6 23 / 0.3) 0%,
        rgb(2 6 23 / 0.16) 42%,
        transparent 100%
    );
}

.pm-submenu-drawer-header {
    flex: 0 0 auto;
    padding: 1.15rem 0.75rem 0.2rem;
    background: transparent;
}

.dark .pm-submenu-drawer-header {
    background: transparent;
}

.pm-submenu-drawer-nav {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 0 0.75rem 0.9rem;
}

.pm-submenu-drawer .sidebar-child-link {
    height: 2.75rem;
    padding-left: 1rem;
    padding-right: 1rem;
}

.pm-submenu-drawer-title {
    margin: 0;
    padding: 0.25rem 0.75rem 0.35rem;
}

.sidebar-collapsed .sidebar-nav .sidebar-link {
    justify-content: center;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.sidebar-collapsed .sidebar-nav .sidebar-link i,
.sidebar-collapsed .sidebar-nav .sidebar-link .lucide,
.sidebar-collapsed .sidebar-nav .sidebar-link svg {
    margin-right: 0 !important;
}

.sidebar-collapsed .sidebar-nav .sidebar-brand a {
    justify-content: center;
}

.sidebar-collapsed .sidebar-nav .sidebar-brand {
    padding-left: 0.35rem !important;
    padding-right: 0.35rem !important;
}

.sidebar-nav .sidebar-label {
    display: inline-block;
    white-space: nowrap;
    overflow: hidden;
    max-width: 10rem;
    opacity: 1;
    transform: translateX(0);
    transition: opacity 0.14s ease, max-width 0.14s ease, transform 0.14s ease;
}

.sidebar-collapsed .sidebar-nav .sidebar-label {
    max-width: 0;
    opacity: 0;
    transform: translateX(-3px);
    pointer-events: none;
}

.sidebar-toggle-ear {
    position: absolute !important;
    left: calc(100% - 1.5rem);
    bottom: 1.25rem;
    background-color: #ffffff !important;
    background-image: none !important;
    box-shadow: none !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, background-color 0.2s ease;
    will-change: transform;
    z-index: 160 !important;
}

.dark .sidebar-toggle-ear {
    background-color: rgb(var(--slate-800) / 1) !important;
    background-image: none !important;
    border-color: rgb(var(--slate-700) / 1) !important;
    box-shadow: none !important;
}

.dark .sidebar-toggle-ear:hover,
.dark .sidebar-toggle-ear:focus-visible {
    background-color: rgb(var(--slate-800) / 1) !important;
    background-image: none !important;
}

.sidebar-toggle-ear .lucide,
.sidebar-toggle-ear svg {
    transition: transform 0.3s var(--premium-ease);
}

.sidebar-toggle-ear.sidebar-toggle-ear-collapsed .lucide,
.sidebar-toggle-ear.sidebar-toggle-ear-collapsed svg {
    transform: rotate(180deg);
}

body.sidebar-preload .workspace-shell,
body.sidebar-preload .workspace-shell *,
body.sidebar-preload .sidebar-shell,
body.sidebar-preload .sidebar-nav,
body.sidebar-preload .sidebar-toggle-ear,
body.sidebar-preload .sidebar-label,
body.sidebar-preload .sidebar-section-title {
    transition: none !important;
    animation: none !important;
}

.workspace-shell > main {
    grid-column: 2;
    grid-row: 2;
    min-width: 0;
    min-height: 0;
}

.sidebar-link[aria-current="page"],
.sidebar-link.pm-active {
    background-color: var(--brand-soft) !important;
    color: var(--brand-contrast) !important;
    font-weight: 600;
}

.dark .sidebar-link[aria-current="page"],
.dark .sidebar-link.pm-active {
    background-color: color-mix(in srgb, var(--brand-contrast) 24%, transparent) !important;
    color: var(--brand-primary) !important;
}

.pm-pagination {
    background: transparent;
    border: 0;
    padding: 0;
    font-size: 0.8125rem;
    line-height: 1rem;
}

.dark .pm-pagination {
    background: transparent;
}

.pm-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 1.75rem;
    gap: 0.1875rem;
    padding-top: 0;
    padding-bottom: 0;
    box-shadow: none !important;
    font-size: inherit;
    line-height: inherit;
    font-weight: 600;
}

.pm-page-btn-prev {
    padding-left: 0.4375rem;
    padding-right: 0.5625rem;
}

.pm-page-btn-next {
    padding-left: 0.5625rem;
    padding-right: 0.4375rem;
}

.pm-page-btn svg {
    display: block;
    width: 0.875rem;
    height: 0.875rem;
    flex-shrink: 0;
    stroke-width: 2.25;
}

.pm-page-btn:disabled,
.pm-page-btn[disabled] {
    cursor: not-allowed;
    pointer-events: none;
    background-image: none;
    transform: none;
    color: rgb(var(--slate-400) / 1);
    border-color: rgb(var(--slate-200) / 1);
}

.pm-page-btn:disabled svg,
.pm-page-btn[disabled] svg {
    color: rgb(var(--slate-400) / 1);
}

.dark .pm-page-btn:disabled,
.dark .pm-page-btn[disabled] {
    color: rgb(var(--slate-500) / 1);
    border-color: rgb(var(--slate-700) / 1);
}

.dark .pm-page-btn:disabled svg,
.dark .pm-page-btn[disabled] svg {
    color: rgb(var(--slate-500) / 1);
}

.pm-page-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: auto;
    height: 2rem;
    padding: 0 0.0625rem;
    border: 0;
    background-color: transparent;
    color: rgb(var(--slate-500) / 1);
    font-size: inherit;
    line-height: inherit;
    font-weight: 600;
    white-space: nowrap;
}

.dark .pm-page-status {
    background-color: transparent;
    color: rgb(var(--slate-400) / 1);
}

.pm-table-footer {
    background: linear-gradient(
        to bottom,
        rgb(255 255 255 / 1) 0%,
        rgb(var(--slate-50) / 1) 100%
    );
}

.dark .pm-table-footer {
    background: linear-gradient(
        to bottom,
        rgb(var(--slate-800) / 0) 0%,
        rgb(var(--slate-800) / 0.6) 100%
    );
}

thead tr {
    background: linear-gradient(
        to bottom,
        rgb(var(--slate-50) / 1) 0%,
        rgb(255 255 255 / 1) 100%
    );
}

.dark thead tr {
    background: linear-gradient(
        to bottom,
        rgb(var(--slate-800) / 0.6) 0%,
        rgb(var(--slate-800) / 0) 100%
    );
}

tbody tr {
    transition: background-color 100ms ease;
}

/* Data row wrappers — alinhamento vertical determinístico em qualquer tabela.
   Aplica quando <tr class="pm-data-row"> + <td> com wrapper interno
   (pm-table-cell-wrap | pm-table-status-wrap | pm-table-actions-wrap).
   Loading/empty/error rows ficam com padding original (sem .pm-data-row). */

tbody tr.pm-data-row td {
    vertical-align: middle;
    padding-top: 0;
    padding-bottom: 0;
}

tbody tr.pm-data-row td > .pm-table-cell-wrap,
tbody tr.pm-data-row td > .pm-table-status-wrap,
tbody tr.pm-data-row td > .pm-table-actions-wrap {
    min-height: 3.5rem;
    display: flex;
    align-items: center;
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
}

tbody tr.pm-data-row td > .pm-table-cell-wrap {
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
}

tbody tr.pm-data-row td > .pm-table-actions-wrap {
    justify-content: flex-end;
    gap: 0.125rem;
}

tbody tr:hover > td {
    background-color: rgb(var(--slate-50) / 1);
}

.dark tbody tr:hover > td {
    background-color: rgb(var(--slate-700) / 0.30);
}

.pm-menu-tab-active i {
    color: currentColor;
}

.dark .pm-menu-tab-active {
    color: var(--brand-primary);
    border-bottom-color: var(--brand-primary);
}

.pm-stagger tr:nth-child(1) { animation: pm-stagger-in 0.22s 0s both var(--premium-ease); }
.pm-stagger tr:nth-child(2) { animation: pm-stagger-in 0.22s 0.04s both var(--premium-ease); }
.pm-stagger tr:nth-child(3) { animation: pm-stagger-in 0.22s 0.08s both var(--premium-ease); }
.pm-stagger tr:nth-child(4) { animation: pm-stagger-in 0.22s 0.12s both var(--premium-ease); }
.pm-stagger tr:nth-child(5) { animation: pm-stagger-in 0.22s 0.16s both var(--premium-ease); }
.pm-stagger tr:nth-child(6) { animation: pm-stagger-in 0.22s 0.2s both var(--premium-ease); }
.pm-stagger tr:nth-child(n+7) { animation: pm-stagger-in 0.22s 0.24s both var(--premium-ease); }

.ui-stagger-run > :nth-child(1) { animation: pm-stagger-in 0.22s 0s both var(--premium-ease); }
.ui-stagger-run > :nth-child(2) { animation: pm-stagger-in 0.22s 0.04s both var(--premium-ease); }
.ui-stagger-run > :nth-child(3) { animation: pm-stagger-in 0.22s 0.08s both var(--premium-ease); }
.ui-stagger-run > :nth-child(4) { animation: pm-stagger-in 0.22s 0.12s both var(--premium-ease); }
.ui-stagger-run > :nth-child(5) { animation: pm-stagger-in 0.22s 0.16s both var(--premium-ease); }
.ui-stagger-run > :nth-child(6) { animation: pm-stagger-in 0.22s 0.2s both var(--premium-ease); }
.ui-stagger-run > :nth-child(n+7) { animation: pm-stagger-in 0.22s 0.24s both var(--premium-ease); }

@keyframes pm-stagger-in {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

.pm-divider {
    border: none;
    height: 1px;
    background: linear-gradient(
        to right,
        transparent 0%,
        rgb(var(--slate-200) / 1) 20%,
        rgb(var(--slate-200) / 1) 80%,
        transparent 100%
    );
}

.dark .pm-divider {
    background: linear-gradient(
        to right,
        transparent 0%,
        rgb(var(--slate-700) / 1) 20%,
        rgb(var(--slate-700) / 1) 80%,
        transparent 100%
    );
}

.toast-enter {
    animation: slideIn 0.25s ease-out forwards;
}

.toast-exit {
    animation: fadeOut 0.25s ease-in forwards;
}

@keyframes slideIn {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes fadeOut {
    from {
        opacity: 1;
    }
    to {
        opacity: 0;
    }
}

@media (max-width: 1023px) {
    .pm-submenu-subgroup-title {
        display: none;
    }

    .pm-submenu-backdrop {
        display: none !important;
    }

    .pm-submenu-drawer-open .sidebar-submenu-chevron {
        transform: rotate(90deg) !important;
        transition: transform 0.18s ease;
    }

    .workspace-shell {
        display: flex !important;
        flex-direction: column;
    }

    .workspace-shell > .workspace-topbar {
        order: 1;
        width: 100%;
    }

    .workspace-shell > .sidebar-shell {
        position: fixed;
        inset: 0 auto 0 0;
        order: initial;
        height: 100vh;
        width: min(18rem, calc(100vw - 2rem));
        min-width: min(18rem, calc(100vw - 2rem));
        max-width: min(18rem, calc(100vw - 2rem));
        transform: translateX(-105%);
        transition: transform 0.24s var(--premium-ease);
        z-index: 40;
        overflow: visible;
    }

    .pm-submenu-drawer {
        position: static;
        inset: auto;
        width: auto;
        height: auto;
        max-height: none;
        left: auto;
        top: auto;
        bottom: auto;
        border-radius: 0;
        border: 0;
        background: transparent;
        backdrop-filter: none;
        box-shadow: none;
        margin: 0;
        padding: 0;
        opacity: 1;
        transform: none;
        pointer-events: auto;
        transition: max-height 0.24s var(--premium-ease), opacity 0.2s ease, margin 0.2s ease;
    }

    .pm-submenu-drawer.hidden {
        display: block !important;
        max-height: 0 !important;
        opacity: 0;
        margin-top: 0 !important;
        margin-bottom: 0 !important;
        overflow: hidden !important;
        pointer-events: none;
    }

    .pm-submenu-drawer:not(.hidden) {
        max-height: 75vh;
        opacity: 1;
    }

    .pm-submenu-drawer-header {
        display: none;
    }

    .pm-submenu-drawer-nav {
        position: relative;
        padding: 0.25rem 0 0.4rem 0;
        overflow: visible;
    }

    .pm-submenu-drawer-nav::before {
        content: "";
        position: absolute;
        left: 1.62rem;
        top: 0.25rem;
        bottom: 0.4rem;
        width: 1px;
        background: rgb(var(--slate-300) / 0.95);
        pointer-events: none;
    }

    .dark .pm-submenu-drawer-nav::before {
        background: rgb(var(--slate-600) / 1);
    }

    .pm-submenu-drawer .sidebar-child-link {
        height: 2.75rem;
        margin-left: 2.1rem;
        width: calc(100% - 2.1rem);
        padding-left: 0.95rem;
        padding-right: 1rem;
        border-radius: 0.75rem;
    }

    .workspace-shell > .sidebar-shell .sidebar-nav {
        width: 100%;
        height: 100%;
        max-height: none;
        padding-top: 0.25rem;
        box-shadow: none;
    }

    .workspace-shell > main {
        order: 2;
        min-height: 0;
    }

    body.pm-mobile-sidebar-open .workspace-shell > .sidebar-shell {
        transform: translateX(0);
    }

    body.pm-mobile-sidebar-open {
        overflow: hidden;
    }

    body.pm-mobile-sidebar-open .pm-mobile-sidebar-backdrop {
        display: block;
    }

    .sidebar-toggle-ear {
        display: none !important;
    }

    .workspace-shell > main > .flex-1 {
        padding: 1rem;
    }

    .pm-table-shell {
        display: none;
    }

    .pm-mobile-list {
        display: block !important;
    }

    .pm-table-footer {
        align-items: flex-start;
        gap: 0.75rem;
    }

    .pm-pagination {
        width: 100%;
        justify-content: space-between;
    }
}

@media (min-width: 1024px) {
    .pm-mobile-sidebar-backdrop,
    .pm-mobile-list {
        display: none !important;
    }
}

/* =============================================================================
 * Ripple effect — usado por initRipple() em assets/js/ui.js de produção.
 * Sem estas regras, o <span class="pm-ripple"> injetado em runtime ao clicar
 * vira elemento inline e expande lateralmente o botão. Com elas, o ripple
 * fica posicionado absolutamente dentro do host com overflow:hidden.
 * ========================================================================== */

.pm-ripple-host {
    position: relative;
    overflow: hidden;
}

.pm-ripple {
    position: absolute;
    border-radius: 50%;
    transform: scale(0);
    animation: pm-ripple-anim 0.55s cubic-bezier(0.22, 1, 0.36, 1) forwards;
    background: rgb(255 255 255 / 0.35);
    pointer-events: none;
}

.dark .pm-ripple {
    background: rgb(255 255 255 / 0.2);
}

@keyframes pm-ripple-anim {
    to { transform: scale(4); opacity: 0; }
}
